diff options
author | Rob Landley <rob@landley.net> | 2018-10-10 05:26:02 -0500 |
---|---|---|
committer | Rob Landley <rob@landley.net> | 2018-10-10 05:26:02 -0500 |
commit | c276b8a8c2a5181558b976b9cb1d60a0180d560e (patch) | |
tree | f2f6cd6bff76573b2a94ade1d0cdadce654a323a /lib/xwrap.c | |
parent | 1f73aace0feb60ce1b200e7bf8e8339c1e2994fa (diff) | |
download | toybox-c276b8a8c2a5181558b976b9cb1d60a0180d560e.tar.gz |
Add xsignal_flags() and more consistently use xsignal() instead of signal().
xsignal() wraps sigaction() giving control of SA_RESTART behavior and such.
Diffstat (limited to 'lib/xwrap.c')
-rw-r--r-- | lib/xwrap.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/lib/xwrap.c b/lib/xwrap.c index 3e0f57e4..7276151f 100644 --- a/lib/xwrap.c +++ b/lib/xwrap.c @@ -841,12 +841,18 @@ char *xtzset(char *new) } // Set a signal handler -void xsignal(int signal, void *handler) +void xsignal_flags(int signal, void *handler, int flags) { struct sigaction *sa = (void *)libbuf; memset(sa, 0, sizeof(struct sigaction)); sa->sa_handler = handler; + sa->sa_flags = flags; if (sigaction(signal, sa, 0)) perror_exit("xsignal %d", signal); } + +void xsignal(int signal, void *handler) +{ + xsignal_flags(signal, handler, 0); +} |