1. 05 6月, 2018 3 次提交
  2. 02 4月, 2018 6 次提交
  3. 01 3月, 2018 1 次提交
  4. 26 2月, 2018 2 次提交
  5. 28 11月, 2017 1 次提交
    • L
      Rename superblock flags (MS_xyz -> SB_xyz) · 1751e8a6
      Linus Torvalds 提交于
      This is a pure automated search-and-replace of the internal kernel
      superblock flags.
      
      The s_flags are now called SB_*, with the names and the values for the
      moment mirroring the MS_* flags that they're equivalent to.
      
      Note how the MS_xyz flags are the ones passed to the mount system call,
      while the SB_xyz flags are what we then use in sb->s_flags.
      
      The script to do this was:
      
          # places to look in; re security/*: it generally should *not* be
          # touched (that stuff parses mount(2) arguments directly), but
          # there are two places where we really deal with superblock flags.
          FILES="drivers/mtd drivers/staging/lustre fs ipc mm \
                  include/linux/fs.h include/uapi/linux/bfs_fs.h \
                  security/apparmor/apparmorfs.c security/apparmor/include/lib.h"
          # the list of MS_... constants
          SYMS="RDONLY NOSUID NODEV NOEXEC SYNCHRONOUS REMOUNT MANDLOCK \
                DIRSYNC NOATIME NODIRATIME BIND MOVE REC VERBOSE SILENT \
                POSIXACL UNBINDABLE PRIVATE SLAVE SHARED RELATIME KERNMOUNT \
                I_VERSION STRICTATIME LAZYTIME SUBMOUNT NOREMOTELOCK NOSEC BORN \
                ACTIVE NOUSER"
      
          SED_PROG=
          for i in $SYMS; do SED_PROG="$SED_PROG -e s/MS_$i/SB_$i/g"; done
      
          # we want files that contain at least one of MS_...,
          # with fs/namespace.c and fs/pnode.c excluded.
          L=$(for i in $SYMS; do git grep -w -l MS_$i $FILES; done| sort|uniq|grep -v '^fs/namespace.c'|grep -v '^fs/pnode.c')
      
          for f in $L; do sed -i $f $SED_PROG; done
      Requested-by: NAl Viro <viro@zeniv.linux.org.uk>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      1751e8a6
  6. 13 11月, 2017 1 次提交
    • J
      ceph: present consistent fsid, regardless of arch endianness · 080a330e
      Jeff Layton 提交于
      Since its inception, ceph has presented the fsid as an opaque value
      without any sort of endianness conversion. This means that the value
      presented is different on architectures of different endianness.
      
      While the value that should be stuffed into f_fsid is poorly-defined,
      I think it would be best to strive for consistency here between
      architectures, and clients (we need to present this properly to the
      userland client as well).
      
      Change ceph_statfs to convert the opaque words to host-endian before
      doing the xor. On an upgrade, a big-endian box may see a different fsid
      than it did before, but little-endian arches should see no change with
      this patch.
      Signed-off-by: NJeff Layton <jlayton@redhat.com>
      Reviewed-by: NSage Weil <sage@redhat.com>
      Signed-off-by: NIlya Dryomov <idryomov@gmail.com>
      080a330e
  7. 07 9月, 2017 6 次提交
  8. 07 7月, 2017 2 次提交
  9. 04 5月, 2017 1 次提交
  10. 21 4月, 2017 1 次提交
  11. 25 2月, 2017 1 次提交
  12. 20 2月, 2017 1 次提交
  13. 13 12月, 2016 1 次提交
  14. 29 10月, 2016 2 次提交
  15. 18 10月, 2016 1 次提交
  16. 03 10月, 2016 1 次提交
  17. 28 7月, 2016 3 次提交
    • N
      ceph: Mark the file cache as unreclaimable · 6b1a9a6c
      Nikolay Borisov 提交于
      Ceph creates multiple caches with the SLAB_RECLAIMABLE flag set, so
      that it can satisfy its internal needs. Inspecting the code shows that
      most of the caches are indeed reclaimable since they are directly
      related to the generic inode/dentry shrinkers. However, one of the
      cache used to satisfy struct file is not reclaimable since its
      entries are freed only when the last reference to the file is
      dropped. If a heavily loaded node opens a lot of files it can
      introduce non-trivial discrepancies between memory shown as reclaimable
      and what is actually reclaimed when drop_caches is used.
      
      Fix this by removing the reclaimable flag for the file's cache.
      Signed-off-by: NNikolay Borisov <n.borisov.lkml@gmail.com>
      Signed-off-by: NYan, Zheng <zyan@redhat.com>
      6b1a9a6c
    • Y
      ceph: mount non-default filesystem by name · 430afbad
      Yan, Zheng 提交于
      To mount non-default filesytem, user currently needs to provide mds
      namespace ID. This is inconvenience.
      
      This patch makes user be able to mount filesystem by name. If user
      wants to mount non-default filesystem. Client first subscribes to
      fsmap.user. Subscribe to mdsmap.<ID> after getting ID of filesystem.
      Signed-off-by: NYan, Zheng <zyan@redhat.com>
      430afbad
    • Y
      ceph: wait unsafe sync writes for evicting inode · 9a5530c6
      Yan, Zheng 提交于
      Otherwise ceph_sync_write_unsafe() may access/modify freed inode.
      Signed-off-by: NYan, Zheng <zyan@redhat.com>
      9a5530c6
  18. 26 5月, 2016 3 次提交
  19. 05 4月, 2016 1 次提交
    • K
      mm, fs: get rid of PAGE_CACHE_* and page_cache_{get,release} macros · 09cbfeaf
      Kirill A. Shutemov 提交于
      PAGE_CACHE_{SIZE,SHIFT,MASK,ALIGN} macros were introduced *long* time
      ago with promise that one day it will be possible to implement page
      cache with bigger chunks than PAGE_SIZE.
      
      This promise never materialized.  And unlikely will.
      
      We have many places where PAGE_CACHE_SIZE assumed to be equal to
      PAGE_SIZE.  And it's constant source of confusion on whether
      PAGE_CACHE_* or PAGE_* constant should be used in a particular case,
      especially on the border between fs and mm.
      
      Global switching to PAGE_CACHE_SIZE != PAGE_SIZE would cause to much
      breakage to be doable.
      
      Let's stop pretending that pages in page cache are special.  They are
      not.
      
      The changes are pretty straight-forward:
      
       - <foo> << (PAGE_CACHE_SHIFT - PAGE_SHIFT) -> <foo>;
      
       - <foo> >> (PAGE_CACHE_SHIFT - PAGE_SHIFT) -> <foo>;
      
       - PAGE_CACHE_{SIZE,SHIFT,MASK,ALIGN} -> PAGE_{SIZE,SHIFT,MASK,ALIGN};
      
       - page_cache_get() -> get_page();
      
       - page_cache_release() -> put_page();
      
      This patch contains automated changes generated with coccinelle using
      script below.  For some reason, coccinelle doesn't patch header files.
      I've called spatch for them manually.
      
      The only adjustment after coccinelle is revert of changes to
      PAGE_CAHCE_ALIGN definition: we are going to drop it later.
      
      There are few places in the code where coccinelle didn't reach.  I'll
      fix them manually in a separate patch.  Comments and documentation also
      will be addressed with the separate patch.
      
      virtual patch
      
      @@
      expression E;
      @@
      - E << (PAGE_CACHE_SHIFT - PAGE_SHIFT)
      + E
      
      @@
      expression E;
      @@
      - E >> (PAGE_CACHE_SHIFT - PAGE_SHIFT)
      + E
      
      @@
      @@
      - PAGE_CACHE_SHIFT
      + PAGE_SHIFT
      
      @@
      @@
      - PAGE_CACHE_SIZE
      + PAGE_SIZE
      
      @@
      @@
      - PAGE_CACHE_MASK
      + PAGE_MASK
      
      @@
      expression E;
      @@
      - PAGE_CACHE_ALIGN(E)
      + PAGE_ALIGN(E)
      
      @@
      expression E;
      @@
      - page_cache_get(E)
      + get_page(E)
      
      @@
      expression E;
      @@
      - page_cache_release(E)
      + put_page(E)
      Signed-off-by: NKirill A. Shutemov <kirill.shutemov@linux.intel.com>
      Acked-by: NMichal Hocko <mhocko@suse.com>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      09cbfeaf
  20. 26 3月, 2016 2 次提交
    • Y
      ceph: fix mounting same fs multiple times · 132ca7e1
      Yan, Zheng 提交于
      Now __ceph_open_session() only accepts closed client. An opened
      client will tigger BUG_ON().
      Signed-off-by: NYan, Zheng <zyan@redhat.com>
      132ca7e1
    • I
      ceph: kill ceph_empty_snapc · 34b759b4
      Ilya Dryomov 提交于
      ceph_empty_snapc->num_snaps == 0 at all times.  Passing such a snapc to
      ceph_osdc_alloc_request() (possibly through ceph_osdc_new_request()) is
      equivalent to passing NULL, as ceph_osdc_alloc_request() uses it only
      for sizing the request message.
      
      Further, in all four cases the subsequent ceph_osdc_build_request() is
      passed NULL for snapc, meaning that 0 is encoded for seq and num_snaps
      and making ceph_empty_snapc entirely useless.  The two cases where it
      actually mattered were removed in commits 86056090 ("ceph: avoid
      sending unnessesary FLUSHSNAP message") and 23078637 ("ceph: fix
      queuing inode to mdsdir's snaprealm").
      Signed-off-by: NIlya Dryomov <idryomov@gmail.com>
      Reviewed-by: NYan, Zheng <zyan@redhat.com>
      34b759b4