From ce28746fb713839e55c8904d32e2b5946d01b2aa Mon Sep 17 00:00:00 2001 From: David Woodhouse Date: Sun, 17 Aug 2008 17:21:18 +0100 Subject: [PATCH] --- yaml --- r: 117471 b: refs/heads/master c: c002a6c7977320f95b5edede5ce4e0eeecf291ff h: refs/heads/master i: 117469: 57692cdac2f6ad4a46324d1601096d7656c5a974 117467: d74b02d3fd1ca3ab573e493d32da67a865e7d1af 117463: 285b4a67335e7a06fa9c43566f6aa4636e341318 117455: 261d012fd24abd14aa0fc08d322d8fafa49534fa 117439: da77bb2022bacb7d5ee379f0135fad24007609ca v: v3 --- [refs] | 2 +- trunk/fs/nfsd/vfs.c | 5 +++-- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/[refs] b/[refs] index 6fe14507d8a7..c7c454b2afe6 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 53c9c5c0e32c69f9df1822e47671c13e3402c82f +refs/heads/master: c002a6c7977320f95b5edede5ce4e0eeecf291ff diff --git a/trunk/fs/nfsd/vfs.c b/trunk/fs/nfsd/vfs.c index e3e37f7c8477..49d4b8725ca3 100644 --- a/trunk/fs/nfsd/vfs.c +++ b/trunk/fs/nfsd/vfs.c @@ -1891,7 +1891,6 @@ static int nfsd_buffered_readdir(struct file *file, filldir_t func, if (!size) break; - de = (struct buffered_dirent *)buf.dirent; while (size > 0) { offset = de->offset; @@ -1908,7 +1907,9 @@ static int nfsd_buffered_readdir(struct file *file, filldir_t func, size -= reclen; de = (struct buffered_dirent *)((char *)de + reclen); } - offset = vfs_llseek(file, 0, 1); + offset = vfs_llseek(file, 0, SEEK_CUR); + if (!buf.full) + break; } done: