• K
    aio: make aio_read_evt() more efficient, convert to hrtimers · a31ad380
    Kent Overstreet 提交于
    Previously, aio_read_event() pulled a single completion off the
    ringbuffer at a time, locking and unlocking each time.  Change it to
    pull off as many events as it can at a time, and copy them directly to
    userspace.
    
    This also fixes a bug where if copying the event to userspace failed,
    we'd lose the event.
    
    Also convert it to wait_event_interruptible_hrtimeout(), which
    simplifies it quite a bit.
    
    [akpm@linux-foundation.org: coding-style fixes]
    Signed-off-by: NKent Overstreet <koverstreet@google.com>
    Cc: Zach Brown <zab@redhat.com>
    Cc: Felipe Balbi <balbi@ti.com>
    Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
    Cc: Mark Fasheh <mfasheh@suse.com>
    Cc: Joel Becker <jlbec@evilplan.org>
    Cc: Rusty Russell <rusty@rustcorp.com.au>
    Cc: Jens Axboe <axboe@kernel.dk>
    Cc: Asai Thambi S P <asamymuthupa@micron.com>
    Cc: Selvan Mani <smani@micron.com>
    Cc: Sam Bradshaw <sbradshaw@micron.com>
    Cc: Jeff Moyer <jmoyer@redhat.com>
    Cc: Al Viro <viro@zeniv.linux.org.uk>
    Cc: Benjamin LaHaise <bcrl@kvack.org>
    Reviewed-by: N"Theodore Ts'o" <tytso@mit.edu>
    Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
    Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
    a31ad380
aio.c 35.7 KB