1. 05 11月, 2007 4 次提交
    • H
      [S390] Fix compile on !CONFIG_SMP. · 0d2be088
      Heiko Carstens 提交于
      Commit fae8b22d
      "[S390] Add per-cpu idle time / idle count sysfs attributes" causes
      a link error on !CONFIG_SMP.
      Fix this by adding some #ifdef's. Real fix would be to cleanup the
      code since we don't register a cpu on !CONFIG_SMP. But that would
      be quite a big patch. For the time being this is good enough.
      
      arch/s390/kernel/built-in.o: In function `do_monitor_call':
      (.text+0x50d4): undefined reference to `per_cpu__s390_idle'
      arch/s390/kernel/built-in.o: In function `cpu_idle':
      (.text+0x518c): undefined reference to `per_cpu__s390_idle'
      make: *** [.tmp_vmlinux1] Error 1
      Signed-off-by: NHeiko Carstens <heiko.carstens@de.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      0d2be088
    • G
      [S390] device_schedule_callback() for dcssblk. · 931bb68b
      Gerald Schaefer 提交于
      Unregistering a device from within a device attribute handler leads to
      a deadlock. Need to use device_schedule_callback() to unregister device
      in error path.
      Signed-off-by: NGerald Schaefer <geraldsc@de.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      931bb68b
    • C
      [S390] Fix smsgiucv init on no iucv machines · 0fc3ddd6
      Christian Borntraeger 提交于
      smsgiucv is a driver that relies on iucv to work properly. If
      iucv ans smsgiucv are compiled into the kernel and run on an
      lpar the following scenario happens:
      iucv is initialized early as a subsystem. It checks for z/VM and
      returns with EPROTONOTSUPPORT. Later smsgiucv tries to run
      driver_register with iucv_bus as bus. As this bus is not
      initialized the driver core and list debugging issue several
      warnings and oopses.
      
      Solution is to let smsgiucv also check for z/VM and return
      EPROTONOTSUPPORT as well.
      Signed-off-by: NChristian Borntraeger <borntraeger@de.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      0fc3ddd6
    • H
      [S390] cio: use INIT_WORK to initialize struct work. · 33583c36
      Heiko Carstens 提交于
      Use INIT_WORK to initialize struct work and don't initialize a
      struct work partial by explicitly initializing its private structures.
      Fixes the following lockdep bug because no key was assigned:
      
      INFO: trying to register non-static key.
      the code is fine but needs lockdep annotation.
      turning off the locking correctness validator.
      0000000001f07bb8 0000000001f07bf8 0000000000000002 0000000000000000
             0000000001f07c98 0000000001f07c10 0000000001f07c10 0000000000015406
             0000000000000000 0000000000000002 0000000000000000 0000000000000000
             0000000001f07bf8 000000000000000c 0000000001f07bf8 0000000001f07c68
             000000000039ae60 0000000000015406 0000000001f07bf8 0000000001f07c48
      Call Trace:
      ([<0000000000015376>] show_trace+0xda/0x104)
       [<0000000000015460>] show_stack+0xc0/0xf8
       [<00000000000154c6>] dump_stack+0x2e/0x3c
       [<000000000006a71e>] __lock_acquire+0x47e/0x11a0
       [<000000000006b4f0>] lock_acquire+0xb0/0xd8
       [<00000000000555a6>] run_workqueue+0x1aa/0x24c
       [<00000000000556de>] worker_thread+0x96/0xf4
       [<000000000005c210>] kthread+0x90/0xb4
       [<000000000001947a>] kernel_thread_starter+0x6/0xc
       [<0000000000019474>] kernel_thread_starter+0x0/0xc
      Signed-off-by: NHeiko Carstens <heiko.carstens@de.ibm.com>
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      33583c36
  2. 03 11月, 2007 33 次提交
  3. 02 11月, 2007 3 次提交