ArmPkg/ArmLib: AARCH64: allow the stack aligment (SA) bit to be managed

In preparation of enabling stack alignment checking, which is mandated
by the UEFI spec for AARCH64, add the code to manage this bit to ArmLib.

Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Reviewed-by: Leif Lindholm <leif.lindholm@linaro.org>
This commit is contained in:
Ard Biesheuvel 2017-02-22 09:38:20 +00:00
parent de2a78247a
commit 97f0d01d5d
2 changed files with 46 additions and 0 deletions

View File

@ -192,6 +192,18 @@ ArmEnableAlignmentCheck (
VOID VOID
); );
VOID
EFIAPI
ArmDisableStackAlignmentCheck (
VOID
);
VOID
EFIAPI
ArmEnableStackAlignmentCheck (
VOID
);
VOID VOID
EFIAPI EFIAPI
ArmDisableAllExceptions ( ArmDisableAllExceptions (

View File

@ -20,6 +20,7 @@
.set CTRL_M_BIT, (1 << 0) .set CTRL_M_BIT, (1 << 0)
.set CTRL_A_BIT, (1 << 1) .set CTRL_A_BIT, (1 << 1)
.set CTRL_C_BIT, (1 << 2) .set CTRL_C_BIT, (1 << 2)
.set CTRL_SA_BIT, (1 << 3)
.set CTRL_I_BIT, (1 << 12) .set CTRL_I_BIT, (1 << 12)
.set CTRL_V_BIT, (1 << 12) .set CTRL_V_BIT, (1 << 12)
.set CPACR_VFP_BITS, (3 << 20) .set CPACR_VFP_BITS, (3 << 20)
@ -259,6 +260,39 @@ ASM_FUNC(ArmDisableAlignmentCheck)
isb isb
ret ret
ASM_FUNC(ArmEnableStackAlignmentCheck)
EL1_OR_EL2(x1)
1: mrs x0, sctlr_el1 // Get control register EL1
b 3f
2: mrs x0, sctlr_el2 // Get control register EL2
3: orr x0, x0, #CTRL_SA_BIT // Set SA (stack alignment check) bit
EL1_OR_EL2(x1)
1: msr sctlr_el1, x0 // Write back control register
b 3f
2: msr sctlr_el2, x0 // Write back control register
3: dsb sy
isb
ret
ASM_FUNC(ArmDisableStackAlignmentCheck)
EL1_OR_EL2_OR_EL3(x1)
1: mrs x0, sctlr_el1 // Get control register EL1
b 4f
2: mrs x0, sctlr_el2 // Get control register EL2
b 4f
3: mrs x0, sctlr_el3 // Get control register EL3
4: bic x0, x0, #CTRL_SA_BIT // Clear SA (stack alignment check) bit
EL1_OR_EL2_OR_EL3(x1)
1: msr sctlr_el1, x0 // Write back control register
b 4f
2: msr sctlr_el2, x0 // Write back control register
b 4f
3: msr sctlr_el3, x0 // Write back control register
4: dsb sy
isb
ret
// Always turned on in AArch64. Else implementation specific. Leave in for C compatibility for now // Always turned on in AArch64. Else implementation specific. Leave in for C compatibility for now
ASM_FUNC(ArmEnableBranchPrediction) ASM_FUNC(ArmEnableBranchPrediction)