Page MenuHomeFreeBSD

Don't include T_USER in si_trapno reported to userland.
ClosedPublic

Authored by jhb on Jul 22 2020, 4:28 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Jun 7, 9:46 PM
Unknown Object (File)
Tue, May 26, 9:12 AM
Unknown Object (File)
Mon, May 25, 10:41 PM
Unknown Object (File)
Mon, May 25, 12:34 PM
Unknown Object (File)
Fri, May 22, 2:48 PM
Unknown Object (File)
Thu, May 14, 11:06 AM
Unknown Object (File)
May 7 2026, 12:21 AM
Unknown Object (File)
May 1 2026, 1:03 PM
Subscribers

Details

Summary

Signals are only reported for user traps, so T_USER is redundant. It
is also a software convention and not included in the value reported
by the hardware.

Test Plan
  • some tests in CheriBSD test the value of si_trapno for some tests and I updated them to remove T_USER after this change

Diff Detail

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

Event Timeline

jhb requested review of this revision.Jul 22 2020, 4:28 PM
jhb created this revision.

Is usermode variable in mips/trap.c::trap() redundant ?

This revision is now accepted and ready to land.Jul 23 2020, 10:28 PM
In D25769#571137, @kib wrote:

Is usermode variable in mips/trap.c::trap() redundant ?

Yes, but I think it's more readable. If anything, I would be tempted to remove all the T_USER stuff and instead add a few more if (usermode) checks in the bodies of some of the cases. I'm not super motivated to rewrite all that though.