Page MenuHomeFreeBSD

DTrace: fix reading a 64-bits register on amd64
ClosedPublic

Authored by oshogbo on May 22 2019, 7:48 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Oct 24, 9:30 PM
Unknown Object (File)
Tue, Oct 21, 1:05 AM
Unknown Object (File)
Fri, Oct 17, 11:32 PM
Unknown Object (File)
Sun, Oct 12, 4:46 PM
Unknown Object (File)
Thu, Oct 9, 8:32 AM
Unknown Object (File)
Sep 13 2025, 9:34 AM
Unknown Object (File)
Sep 11 2025, 10:03 PM
Unknown Object (File)
Aug 31 2025, 8:08 PM
Subscribers

Details

Summary

The registers in ilumos and FreeBSD have a different number.
In the illumos, last 32-bits register defined is SS an in FreeBSD is GS.
This off-by-one caused the uregs array to returns the wrong 64-bits register
on amd64.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

markj added inline comments.
sys/cddl/dev/dtrace/amd64/dtrace_isa.c
519 ↗(On Diff #57718)

I wouldn't bother with the comment in such a small block.

This revision is now accepted and ready to land.May 22 2019, 9:10 PM
This revision was automatically updated to reflect the committed changes.