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)
Wed, Nov 12, 10:20 PM
Unknown Object (File)
Tue, Nov 11, 1:45 AM
Unknown Object (File)
Tue, Nov 11, 12:09 AM
Unknown Object (File)
Mon, Nov 10, 9:14 AM
Unknown Object (File)
Mon, Nov 10, 4:52 AM
Unknown Object (File)
Mon, Nov 3, 4:54 AM
Unknown Object (File)
Mon, Nov 3, 12:05 AM
Unknown Object (File)
Sun, Nov 2, 4:30 PM
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.Jun 17 2025, 1:26 PM
This revision was not accepted when it landed; it landed in state Needs Review.Jun 23 2025, 12:08 PM
This revision was automatically updated to reflect the committed changes.