Page MenuHomeFreeBSD

arm64: add inline functions for FEAT_WFxT instructions
ClosedPublic

Authored by harry.moulton_arm.com on Jan 21 2025, 3:21 PM.
Tags
None
Referenced Files
F133553981: D48579.id149675.diff
Sun, Oct 26, 3:08 PM
F133492302: D48579.id149675.diff
Sun, Oct 26, 4:47 AM
F133483872: D48579.id149805.diff
Sun, Oct 26, 3:22 AM
Unknown Object (File)
Sat, Oct 25, 6:18 AM
Unknown Object (File)
Fri, Oct 24, 6:41 PM
Unknown Object (File)
Fri, Oct 24, 2:10 PM
Unknown Object (File)
Sep 24 2025, 8:07 AM
Unknown Object (File)
Sep 22 2025, 10:53 PM
Subscribers

Details

Summary

This adds inline functions for WFET/WFIT instructions introduced with
ARMv8.7 FEAT_WFxT. These instructions allow for regular WFE/WFI
instructions to be bound by a timeout. Once the value of CNTVCT_EL0
reaches, or exceeds, that of the timeout value, the WFE/WFI state will
be exited and the PE will continue.

These instructions are implemented as inline functions, with a write to
the corresponding system register acting as an alias for the two
instructions. Writing to these registers is only valid on ARMv8.7 and
above, therefore the use of these functions must be guarded by a feature
check.

Sponsored By: Arm Ltd
Signed-off-by: Harry Moulton <harry.moulton@arm.com>

Diff Detail

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

Event Timeline

sys/arm64/include/cpufunc.h
169

Do you need the cast here? val is already a uint64_t

Cast to uint64_t not needed, removed.

This revision is now accepted and ready to land.Jan 21 2025, 5:41 PM