diff --git a/[refs] b/[refs] index 5159904e97ba..b5529aa5c59f 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 2121e24bd8dd16b4e3f8d995428e2a748d5180cc +refs/heads/master: 6d18c9220965b437287c3a7e803725c24992ceac diff --git a/trunk/fs/compat.c b/trunk/fs/compat.c index 9cf75df9b2bb..2487b83b18df 100644 --- a/trunk/fs/compat.c +++ b/trunk/fs/compat.c @@ -46,6 +46,7 @@ #include #include #include +#include #include #include #include @@ -2199,3 +2200,28 @@ asmlinkage long compat_sys_epoll_pwait(int epfd, #endif /* TIF_RESTORE_SIGMASK */ #endif /* CONFIG_EPOLL */ + +#ifdef CONFIG_SIGNALFD + +asmlinkage long compat_sys_signalfd(int ufd, + const compat_sigset_t __user *sigmask, + compat_size_t sigsetsize) +{ + compat_sigset_t ss32; + sigset_t tmp; + sigset_t __user *ksigmask; + + if (sigsetsize != sizeof(compat_sigset_t)) + return -EINVAL; + if (copy_from_user(&ss32, sigmask, sizeof(ss32))) + return -EFAULT; + sigset_from_compat(&tmp, &ss32); + ksigmask = compat_alloc_user_space(sizeof(sigset_t)); + if (copy_to_user(ksigmask, &tmp, sizeof(sigset_t))) + return -EFAULT; + + return sys_signalfd(ufd, ksigmask, sizeof(sigset_t)); +} + +#endif /* CONFIG_SIGNALFD */ +