1. 12 2月, 2007 1 次提交
    • E
      [PATCH] struct vfsmount: keep mnt_count & mnt_expiry_mark away from mnt_flags · 4ba4d4c0
      Eric Dumazet 提交于
      I noticed cache misses in touch_atime() that can be avoided if we keep
      mnt_count & mnt_expiry_mark in a different cache line than mnt_flags
      (mostly read)
      
      mnt_count & mnt_expiry_mark are modified each time a file is opened/closed
      in a file system.
      
      touch_atime() is called each time a file is read, and generally needs to
      read mnt_flags.
      
      Other fields of struct vfsmount are mostly read so I chose to move
      mnt_count & mnt_expiry_mark at the end of struct vfsmount.  And adding a
      comment so that nobody tries to re-arrange fields to fill the holes :)
      
      On 64bits platforms, the new offsetof(mnt_count) is 0xC0
      On 32bits platforms, it is 0x60, so I didnot add a
      ____cacheline_aligned_in_smp because it would have a too big impact on the
      size of this object (in particular if CONFIG_X86_L1_CACHE_SHIFT=7)
      Signed-off-by: NEric Dumazet <dada1@cosmosbay.com>
      Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      4ba4d4c0
  2. 14 12月, 2006 1 次提交
  3. 09 12月, 2006 1 次提交
  4. 23 6月, 2006 1 次提交
  5. 09 6月, 2006 2 次提交
  6. 11 1月, 2006 1 次提交
    • C
      [PATCH] per-mountpoint noatime/nodiratime · fc33a7bb
      Christoph Hellwig 提交于
      Turn noatime and nodiratime into per-mount instead of per-sb flags.
      
      After all the preparations this is a rather trivial patch.  The mount code
      needs to treat the two options as per-mount instead of per-superblock, and
      touch_atime needs to be changed to check the new MNT_ flags in addition to
      the MS_ flags that are kept for filesystems that are always
      noatime/nodiratime but not user settable anymore.  Besides that core code
      only nfs needed an update because it's leaving atime updates to the server
      and thus sets the S_NOATIME flag on every inode, but needs to know whether
      it's a real noatime mount for an getattr optimization.
      
      While we're at it I've killed the IS_NOATIME/IS_NODIRATIME macros that were
      only used by touch_atime.
      Signed-off-by: NChristoph Hellwig <hch@lst.de>
      Signed-off-by: NAndrew Morton <akpm@osdl.org>
      Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
      fc33a7bb
  7. 09 1月, 2006 1 次提交
  8. 08 11月, 2005 5 次提交
    • R
      [PATCH] unbindable mounts · 9676f0c6
      Ram Pai 提交于
      An unbindable mount does not forward or receive propagation.  Also
      unbindable mount disallows bind mounts.  The semantics is as follows.
      
      Bind semantics:
        It is invalid to bind mount an unbindable mount.
      
      Move semantics:
        It is invalid to move an unbindable mount under shared mount.
      
      Clone-namespace semantics:
        If a mount is unbindable in the parent namespace, the corresponding
        cloned mount in the child namespace becomes unbindable too.  Note:
        there is subtle difference, unbindable mounts cannot be bind mounted
        but can be cloned during clone-namespace.
      Signed-off-by: NRam Pai <linuxram@us.ibm.com>
      Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
      Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
      9676f0c6
    • R
      [PATCH] introduce slave mounts · a58b0eb8
      Ram Pai 提交于
      A slave mount always has a master mount from which it receives
      mount/umount events.  Unlike shared mount the event propagation does not
      flow from the slave mount to the master.
      Signed-off-by: NRam Pai <linuxram@us.ibm.com>
      Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
      Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
      a58b0eb8
    • R
      [PATCH] introduce shared mounts · 03e06e68
      Ram Pai 提交于
      This creates shared mounts.  A shared mount when bind-mounted to some
      mountpoint, propagates mount/umount events to each other.  All the
      shared mounts that propagate events to each other belong to the same
      peer-group.
      Signed-off-by: NRam Pai <linuxram@us.ibm.com>
      Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
      Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
      03e06e68
    • R
      [PATCH] beginning of the shared-subtree proper · 07b20889
      Ram Pai 提交于
      A private mount does not forward or receive propagation.  This patch
      provides user the ability to convert any mount to private.
      Signed-off-by: NRam Pai <linuxram@us.ibm.com>
      Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
      Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
      07b20889
    • A
      [PATCH] saner handling of auto_acct_off() and DQUOT_OFF() in umount · 7b7b1ace
      Al Viro 提交于
      The way we currently deal with quota and process accounting that might
      keep vfsmount busy at umount time is inherently broken; we try to turn
      them off just in case (not quite correctly, at that) and
      
        a) pray umount doesn't fail (otherwise they'll stay turned off)
        b) pray nobody doesn anything funny just as we turn quota off
      
      Moreover, LSM provides hooks for doing the same sort of broken logics.
      
      The proper way to deal with that is to introduce the second kind of
      reference to vfsmount.  Semantics:
      
       - when the last normal reference is dropped, all special ones are
         converted to normal ones and if there had been any, cleanup is done.
       - normal reference can be cloned into a special one
       - special reference can be converted to normal one; that's a no-op if
         we'd already passed the point of no return (i.e.  mntput() had
         converted special references to normal and started cleanup).
      
      The way it works: e.g. starting process accounting converts the vfsmount
      reference pinned by the opened file into special one and turns it back
      to normal when it gets shut down; acct_auto_close() is done when no
      normal references are left.  That way it does *not* obstruct umount(2)
      and it silently gets turned off when the last normal reference to
      vfsmount is gone.  Which is exactly what we want...
      
      The same should be done by LSM module that holds some internal
      references to vfsmount and wants to shut them down on umount - it should
      make them special and security_sb_umount_close() will be called exactly
      when the last normal reference to vfsmount is gone.
      
      quota handling is even simpler - we don't use normal file IO anymore, so
      there's no need to hold vfsmounts at all.  DQUOT_OFF() is done from
      deactivate_super(), where it really belongs.
      Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
      Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
      7b7b1ace
  9. 13 7月, 2005 1 次提交
  10. 08 7月, 2005 2 次提交
  11. 17 4月, 2005 1 次提交
    • L
      Linux-2.6.12-rc2 · 1da177e4
      Linus Torvalds 提交于
      Initial git repository build. I'm not bothering with the full history,
      even though we have it. We can create a separate "historical" git
      archive of that later if we want to, and in the meantime it's about
      3.2GB when imported into git - space that would just make the early
      git days unnecessarily complicated, when we don't have a lot of good
      infrastructure for it.
      
      Let it rip!
      1da177e4