Page MenuHomeFreeBSD

arm64: Ensure sctlr and pstate are in known states
ClosedPublic

Authored by andrew on Jun 7 2024, 2:25 PM.
Tags
None
Referenced Files
F159902760: D45528.diff
Fri, Jun 19, 7:51 AM
F159898704: D45528.diff
Fri, Jun 19, 6:32 AM
Unknown Object (File)
Thu, Jun 4, 11:50 PM
Unknown Object (File)
Thu, Jun 4, 9:52 AM
Unknown Object (File)
Wed, Jun 3, 10:57 PM
Unknown Object (File)
Wed, Jun 3, 7:03 PM
Unknown Object (File)
Sun, May 31, 1:17 PM
Unknown Object (File)
May 12 2026, 12:44 AM
Subscribers

Details

Summary

Before entering the kernel exception level ensure sctlr_el2 and
sctlr_el1 are in a known state. The EOS flag needs to be set to ensure
an eret instruction is a context synchronization event.

Set spcr_el1 when entering the kernel from EL1 and use an eret
instruction to return to the caller. This ensures the CPU pstate is
consistent with the value in spcr_el1 as it is the only way to set it
directly.

Sponsored by: Arm Ltd

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 58347
Build 55235: arc lint + arc unit

Event Timeline

Readd the isb at the end of enter_kernel_el. It seems to be needed.

This revision was not accepted when it landed; it landed in state Needs Review.Jul 23 2024, 9:52 AM
This revision was automatically updated to reflect the committed changes.