epoll keyed wakeups: make eventfd use keyed wakeups
Introduce keyed event wakeups inside the eventfd code. Signed-off-by: Davide Libenzi <davidel@xmailserver.org> Cc: Alan Cox <alan@lxorguk.ukuu.org.uk> Cc: Ingo Molnar <mingo@elte.hu> Cc: David Miller <davem@davemloft.net> Cc: William Lee Irwin III <wli@movementarian.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
2dfa4eeab0
commit
395108880e
|
@ -51,7 +51,7 @@ int eventfd_signal(struct file *file, int n)
|
||||||
n = (int) (ULLONG_MAX - ctx->count);
|
n = (int) (ULLONG_MAX - ctx->count);
|
||||||
ctx->count += n;
|
ctx->count += n;
|
||||||
if (waitqueue_active(&ctx->wqh))
|
if (waitqueue_active(&ctx->wqh))
|
||||||
wake_up_locked(&ctx->wqh);
|
wake_up_locked_poll(&ctx->wqh, POLLIN);
|
||||||
spin_unlock_irqrestore(&ctx->wqh.lock, flags);
|
spin_unlock_irqrestore(&ctx->wqh.lock, flags);
|
||||||
|
|
||||||
return n;
|
return n;
|
||||||
|
@ -120,7 +120,7 @@ static ssize_t eventfd_read(struct file *file, char __user *buf, size_t count,
|
||||||
ucnt = (ctx->flags & EFD_SEMAPHORE) ? 1 : ctx->count;
|
ucnt = (ctx->flags & EFD_SEMAPHORE) ? 1 : ctx->count;
|
||||||
ctx->count -= ucnt;
|
ctx->count -= ucnt;
|
||||||
if (waitqueue_active(&ctx->wqh))
|
if (waitqueue_active(&ctx->wqh))
|
||||||
wake_up_locked(&ctx->wqh);
|
wake_up_locked_poll(&ctx->wqh, POLLOUT);
|
||||||
}
|
}
|
||||||
spin_unlock_irq(&ctx->wqh.lock);
|
spin_unlock_irq(&ctx->wqh.lock);
|
||||||
if (res > 0 && put_user(ucnt, (__u64 __user *) buf))
|
if (res > 0 && put_user(ucnt, (__u64 __user *) buf))
|
||||||
|
@ -169,7 +169,7 @@ static ssize_t eventfd_write(struct file *file, const char __user *buf, size_t c
|
||||||
if (likely(res > 0)) {
|
if (likely(res > 0)) {
|
||||||
ctx->count += ucnt;
|
ctx->count += ucnt;
|
||||||
if (waitqueue_active(&ctx->wqh))
|
if (waitqueue_active(&ctx->wqh))
|
||||||
wake_up_locked(&ctx->wqh);
|
wake_up_locked_poll(&ctx->wqh, POLLIN);
|
||||||
}
|
}
|
||||||
spin_unlock_irq(&ctx->wqh.lock);
|
spin_unlock_irq(&ctx->wqh.lock);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue