Page MenuHomeFreeBSD

arm64: validate breakpoint registers
ClosedPublic

Authored by mhorne on Feb 9 2021, 8:39 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Apr 21, 1:51 PM
Unknown Object (File)
Mon, Apr 20, 7:55 AM
Unknown Object (File)
Sat, Apr 18, 9:40 PM
Unknown Object (File)
Wed, Apr 15, 1:59 PM
Unknown Object (File)
Sun, Apr 12, 3:36 PM
Unknown Object (File)
Sun, Apr 12, 2:52 PM
Unknown Object (File)
Sat, Apr 11, 4:30 PM
Unknown Object (File)
Sat, Apr 11, 12:25 AM
Subscribers

Details

Summary

In particular, we want to disallow setting breakpoints on kernel
addresses from userspace. The control register fields are validated or
ignored as appropriate.

For reference: https://developer.arm.com/documentation/ddi0595/2020-12/AArch64-Registers/DBGBCR-n--EL1--Debug-Breakpoint-Control-Registers

Diff Detail

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

Event Timeline

mhorne requested review of this revision.Feb 9 2021, 8:39 PM
sys/arm64/arm64/machdep.c
374

I think this should be a >=. Contrary to the name, VM_MAXUSER_ADDRESS is not a valid user address.

I guess it's ok to silently round down the address to the nearest half word boundary?

396–400

The dbg_enable_count value is left non-zero in error paths. I guess that's ok so long as we don't set DBGMON_ENABLED.

Fix VM_MAXUSER_ADDRESS conditional. Round down address.

This revision is now accepted and ready to land.Feb 12 2021, 3:25 PM
This revision was automatically updated to reflect the committed changes.