aboutsummaryrefslogtreecommitdiffstats
path: root/fs/eventpoll.c
diff options
context:
space:
mode:
authorPavel Emelianov <xemul@sw.ru>2007-05-08 03:30:19 -0400
committerLinus Torvalds <torvalds@woody.linux-foundation.org>2007-05-08 14:15:11 -0400
commitb5e618181a927210f8be1d3d2249d31904ba358d (patch)
tree731f1ae4ff1ba56d402bb329182b7d935bb439a1 /fs/eventpoll.c
parentdb9c02fa8bd50eb104781a9f78cae923d8da1e74 (diff)
Introduce a handy list_first_entry macro
There are many places in the kernel where the construction like foo = list_entry(head->next, struct foo_struct, list); are used. The code might look more descriptive and neat if using the macro list_first_entry(head, type, member) \ list_entry((head)->next, type, member) Here is the macro itself and the examples of its usage in the generic code. If it will turn out to be useful, I can prepare the set of patches to inject in into arch-specific code, drivers, networking, etc. Signed-off-by: Pavel Emelianov <xemul@openvz.org> Signed-off-by: Kirill Korotaev <dev@openvz.org> Cc: Randy Dunlap <randy.dunlap@oracle.com> Cc: Andi Kleen <andi@firstfloor.org> Cc: Zach Brown <zach.brown@oracle.com> Cc: Davide Libenzi <davidel@xmailserver.org> Cc: John McCutchan <ttb@tentacle.dhs.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Ingo Molnar <mingo@elte.hu> Cc: john stultz <johnstul@us.ibm.com> Cc: Ram Pai <linuxram@us.ibm.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'fs/eventpoll.c')
-rw-r--r--fs/eventpoll.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/fs/eventpoll.c b/fs/eventpoll.c
index d0b86060cc19..b5c7ca584939 100644
--- a/fs/eventpoll.c
+++ b/fs/eventpoll.c
@@ -453,7 +453,7 @@ void eventpoll_release_file(struct file *file)
453 mutex_lock(&epmutex); 453 mutex_lock(&epmutex);
454 454
455 while (!list_empty(lsthead)) { 455 while (!list_empty(lsthead)) {
456 epi = list_entry(lsthead->next, struct epitem, fllink); 456 epi = list_first_entry(lsthead, struct epitem, fllink);
457 457
458 ep = epi->ep; 458 ep = epi->ep;
459 list_del_init(&epi->fllink); 459 list_del_init(&epi->fllink);
@@ -1143,7 +1143,7 @@ static void ep_unregister_pollwait(struct eventpoll *ep, struct epitem *epi)
1143 1143
1144 if (nwait) { 1144 if (nwait) {
1145 while (!list_empty(lsthead)) { 1145 while (!list_empty(lsthead)) {
1146 pwq = list_entry(lsthead->next, struct eppoll_entry, llink); 1146 pwq = list_first_entry(lsthead, struct eppoll_entry, llink);
1147 1147
1148 list_del_init(&pwq->llink); 1148 list_del_init(&pwq->llink);
1149 remove_wait_queue(pwq->whead, &pwq->wait); 1149 remove_wait_queue(pwq->whead, &pwq->wait);
@@ -1359,7 +1359,7 @@ static int ep_send_events(struct eventpoll *ep, struct list_head *txlist,
1359 * read. 1359 * read.
1360 */ 1360 */
1361 for (eventcnt = 0; !list_empty(txlist) && eventcnt < maxevents;) { 1361 for (eventcnt = 0; !list_empty(txlist) && eventcnt < maxevents;) {
1362 epi = list_entry(txlist->next, struct epitem, rdllink); 1362 epi = list_first_entry(txlist, struct epitem, rdllink);
1363 prefetch(epi->rdllink.next); 1363 prefetch(epi->rdllink.next);
1364 1364
1365 /* 1365 /*