diff options
Diffstat (limited to 'fs/eventfd.c')
-rw-r--r-- | fs/eventfd.c | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/fs/eventfd.c b/fs/eventfd.c index 343942deeec1..08bf558d0408 100644 --- a/fs/eventfd.c +++ b/fs/eventfd.c | |||
@@ -198,11 +198,18 @@ struct file *eventfd_fget(int fd) | |||
198 | return file; | 198 | return file; |
199 | } | 199 | } |
200 | 200 | ||
201 | asmlinkage long sys_eventfd(unsigned int count) | 201 | asmlinkage long sys_eventfd2(unsigned int count, int flags) |
202 | { | 202 | { |
203 | int fd; | 203 | int fd; |
204 | struct eventfd_ctx *ctx; | 204 | struct eventfd_ctx *ctx; |
205 | 205 | ||
206 | /* Check the EFD_* constants for consistency. */ | ||
207 | BUILD_BUG_ON(EFD_CLOEXEC != O_CLOEXEC); | ||
208 | BUILD_BUG_ON(EFD_NONBLOCK != O_NONBLOCK); | ||
209 | |||
210 | if (flags & ~(EFD_CLOEXEC | EFD_NONBLOCK)) | ||
211 | return -EINVAL; | ||
212 | |||
206 | ctx = kmalloc(sizeof(*ctx), GFP_KERNEL); | 213 | ctx = kmalloc(sizeof(*ctx), GFP_KERNEL); |
207 | if (!ctx) | 214 | if (!ctx) |
208 | return -ENOMEM; | 215 | return -ENOMEM; |
@@ -214,9 +221,15 @@ asmlinkage long sys_eventfd(unsigned int count) | |||
214 | * When we call this, the initialization must be complete, since | 221 | * When we call this, the initialization must be complete, since |
215 | * anon_inode_getfd() will install the fd. | 222 | * anon_inode_getfd() will install the fd. |
216 | */ | 223 | */ |
217 | fd = anon_inode_getfd("[eventfd]", &eventfd_fops, ctx); | 224 | fd = anon_inode_getfd("[eventfd]", &eventfd_fops, ctx, |
225 | flags & (O_CLOEXEC | O_NONBLOCK)); | ||
218 | if (fd < 0) | 226 | if (fd < 0) |
219 | kfree(ctx); | 227 | kfree(ctx); |
220 | return fd; | 228 | return fd; |
221 | } | 229 | } |
222 | 230 | ||
231 | asmlinkage long sys_eventfd(unsigned int count) | ||
232 | { | ||
233 | return sys_eventfd2(count, 0); | ||
234 | } | ||
235 | |||