FROMGIT: KVM: arm64: Turn SCTLR_ELx_FLAGS into INIT_SCTLR_EL2_MMU_ON
Only the nVHE EL2 code is using this define, so let's make it plain that it is EL2 only, and refactor it to contain all the bits we need when configuring the EL2 MMU, and only those. Acked-by: Will Deacon <will@kernel.org> Acked-by: Mark Rutland <mark.rutland@arm.com> Signed-off-by: Marc Zyngier <maz@kernel.org> (cherry picked from commit fe2c8d19189e23a951e45fdb73aade25b1665bce git://git.kernel.org/pub/scm/linux/kernel/git/kvmarm/kvmarm.git next) Signed-off-by: Will Deacon <willdeacon@google.com> Bug: 178098380 Test: atest VirtualizationHostTestCases on an EL2-enabled device Change-Id: I43b562a2a0100b970910da06e2823b5e3858c06f
This commit is contained in:

committed by
Quentin Perret

parent
f47a4d91e5
commit
8f25c7432f
@@ -624,9 +624,6 @@
|
|||||||
#define SCTLR_ELx_A (BIT(1))
|
#define SCTLR_ELx_A (BIT(1))
|
||||||
#define SCTLR_ELx_M (BIT(0))
|
#define SCTLR_ELx_M (BIT(0))
|
||||||
|
|
||||||
#define SCTLR_ELx_FLAGS (SCTLR_ELx_M | SCTLR_ELx_A | SCTLR_ELx_C | \
|
|
||||||
SCTLR_ELx_SA | SCTLR_ELx_I | SCTLR_ELx_IESB)
|
|
||||||
|
|
||||||
/* SCTLR_EL2 specific flags. */
|
/* SCTLR_EL2 specific flags. */
|
||||||
#define SCTLR_EL2_RES1 ((BIT(4)) | (BIT(5)) | (BIT(11)) | (BIT(16)) | \
|
#define SCTLR_EL2_RES1 ((BIT(4)) | (BIT(5)) | (BIT(11)) | (BIT(16)) | \
|
||||||
(BIT(18)) | (BIT(22)) | (BIT(23)) | (BIT(28)) | \
|
(BIT(18)) | (BIT(22)) | (BIT(23)) | (BIT(28)) | \
|
||||||
@@ -638,6 +635,10 @@
|
|||||||
#define ENDIAN_SET_EL2 0
|
#define ENDIAN_SET_EL2 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#define INIT_SCTLR_EL2_MMU_ON \
|
||||||
|
(SCTLR_ELx_M | SCTLR_ELx_C | SCTLR_ELx_SA | SCTLR_ELx_I | \
|
||||||
|
SCTLR_ELx_IESB | ENDIAN_SET_EL2 | SCTLR_EL2_RES1)
|
||||||
|
|
||||||
#define INIT_SCTLR_EL2_MMU_OFF \
|
#define INIT_SCTLR_EL2_MMU_OFF \
|
||||||
(SCTLR_EL2_RES1 | ENDIAN_SET_EL2)
|
(SCTLR_EL2_RES1 | ENDIAN_SET_EL2)
|
||||||
|
|
||||||
|
@@ -122,13 +122,7 @@ alternative_else_nop_endif
|
|||||||
tlbi vmalls12e1
|
tlbi vmalls12e1
|
||||||
dsb sy
|
dsb sy
|
||||||
|
|
||||||
/*
|
mov_q x0, INIT_SCTLR_EL2_MMU_ON
|
||||||
* Preserve all the RES1 bits while setting the default flags,
|
|
||||||
* as well as the EE bit on BE. Drop the A flag since the compiler
|
|
||||||
* is allowed to generate unaligned accesses.
|
|
||||||
*/
|
|
||||||
mov_q x0, (SCTLR_EL2_RES1 | (SCTLR_ELx_FLAGS & ~SCTLR_ELx_A))
|
|
||||||
CPU_BE( orr x0, x0, #SCTLR_ELx_EE)
|
|
||||||
alternative_if ARM64_HAS_ADDRESS_AUTH
|
alternative_if ARM64_HAS_ADDRESS_AUTH
|
||||||
mov_q x1, (SCTLR_ELx_ENIA | SCTLR_ELx_ENIB | \
|
mov_q x1, (SCTLR_ELx_ENIA | SCTLR_ELx_ENIB | \
|
||||||
SCTLR_ELx_ENDA | SCTLR_ELx_ENDB)
|
SCTLR_ELx_ENDA | SCTLR_ELx_ENDB)
|
||||||
|
Reference in New Issue
Block a user