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)
Nov 20 2025, 3:56 PM
Unknown Object (File)
Nov 20 2025, 3:56 PM
Unknown Object (File)
Nov 20 2025, 3:56 PM
Unknown Object (File)
Nov 20 2025, 3:46 PM
Unknown Object (File)
Nov 9 2025, 5:05 PM
Unknown Object (File)
Nov 4 2025, 5:57 AM
Unknown Object (File)
Nov 1 2025, 2:54 PM
Unknown Object (File)
Nov 1 2025, 2:54 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

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 24407
Build 23223: arc lint + arc unit

Event Timeline

markj added inline comments.
sys/cddl/dev/dtrace/amd64/dtrace_isa.c
519

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.