diff options
Diffstat (limited to 'fs')
| -rw-r--r-- | fs/eventpoll.c | 38 |
1 files changed, 3 insertions, 35 deletions
diff --git a/fs/eventpoll.c b/fs/eventpoll.c index da72250ddc1c..cd96649bfe62 100644 --- a/fs/eventpoll.c +++ b/fs/eventpoll.c | |||
| @@ -346,7 +346,7 @@ static inline struct epitem *ep_item_from_epqueue(poll_table *p) | |||
| 346 | /* Tells if the epoll_ctl(2) operation needs an event copy from userspace */ | 346 | /* Tells if the epoll_ctl(2) operation needs an event copy from userspace */ |
| 347 | static inline int ep_op_has_event(int op) | 347 | static inline int ep_op_has_event(int op) |
| 348 | { | 348 | { |
| 349 | return op == EPOLL_CTL_ADD || op == EPOLL_CTL_MOD; | 349 | return op != EPOLL_CTL_DEL; |
| 350 | } | 350 | } |
| 351 | 351 | ||
| 352 | /* Initialize the poll safe wake up structure */ | 352 | /* Initialize the poll safe wake up structure */ |
| @@ -676,34 +676,6 @@ static int ep_remove(struct eventpoll *ep, struct epitem *epi) | |||
| 676 | return 0; | 676 | return 0; |
| 677 | } | 677 | } |
| 678 | 678 | ||
| 679 | /* | ||
| 680 | * Disables a "struct epitem" in the eventpoll set. Returns -EBUSY if the item | ||
| 681 | * had no event flags set, indicating that another thread may be currently | ||
| 682 | * handling that item's events (in the case that EPOLLONESHOT was being | ||
| 683 | * used). Otherwise a zero result indicates that the item has been disabled | ||
| 684 | * from receiving events. A disabled item may be re-enabled via | ||
| 685 | * EPOLL_CTL_MOD. Must be called with "mtx" held. | ||
| 686 | */ | ||
| 687 | static int ep_disable(struct eventpoll *ep, struct epitem *epi) | ||
| 688 | { | ||
| 689 | int result = 0; | ||
| 690 | unsigned long flags; | ||
| 691 | |||
| 692 | spin_lock_irqsave(&ep->lock, flags); | ||
| 693 | if (epi->event.events & ~EP_PRIVATE_BITS) { | ||
| 694 | if (ep_is_linked(&epi->rdllink)) | ||
| 695 | list_del_init(&epi->rdllink); | ||
| 696 | /* Ensure ep_poll_callback will not add epi back onto ready | ||
| 697 | list: */ | ||
| 698 | epi->event.events &= EP_PRIVATE_BITS; | ||
| 699 | } | ||
| 700 | else | ||
| 701 | result = -EBUSY; | ||
| 702 | spin_unlock_irqrestore(&ep->lock, flags); | ||
| 703 | |||
| 704 | return result; | ||
| 705 | } | ||
| 706 | |||
| 707 | static void ep_free(struct eventpoll *ep) | 679 | static void ep_free(struct eventpoll *ep) |
| 708 | { | 680 | { |
| 709 | struct rb_node *rbp; | 681 | struct rb_node *rbp; |
| @@ -1048,6 +1020,8 @@ static void ep_rbtree_insert(struct eventpoll *ep, struct epitem *epi) | |||
| 1048 | rb_insert_color(&epi->rbn, &ep->rbr); | 1020 | rb_insert_color(&epi->rbn, &ep->rbr); |
| 1049 | } | 1021 | } |
| 1050 | 1022 | ||
| 1023 | |||
| 1024 | |||
| 1051 | #define PATH_ARR_SIZE 5 | 1025 | #define PATH_ARR_SIZE 5 |
| 1052 | /* | 1026 | /* |
| 1053 | * These are the number paths of length 1 to 5, that we are allowing to emanate | 1027 | * These are the number paths of length 1 to 5, that we are allowing to emanate |
| @@ -1813,12 +1787,6 @@ SYSCALL_DEFINE4(epoll_ctl, int, epfd, int, op, int, fd, | |||
| 1813 | } else | 1787 | } else |
| 1814 | error = -ENOENT; | 1788 | error = -ENOENT; |
| 1815 | break; | 1789 | break; |
| 1816 | case EPOLL_CTL_DISABLE: | ||
| 1817 | if (epi) | ||
| 1818 | error = ep_disable(ep, epi); | ||
| 1819 | else | ||
| 1820 | error = -ENOENT; | ||
| 1821 | break; | ||
| 1822 | } | 1790 | } |
| 1823 | mutex_unlock(&ep->mtx); | 1791 | mutex_unlock(&ep->mtx); |
| 1824 | 1792 | ||
