mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-07 22:42:04 +00:00
epoll: optimize setting task running after blocking
After waking up a task waiting for an event, we explicitly mark it as TASK_RUNNING (which is necessary as we do the checks for wakeups as TASK_INTERRUPTIBLE). Once running and dealing with actually delivering the events, we're obviously not planning on calling schedule, thus we can relax the implied barrier and simply update the state with __set_current_state(). Signed-off-by: Davidlohr Bueso <dbueso@suse.de> Cc: Alexander Viro <viro@zeniv.linux.org.uk> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
0f3c5aab5e
commit
4d5755b147
@ -1639,9 +1639,9 @@ static int ep_poll(struct eventpoll *ep, struct epoll_event __user *events,
|
|||||||
|
|
||||||
spin_lock_irqsave(&ep->lock, flags);
|
spin_lock_irqsave(&ep->lock, flags);
|
||||||
}
|
}
|
||||||
__remove_wait_queue(&ep->wq, &wait);
|
|
||||||
|
|
||||||
set_current_state(TASK_RUNNING);
|
__remove_wait_queue(&ep->wq, &wait);
|
||||||
|
__set_current_state(TASK_RUNNING);
|
||||||
}
|
}
|
||||||
check_events:
|
check_events:
|
||||||
/* Is it worth to try to dig for events ? */
|
/* Is it worth to try to dig for events ? */
|
||||||
|
Loading…
Reference in New Issue
Block a user