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)
Thu, May 14, 11:06 AM
Unknown Object (File)
Thu, May 7, 12:21 AM
Unknown Object (File)
Fri, May 1, 1:03 PM
Unknown Object (File)
Wed, Apr 29, 8:51 AM
Unknown Object (File)
Mon, Apr 27, 5:55 PM
Unknown Object (File)
Mon, Apr 27, 3:38 PM
Unknown Object (File)
Sun, Apr 26, 8:23 PM
Unknown Object (File)
Sun, Apr 26, 6:31 AM
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.