Implements real_sigaction() which it turns out is required for
internal_sigaction() to bypass the libc interceptors.
Details
Details
Diff Detail
Diff Detail
- Repository
- rL LLVM
Event Timeline
Comment Actions
Without this CL, our internal_sigaction calls that we make every run are only during init, where the EsanDuringInit check in COMMON_INTERCEPTOR_ENTER does end up calling the original libc sigaction and we do avoid running our interception action on our own calls that way (but it does not feel right for an "internal_" call to go through the interceptor). The real problem is when we call internal_sigaction after we're initialized, which only happens on an unhandled SIGSEGV for which the app has no handler: then we'll spin in an infinite loop as our attempts to remove our own handler repeatedly fail. It's not easy to add such a test. I'll add some of this explanation to the CL.