diff options
Diffstat (limited to 'fs/signalfd.c')
-rw-r--r-- | fs/signalfd.c | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/fs/signalfd.c b/fs/signalfd.c index f329849ce3c0..492465b451dd 100644 --- a/fs/signalfd.c +++ b/fs/signalfd.c | |||
@@ -88,6 +88,7 @@ static int signalfd_copyinfo(struct signalfd_siginfo __user *uinfo, | |||
88 | err |= __put_user(kinfo->si_tid, &uinfo->ssi_tid); | 88 | err |= __put_user(kinfo->si_tid, &uinfo->ssi_tid); |
89 | err |= __put_user(kinfo->si_overrun, &uinfo->ssi_overrun); | 89 | err |= __put_user(kinfo->si_overrun, &uinfo->ssi_overrun); |
90 | err |= __put_user((long) kinfo->si_ptr, &uinfo->ssi_ptr); | 90 | err |= __put_user((long) kinfo->si_ptr, &uinfo->ssi_ptr); |
91 | err |= __put_user(kinfo->si_int, &uinfo->ssi_int); | ||
91 | break; | 92 | break; |
92 | case __SI_POLL: | 93 | case __SI_POLL: |
93 | err |= __put_user(kinfo->si_band, &uinfo->ssi_band); | 94 | err |= __put_user(kinfo->si_band, &uinfo->ssi_band); |
@@ -98,6 +99,16 @@ static int signalfd_copyinfo(struct signalfd_siginfo __user *uinfo, | |||
98 | #ifdef __ARCH_SI_TRAPNO | 99 | #ifdef __ARCH_SI_TRAPNO |
99 | err |= __put_user(kinfo->si_trapno, &uinfo->ssi_trapno); | 100 | err |= __put_user(kinfo->si_trapno, &uinfo->ssi_trapno); |
100 | #endif | 101 | #endif |
102 | #ifdef BUS_MCEERR_AO | ||
103 | /* | ||
104 | * Other callers might not initialize the si_lsb field, | ||
105 | * so check explicitly for the right codes here. | ||
106 | */ | ||
107 | if (kinfo->si_code == BUS_MCEERR_AR || | ||
108 | kinfo->si_code == BUS_MCEERR_AO) | ||
109 | err |= __put_user((short) kinfo->si_addr_lsb, | ||
110 | &uinfo->ssi_addr_lsb); | ||
111 | #endif | ||
101 | break; | 112 | break; |
102 | case __SI_CHLD: | 113 | case __SI_CHLD: |
103 | err |= __put_user(kinfo->si_pid, &uinfo->ssi_pid); | 114 | err |= __put_user(kinfo->si_pid, &uinfo->ssi_pid); |
@@ -111,6 +122,7 @@ static int signalfd_copyinfo(struct signalfd_siginfo __user *uinfo, | |||
111 | err |= __put_user(kinfo->si_pid, &uinfo->ssi_pid); | 122 | err |= __put_user(kinfo->si_pid, &uinfo->ssi_pid); |
112 | err |= __put_user(kinfo->si_uid, &uinfo->ssi_uid); | 123 | err |= __put_user(kinfo->si_uid, &uinfo->ssi_uid); |
113 | err |= __put_user((long) kinfo->si_ptr, &uinfo->ssi_ptr); | 124 | err |= __put_user((long) kinfo->si_ptr, &uinfo->ssi_ptr); |
125 | err |= __put_user(kinfo->si_int, &uinfo->ssi_int); | ||
114 | break; | 126 | break; |
115 | default: | 127 | default: |
116 | /* | 128 | /* |
@@ -204,6 +216,7 @@ static const struct file_operations signalfd_fops = { | |||
204 | .release = signalfd_release, | 216 | .release = signalfd_release, |
205 | .poll = signalfd_poll, | 217 | .poll = signalfd_poll, |
206 | .read = signalfd_read, | 218 | .read = signalfd_read, |
219 | .llseek = noop_llseek, | ||
207 | }; | 220 | }; |
208 | 221 | ||
209 | SYSCALL_DEFINE4(signalfd4, int, ufd, sigset_t __user *, user_mask, | 222 | SYSCALL_DEFINE4(signalfd4, int, ufd, sigset_t __user *, user_mask, |