OSDN Git Service

target/arm: Define and use new regime_tcr_value() function
authorPeter Maydell <peter.maydell@linaro.org>
Thu, 14 Jul 2022 13:22:57 +0000 (14:22 +0100)
committerPeter Maydell <peter.maydell@linaro.org>
Mon, 18 Jul 2022 12:20:13 +0000 (13:20 +0100)
commitdfce4aa8feccf77dc10e27b7491a97c94326460d
tree9a3d9fdaa741385f74d94726f1afaa00d41bb029
parent7f2cf760fe649972dba0948f8e3fc5618cb1fb37
target/arm: Define and use new regime_tcr_value() function

The regime_tcr() function returns a pointer to a struct TCR
corresponding to the TCR controlling a translation regime.  The
struct TCR has the raw value of the register, plus two fields mask
and base_mask which are used as a small optimization in the case of
32-bit short-descriptor lookups.  Almost all callers of regime_tcr()
only want the raw register value.  Define and use a new
regime_tcr_value() function which returns only the raw 64-bit
register value.

This is a preliminary to removing the 32-bit short descriptor
optimization -- it only saves a handful of bit operations, which is
tiny compared to the overhead of doing a page table walk at all, and
the TCR struct is awkward and makes fixing
https://gitlab.com/qemu-project/qemu/-/issues/1103 unnecessarily
difficult.

Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-id: 20220714132303.1287193-2-peter.maydell@linaro.org
target/arm/helper.c
target/arm/internals.h
target/arm/ptw.c
target/arm/tlb_helper.c