Page MenuHomeFreeBSD

arm64: Set the endian without a memory access
ClosedPublic

Authored by andrew on Jun 24 2025, 2:27 PM.
Tags
None
Referenced Files
F133436983: D51012.id162337.diff
Sat, Oct 25, 7:07 PM
Unknown Object (File)
Sat, Oct 25, 2:28 AM
Unknown Object (File)
Wed, Oct 22, 1:37 AM
Unknown Object (File)
Tue, Oct 21, 2:25 AM
Unknown Object (File)
Sun, Oct 5, 10:38 AM
Unknown Object (File)
Sep 22 2025, 3:06 AM
Unknown Object (File)
Sep 21 2025, 8:45 PM
Unknown Object (File)
Sep 21 2025, 7:18 PM
Subscribers

Details

Summary

Early in the kernel we set the endian through the sctlr_el1 and
sctlr_el2 registers. To get the value to put into these registers we
load them from memory. As this will depend on the endian to get the
fields in the correct order then it will fail if the endian is not
what the kernel expects.

Add a macro to load a 64-bit value into a register without a memory
access and use this to set the register. As instructions are not
affected by the endian set in sctlr this is safe.

It is unlikely this will be hit as UEFI requires the processor to be
in little endian mode, however when booting using the Linux ABI the
kernel may start in big-endian, and secondary CPUs could be big-endian.

Sponsored by: Arm Ltd

Diff Detail

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

Event Timeline

sys/arm64/arm64/locore.S
381

Add a comment here that the system is in little endian mode and memory operations can be used from here on? Or extend the comment above with something like memory operations can be used after this operation?

This revision is now accepted and ready to land.Sep 18 2025, 6:54 PM