x86, mce: remove oops_begin() use in 64bit machine check
authorAndi Kleen <ak@linux.intel.com>
Tue, 28 Apr 2009 12:25:18 +0000 (14:25 +0200)
committerH. Peter Anvin <hpa@zytor.com>
Thu, 28 May 2009 16:24:13 +0000 (09:24 -0700)
First 32bit doesn't have oops_begin, so it's a barrier of using
this code on 32bit.

On closer examination it turns out oops_begin is not
a good idea in a machine check panic anyways. All oops_begin
does it so check for recursive/parallel oopses and implement the
"wait on oops" heuristic. But there's actually no good reason
to lock machine checks against oopses or prevent them
from recursion. Also "wait on oops" does not really make
sense for a machine check too.

Replace it with a manual bust_spinlocks/console_verbose.

Signed-off-by: Andi Kleen <ak@linux.intel.com>
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
Signed-off-by: Hidetoshi Seto <seto.hidetoshi@jp.fujitsu.com>
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
arch/x86/kernel/cpu/mcheck/mce.c

index 7562c1f674f31759e0eb00654c53971a0b072cb6..f4d6841d2bdf5860c6f545d51cf12034373745db 100644 (file)
@@ -178,7 +178,8 @@ static void mce_panic(char *msg, struct mce *backup, u64 start)
 {
        int i;
 
-       oops_begin();
+       bust_spinlocks(1);
+       console_verbose();
        for (i = 0; i < MCE_LOG_LEN; i++) {
                u64 tsc = mcelog.entry[i].tsc;