From: behlendo Date: Mon, 17 Mar 2008 18:29:57 +0000 (+0000) Subject: Minimal signal handling interface. X-Git-Tag: zfs-0.8.0-rc1~152^2~930 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=1ec74a114cc4ec5055e7bc45cffda483505d8aba;p=zfs Minimal signal handling interface. git-svn-id: https://outreach.scidac.gov/svn/spl/trunk@49 7e1ea52c-4ff2-0310-8f11-9dd32ca42a1c --- diff --git a/include/sys/signal.h b/include/sys/signal.h new file mode 100644 index 000000000..120329686 --- /dev/null +++ b/include/sys/signal.h @@ -0,0 +1,24 @@ +#ifndef _SPL_SIGNAL_H +#define _SPL_SIGNAL_H + +#define FORREAL 0 /* Usual side-effects */ +#define JUSTLOOKING 1 /* Don't stop the process */ + +/* The "why" argument indicates the allowable side-effects of the call: + * + * FORREAL: Extract the next pending signal from p_sig into p_cursig; + * stop the process if a stop has been requested or if a traced signal + * is pending. + * + * JUSTLOOKING: Don't stop the process, just indicate whether or not + * a signal might be pending (FORREAL is needed to tell for sure). + */ +static __inline__ int +issig(int why) +{ + BUG_ON(!(why == FORREAL || why == JUSTLOOKING)); + + return signal_pending(current); +} + +#endif /* SPL_SIGNAL_H */ diff --git a/include/sys/sysmacros.h b/include/sys/sysmacros.h index eeaedf9cb..83e421b6a 100644 --- a/include/sys/sysmacros.h +++ b/include/sys/sysmacros.h @@ -8,6 +8,7 @@ extern "C" { #include #include #include +#include #ifndef _KERNEL #define _KERNEL __KERNEL__