Page MenuHomeFreeBSD

dtrace: Add a "regs" variable
ClosedPublic

Authored by markj on Sep 29 2022, 5:36 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Nov 11, 5:25 AM
Unknown Object (File)
Fri, Nov 1, 2:36 PM
Unknown Object (File)
Oct 1 2024, 7:43 PM
Unknown Object (File)
Sep 28 2024, 6:06 PM
Unknown Object (File)
Sep 26 2024, 11:48 AM
Unknown Object (File)
Sep 23 2024, 8:35 AM
Unknown Object (File)
Sep 22 2024, 7:42 PM
Unknown Object (File)
Aug 19 2024, 2:13 AM
Subscribers

Details

Summary

This allows invop-based providers (i.e., fbt and kinst) to expose the
register file of the CPU at the point where the probe fired. It does
not work for SDT providers because their probes are implemented as plain
function calls and so don't save registers. It's not clear what
semantics "regs" should have for them anyway.

This is akin to "uregs", which nominally provides access to the
userspace registers. In fact, DIF already had a DIF_VAR_REGS variable
defined, it was simply unimplemented.

Usage example: print the contents of %rdi upon each call to
amd64_syscall():

fbt::amd64_syscall:entry {printf("%x", regs[R_RDI]);}

Note that the R_* constants are defined in /usr/lib/dtrace/regs_x86.d.
Currently there are no similar definitions for non-x86 platforms.

Diff Detail

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