aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2014-02-01 13:43:45 -0500
committerLinus Torvalds <torvalds@linux-foundation.org>2014-02-01 13:43:45 -0500
commitefc518eb318c4d776933c23e7b82c2e5402b62de (patch)
treeee9100af7dd17039524c7833e0128de49eab5be1 /fs
parentfea8893da7c52906caa1a8dc3199f4b2ed3b8dbd (diff)
parentd22e6338db7f613dd4f6095c190682fcc519e4b7 (diff)
Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs
Pull vfs fixes from Al Viro: "Several obvious fixes" * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs: Fix mountpoint reference leakage in linkat hfsplus: use xattr handlers for removexattr Typo in compat_sys_lseek() declaration fs/super.c: sync ro remount after blocking writers vfs: unexport the getname() symbol
Diffstat (limited to 'fs')
-rw-r--r--fs/hfsplus/dir.c2
-rw-r--r--fs/hfsplus/inode.c2
-rw-r--r--fs/hfsplus/xattr.c60
-rw-r--r--fs/hfsplus/xattr.h2
-rw-r--r--fs/namei.c6
-rw-r--r--fs/super.c3
6 files changed, 25 insertions, 50 deletions
diff --git a/fs/hfsplus/dir.c b/fs/hfsplus/dir.c
index 9ee62985e739..bdec66522de3 100644
--- a/fs/hfsplus/dir.c
+++ b/fs/hfsplus/dir.c
@@ -529,7 +529,7 @@ const struct inode_operations hfsplus_dir_inode_operations = {
529 .setxattr = generic_setxattr, 529 .setxattr = generic_setxattr,
530 .getxattr = generic_getxattr, 530 .getxattr = generic_getxattr,
531 .listxattr = hfsplus_listxattr, 531 .listxattr = hfsplus_listxattr,
532 .removexattr = hfsplus_removexattr, 532 .removexattr = generic_removexattr,
533#ifdef CONFIG_HFSPLUS_FS_POSIX_ACL 533#ifdef CONFIG_HFSPLUS_FS_POSIX_ACL
534 .get_acl = hfsplus_get_posix_acl, 534 .get_acl = hfsplus_get_posix_acl,
535 .set_acl = hfsplus_set_posix_acl, 535 .set_acl = hfsplus_set_posix_acl,
diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c
index 4551cbd6bd43..fa929f325f87 100644
--- a/fs/hfsplus/inode.c
+++ b/fs/hfsplus/inode.c
@@ -331,7 +331,7 @@ static const struct inode_operations hfsplus_file_inode_operations = {
331 .setxattr = generic_setxattr, 331 .setxattr = generic_setxattr,
332 .getxattr = generic_getxattr, 332 .getxattr = generic_getxattr,
333 .listxattr = hfsplus_listxattr, 333 .listxattr = hfsplus_listxattr,
334 .removexattr = hfsplus_removexattr, 334 .removexattr = generic_removexattr,
335#ifdef CONFIG_HFSPLUS_FS_POSIX_ACL 335#ifdef CONFIG_HFSPLUS_FS_POSIX_ACL
336 .get_acl = hfsplus_get_posix_acl, 336 .get_acl = hfsplus_get_posix_acl,
337 .set_acl = hfsplus_set_posix_acl, 337 .set_acl = hfsplus_set_posix_acl,
diff --git a/fs/hfsplus/xattr.c b/fs/hfsplus/xattr.c
index 0b4a5c9b93c4..4e27edc082a4 100644
--- a/fs/hfsplus/xattr.c
+++ b/fs/hfsplus/xattr.c
@@ -11,6 +11,8 @@
11#include "xattr.h" 11#include "xattr.h"
12#include "acl.h" 12#include "acl.h"
13 13
14static int hfsplus_removexattr(struct inode *inode, const char *name);
15
14const struct xattr_handler *hfsplus_xattr_handlers[] = { 16const struct xattr_handler *hfsplus_xattr_handlers[] = {
15 &hfsplus_xattr_osx_handler, 17 &hfsplus_xattr_osx_handler,
16 &hfsplus_xattr_user_handler, 18 &hfsplus_xattr_user_handler,
@@ -274,14 +276,8 @@ int __hfsplus_setxattr(struct inode *inode, const char *name,
274 HFSPLUS_IS_RSRC(inode)) 276 HFSPLUS_IS_RSRC(inode))
275 return -EOPNOTSUPP; 277 return -EOPNOTSUPP;
276 278
277 if (strncmp(name, XATTR_MAC_OSX_PREFIX, 279 if (value == NULL)
278 XATTR_MAC_OSX_PREFIX_LEN) == 0) 280 return hfsplus_removexattr(inode, name);
279 name += XATTR_MAC_OSX_PREFIX_LEN;
280
281 if (value == NULL) {
282 value = "";
283 size = 0;
284 }
285 281
286 err = hfs_find_init(HFSPLUS_SB(inode->i_sb)->cat_tree, &cat_fd); 282 err = hfs_find_init(HFSPLUS_SB(inode->i_sb)->cat_tree, &cat_fd);
287 if (err) { 283 if (err) {
@@ -399,16 +395,11 @@ end_setxattr:
399 return err; 395 return err;
400} 396}
401 397
402static inline int is_osx_xattr(const char *xattr_name)
403{
404 return !is_known_namespace(xattr_name);
405}
406
407static int name_len(const char *xattr_name, int xattr_name_len) 398static int name_len(const char *xattr_name, int xattr_name_len)
408{ 399{
409 int len = xattr_name_len + 1; 400 int len = xattr_name_len + 1;
410 401
411 if (is_osx_xattr(xattr_name)) 402 if (!is_known_namespace(xattr_name))
412 len += XATTR_MAC_OSX_PREFIX_LEN; 403 len += XATTR_MAC_OSX_PREFIX_LEN;
413 404
414 return len; 405 return len;
@@ -419,7 +410,7 @@ static int copy_name(char *buffer, const char *xattr_name, int name_len)
419 int len = name_len; 410 int len = name_len;
420 int offset = 0; 411 int offset = 0;
421 412
422 if (is_osx_xattr(xattr_name)) { 413 if (!is_known_namespace(xattr_name)) {
423 strncpy(buffer, XATTR_MAC_OSX_PREFIX, XATTR_MAC_OSX_PREFIX_LEN); 414 strncpy(buffer, XATTR_MAC_OSX_PREFIX, XATTR_MAC_OSX_PREFIX_LEN);
424 offset += XATTR_MAC_OSX_PREFIX_LEN; 415 offset += XATTR_MAC_OSX_PREFIX_LEN;
425 len += XATTR_MAC_OSX_PREFIX_LEN; 416 len += XATTR_MAC_OSX_PREFIX_LEN;
@@ -497,18 +488,6 @@ ssize_t __hfsplus_getxattr(struct inode *inode, const char *name,
497 HFSPLUS_IS_RSRC(inode)) 488 HFSPLUS_IS_RSRC(inode))
498 return -EOPNOTSUPP; 489 return -EOPNOTSUPP;
499 490
500 if (strncmp(name, XATTR_MAC_OSX_PREFIX,
501 XATTR_MAC_OSX_PREFIX_LEN) == 0) {
502 /* skip "osx." prefix */
503 name += XATTR_MAC_OSX_PREFIX_LEN;
504 /*
505 * Don't allow retrieving properly prefixed attributes
506 * by prepending them with "osx."
507 */
508 if (is_known_namespace(name))
509 return -EOPNOTSUPP;
510 }
511
512 if (!strcmp_xattr_finder_info(name)) 491 if (!strcmp_xattr_finder_info(name))
513 return hfsplus_getxattr_finder_info(inode, value, size); 492 return hfsplus_getxattr_finder_info(inode, value, size);
514 493
@@ -743,28 +722,18 @@ end_listxattr:
743 return res; 722 return res;
744} 723}
745 724
746int hfsplus_removexattr(struct dentry *dentry, const char *name) 725static int hfsplus_removexattr(struct inode *inode, const char *name)
747{ 726{
748 int err = 0; 727 int err = 0;
749 struct inode *inode = dentry->d_inode;
750 struct hfs_find_data cat_fd; 728 struct hfs_find_data cat_fd;
751 u16 flags; 729 u16 flags;
752 u16 cat_entry_type; 730 u16 cat_entry_type;
753 int is_xattr_acl_deleted = 0; 731 int is_xattr_acl_deleted = 0;
754 int is_all_xattrs_deleted = 0; 732 int is_all_xattrs_deleted = 0;
755 733
756 if ((!S_ISREG(inode->i_mode) &&
757 !S_ISDIR(inode->i_mode)) ||
758 HFSPLUS_IS_RSRC(inode))
759 return -EOPNOTSUPP;
760
761 if (!HFSPLUS_SB(inode->i_sb)->attr_tree) 734 if (!HFSPLUS_SB(inode->i_sb)->attr_tree)
762 return -EOPNOTSUPP; 735 return -EOPNOTSUPP;
763 736
764 if (strncmp(name, XATTR_MAC_OSX_PREFIX,
765 XATTR_MAC_OSX_PREFIX_LEN) == 0)
766 name += XATTR_MAC_OSX_PREFIX_LEN;
767
768 if (!strcmp_xattr_finder_info(name)) 737 if (!strcmp_xattr_finder_info(name))
769 return -EOPNOTSUPP; 738 return -EOPNOTSUPP;
770 739
@@ -838,8 +807,12 @@ static int hfsplus_osx_getxattr(struct dentry *dentry, const char *name,
838 if (len > HFSPLUS_ATTR_MAX_STRLEN) 807 if (len > HFSPLUS_ATTR_MAX_STRLEN)
839 return -EOPNOTSUPP; 808 return -EOPNOTSUPP;
840 809
841 strcpy(xattr_name, XATTR_MAC_OSX_PREFIX); 810 /*
842 strcpy(xattr_name + XATTR_MAC_OSX_PREFIX_LEN, name); 811 * Don't allow retrieving properly prefixed attributes
812 * by prepending them with "osx."
813 */
814 if (is_known_namespace(name))
815 return -EOPNOTSUPP;
843 816
844 return hfsplus_getxattr(dentry, xattr_name, buffer, size); 817 return hfsplus_getxattr(dentry, xattr_name, buffer, size);
845} 818}
@@ -857,12 +830,13 @@ static int hfsplus_osx_setxattr(struct dentry *dentry, const char *name,
857 if (len > HFSPLUS_ATTR_MAX_STRLEN) 830 if (len > HFSPLUS_ATTR_MAX_STRLEN)
858 return -EOPNOTSUPP; 831 return -EOPNOTSUPP;
859 832
833 /*
834 * Don't allow setting properly prefixed attributes
835 * by prepending them with "osx."
836 */
860 if (is_known_namespace(name)) 837 if (is_known_namespace(name))
861 return -EOPNOTSUPP; 838 return -EOPNOTSUPP;
862 839
863 strcpy(xattr_name, XATTR_MAC_OSX_PREFIX);
864 strcpy(xattr_name + XATTR_MAC_OSX_PREFIX_LEN, name);
865
866 return hfsplus_setxattr(dentry, xattr_name, buffer, size, flags); 840 return hfsplus_setxattr(dentry, xattr_name, buffer, size, flags);
867} 841}
868 842
diff --git a/fs/hfsplus/xattr.h b/fs/hfsplus/xattr.h
index 9e214490c313..288530cf80b5 100644
--- a/fs/hfsplus/xattr.h
+++ b/fs/hfsplus/xattr.h
@@ -40,8 +40,6 @@ static inline ssize_t hfsplus_getxattr(struct dentry *dentry,
40 40
41ssize_t hfsplus_listxattr(struct dentry *dentry, char *buffer, size_t size); 41ssize_t hfsplus_listxattr(struct dentry *dentry, char *buffer, size_t size);
42 42
43int hfsplus_removexattr(struct dentry *dentry, const char *name);
44
45int hfsplus_init_security(struct inode *inode, struct inode *dir, 43int hfsplus_init_security(struct inode *inode, struct inode *dir,
46 const struct qstr *qstr); 44 const struct qstr *qstr);
47 45
diff --git a/fs/namei.c b/fs/namei.c
index bcb838e2e52f..d580df2e6804 100644
--- a/fs/namei.c
+++ b/fs/namei.c
@@ -209,7 +209,6 @@ getname(const char __user * filename)
209{ 209{
210 return getname_flags(filename, 0, NULL); 210 return getname_flags(filename, 0, NULL);
211} 211}
212EXPORT_SYMBOL(getname);
213 212
214#ifdef CONFIG_AUDITSYSCALL 213#ifdef CONFIG_AUDITSYSCALL
215void putname(struct filename *name) 214void putname(struct filename *name)
@@ -3927,10 +3926,13 @@ out_dput:
3927 done_path_create(&new_path, new_dentry); 3926 done_path_create(&new_path, new_dentry);
3928 if (delegated_inode) { 3927 if (delegated_inode) {
3929 error = break_deleg_wait(&delegated_inode); 3928 error = break_deleg_wait(&delegated_inode);
3930 if (!error) 3929 if (!error) {
3930 path_put(&old_path);
3931 goto retry; 3931 goto retry;
3932 }
3932 } 3933 }
3933 if (retry_estale(error, how)) { 3934 if (retry_estale(error, how)) {
3935 path_put(&old_path);
3934 how |= LOOKUP_REVAL; 3936 how |= LOOKUP_REVAL;
3935 goto retry; 3937 goto retry;
3936 } 3938 }
diff --git a/fs/super.c b/fs/super.c
index cecd780e0f44..80d5cf2ca765 100644
--- a/fs/super.c
+++ b/fs/super.c
@@ -703,7 +703,6 @@ int do_remount_sb(struct super_block *sb, int flags, void *data, int force)
703 if (flags & MS_RDONLY) 703 if (flags & MS_RDONLY)
704 acct_auto_close(sb); 704 acct_auto_close(sb);
705 shrink_dcache_sb(sb); 705 shrink_dcache_sb(sb);
706 sync_filesystem(sb);
707 706
708 remount_ro = (flags & MS_RDONLY) && !(sb->s_flags & MS_RDONLY); 707 remount_ro = (flags & MS_RDONLY) && !(sb->s_flags & MS_RDONLY);
709 708
@@ -720,6 +719,8 @@ int do_remount_sb(struct super_block *sb, int flags, void *data, int force)
720 } 719 }
721 } 720 }
722 721
722 sync_filesystem(sb);
723
723 if (sb->s_op->remount_fs) { 724 if (sb->s_op->remount_fs) {
724 retval = sb->s_op->remount_fs(sb, &flags, data); 725 retval = sb->s_op->remount_fs(sb, &flags, data);
725 if (retval) { 726 if (retval) {