aboutsummaryrefslogtreecommitdiff
path: root/scripts/xen-detect.c
diff options
context:
space:
mode:
authorPeter Maydell <peter.maydell@linaro.org>2023-08-22 17:31:08 +0100
committerPeter Maydell <peter.maydell@linaro.org>2023-08-22 17:31:08 +0100
commitb9c139dc581c793094b1889f304e049a75e2d455 (patch)
tree8ea7763a7d18fb8f71e1baa4a18676369fc205da /scripts/xen-detect.c
parent4477020d3811d0509241d0b752015f1ead2196bc (diff)
downloadqemu-b9c139dc581c793094b1889f304e049a75e2d455.zip
qemu-b9c139dc581c793094b1889f304e049a75e2d455.tar.gz
qemu-b9c139dc581c793094b1889f304e049a75e2d455.tar.bz2
target/arm/ptw: Only fold in NSTable bit effects in Secure state
When we do a translation in Secure state, the NSTable bits in table descriptors may downgrade us to NonSecure; we update ptw->in_secure and ptw->in_space accordingly. We guard that check correctly with a conditional that means it's only applied for Secure stage 1 translations. However, later on in get_phys_addr_lpae() we fold the effects of the NSTable bits into the final descriptor attributes bits, and there we do it unconditionally regardless of the CPU state. That means that in Realm state (where in_secure is false) we will set bit 5 in attrs, and later use it to decide to output to non-secure space. We don't in fact need to do this folding in at all any more (since commit 2f1ff4e7b9f30c): if an NSTable bit was set then we have already set ptw->in_space to ARMSS_NonSecure, and in that situation we don't look at attrs bit 5. The only thing we still need to deal with is the real NS bit in the final descriptor word, so we can just drop the code that ORed in the NSTable bit. Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Message-id: 20230807141514.19075-9-peter.maydell@linaro.org
Diffstat (limited to 'scripts/xen-detect.c')
0 files changed, 0 insertions, 0 deletions