target-arm queue:
* tests/decode: Suppress "error: " string for expected-failure tests * ui/curses: For curses display, recognize a few more control keys * target/arm: Special case M-profile in debug_helper.c code * scripts/git-submodule.sh: Don't rely on non-POSIX 'read' behaviour * hw/arm/smmu: Handle big-endian hosts correctly -----BEGIN PGP SIGNATURE----- iQJNBAABCAA3FiEE4aXFk81BneKOgxXPPCUl7RQ2DN4FAmS/ot8ZHHBldGVyLm1h eWRlbGxAbGluYXJvLm9yZwAKCRA8JSXtFDYM3slqEACaLJwIYl1bJBfCda2u53+C q20t50SQjkvV2CSW6A9uOHPPahKUcxAXh6K+d54BhzD6Dsrv5g1rpo/2fnNhHDSG 7fHlla+fPnywmAOahE2FPUw4pckRX1tpPIM1RDjM9szLYqkJlShKYP28QsLu1Eku bnTty6OcId5hAZILag53QLwL9EYsVYoCEe6xRcgY3He0UZcCEisCUdfeCXEN1Uc8 57wd+q3KNUTgOScqmDJRAH2NaET0UOYlUvQGVu8/Bh3t0huQCtfyT4gc8z7v/TZ8 2PfI6bFb9nei09avxhBMN9Nu7BVD6eHBkAAe4JHDBhkJKCZn+LASDCMUAFPrFD2V NeIObNHBMaE9FqIG/SZxf7kEOaFcUwt4GrVfQNguaqiXIwALsfT/jiX4r+jXX4WS ii0mdoS2ZuAcRtUhTA7S6x44B3wa47sidSogoe3t2k8ObYB/AZ34F1cSZDgEmIG7 nobJE2OgzSRMWUHXhCUEzGvn8MMPeI0HQmKr4sOD6CnlqHIzLZDH4Jx0DL4yvoyc XLs0D2G4yscUTtWh15R/nTWTJKxjumbs05bqwRKLTMsVj6kpDDY/EqhHMvB6Xm70 z+xDGki9xsBOTGRO7GdqGlWEKfnwUIPjipwy9crhsjSe121XrP8uwmmDBL1tOLgc L+geqtruzJgFmo3rOBGxXA== =4paq -----END PGP SIGNATURE----- Merge tag 'pull-target-arm-20230725' of https://git.linaro.org/people/pmaydell/qemu-arm into staging target-arm queue: * tests/decode: Suppress "error: " string for expected-failure tests * ui/curses: For curses display, recognize a few more control keys * target/arm: Special case M-profile in debug_helper.c code * scripts/git-submodule.sh: Don't rely on non-POSIX 'read' behaviour * hw/arm/smmu: Handle big-endian hosts correctly # -----BEGIN PGP SIGNATURE----- # # iQJNBAABCAA3FiEE4aXFk81BneKOgxXPPCUl7RQ2DN4FAmS/ot8ZHHBldGVyLm1h # eWRlbGxAbGluYXJvLm9yZwAKCRA8JSXtFDYM3slqEACaLJwIYl1bJBfCda2u53+C # q20t50SQjkvV2CSW6A9uOHPPahKUcxAXh6K+d54BhzD6Dsrv5g1rpo/2fnNhHDSG # 7fHlla+fPnywmAOahE2FPUw4pckRX1tpPIM1RDjM9szLYqkJlShKYP28QsLu1Eku # bnTty6OcId5hAZILag53QLwL9EYsVYoCEe6xRcgY3He0UZcCEisCUdfeCXEN1Uc8 # 57wd+q3KNUTgOScqmDJRAH2NaET0UOYlUvQGVu8/Bh3t0huQCtfyT4gc8z7v/TZ8 # 2PfI6bFb9nei09avxhBMN9Nu7BVD6eHBkAAe4JHDBhkJKCZn+LASDCMUAFPrFD2V # NeIObNHBMaE9FqIG/SZxf7kEOaFcUwt4GrVfQNguaqiXIwALsfT/jiX4r+jXX4WS # ii0mdoS2ZuAcRtUhTA7S6x44B3wa47sidSogoe3t2k8ObYB/AZ34F1cSZDgEmIG7 # nobJE2OgzSRMWUHXhCUEzGvn8MMPeI0HQmKr4sOD6CnlqHIzLZDH4Jx0DL4yvoyc # XLs0D2G4yscUTtWh15R/nTWTJKxjumbs05bqwRKLTMsVj6kpDDY/EqhHMvB6Xm70 # z+xDGki9xsBOTGRO7GdqGlWEKfnwUIPjipwy9crhsjSe121XrP8uwmmDBL1tOLgc # L+geqtruzJgFmo3rOBGxXA== # =4paq # -----END PGP SIGNATURE----- # gpg: Signature made Tue 25 Jul 2023 11:24:31 BST # gpg: using RSA key E1A5C593CD419DE28E8315CF3C2525ED14360CDE # gpg: issuer "peter.maydell@linaro.org" # gpg: Good signature from "Peter Maydell <peter.maydell@linaro.org>" [ultimate] # gpg: aka "Peter Maydell <pmaydell@gmail.com>" [ultimate] # gpg: aka "Peter Maydell <pmaydell@chiark.greenend.org.uk>" [ultimate] # gpg: aka "Peter Maydell <peter@archaic.org.uk>" [ultimate] # Primary key fingerprint: E1A5 C593 CD41 9DE2 8E83 15CF 3C25 25ED 1436 0CDE * tag 'pull-target-arm-20230725' of https://git.linaro.org/people/pmaydell/qemu-arm: tests/decode: Suppress "error: " string for expected-failure tests For curses display, recognize a few more control keys target/arm: Special case M-profile in debug_helper.c code scripts/git-submodule.sh: Don't rely on non-POSIX 'read' behaviour hw/arm/smmu: Handle big-endian hosts correctly Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
a279ca4ea0
@ -216,8 +216,7 @@ static int get_pte(dma_addr_t baseaddr, uint32_t index, uint64_t *pte,
|
||||
dma_addr_t addr = baseaddr + index * sizeof(*pte);
|
||||
|
||||
/* TODO: guarantee 64-bit single-copy atomicity */
|
||||
ret = dma_memory_read(&address_space_memory, addr, pte, sizeof(*pte),
|
||||
MEMTXATTRS_UNSPECIFIED);
|
||||
ret = ldq_le_dma(&address_space_memory, addr, pte, MEMTXATTRS_UNSPECIFIED);
|
||||
|
||||
if (ret != MEMTX_OK) {
|
||||
info->type = SMMU_PTW_ERR_WALK_EABT;
|
||||
|
@ -102,20 +102,34 @@ static void smmuv3_write_gerrorn(SMMUv3State *s, uint32_t new_gerrorn)
|
||||
trace_smmuv3_write_gerrorn(toggled & pending, s->gerrorn);
|
||||
}
|
||||
|
||||
static inline MemTxResult queue_read(SMMUQueue *q, void *data)
|
||||
static inline MemTxResult queue_read(SMMUQueue *q, Cmd *cmd)
|
||||
{
|
||||
dma_addr_t addr = Q_CONS_ENTRY(q);
|
||||
MemTxResult ret;
|
||||
int i;
|
||||
|
||||
return dma_memory_read(&address_space_memory, addr, data, q->entry_size,
|
||||
MEMTXATTRS_UNSPECIFIED);
|
||||
ret = dma_memory_read(&address_space_memory, addr, cmd, sizeof(Cmd),
|
||||
MEMTXATTRS_UNSPECIFIED);
|
||||
if (ret != MEMTX_OK) {
|
||||
return ret;
|
||||
}
|
||||
for (i = 0; i < ARRAY_SIZE(cmd->word); i++) {
|
||||
le32_to_cpus(&cmd->word[i]);
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
static MemTxResult queue_write(SMMUQueue *q, void *data)
|
||||
static MemTxResult queue_write(SMMUQueue *q, Evt *evt_in)
|
||||
{
|
||||
dma_addr_t addr = Q_PROD_ENTRY(q);
|
||||
MemTxResult ret;
|
||||
Evt evt = *evt_in;
|
||||
int i;
|
||||
|
||||
ret = dma_memory_write(&address_space_memory, addr, data, q->entry_size,
|
||||
for (i = 0; i < ARRAY_SIZE(evt.word); i++) {
|
||||
cpu_to_le32s(&evt.word[i]);
|
||||
}
|
||||
ret = dma_memory_write(&address_space_memory, addr, &evt, sizeof(Evt),
|
||||
MEMTXATTRS_UNSPECIFIED);
|
||||
if (ret != MEMTX_OK) {
|
||||
return ret;
|
||||
@ -298,7 +312,7 @@ static void smmuv3_init_regs(SMMUv3State *s)
|
||||
static int smmu_get_ste(SMMUv3State *s, dma_addr_t addr, STE *buf,
|
||||
SMMUEventInfo *event)
|
||||
{
|
||||
int ret;
|
||||
int ret, i;
|
||||
|
||||
trace_smmuv3_get_ste(addr);
|
||||
/* TODO: guarantee 64-bit single-copy atomicity */
|
||||
@ -311,6 +325,9 @@ static int smmu_get_ste(SMMUv3State *s, dma_addr_t addr, STE *buf,
|
||||
event->u.f_ste_fetch.addr = addr;
|
||||
return -EINVAL;
|
||||
}
|
||||
for (i = 0; i < ARRAY_SIZE(buf->word); i++) {
|
||||
le32_to_cpus(&buf->word[i]);
|
||||
}
|
||||
return 0;
|
||||
|
||||
}
|
||||
@ -320,7 +337,7 @@ static int smmu_get_cd(SMMUv3State *s, STE *ste, uint32_t ssid,
|
||||
CD *buf, SMMUEventInfo *event)
|
||||
{
|
||||
dma_addr_t addr = STE_CTXPTR(ste);
|
||||
int ret;
|
||||
int ret, i;
|
||||
|
||||
trace_smmuv3_get_cd(addr);
|
||||
/* TODO: guarantee 64-bit single-copy atomicity */
|
||||
@ -333,6 +350,9 @@ static int smmu_get_cd(SMMUv3State *s, STE *ste, uint32_t ssid,
|
||||
event->u.f_ste_fetch.addr = addr;
|
||||
return -EINVAL;
|
||||
}
|
||||
for (i = 0; i < ARRAY_SIZE(buf->word); i++) {
|
||||
le32_to_cpus(&buf->word[i]);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -569,7 +589,7 @@ static int smmu_find_ste(SMMUv3State *s, uint32_t sid, STE *ste,
|
||||
return -EINVAL;
|
||||
}
|
||||
if (s->features & SMMU_FEATURE_2LVL_STE) {
|
||||
int l1_ste_offset, l2_ste_offset, max_l2_ste, span;
|
||||
int l1_ste_offset, l2_ste_offset, max_l2_ste, span, i;
|
||||
dma_addr_t l1ptr, l2ptr;
|
||||
STEDesc l1std;
|
||||
|
||||
@ -593,6 +613,9 @@ static int smmu_find_ste(SMMUv3State *s, uint32_t sid, STE *ste,
|
||||
event->u.f_ste_fetch.addr = l1ptr;
|
||||
return -EINVAL;
|
||||
}
|
||||
for (i = 0; i < ARRAY_SIZE(l1std.word); i++) {
|
||||
le32_to_cpus(&l1std.word[i]);
|
||||
}
|
||||
|
||||
span = L1STD_SPAN(&l1std);
|
||||
|
||||
|
@ -134,6 +134,10 @@ def error_with_file(file, lineno, *args):
|
||||
global output_file
|
||||
global output_fd
|
||||
|
||||
# For the test suite expected-errors case, don't print the
|
||||
# string "error: ", so they don't turn up as false positives
|
||||
# if you grep the meson logs for strings like that.
|
||||
end = 'error: ' if not testforerror else 'detected: '
|
||||
prefix = ''
|
||||
if file:
|
||||
prefix += f'{file}:'
|
||||
@ -141,7 +145,7 @@ def error_with_file(file, lineno, *args):
|
||||
prefix += f'{lineno}:'
|
||||
if prefix:
|
||||
prefix += ' '
|
||||
print(prefix, end='error: ', file=sys.stderr)
|
||||
print(prefix, end=end, file=sys.stderr)
|
||||
print(*args, file=sys.stderr)
|
||||
|
||||
if output_file and output_fd:
|
||||
|
@ -103,7 +103,7 @@ update)
|
||||
check_updated $module || echo Updated "$module"
|
||||
done
|
||||
|
||||
(while read -r; do
|
||||
(while read -r REPLY; do
|
||||
for module in $modules; do
|
||||
case $REPLY in
|
||||
*" $module "*) continue 2 ;;
|
||||
|
@ -21,6 +21,10 @@ static int arm_debug_target_el(CPUARMState *env)
|
||||
bool secure = arm_is_secure(env);
|
||||
bool route_to_el2 = false;
|
||||
|
||||
if (arm_feature(env, ARM_FEATURE_M)) {
|
||||
return 1;
|
||||
}
|
||||
|
||||
if (arm_is_el2_enabled(env)) {
|
||||
route_to_el2 = env->cp15.hcr_el2 & HCR_TGE ||
|
||||
env->cp15.mdcr_el2 & MDCR_TDE;
|
||||
@ -434,18 +438,20 @@ static uint32_t arm_debug_exception_fsr(CPUARMState *env)
|
||||
{
|
||||
ARMMMUFaultInfo fi = { .type = ARMFault_Debug };
|
||||
int target_el = arm_debug_target_el(env);
|
||||
bool using_lpae = false;
|
||||
bool using_lpae;
|
||||
|
||||
if (target_el == 2 || arm_el_is_aa64(env, target_el)) {
|
||||
if (arm_feature(env, ARM_FEATURE_M)) {
|
||||
using_lpae = false;
|
||||
} else if (target_el == 2 || arm_el_is_aa64(env, target_el)) {
|
||||
using_lpae = true;
|
||||
} else if (arm_feature(env, ARM_FEATURE_PMSA) &&
|
||||
arm_feature(env, ARM_FEATURE_V8)) {
|
||||
using_lpae = true;
|
||||
} else if (arm_feature(env, ARM_FEATURE_LPAE) &&
|
||||
(env->cp15.tcr_el[target_el] & TTBCR_EAE)) {
|
||||
using_lpae = true;
|
||||
} else {
|
||||
if (arm_feature(env, ARM_FEATURE_LPAE) &&
|
||||
(env->cp15.tcr_el[target_el] & TTBCR_EAE)) {
|
||||
using_lpae = true;
|
||||
}
|
||||
using_lpae = false;
|
||||
}
|
||||
|
||||
if (using_lpae) {
|
||||
|
@ -210,6 +210,12 @@ static const int _curses2keycode[CURSES_CHARS] = {
|
||||
['N' - '@'] = 49 | CNTRL, /* Control + n */
|
||||
/* Control + m collides with the keycode for Enter */
|
||||
|
||||
['@' - '@'] = 3 | CNTRL, /* Control + @ */
|
||||
/* Control + [ collides with the keycode for Escape */
|
||||
['\\' - '@'] = 43 | CNTRL, /* Control + Backslash */
|
||||
[']' - '@'] = 27 | CNTRL, /* Control + ] */
|
||||
['^' - '@'] = 7 | CNTRL, /* Control + ^ */
|
||||
['_' - '@'] = 12 | CNTRL, /* Control + Underscore */
|
||||
};
|
||||
|
||||
static const int _curseskey2keycode[CURSES_KEYS] = {
|
||||
|
Loading…
Reference in New Issue
Block a user