diff options
author | Markos Chandras <markos.chandras@imgtec.com> | 2012-10-11 10:12:24 +0100 |
---|---|---|
committer | Bernhard Reutner-Fischer <rep.dot.nop@gmail.com> | 2013-02-20 13:45:11 +0100 |
commit | 257323e525f0cc2774bea4823b3518d0dce87142 (patch) | |
tree | 2b68e1361e13b6ea415393702d172a0131f39e52 /libc | |
parent | dde074b3905cce833e1cdca591174454e046083e (diff) |
epoll: Use epoll_create1 if arch does not have the epoll_create syscall
Signed-off-by: Markos Chandras <markos.chandras@imgtec.com>
Signed-off-by: Bernhard Reutner-Fischer <rep.dot.nop@gmail.com>
Diffstat (limited to 'libc')
-rw-r--r-- | libc/sysdeps/linux/common/epoll.c | 8 | ||||
-rw-r--r-- | libc/sysdeps/linux/common/stubs.c | 3 |
2 files changed, 10 insertions, 1 deletions
diff --git a/libc/sysdeps/linux/common/epoll.c b/libc/sysdeps/linux/common/epoll.c index 29b4600d1..b7366262a 100644 --- a/libc/sysdeps/linux/common/epoll.c +++ b/libc/sysdeps/linux/common/epoll.c @@ -19,6 +19,14 @@ _syscall1(int, epoll_create, int, size) _syscall1(int, epoll_create1, int, flags) #endif +#if defined __NR_epoll_create1 && !defined __NR_epoll_create +int epoll_create(int size) +{ + return INLINE_SYSCALL(epoll_create1, 1, 0); +} + +#endif + #ifdef __NR_epoll_ctl _syscall4(int, epoll_ctl, int, epfd, int, op, int, fd, struct epoll_event *, event) #endif diff --git a/libc/sysdeps/linux/common/stubs.c b/libc/sysdeps/linux/common/stubs.c index 1f985e05f..0f000f0ed 100644 --- a/libc/sysdeps/linux/common/stubs.c +++ b/libc/sysdeps/linux/common/stubs.c @@ -94,7 +94,8 @@ make_stub(create_module) make_stub(delete_module) #endif -#if !defined __NR_epoll_create && defined __UCLIBC_HAS_EPOLL__ +#if !defined __NR_epoll_create && defined __UCLIBC_HAS_EPOLL__ \ + && !defined __NR_epoll_create1 make_stub(epoll_create) #endif |