12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- #ifndef _LINUX_EVENTPOLL_H
- #define _LINUX_EVENTPOLL_H
- #include <linux/fcntl.h>
- #include <linux/types.h>
- #define EPOLL_CLOEXEC O_CLOEXEC
- #define EPOLL_CTL_ADD 1
- #define EPOLL_CTL_DEL 2
- #define EPOLL_CTL_MOD 3
- #define EPOLLEXCLUSIVE (1 << 28)
- #define EPOLLWAKEUP (1 << 29)
- #define EPOLLONESHOT (1 << 30)
- #define EPOLLET (1 << 31)
- #ifdef __x86_64__
- #define EPOLL_PACKED __attribute__((packed))
- #else
- #define EPOLL_PACKED
- #endif
- struct epoll_event {
- __u32 events;
- __u64 data;
- } EPOLL_PACKED;
- #ifdef CONFIG_PM_SLEEP
- static __inline__ void ep_take_care_of_epollwakeup(struct epoll_event *epev)
- {
- if ((epev->events & EPOLLWAKEUP) && !capable(CAP_BLOCK_SUSPEND))
- epev->events &= ~EPOLLWAKEUP;
- }
- #else
- static __inline__ void ep_take_care_of_epollwakeup(struct epoll_event *epev)
- {
- epev->events &= ~EPOLLWAKEUP;
- }
- #endif
- #endif
|