1. 14 7月, 2008 35 次提交
  2. 13 7月, 2008 5 次提交
    • D
      cpusets, hotplug, scheduler: fix scheduler domain breakage · 3e84050c
      Dmitry Adamushko 提交于
      Commit f18f982a ("sched: CPU hotplug events must not destroy scheduler
      domains created by the cpusets") introduced a hotplug-related problem as
      described below:
      
      Upon CPU_DOWN_PREPARE,
      
        update_sched_domains() -> detach_destroy_domains(&cpu_online_map)
      
      does the following:
      
      /*
       * Force a reinitialization of the sched domains hierarchy. The domains
       * and groups cannot be updated in place without racing with the balancing
       * code, so we temporarily attach all running cpus to the NULL domain
       * which will prevent rebalancing while the sched domains are recalculated.
       */
      
      The sched-domains should be rebuilt when a CPU_DOWN ops. has been
      completed, effectively either upon CPU_DEAD{_FROZEN} (upon success) or
      CPU_DOWN_FAILED{_FROZEN} (upon failure -- restore the things to their
      initial state). That's what update_sched_domains() also does but only
      for !CPUSETS case.
      
      With f18f982a, sched-domains' reinitialization is delegated to
      CPUSETS code:
      
      cpuset_handle_cpuhp() -> common_cpu_mem_hotplug_unplug() ->
      rebuild_sched_domains()
      
      Being called for CPU_UP_PREPARE and if its callback is called after
      update_sched_domains()), it just negates all the work done by
      update_sched_domains() -- i.e. a soon-to-be-offline cpu is included in
      the sched-domains and that makes it visible for the load-balancer
      while the CPU_DOWN ops. is in progress.
      
      __migrate_live_tasks() moves the tasks off a 'dead' cpu (it's already
      "offline" when this function is called).
      
      try_to_wake_up() is called for one of these tasks from another CPU ->
      the load-balancer (wake_idle()) picks up a "dead" CPU and places the
      task on it. Then e.g. BUG_ON(rq->nr_running) detects this a bit later
      -> oops.
      Signed-off-by: NDmitry Adamushko <dmitry.adamushko@gmail.com>
      Tested-by: NVegard Nossum <vegard.nossum@gmail.com>
      Cc: Paul Menage <menage@google.com>
      Cc: Max Krasnyansky <maxk@qualcomm.com>
      Cc: Paul Jackson <pj@sgi.com>
      Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
      Cc: miaox@cn.fujitsu.com
      Cc: rostedt@goodmis.org
      Cc: Linus Torvalds <torvalds@linux-foundation.org>
      Signed-off-by: NIngo Molnar <mingo@elte.hu>
      3e84050c
    • L
      Merge branch 'x86-fixes-for-linus' of... · 9df2fe98
      Linus Torvalds 提交于
      Merge branch 'x86-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip
      
      * 'x86-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip:
        x86: fix ldt limit for 64 bit
      9df2fe98
    • L
      Merge git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi-rc-fixes-2.6 · de72aa4c
      Linus Torvalds 提交于
      * git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi-rc-fixes-2.6:
        [SCSI] bsg: fix oops on remove
        [SCSI] fusion: default MSI to disabled for SPI and FC controllers
        [SCSI] ipr: Fix HDIO_GET_IDENTITY oops for SATA devices
        [SCSI] mptspi: fix oops in mptspi_dv_renegotiate_work()
        [SCSI] erase invalid data returned by device
      de72aa4c
    • J
      cifs: fix wksidarr declaration to be big-endian friendly · 536abdb0
      Jeff Layton 提交于
      The current definition of wksidarr works fine on little endian arches
      (since cpu_to_le32 is a no-op there), but on big-endian arches, it fails
      to compile with this error:
      
      error: braced-group within expression allowed only inside a function
      
      The problem is that this static declaration has cpu_to_le32 embedded
      within it, and that expands into a function macro.  We need to use
      __constant_cpu_to_le32() instead.
      Signed-off-by: NJeff Layton <jlayton@redhat.com>
      Cc: Steven French <sfrench@us.ibm.com>
      Cc: <stable@kernel.org>
      Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      536abdb0
    • J
      cifs: fix inode leak in cifs_get_inode_info_unix · e911d0cc
      Jeff Layton 提交于
      Try this:
      
          mount a share with unix extensions
          create a file on it
          umount the share
      
      You'll get the following message in the ring buffer:
      
      VFS: Busy inodes after unmount of cifs. Self-destruct in 5 seconds.  Have a
      nice day...
      
      ...the problem is that cifs_get_inode_info_unix is creating and hashing
      a new inode even when it's going to return error anyway. The first
      lookup when creating a file returns an error so we end up leaking this
      inode before we do the actual create. This appears to be a regression
      caused by commit 0e4bbde9.
      
      The following patch seems to fix it for me, and fixes a minor
      formatting nit as well.
      Signed-off-by: NJeff Layton <jlayton@redhat.com>
      Acked-by: NSteven French <sfrench@us.ibm.com>
      Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      e911d0cc