Looks good to me Reviewed-by: Carlos Maiolino <cmaiolino@xxxxxxxxxx> On Fri, Mar 29, 2013 at 05:09:44PM +0100, Jan Kara wrote: > After commit 21d8a15a (lookup_one_len: don't accept . and ..) reiserfs > started failing to delete xattrs from inode. This was due to a buggy > test for '.' and '..' in fill_with_dentries() which resulted in passing > '.' and '..' entries to lookup_one_len() in some cases. That returned > error and so we failed to iterate over all xattrs of and inode. > > Fix the test in fill_with_dentries() along the lines of the one in > lookup_one_len(). > > Reported-by: Pawel Zawora <pzawora@xxxxxxxxx> > CC: stable@xxxxxxxxxxxxxxx > Signed-off-by: Jan Kara <jack@xxxxxxx> > --- > fs/reiserfs/xattr.c | 4 ++-- > 1 files changed, 2 insertions(+), 2 deletions(-) > > diff --git a/fs/reiserfs/xattr.c b/fs/reiserfs/xattr.c > index c196369..4cce1d9 100644 > --- a/fs/reiserfs/xattr.c > +++ b/fs/reiserfs/xattr.c > @@ -187,8 +187,8 @@ fill_with_dentries(void *buf, const char *name, int namelen, loff_t offset, > if (dbuf->count == ARRAY_SIZE(dbuf->dentries)) > return -ENOSPC; > > - if (name[0] == '.' && (name[1] == '\0' || > - (name[1] == '.' && name[2] == '\0'))) > + if (name[0] == '.' && (namelen < 2 || > + (namelen == 2 && name[1] == '.'))) > return 0; > > dentry = lookup_one_len(name, dbuf->xadir, namelen); > -- > 1.7.1 > > -- > To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html -- Carlos -- To unsubscribe from this list: send the line "unsubscribe stable" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html