fuse: no ENOENT from fuse device read

Don't return -ENOENT for a read() on the fuse device when the request was
aborted.  Instead return -ENODEV, meaning the filesystem has been
force-umounted or aborted.

Previously ENOENT meant that the request was interrupted, but now the
'aborted' flag is not set in case of interrupts.

Signed-off-by: Miklos Szeredi <mszeredi@suse.cz>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
Miklos Szeredi 2007-10-16 23:31:05 -07:00 committed by Linus Torvalds
parent a131de0a48
commit c9c9d7df5f

View File

@ -747,11 +747,12 @@ static ssize_t fuse_dev_read(struct kiocb *iocb, const struct iovec *iov,
fuse_copy_finish(&cs);
spin_lock(&fc->lock);
req->locked = 0;
if (!err && req->aborted)
err = -ENOENT;
if (req->aborted) {
request_end(fc, req);
return -ENODEV;
}
if (err) {
if (!req->aborted)
req->out.h.error = -EIO;
req->out.h.error = -EIO;
request_end(fc, req);
return err;
}