From: Miklos Szeredi Date: Fri, 8 Apr 2005 16:39:09 +0000 (+0000) Subject: fix X-Git-Tag: fuse_2_3_pre5~4 X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=89814a18530fd45af0793c1dd7b240453421c1bf;p=qemu-gpiodev%2Flibfuse.git fix --- diff --git a/ChangeLog b/ChangeLog index 24d9da8..4d83e65 100644 --- a/ChangeLog +++ b/ChangeLog @@ -2,6 +2,9 @@ * Fix Oops in case of nfs export. Spotted by David Shaw + * Fix another Oops in case of write over nfs with direct_io turned + on. Again spotted by David Shaw + 2005-04-07 Miklos Szeredi * Released 2.3-pre4 diff --git a/kernel/file.c b/kernel/file.c index a886546..e7de38a 100644 --- a/kernel/file.c +++ b/kernel/file.c @@ -508,6 +508,10 @@ static int fuse_get_user_pages(struct fuse_req *req, const char __user *buf, unsigned offset = user_addr & ~PAGE_MASK; int npages; + /* This doesn't work with nfsd */ + if (!current->mm) + return -EPERM; + nbytes = min(nbytes, (unsigned) FUSE_MAX_PAGES_PER_REQ << PAGE_SHIFT); npages = (nbytes + offset + PAGE_SIZE - 1) >> PAGE_SHIFT; npages = min(npages, FUSE_MAX_PAGES_PER_REQ);