X-Git-Url: https://git.openpandora.org/cgi-bin/gitweb.cgi?p=pandora-kernel.git;a=blobdiff_plain;f=fs%2Ffuse%2Fdir.c;h=4041f76dd6c4ddeba343c9620e7144cfe85f4a29;hp=499217e8bbe365ef107644476fde5bd1569f6d9c;hb=b60c85b47c061f6423cab77faf87402be5f6465a;hpb=93d390202a5fd61e4677dd7b42b44c3b290d88c3 diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c index 499217e8bbe3..4041f76dd6c4 100644 --- a/fs/fuse/dir.c +++ b/fs/fuse/dir.c @@ -1536,6 +1536,23 @@ static ssize_t fuse_getxattr(struct dentry *entry, const char *name, return ret; } +static int fuse_verify_xattr_list(char *list, size_t size) +{ + size_t origsize = size; + + while (size) { + size_t thislen = strnlen(list, size); + + if (!thislen || thislen == size) + return -EIO; + + size -= thislen + 1; + list += thislen + 1; + } + + return origsize; +} + static ssize_t fuse_listxattr(struct dentry *entry, char *list, size_t size) { struct inode *inode = entry->d_inode; @@ -1574,9 +1591,11 @@ static ssize_t fuse_listxattr(struct dentry *entry, char *list, size_t size) } fuse_request_send(fc, req); ret = req->out.h.error; - if (!ret) + if (!ret) { ret = size ? req->out.args[0].size : outarg.size; - else { + if (ret > 0 && size) + ret = fuse_verify_xattr_list(list, ret); + } else { if (ret == -ENOSYS) { fc->no_listxattr = 1; ret = -EOPNOTSUPP;