[PATCH 0/6] fuse: Interrupt-related optimizations and improvements

From: Kirill Tkhai
Date: Tue Nov 06 2018 - 04:30:32 EST


This patchset consists of several parts. Patches [1-2] optimize
likely case of request_end(), and make this function to take
fiq->waitq.lock only, when it is really needed. This improves
performance of this function completes.

Patch 3 makes request_end() to call wake_up() only for not
background requests (background requests never wait answer),
and this optimizes this function a bit more

Patches [4-6] makes code to check userspace requests correct
interrupt id to requeue (whether we've sent this interrupt).

---

Kirill Tkhai (6):
fuse: Kill fasync only if interrupt is queued in queue_interrupt()
fuse: Optimize request_end() by not taking fiq->waitq.lock
fuse: Wake up req->waitq of only not background requests in request_end()
fuse: Check for FR_SENT bit in fuse_dev_do_write()
fuse: Do some refactoring in fuse_dev_do_write()
fuse: Verify userspace asks to requeue interrupt that we really sent


fs/fuse/dev.c | 73 +++++++++++++++++++++++++++++++++++++++++----------------
1 file changed, 53 insertions(+), 20 deletions(-)

--
Signed-off-by: Kirill Tkhai <ktkhai@xxxxxxxxxxxxx>