From mboxrd@z Thu Jan 1 00:00:00 1970 From: Hagen Paul Pfeifer Subject: Re: [PATCH Resend] epoll: add EPOLLEXCLUSIVE support Date: Wed, 28 Mar 2012 21:58:48 +0200 Message-ID: <20120328195848.GA5331@hell> References: <1332943060-18374-1-git-send-email-hagen@jauu.net> <20120328162108.GB2381@redhat.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Cc: richard -rw- weinberger , torvalds@linux-foundation.org, LKML , Al Viro , Lucas De Marchi , Andrew Morton , linux-fsdevel@vger.kernel.org, eric.dumazet@gmail.com To: Jason Baron Return-path: Content-Disposition: inline In-Reply-To: <20120328162108.GB2381@redhat.com> Sender: linux-kernel-owner@vger.kernel.org List-Id: linux-fsdevel.vger.kernel.org * Jason Baron | 2012-03-28 12:21:08 [-0400]: >Hmmm...Looking at ep_poll() it does an '__add_wait_queue_exclusive()'. >So, I *think* epoll_wait() should do what you want, if you are waiting >on the same epfd in all the threads. > >I think the case you are describing is where each thread does its own >ep_create(), and then a subsequent epoll_wait() on the fd from the >create? > >So, I *think* you can get what you want without adding this flag. ;) sorry: epoll_wait returned epoll_wait returned epoll_wait returned epoll_wait returned epoll_wait returned epoll_wait returned epoll_wait returned epoll_wait returned epoll_wait returned epoll_wait returned minimal example: >>>>>>>>>>> #include #include #include #include #include #include #define AMAX 16 static void *runner(void *args) { int fd = (int) *((int *) args); struct epoll_event events[AMAX]; epoll_wait(fd, events, AMAX, -1); write(1, "epoll_wait returned\n", 20); return NULL; } int main(int ac, char **av) { int i, evfd, pipefd[2]; pthread_t thread_id[2]; struct epoll_event epoll_ev; pipe(pipefd); evfd = epoll_create(64); memset(&epoll_ev, 0, sizeof(struct epoll_event)); epoll_ev.events = EPOLLIN | EPOLLPRI | EPOLLERR | EPOLLHUP; epoll_ctl(evfd, EPOLL_CTL_ADD, pipefd[0], &epoll_ev); for (i = 0; i < 10; i++) pthread_create(&thread_id[0], NULL, runner, &evfd); sleep(1); close(pipefd[1]); write(pipefd[0], "x", 1); sleep(1); return EXIT_SUCCESS; } <<<<<<<<<<< Cheers, Hagen