summaryrefslogtreecommitdiff
path: root/fs/hfsplus
diff options
context:
space:
mode:
authorMatthew Garrett <mjg@redhat.com>2012-03-13 12:10:34 -0400
committerAl Viro <viro@zeniv.linux.org.uk>2012-03-20 21:29:52 -0400
commitf3922382ce930e76773fb06416a7a6081a8702ad (patch)
tree41de4a013a7d0686403da8a37880644cc3390b81 /fs/hfsplus
parent7cd916f6ea86e8538b1e8136847dfb941813fe94 (diff)
downloadlinux-3.10-f3922382ce930e76773fb06416a7a6081a8702ad.tar.gz
linux-3.10-f3922382ce930e76773fb06416a7a6081a8702ad.tar.bz2
linux-3.10-f3922382ce930e76773fb06416a7a6081a8702ad.zip
hfsplus: initialise userflags
The userflags field was being written to the filesystem without being initialised. Make sure it's clear, since otherwise files end up with garbage attributes. Signed-off-by: Matthew Garrett <mjg@redhat.com> Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs/hfsplus')
-rw-r--r--fs/hfsplus/inode.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c
index 6643b242bdd..82b69ee4dac 100644
--- a/fs/hfsplus/inode.c
+++ b/fs/hfsplus/inode.c
@@ -193,6 +193,7 @@ static struct dentry *hfsplus_file_lookup(struct inode *dir,
mutex_init(&hip->extents_lock);
hip->extent_state = 0;
hip->flags = 0;
+ hip->userflags = 0;
set_bit(HFSPLUS_I_RSRC, &hip->flags);
err = hfs_find_init(HFSPLUS_SB(sb)->cat_tree, &fd);
@@ -400,6 +401,7 @@ struct inode *hfsplus_new_inode(struct super_block *sb, umode_t mode)
atomic_set(&hip->opencnt, 0);
hip->extent_state = 0;
hip->flags = 0;
+ hip->userflags = 0;
memset(hip->first_extents, 0, sizeof(hfsplus_extent_rec));
memset(hip->cached_extents, 0, sizeof(hfsplus_extent_rec));
hip->alloc_blocks = 0;