1. 15 May, 2004 18 commits
    • Andrew Morton's avatar
      [PATCH] autofs4 race fix · e246a5f2
      Andrew Morton authored
      From: Ian Kent <raven@themaw.net>
      
      The case where two process similtaneously trigger a mount in autofs4 can
      cause multiple requests to the daemon for the same mount.  The daemon
      handles this OK but it's possible an incorrect error to be returned.  For
      this reason I believe it is better to change the spin lock to a semaphore
      in waitq.c.  This makes the second and subsequent request wait on the q as
      ther supposed to.
      e246a5f2
    • Andrew Morton's avatar
      [PATCH] autofs4: readdir futureproofing · 9ca0507d
      Andrew Morton authored
      From: Ian Kent <raven@themaw.net>
      
      Needed for support coming development plans.
      9ca0507d
    • Andrew Morton's avatar
      [PATCH] autofs4: add ioctl to query unmountability · 340a9772
      Andrew Morton authored
      From: Ian Kent <raven@themaw.net>
      
      Add ioctl to find out if autofs mount can be umounted.  When the daemon
      discovers this it's past the point of no return.
      340a9772
    • Andrew Morton's avatar
      [PATCH] autofs4: fix handling of chdir and chroot · f69b6618
      Andrew Morton authored
      From: <raven@themaw.net>
      
      Pushed changes in sys_chdir and sys_chroot into the revalidate/lookup by
      using nameidata hint.
      f69b6618
    • Andrew Morton's avatar
      [PATCH] autofs4: readdir fixes · 7d1f193d
      Andrew Morton authored
      From: Ian Kent <raven@themaw.net>
      
      a. Implement readdir and friends for directory lookup for late mounting.
         This is done largely by replacing a catch all condition in
         try_to_fill_dentry with appropriate cases.
      
      b. Add path calc.  function in waitq.c to get extended path to return to
         daemon (for direct mounts).
      
      c. Add revalidate calls to sys_chdir and sys_chroot so that pwd lookups
         work correctly.
      
      d. Add ioctl to retrieve minor version for automount daemon (and me) to
         recognise module fix level.  Bumped minor version to 5.
      
      From: Hugh Dickins <hugh@veritas.com>
      
        After chdir (or chroot) to non-existent directory on 2.6.5-mm5, you can no
        longer unmount filesystem holding working directory (or root).
      7d1f193d
    • Andrew Morton's avatar
      [PATCH] autofs4: may_umount_tree() cleanup · 8b22c0c5
      Andrew Morton authored
      From: <raven@themaw.net>
      
      Patch to sync 2.6.6-rc2-mm2 with the result of my discussion with 
      Christoph Hellwig.
      
      Difference is that Christoph realised that merging may_umount_tree and
      may_umount was not worth it. They are now seperate functions.
      8b22c0c5
    • Andrew Morton's avatar
      [PATCH] autofs4: expiry refcount fixes · ee81def6
      Andrew Morton authored
      From: Ian Kent <raven@themaw.net>
      
      This patch is the result of an e-mail discussion with Soni Maneesh.  He felt
      that the use of reference counts in the expire module is unreliable (in the
      presence of rcu) and suggested it should use standard VFS calls where
      possible.  This has been done.  Once the boundary in autofs is reached we
      have no choice but to resort using reference counts (but under the
      vfsmount_lock).
      
      
      After review by hch:
      
      - renamed autofs4_may_umount to __may_umount_tree, made it static and moved
        it to namespace.c.
      
      - added stub function may_umount_tree with description
      
      - altered may_umount to use above stub function and added little description
      
      - added may_umount_tree prototype to fs.h
      
      - removed the EXPORT_SYMBOL for vfsmount_lock
      
      - updated expire.c to suit
      ee81def6
    • Andrew Morton's avatar
      [PATCH] autofs4: locking rework · 79c2bc37
      Andrew Morton authored
      From: Ian Kent <raven@themaw.net>
      
      Remove BKL from autofs4 module and add spinlock to serialise access to the
      automount daemon communication waitq.
      
      Locking requirements are different in 2.6 and so I'm seeking comments and
      suggestions on this.  I have taken a rather heavy handed approach to this in
      the patch.  For example, the VFS operations that directly change the
      filesystem, such as autofs4_mkdir etc, hold the inode semaphore on entry so
      the BKL has been removed.  I can't see why two locking mechanisms are needed.
       Rather than add locking all over the place, I'm looking for justification
      it's needed, as I don't see it myself.
      79c2bc37
    • Andrew Morton's avatar
      [PATCH] autofs4: printk cleanups and memory leak fix · 3c51ca5f
      Andrew Morton authored
      From: Ian Kent <raven@themaw.net>
      
      - Correct text in DPRINTK messages and comments, a little reformating and
        correct URL location for autofs v4 in Kconfig message.
      
      - Fix error-path memory leak in autofs4_fill_super()
      3c51ca5f
    • Andrew Morton's avatar
      [PATCH] autofs4: dnotify + autofs may create signal/restart syscall loop · 44367d15
      Andrew Morton authored
      From: Ian Kent <raven@themaw.net>
      
      From: Jeff Mahoney <jeffm@suse.com>
      
      I saw a recent bug report that showed when a process set up a dnotify
      against the autofs root and then attempted an access(2) call inside the
      autofs namespace on a mount that would fail, it would create a
      signal/restart loop.
      
      The cause is that the autofs code checks to see if any signals are pending
      after it waits on a response from the autofs daemon.  If it finds any, it
      assumes that autofs_wait was interrupted, and that it should return
      -ERESTARTNOINTR.  The problem with this is that a signal_pending(current)
      check will return true if *any* signals were received, not just if a signal
      that interrupted the wait was received.  autofs_wait explicitly blocks all
      signals except for SIGKILL, SIGQUIT, and SIGINT before calling
      interruptible_sleep_on.
      
      The effect is that if a dnotify is set against the autofs root, when the
      autofs daemon creates the directory, a dnotify event will be sent to the
      originating process.  Since the code in autofs_root_lookup doesn't check to
      see what signals are actually pending, it bails early, telling the caller
      to try again.  The loop goes on forever until interrupted via one of the
      actual interrupting signals.
      
      The following patch makes both autofs_root_lookup and autofs4_root_lookup
      verify that one of its defined "shutdown" signals are pending before
      bailing out early.  Any other signal should be delivered later, as
      expected.  It doesn't matter if the signal occured outside of the sleep in
      autofs_wait.  The calling process will either go away or try again.
      44367d15
    • Andrew Morton's avatar
      [PATCH] Use -msoft-float · 55faa529
      Andrew Morton authored
      From: Dave Jones <davej@redhat.com>
      
      To catch accidental usage of floating point.  Has been in -mm for ages.
      55faa529
    • Andrew Morton's avatar
      [PATCH] sched: reduce node balancing interval · 44469277
      Andrew Morton authored
      From: Nick Piggin <nickpiggin@yahoo.com.au>
      
      From: Suresh Siddha <suresh.b.siddha@intel.com>
      
      Node max rebalance interval is too large.  It is currently dependent on
      number of online cpus.  For 16 cpu system, max node balance interval in
      busy case is 32 seconds.  Agreed that it will use max 32 seconds only when
      it doesn't find imbalance for a long time.  But this will lead to slow
      response time in cases where load runs for a second with no imbalance and
      suddently creates an imbalance.  My patch makes the busy max node rebalance
      interval equal to the base [scheduler].
      44469277
    • Andrew Morton's avatar
      [PATCH] sched: less locking in balancing · 632eb5ca
      Andrew Morton authored
      From: Nick Piggin <nickpiggin@yahoo.com.au>
      
      Analysis and basic idea from Suresh Siddha <suresh.b.siddha@intel.com>
      
      "This small change in load_balance() brings the performance back upto base
      scheduler(infact I see a ~1.5% performance improvement now).  Basically
      this fix removes the unnecessary double_lock.."
      
      Workload is SpecJBB on 16-way Altix.
      632eb5ca
    • Andrew Morton's avatar
      [PATCH] sched: fix scheduler for unsynched processor sched_clock · 44069c37
      Andrew Morton authored
      From: Nick Piggin <nickpiggin@yahoo.com.au>
      
      Fine-tune the unsynched sched_clock handling.
      
      Basically, you need to be careful about ensuring timestamps get correctly
      adjusted when moving CPUs, and you *can't* look at your unadjusted
      sched_clock() and a remote task's ->timestamp and try to come up with
      anything meaningful.
      
      I think this second problem will really hit hard in the activate_task path
      on systems with unsynched sched_clock when you're waking up a remote task,
      which happens very often.  Andi, I thought some Opterons have unsynched
      tscs?  Maybe this is causing your unexplained bad interactivity?
      
      Another problem is a fixup in pull_task.  When adjusting ->timestamp from
      one processor to another, you must use timestamp_last_tick for the local
      processor too.  Using sched_clock() will cause ->timestamp to creep
      forward.
      
      A final small fix is for sync wakeups.  They were using __activate_task for
      some reason, thus they don't get credited for sleeping at all AFAIKS.
      
      And another thing, do we want to #ifdef timestamp_last_tick so it doesn't
      show on UP?
      44069c37
    • Andrew Morton's avatar
      [PATCH] sched: improved cpu_load rounding · b75125de
      Andrew Morton authored
      From: Nick Piggin <nickpiggin@yahoo.com.au>
      
      "Siddha, Suresh B" <suresh.b.siddha@intel.com> noticed a problem in the
      cpu_load averaging where the integer truncation could sometimes cause cpu_load
      to never quite reach its target.
      
      I'm not sure that you could demonstrate a real world problem, but I quite
      like this fix.
      b75125de
    • Andrew Morton's avatar
      [PATCH] Fix writeback_inodes-vs-umount race · 3d48f700
      Andrew Morton authored
      Fix bug identified by Chris Mason.
      
      If writeback_inodes is left holding a ref on the superblock's last inode then
      the superblock list walk can race with umount and the superblock can be
      released.
      
      Take and put a ref against the superblock to fix that.
      3d48f700
    • Andrew Morton's avatar
      [PATCH] x86: stack dumps using frame pointers · 066479e3
      Andrew Morton authored
      From: Adam Litke <agl@us.ibm.com>
      
      Teach the x86 stack tracing code to use frame pointers, if they are available.
      It eliminates all the false-positives in the normal stack traces.
      
      This is a big improvement, and -fomit-frame-pointer seems to make no
      difference at all to generated code size.  Maybe we should kill off
      -fomit-frame-pointer.
      066479e3
    • Shai Fultheim's avatar
      [PATCH] Multiple (ICH3) IDE-controllers in a system · fc4c3ad2
      Shai Fultheim authored
      This fixes a problem with multiple IDE controllers in a system.
      
      The problem is that pcibios_fixups table (in arch/i386/pci/fixup.c) uses
      the pci_fixup_ide_trash() quirk for Intel's ICH3 (my case specifically
      8086:248b).  This clears any bogus BAR information set up by the BIOS.
      
      In a system which has multiple ICH3's can't use any of the IDE
      controllers beside the one on the first ICH3.
      
      Anyhow, the fix is to make sure pci_fixup_ide_trash resets the BARs only
      for first time being called, so the subsequent IDE controllers will use
      the BIOS BARs.  This is better than "loosing" all these IDE controllers
      in the case their BARs set right.
      
      The issue discussed and agreed with Bartlomiej Zolnierkiewicz (see below).
      fc4c3ad2
  2. 14 May, 2004 22 commits