Page MenuHomeFreeBSD

abort2: Generate a core dump
ClosedPublic

Authored by jhb on Oct 11 2023, 9:20 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Dec 21, 4:13 AM
Unknown Object (File)
Oct 22 2024, 10:08 AM
Unknown Object (File)
Oct 22 2024, 10:08 AM
Unknown Object (File)
Oct 22 2024, 10:08 AM
Unknown Object (File)
Oct 22 2024, 10:07 AM
Unknown Object (File)
Oct 22 2024, 9:57 AM
Unknown Object (File)
Oct 20 2024, 7:25 AM
Unknown Object (File)
Sep 30 2024, 7:14 PM
Subscribers

Details

Summary

Call sigexit rather than exit1 so that a core is generated.

If running the SIGABRT handler is desired, this would need to use
kern_psignal() instead. In that case a userspace wrapper in libc
would be needed to force an exit if the handler doesn't exit. Given
that abort2(2)'s intended use case is when userland is in a
sufficiently bad state such that it can't safely call syslog(3) before
abort(3), a userspace abort2(3) wrapper in libc might be dubious.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 53932
Build 50822: arc lint + arc unit

Event Timeline

jhb requested review of this revision.Oct 11 2023, 9:20 PM

This change is a clear improvement (core dumped on SIGABRT), so IMHO should go in regardless of the "executing the SIGABRT handler" refinement.

sys/kern/kern_exit.c
832–833

sigexit() doesn't return (as exit1()), so the call to PROC_UNLOCK() is unnecesary, as well as the return.

I would remove them. I don't know for sure if there are still relevant compilers that would issue a warning or even an error about the function not containing a return statement at end, but I can say it's not a problem for clang 16.

jhb marked an inline comment as done.Oct 20 2023, 5:46 PM
This revision is now accepted and ready to land.Oct 20 2023, 7:52 PM
This revision was automatically updated to reflect the committed changes.