While testing our KVM code for s390 (starting and killall kvm in a loop)
I can reproduce the following oops:
  Unable to handle kernel pointer dereference at virtual kernel address 
6b6b6b6b6b6b6000 Oops: 0038 [#1] SMP
  Modules linked in: dm_multipath sunrpc qeth_l3 qeth_l2 dm_mod qeth
  ccwgroup CPU: 1 Not tainted 2.6.27-rc1 #54
  Process kuli (pid: 4409, task: 
00000000b6aa5940, ksp: 
00000000b7343e10)
  Krnl PSW : 
0704e00180000000 00000000002e0b8c
  (disassociate_ctty+0x1c0/0x288) R:0 T:1 IO:1 EX:1 Key:0 M:1 W:0 P:0 AS:3
  CC:2 PM:0 EA:3 Krnl GPRS: 
0000000000000000 6b6b6b6b6b6b6b6b
  0000000000000001 00000000000003a6 00000000002e0a46 00000000004b4160
  0000000000000001 00000000bbd79758 00000000b7343e58 00000000b8854148
  00000000bd34dea0 00000000b7343c20 0000000000000001 00000000004b6d08
  00000000002e0a46 00000000b7343c20 Krnl Code: 
00000000002e0b7e:
  
eb9fb0a00004	lmg	%r9,%r15,160(%r11) 
00000000002e0b84:
  07f4		bcr	15,%r4 
00000000002e0b86:
  
e31090080004	lg	%r1,8(%r9) >
00000000002e0b8c:
  
d501109cd000	clc	156(2,%r1),0(%r13) 
00000000002e0b92:
  
a784ff5d		brc	8,2e0a4c 
00000000002e0b96:
  
b9040029		lgr	%r2,%r9 
00000000002e0b9a:
  
c0e5fffff9c3	brasl	%r14,2dff20 
00000000002e0ba0:
  
a7f4ff56		brc	15,2e0a4c Call Trace:
  ([<
00000000002e0a46>] disassociate_ctty+0x7a/0x288)
   [<
0000000000141fe6>] do_exit+0x212/0x8d4
   [<
0000000000142708>] do_group_exit+0x60/0xcc
   [<
0000000000150660>] get_signal_to_deliver+0x270/0x3ac
   [<
000000000010bfd6>] do_signal+0x8e/0x8dc
   [<
0000000000113772>] sysc_sigpending+0xe/0x22
   [<
000001ff0000b134>] 0x1ff0000b134
  INFO: lockdep is turned off.
  Last Breaking-Event-Address:
   [<
00000000002e0a48>] disassociate_ctty+0x7c/0x288
  Kernel panic - not syncing: Fatal exception: panic_on_oops
It seems that tty was already free in disassocate_ctty when it tries
to dereference tty->driver.
After moving the lock_kernel before the mutex_unlock, I can no longer
reproduce the problem.
[ This is a temporary partial fix for the documented and long standing
  race in disassociate_tty.  This stops most problem cases for now.
  For the next release the -next tree has an initial implementation of
  kref counting for tty structures and this quickfix will be dropped.
                                                              - Alan ]
Signed-off-by: Christian Borntraeger <borntraeger@de.ibm.com>
Signed-off-by; Alan Cox <alan@redhat.com>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>