mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-15 04:30:12 +00:00
When we restore signal handlers, restore them back to what they
were when we came around, not to their default handler. This should fix PR3848 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@67509 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
1c4d8a00ab
commit
eab5cb3b55
@ -57,23 +57,45 @@ static const int KillSigs[] = {
|
|||||||
static const int *const KillSigsEnd =
|
static const int *const KillSigsEnd =
|
||||||
KillSigs + sizeof(KillSigs) / sizeof(KillSigs[0]);
|
KillSigs + sizeof(KillSigs) / sizeof(KillSigs[0]);
|
||||||
|
|
||||||
// Just call signal
|
static unsigned NumRegisteredSignals = 0;
|
||||||
|
static struct {
|
||||||
|
struct sigaction SA;
|
||||||
|
int SigNo;
|
||||||
|
} RegisteredSignalInfo[(sizeof(IntSigs)+sizeof(KillSigs))/sizeof(KillSigs[0])];
|
||||||
|
|
||||||
|
|
||||||
static void RegisterHandler(int Signal) {
|
static void RegisterHandler(int Signal) {
|
||||||
signal(Signal, SignalHandler);
|
assert(NumRegisteredSignals <
|
||||||
|
sizeof(RegisteredSignalInfo)/sizeof(RegisteredSignalInfo[0]) &&
|
||||||
|
"Out of space for signal handlers!");
|
||||||
|
|
||||||
|
struct sigaction NewHandler;
|
||||||
|
|
||||||
|
NewHandler.sa_handler = SignalHandler;
|
||||||
|
NewHandler.sa_flags = SA_NODEFER|SA_RESETHAND;
|
||||||
|
sigemptyset(&NewHandler.sa_mask);
|
||||||
|
|
||||||
|
// Install the new handler, save the old one in RegisteredSignalInfo.
|
||||||
|
sigaction(Signal, &NewHandler,
|
||||||
|
&RegisteredSignalInfo[NumRegisteredSignals].SA);
|
||||||
|
RegisteredSignalInfo[NumRegisteredSignals].SigNo = Signal;
|
||||||
|
++NumRegisteredSignals;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void RegisterHandlers() {
|
static void RegisterHandlers() {
|
||||||
|
// If the handlers are already registered, we're done.
|
||||||
|
if (NumRegisteredSignals != 0) return;
|
||||||
|
|
||||||
std::for_each(IntSigs, IntSigsEnd, RegisterHandler);
|
std::for_each(IntSigs, IntSigsEnd, RegisterHandler);
|
||||||
std::for_each(KillSigs, KillSigsEnd, RegisterHandler);
|
std::for_each(KillSigs, KillSigsEnd, RegisterHandler);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void UnregisterHandler(int Signal) {
|
|
||||||
signal(Signal, SIG_DFL);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void UnregisterHandlers() {
|
static void UnregisterHandlers() {
|
||||||
std::for_each(KillSigs, KillSigsEnd, UnregisterHandler);
|
// Restore all of the signal handlers to how they were before we showed up.
|
||||||
std::for_each(IntSigs, IntSigsEnd, UnregisterHandler);
|
for (unsigned i = 0, e = NumRegisteredSignals; i != e; ++i)
|
||||||
|
sigaction(RegisteredSignalInfo[NumRegisteredSignals].SigNo,
|
||||||
|
&RegisteredSignalInfo[NumRegisteredSignals].SA, 0);
|
||||||
|
NumRegisteredSignals = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user