arm64: Simplify init_el2_state to be non-VHE only
As init_el2_state is now nVHE only, let's simplify it and drop the VHE setup. Signed-off-by: Marc Zyngier <maz@kernel.org> Acked-by: David Brazdil <dbrazdil@google.com> Acked-by: Catalin Marinas <catalin.marinas@arm.com> Link: https://lore.kernel.org/r/20210208095732.3267263-9-maz@kernel.org Signed-off-by: Will Deacon <will@kernel.org>
This commit is contained in:
Родитель
19e87e1319
Коммит
e2df464173
|
@ -32,16 +32,14 @@
|
||||||
* to transparently mess with the EL0 bits via CNTKCTL_EL1 access in
|
* to transparently mess with the EL0 bits via CNTKCTL_EL1 access in
|
||||||
* EL2.
|
* EL2.
|
||||||
*/
|
*/
|
||||||
.macro __init_el2_timers mode
|
.macro __init_el2_timers
|
||||||
.ifeqs "\mode", "nvhe"
|
|
||||||
mrs x0, cnthctl_el2
|
mrs x0, cnthctl_el2
|
||||||
orr x0, x0, #3 // Enable EL1 physical timers
|
orr x0, x0, #3 // Enable EL1 physical timers
|
||||||
msr cnthctl_el2, x0
|
msr cnthctl_el2, x0
|
||||||
.endif
|
|
||||||
msr cntvoff_el2, xzr // Clear virtual offset
|
msr cntvoff_el2, xzr // Clear virtual offset
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
.macro __init_el2_debug mode
|
.macro __init_el2_debug
|
||||||
mrs x1, id_aa64dfr0_el1
|
mrs x1, id_aa64dfr0_el1
|
||||||
sbfx x0, x1, #ID_AA64DFR0_PMUVER_SHIFT, #4
|
sbfx x0, x1, #ID_AA64DFR0_PMUVER_SHIFT, #4
|
||||||
cmp x0, #1
|
cmp x0, #1
|
||||||
|
@ -55,7 +53,6 @@
|
||||||
ubfx x0, x1, #ID_AA64DFR0_PMSVER_SHIFT, #4
|
ubfx x0, x1, #ID_AA64DFR0_PMSVER_SHIFT, #4
|
||||||
cbz x0, .Lskip_spe_\@ // Skip if SPE not present
|
cbz x0, .Lskip_spe_\@ // Skip if SPE not present
|
||||||
|
|
||||||
.ifeqs "\mode", "nvhe"
|
|
||||||
mrs_s x0, SYS_PMBIDR_EL1 // If SPE available at EL2,
|
mrs_s x0, SYS_PMBIDR_EL1 // If SPE available at EL2,
|
||||||
and x0, x0, #(1 << SYS_PMBIDR_EL1_P_SHIFT)
|
and x0, x0, #(1 << SYS_PMBIDR_EL1_P_SHIFT)
|
||||||
cbnz x0, .Lskip_spe_el2_\@ // then permit sampling of physical
|
cbnz x0, .Lskip_spe_el2_\@ // then permit sampling of physical
|
||||||
|
@ -66,7 +63,6 @@
|
||||||
mov x0, #(MDCR_EL2_E2PB_MASK << MDCR_EL2_E2PB_SHIFT)
|
mov x0, #(MDCR_EL2_E2PB_MASK << MDCR_EL2_E2PB_SHIFT)
|
||||||
orr x2, x2, x0 // If we don't have VHE, then
|
orr x2, x2, x0 // If we don't have VHE, then
|
||||||
// use EL1&0 translation.
|
// use EL1&0 translation.
|
||||||
.endif
|
|
||||||
|
|
||||||
.Lskip_spe_\@:
|
.Lskip_spe_\@:
|
||||||
msr mdcr_el2, x2 // Configure debug traps
|
msr mdcr_el2, x2 // Configure debug traps
|
||||||
|
@ -142,37 +138,24 @@
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initialize EL2 registers to sane values. This should be called early on all
|
* Initialize EL2 registers to sane values. This should be called early on all
|
||||||
* cores that were booted in EL2.
|
* cores that were booted in EL2. Note that everything gets initialised as
|
||||||
|
* if VHE was not evailable. The kernel context will be upgraded to VHE
|
||||||
|
* if possible later on in the boot process
|
||||||
*
|
*
|
||||||
* Regs: x0, x1 and x2 are clobbered.
|
* Regs: x0, x1 and x2 are clobbered.
|
||||||
*/
|
*/
|
||||||
.macro init_el2_state mode
|
.macro init_el2_state
|
||||||
.ifnes "\mode", "vhe"
|
|
||||||
.ifnes "\mode", "nvhe"
|
|
||||||
.error "Invalid 'mode' argument"
|
|
||||||
.endif
|
|
||||||
.endif
|
|
||||||
|
|
||||||
__init_el2_sctlr
|
__init_el2_sctlr
|
||||||
__init_el2_timers \mode
|
__init_el2_timers
|
||||||
__init_el2_debug \mode
|
__init_el2_debug
|
||||||
__init_el2_lor
|
__init_el2_lor
|
||||||
__init_el2_stage2
|
__init_el2_stage2
|
||||||
__init_el2_gicv3
|
__init_el2_gicv3
|
||||||
__init_el2_hstr
|
__init_el2_hstr
|
||||||
|
|
||||||
/*
|
|
||||||
* When VHE is not in use, early init of EL2 needs to be done here.
|
|
||||||
* When VHE _is_ in use, EL1 will not be used in the host and
|
|
||||||
* requires no configuration, and all non-hyp-specific EL2 setup
|
|
||||||
* will be done via the _EL1 system register aliases in __cpu_setup.
|
|
||||||
*/
|
|
||||||
.ifeqs "\mode", "nvhe"
|
|
||||||
__init_el2_nvhe_idregs
|
__init_el2_nvhe_idregs
|
||||||
__init_el2_nvhe_cptr
|
__init_el2_nvhe_cptr
|
||||||
__init_el2_nvhe_sve
|
__init_el2_nvhe_sve
|
||||||
__init_el2_nvhe_prepare_eret
|
__init_el2_nvhe_prepare_eret
|
||||||
.endif
|
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
#endif /* __ARM_KVM_INIT_H__ */
|
#endif /* __ARM_KVM_INIT_H__ */
|
||||||
|
|
|
@ -501,7 +501,7 @@ SYM_INNER_LABEL(init_el2, SYM_L_LOCAL)
|
||||||
msr hcr_el2, x0
|
msr hcr_el2, x0
|
||||||
isb
|
isb
|
||||||
|
|
||||||
init_el2_state nvhe
|
init_el2_state
|
||||||
|
|
||||||
/* Hypervisor stub */
|
/* Hypervisor stub */
|
||||||
adr_l x0, __hyp_stub_vectors
|
adr_l x0, __hyp_stub_vectors
|
||||||
|
|
|
@ -189,7 +189,7 @@ SYM_CODE_START_LOCAL(__kvm_hyp_init_cpu)
|
||||||
2: msr SPsel, #1 // We want to use SP_EL{1,2}
|
2: msr SPsel, #1 // We want to use SP_EL{1,2}
|
||||||
|
|
||||||
/* Initialize EL2 CPU state to sane values. */
|
/* Initialize EL2 CPU state to sane values. */
|
||||||
init_el2_state nvhe // Clobbers x0..x2
|
init_el2_state // Clobbers x0..x2
|
||||||
|
|
||||||
/* Enable MMU, set vectors and stack. */
|
/* Enable MMU, set vectors and stack. */
|
||||||
mov x0, x28
|
mov x0, x28
|
||||||
|
|
Загрузка…
Ссылка в новой задаче