diff options
Diffstat (limited to 'fs/hfsplus')
-rw-r--r-- | fs/hfsplus/catalog.c | 1 | ||||
-rw-r--r-- | fs/hfsplus/hfsplus_fs.h | 2 | ||||
-rw-r--r-- | fs/hfsplus/inode.c | 1 | ||||
-rw-r--r-- | fs/hfsplus/ioctl.c | 25 |
4 files changed, 12 insertions, 17 deletions
diff --git a/fs/hfsplus/catalog.c b/fs/hfsplus/catalog.c index 9d1594b0a07a..bbcf5a27b5d3 100644 --- a/fs/hfsplus/catalog.c +++ b/fs/hfsplus/catalog.c | |||
@@ -77,7 +77,6 @@ static void hfsplus_set_perms(struct inode *inode, struct hfsplus_perm *perms) | |||
77 | perms->rootflags |= HFSPLUS_FLG_APPEND; | 77 | perms->rootflags |= HFSPLUS_FLG_APPEND; |
78 | else | 78 | else |
79 | perms->rootflags &= ~HFSPLUS_FLG_APPEND; | 79 | perms->rootflags &= ~HFSPLUS_FLG_APPEND; |
80 | HFSPLUS_I(inode)->rootflags = perms->rootflags; | ||
81 | HFSPLUS_I(inode)->userflags = perms->userflags; | 80 | HFSPLUS_I(inode)->userflags = perms->userflags; |
82 | perms->mode = cpu_to_be16(inode->i_mode); | 81 | perms->mode = cpu_to_be16(inode->i_mode); |
83 | perms->owner = cpu_to_be32(inode->i_uid); | 82 | perms->owner = cpu_to_be32(inode->i_uid); |
diff --git a/fs/hfsplus/hfsplus_fs.h b/fs/hfsplus/hfsplus_fs.h index d92f590d6633..0d77844a00e8 100644 --- a/fs/hfsplus/hfsplus_fs.h +++ b/fs/hfsplus/hfsplus_fs.h | |||
@@ -188,7 +188,7 @@ struct hfsplus_inode_info { | |||
188 | * Protected by i_mutex. | 188 | * Protected by i_mutex. |
189 | */ | 189 | */ |
190 | sector_t fs_blocks; | 190 | sector_t fs_blocks; |
191 | u8 rootflags, userflags; /* BSD system and user file flags */ | 191 | u8 userflags; /* BSD user file flags */ |
192 | struct list_head open_dir_list; | 192 | struct list_head open_dir_list; |
193 | loff_t phys_size; | 193 | loff_t phys_size; |
194 | 194 | ||
diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c index 746e0ee20717..df57ea1f3a71 100644 --- a/fs/hfsplus/inode.c +++ b/fs/hfsplus/inode.c | |||
@@ -241,7 +241,6 @@ static void hfsplus_get_perms(struct inode *inode, struct hfsplus_perm *perms, i | |||
241 | mode = S_IFREG | ((S_IRUGO|S_IWUGO) & ~(sbi->umask)); | 241 | mode = S_IFREG | ((S_IRUGO|S_IWUGO) & ~(sbi->umask)); |
242 | inode->i_mode = mode; | 242 | inode->i_mode = mode; |
243 | 243 | ||
244 | HFSPLUS_I(inode)->rootflags = perms->rootflags; | ||
245 | HFSPLUS_I(inode)->userflags = perms->userflags; | 244 | HFSPLUS_I(inode)->userflags = perms->userflags; |
246 | if (perms->rootflags & HFSPLUS_FLG_IMMUTABLE) | 245 | if (perms->rootflags & HFSPLUS_FLG_IMMUTABLE) |
247 | inode->i_flags |= S_IMMUTABLE; | 246 | inode->i_flags |= S_IMMUTABLE; |
diff --git a/fs/hfsplus/ioctl.c b/fs/hfsplus/ioctl.c index c9ac443d202a..80eb5b3a5edd 100644 --- a/fs/hfsplus/ioctl.c +++ b/fs/hfsplus/ioctl.c | |||
@@ -26,9 +26,9 @@ static int hfsplus_ioctl_getflags(struct file *file, int __user *user_flags) | |||
26 | struct hfsplus_inode_info *hip = HFSPLUS_I(inode); | 26 | struct hfsplus_inode_info *hip = HFSPLUS_I(inode); |
27 | unsigned int flags = 0; | 27 | unsigned int flags = 0; |
28 | 28 | ||
29 | if (hip->rootflags & HFSPLUS_FLG_IMMUTABLE) | 29 | if (inode->i_flags & S_IMMUTABLE) |
30 | flags |= FS_IMMUTABLE_FL; | 30 | flags |= FS_IMMUTABLE_FL; |
31 | if (hip->rootflags & HFSPLUS_FLG_APPEND) | 31 | if (inode->i_flags |= S_APPEND) |
32 | flags |= FS_APPEND_FL; | 32 | flags |= FS_APPEND_FL; |
33 | if (hip->userflags & HFSPLUS_FLG_NODUMP) | 33 | if (hip->userflags & HFSPLUS_FLG_NODUMP) |
34 | flags |= FS_NODUMP_FL; | 34 | flags |= FS_NODUMP_FL; |
@@ -59,8 +59,8 @@ static int hfsplus_ioctl_setflags(struct file *file, int __user *user_flags) | |||
59 | 59 | ||
60 | mutex_lock(&inode->i_mutex); | 60 | mutex_lock(&inode->i_mutex); |
61 | 61 | ||
62 | if (flags & (FS_IMMUTABLE_FL|FS_APPEND_FL) || | 62 | if ((flags & (FS_IMMUTABLE_FL|FS_APPEND_FL)) || |
63 | hip->rootflags & (HFSPLUS_FLG_IMMUTABLE|HFSPLUS_FLG_APPEND)) { | 63 | inode->i_flags & (S_IMMUTABLE|S_APPEND)) { |
64 | if (!capable(CAP_LINUX_IMMUTABLE)) { | 64 | if (!capable(CAP_LINUX_IMMUTABLE)) { |
65 | err = -EPERM; | 65 | err = -EPERM; |
66 | goto out_unlock_inode; | 66 | goto out_unlock_inode; |
@@ -72,20 +72,17 @@ static int hfsplus_ioctl_setflags(struct file *file, int __user *user_flags) | |||
72 | err = -EOPNOTSUPP; | 72 | err = -EOPNOTSUPP; |
73 | goto out_unlock_inode; | 73 | goto out_unlock_inode; |
74 | } | 74 | } |
75 | if (flags & FS_IMMUTABLE_FL) { | 75 | |
76 | if (flags & FS_IMMUTABLE_FL) | ||
76 | inode->i_flags |= S_IMMUTABLE; | 77 | inode->i_flags |= S_IMMUTABLE; |
77 | hip->rootflags |= HFSPLUS_FLG_IMMUTABLE; | 78 | else |
78 | } else { | ||
79 | inode->i_flags &= ~S_IMMUTABLE; | 79 | inode->i_flags &= ~S_IMMUTABLE; |
80 | hip->rootflags &= ~HFSPLUS_FLG_IMMUTABLE; | 80 | |
81 | } | 81 | if (flags & FS_APPEND_FL) |
82 | if (flags & FS_APPEND_FL) { | ||
83 | inode->i_flags |= S_APPEND; | 82 | inode->i_flags |= S_APPEND; |
84 | hip->rootflags |= HFSPLUS_FLG_APPEND; | 83 | else |
85 | } else { | ||
86 | inode->i_flags &= ~S_APPEND; | 84 | inode->i_flags &= ~S_APPEND; |
87 | hip->rootflags &= ~HFSPLUS_FLG_APPEND; | 85 | |
88 | } | ||
89 | if (flags & FS_NODUMP_FL) | 86 | if (flags & FS_NODUMP_FL) |
90 | hip->userflags |= HFSPLUS_FLG_NODUMP; | 87 | hip->userflags |= HFSPLUS_FLG_NODUMP; |
91 | else | 88 | else |