signal/signalfd: Add support for SIGSYS
[linux-block.git] / fs / signalfd.c
index 31e960209a084aea91e579bc7f9688d1a7181d86..f652249f59f99e5cf413cf42972c818a586d3352 100644 (file)
@@ -134,7 +134,6 @@ static int signalfd_copyinfo(struct signalfd_siginfo __user *uinfo,
                new.ssi_stime  = kinfo->si_stime;
                break;
        case SIL_RT:
-       default:
                /*
                 * This case catches also the signals queued by sigqueue().
                 */
@@ -143,6 +142,11 @@ static int signalfd_copyinfo(struct signalfd_siginfo __user *uinfo,
                new.ssi_ptr = (long) kinfo->si_ptr;
                new.ssi_int = kinfo->si_int;
                break;
+       case SIL_SYS:
+               new.ssi_call_addr = (long) kinfo->si_call_addr;
+               new.ssi_syscall   = kinfo->si_syscall;
+               new.ssi_arch      = kinfo->si_arch;
+               break;
        }
 
        if (copy_to_user(uinfo, &new, sizeof(struct signalfd_siginfo)))