X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=fs%2Feventpoll.c;h=ead00467282dd2004c5e3cf792f8db0ed100fcad;hb=5a47f7ed643ef221a645da68031bfdfd36340aa1;hp=af903128891cfa0365f7fac36ba8fc052cc584a4;hpb=4e13c5d0212f25d69a97606b9d5a85edb52a7737;p=platform%2Fadaptation%2Frenesas_rcar%2Frenesas_kernel.git diff --git a/fs/eventpoll.c b/fs/eventpoll.c index af90312..ead0046 100644 --- a/fs/eventpoll.c +++ b/fs/eventpoll.c @@ -910,7 +910,7 @@ static const struct file_operations eventpoll_fops = { void eventpoll_release_file(struct file *file) { struct eventpoll *ep; - struct epitem *epi; + struct epitem *epi, *next; /* * We don't want to get "file->f_lock" because it is not @@ -926,7 +926,7 @@ void eventpoll_release_file(struct file *file) * Besides, ep_remove() acquires the lock, so we can't hold it here. */ mutex_lock(&epmutex); - list_for_each_entry_rcu(epi, &file->f_ep_links, fllink) { + list_for_each_entry_safe(epi, next, &file->f_ep_links, fllink) { ep = epi->ep; mutex_lock_nested(&ep->mtx, 0); ep_remove(ep, epi);