From: Todd Poynor Date: Wed, 24 Aug 2011 22:01:30 +0000 (-0700) Subject: ANDROID: fs: fuse: Freeze client on suspend when request sent to userspace X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=090f104c111f17df53e4ec64bfea589e514d00a8;p=GitHub%2FLineageOS%2Fandroid_kernel_motorola_exynos9610.git ANDROID: fs: fuse: Freeze client on suspend when request sent to userspace Suspend attempts can abort when the FUSE daemon is already frozen and a client is waiting uninterruptibly for a response, causing freezing of tasks to fail. Use the freeze-friendly wait API, but disregard other signals. Change-Id: Icefb7e4bbc718ccb76bf3c04daaa5eeea7e0e63c Signed-off-by: Todd Poynor --- diff --git a/fs/fuse/dev.c b/fs/fuse/dev.c index 13c65dd2d37d..9b35551d9986 100644 --- a/fs/fuse/dev.c +++ b/fs/fuse/dev.c @@ -21,6 +21,7 @@ #include #include #include +#include MODULE_ALIAS_MISCDEV(FUSE_MINOR); MODULE_ALIAS("devname:fuse"); @@ -454,7 +455,9 @@ static void request_wait_answer(struct fuse_conn *fc, struct fuse_req *req) * Either request is already in userspace, or it was forced. * Wait it out. */ - wait_event(req->waitq, test_bit(FR_FINISHED, &req->flags)); + while (!test_bit(FR_FINISHED, &req->flags)) + wait_event_freezable(req->waitq, + test_bit(FR_FINISHED, &req->flags)); } static void __fuse_request_send(struct fuse_conn *fc, struct fuse_req *req)