Page MenuHomeFreeBSD

arm64: Enable FEAT_E0PD when supported
ClosedPublic

Authored by andrew on Sep 6 2023, 11:25 AM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Jan 24, 5:41 PM
Unknown Object (File)
Thu, Jan 23, 6:42 PM
Unknown Object (File)
Thu, Jan 23, 6:34 PM
Unknown Object (File)
Mon, Jan 20, 2:38 PM
Unknown Object (File)
Mon, Jan 20, 1:23 PM
Unknown Object (File)
Mon, Jan 20, 8:53 AM
Unknown Object (File)
Sat, Jan 18, 9:26 PM
Unknown Object (File)
Wed, Jan 15, 5:35 PM
Subscribers

Details

Summary

FEAT_E0PD adds two fields to the tcr_el1 special register that, when
set, cause userspace access to either the top or bottom half of the
address spaces without a page walk.

This can be used to stop userspace probing the kernel address space
as the CPU will raise an exception in the same time if the probed
address is in the TLB or not.

Sponsored by: Arm Ltd

Diff Detail

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

Event Timeline

kevans added inline comments.
sys/arm64/arm64/identcpu.c
2238

I note this will only get called on the boot AP since SI_SUB_CPU is pretty early, was that intentional or should it be run after other APs are running regularly @ SI_SUB_SMP?

This revision is now accepted and ready to land.Sep 6 2023, 5:03 PM
This revision was automatically updated to reflect the committed changes.