1. 28 7月, 2010 38 次提交
  2. 22 7月, 2009 1 次提交
    • E
      inotify: use GFP_NOFS under potential memory pressure · f44aebcc
      Eric Paris 提交于
      inotify can have a watchs removed under filesystem reclaim.
      
      =================================
      [ INFO: inconsistent lock state ]
      2.6.31-rc2 #16
      ---------------------------------
      inconsistent {IN-RECLAIM_FS-W} -> {RECLAIM_FS-ON-W} usage.
      khubd/217 [HC0[0]:SC0[0]:HE1:SE1] takes:
       (iprune_mutex){+.+.?.}, at: [<c10ba899>] invalidate_inodes+0x20/0xe3
      {IN-RECLAIM_FS-W} state was registered at:
        [<c10536ab>] __lock_acquire+0x2c9/0xac4
        [<c1053f45>] lock_acquire+0x9f/0xc2
        [<c1308872>] __mutex_lock_common+0x2d/0x323
        [<c1308c00>] mutex_lock_nested+0x2e/0x36
        [<c10ba6ff>] shrink_icache_memory+0x38/0x1b2
        [<c108bfb6>] shrink_slab+0xe2/0x13c
        [<c108c3e1>] kswapd+0x3d1/0x55d
        [<c10449b5>] kthread+0x66/0x6b
        [<c1003fdf>] kernel_thread_helper+0x7/0x10
        [<ffffffff>] 0xffffffff
      
      Two things are needed to fix this.  First we need a method to tell
      fsnotify_create_event() to use GFP_NOFS and second we need to stop using
      one global IN_IGNORED event and allocate them one at a time.  This solves
      current issues with multiple IN_IGNORED on a queue having tail drop
      problems and simplifies the allocations since we don't have to worry about
      two tasks opperating on the IGNORED event concurrently.
      Signed-off-by: NEric Paris <eparis@redhat.com>
      f44aebcc
  3. 29 6月, 2009 1 次提交
    • J
      fs: allow d_instantiate to be called with negative parent dentry · e6ce3066
      Jeremy Kerr 提交于
      The new fsnotify infrastructure (starting at 90586523) causes an oops in
      spufs, where we populate a directory with files before instantiating the
      directory itself. The new changes seem to have introduced an assumption
      that a dentry's parent will be positive when instantiating.
      
      This change makes it once again possible to d_instantiate a dentry
      with a negative parent, and brings __fsnotify_d_instantiate() into
      line with inotify_d_instantiate(), which already has this NULL check.
      Signed-off-by: NJeremy Kerr <jk@ozlabs.org>
      Signed-off-by: NEric Paris <eparis@redhat.com>
      e6ce3066