summaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorGreg Kroah-Hartman <gregkh@suse.de>2009-01-20 15:51:16 -0800
committerGreg Kroah-Hartman <gregkh@suse.de>2009-01-20 20:52:09 -0800
commit4503efd0891c40e30928afb4b23dc3f99c62a6b2 (patch)
treeb92d71b333e30f90b4a91a4e4bea895f5489a6ae /fs
parent72638f598ec9f05a43fcb22dc1dd8dc34c43acc1 (diff)
downloadkernel-crypto-4503efd0891c40e30928afb4b23dc3f99c62a6b2.tar.gz
kernel-crypto-4503efd0891c40e30928afb4b23dc3f99c62a6b2.tar.xz
kernel-crypto-4503efd0891c40e30928afb4b23dc3f99c62a6b2.zip
sysfs: fix problems with binary files
Some sysfs binary files don't like having 0 passed to them as a size. Fix this up at the root by just returning to the vfs if userspace asks us for a zero sized buffer. Thanks to Pavel Roskin for pointing this out. Reported-by: Pavel Roskin <proski@gnu.org> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'fs')
-rw-r--r--fs/sysfs/bin.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/fs/sysfs/bin.c b/fs/sysfs/bin.c
index 66f6e58a7e4..f2c478c3424 100644
--- a/fs/sysfs/bin.c
+++ b/fs/sysfs/bin.c
@@ -63,6 +63,9 @@ read(struct file *file, char __user *userbuf, size_t bytes, loff_t *off)
int count = min_t(size_t, bytes, PAGE_SIZE);
char *temp;
+ if (!bytes)
+ return 0;
+
if (size) {
if (offs > size)
return 0;
@@ -131,6 +134,9 @@ static ssize_t write(struct file *file, const char __user *userbuf,
int count = min_t(size_t, bytes, PAGE_SIZE);
char *temp;
+ if (!bytes)
+ return 0;
+
if (size) {
if (offs > size)
return 0;