]> git.baikalelectronics.ru Git - kernel.git/commitdiff
Merge branch 'work.inode-type-fixes' of git://git.kernel.org/pub/scm/linux/kernel...
authorLinus Torvalds <torvalds@linux-foundation.org>
Tue, 27 Apr 2021 17:57:42 +0000 (10:57 -0700)
committerLinus Torvalds <torvalds@linux-foundation.org>
Tue, 27 Apr 2021 17:57:42 +0000 (10:57 -0700)
Pull vfs inode type handling updates from Al Viro:
 "We should never change the type bits of ->i_mode or the method tables
  (->i_op and ->i_fop) of a live inode.

  Unfortunately, not all filesystems took care to prevent that"

* 'work.inode-type-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs:
  spufs: fix bogosity in S_ISGID handling
  9p: missing chunk of "fs/9p: Don't update file type when updating file attributes"
  openpromfs: don't do unlock_new_inode() until the new inode is set up
  hostfs_mknod(): don't bother with init_special_inode()
  cifs: have cifs_fattr_to_inode() refuse to change type on live inode
  cifs: have ->mkdir() handle race with another client sanely
  do_cifs_create(): don't set ->i_mode of something we had not created
  gfs2: be careful with inode refresh
  ocfs2_inode_lock_update(): make sure we don't change the type bits of i_mode
  orangefs_inode_is_stale(): i_mode type bits do *not* form a bitmap...
  vboxsf: don't allow to change the inode type
  afs: Fix updating of i_mode due to 3rd party change
  ceph: don't allow type or device number to change on non-I_NEW inodes
  ceph: fix up error handling with snapdirs
  new helper: inode_wrong_type()

1  2 
fs/afs/inode.c
fs/cifs/cifsproto.h
fs/cifs/dir.c
fs/cifs/file.c
fs/cifs/inode.c
fs/cifs/readdir.c
fs/hostfs/hostfs_kern.c
fs/nfs/inode.c
fs/nfsd/nfsproc.c

diff --cc fs/afs/inode.c
Simple merge
Simple merge
diff --cc fs/cifs/dir.c
Simple merge
diff --cc fs/cifs/file.c
index 3d4e6e7dac1d2341da5de5261733a9dfaca242e9,78266f0e05958d2023a63cd1a5af89c00b9ff965..639c59596d4f3665dfafd057298c421b7e2b407f
@@@ -165,8 -165,7 +165,8 @@@ int cifs_posix_open(const char *full_pa
                        goto posix_open_ret;
                }
        } else {
-               cifs_fattr_to_inode(*pinode, &fattr);
 +              cifs_revalidate_mapping(*pinode);
+               rc = cifs_fattr_to_inode(*pinode, &fattr);
        }
  
  posix_open_ret:
diff --cc fs/cifs/inode.c
Simple merge
Simple merge
Simple merge
diff --cc fs/nfs/inode.c
Simple merge
Simple merge