Page MenuHomeFreeBSD

arm64: Reduce where we decode msr/mrs instructions
ClosedPublic

Authored by andrew on May 6 2025, 5:05 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Jul 11, 10:27 AM
Unknown Object (File)
Mon, Jul 7, 12:21 PM
Unknown Object (File)
Mon, Jul 7, 3:48 AM
Unknown Object (File)
Sun, Jul 6, 1:22 AM
Unknown Object (File)
Sat, Jul 5, 11:29 PM
Unknown Object (File)
Sat, Jul 5, 6:07 AM
Unknown Object (File)
Sat, Jul 5, 1:48 AM
Unknown Object (File)
Fri, Jul 4, 1:00 AM
Subscribers

Details

Summary

We only use the mrs_Op* and mrs_CR* functions and MRS_* macros when
handling userspace executing a msr/msr instruction.

Move the macros to where they are used and expand the functions to
just use the macros directly.

While here update MRS_Op0_MASK to include bit 20 as this will cause
the correct op0 value to be calculated for all instructions we decode.

Sponsored by: Arm Ltd

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

andrew requested review of this revision.May 6 2025, 5:05 PM
This revision is now accepted and ready to land.May 9 2025, 3:30 PM

Rebase on D50906 to move all MRS_ macros to undefined.c

This revision now requires review to proceed.Tue, Jun 17, 1:26 PM
This revision was not accepted when it landed; it landed in state Needs Review.Mon, Jun 23, 12:08 PM
This revision was automatically updated to reflect the committed changes.