Kernel crash caused by cpufreq
Vaidyanathan Srinivasan
svaidy at linux.vnet.ibm.com
Mon Jul 28 20:28:58 EST 2014
* Michael Ellerman <mpe at ellerman.id.au> [2014-07-28 17:03:10]:
> On Fri, 2014-07-25 at 11:07 +1000, Gavin Shan wrote:
> > I'm tracing one LSI interrupt issue on P8 box, and eventually into the
> > following kernel crash. Not sure if there is one fix against this? :-)
>
> Vaidy wrote that I'm pretty sure (on CC).
Yes, I did :)
> > Starting Linux PPC64 #401 SMP Fri Jul 25 10:52:28 EST 2014
> > -----------------------------------------------------
> > ppc64_pft_size = 0x0
> > physicalMemorySize = 0x800000000
> > htab_address = 0xc0000007fe000000
> > htab_hash_mask = 0x3ffff
> > -----------------------------------------------------
> > <- setup_system()
> > Initializing cgroup subsys cpuset
> > Initializing cgroup subsys cpuacct
> > Linux version 3.16.0-rc6-00076-g4226dbe-dirty (shangw at shangw) (gcc version 4.5.2 (crosstool-NG 1.19.0) ) #401 SMP Fri Jul 25 10:52:28 EST 2014
> > :
> > < Unrelated log stripped >
>
> Are you sure there's nothing else in the log that might be related? See the
> messages in init_powernv_pstates() for example.
Most likely PMSR register is showing out of bound values because of
potential firmware (OPAL) issue.
> > ------------[ cut here ]------------
> > kernel BUG at drivers/cpufreq/powernv-cpufreq.c:134!
> > cpu 0x1: Vector: 700 (Program Check) at [c0000007f8483370]
> > pc: c00000000096f32c: .pstate_id_to_freq+0x2c/0x50
> > lr: c00000000096f37c: .powernv_read_cpu_freq+0x2c/0x50
> > sp: c0000007f84835f0
> > msr: 9000000000029032
> > current = 0xc0000007f8400000
> > paca = 0xc00000000ff00400 softe: 0 irq_happened: 0x01
> > pid = 1, comm = swapper/0
> > kernel BUG at drivers/cpufreq/powernv-cpufreq.c:134!
> > enter ? for help
> > [link register ] c00000000096f37c .powernv_read_cpu_freq+0x2c/0x50
> > [c0000007f84835f0] c000000001076070 key_type_dns_resolver+0xef20/0x40d20 (unreliable)
> > [c0000007f8483670] c00000000010812c .generic_exec_single+0x8c/0x270
> > [c0000007f8483730] c0000000001083d0 .smp_call_function_single+0x90/0xb0
> > [c0000007f84837b0] c000000000108cec .smp_call_function_any+0x15c/0x200
> > [c0000007f8483860] c00000000096f27c .powernv_cpufreq_get+0x3c/0x60
> > [c0000007f84838f0] c000000000969dc4 .__cpufreq_add_dev.clone.11+0x574/0xa20
> > [c0000007f84839e0] c0000000005f7a4c .subsys_interface_register+0xec/0x130
> > [c0000007f8483a90] c000000000967af8 .cpufreq_register_driver+0x168/0x2d0
> > [c0000007f8483b30] c000000000f774cc .powernv_cpufreq_init+0x210/0x244
> > [c0000007f8483be0] c00000000000bc08 .do_one_initcall+0xc8/0x240
> > [c0000007f8483ce0] c000000000f44054 .kernel_init_freeable+0x268/0x33c
> > [c0000007f8483db0] c00000000000c4dc .kernel_init+0x1c/0x110
> > [c0000007f8483e30] c00000000000a428 .ret_from_kernel_thread+0x58/0xb0
> > 1:mon> e
> > cpu 0x1: Vector: 700 (Program Check) at [c0000007f8483370]
> > pc: c00000000096f32c: .pstate_id_to_freq+0x2c/0x50
> > lr: c00000000096f37c: .powernv_read_cpu_freq+0x2c/0x50
> > sp: c0000007f84835f0
> > msr: 9000000000029032
> > current = 0xc0000007f8400000
> > paca = 0xc00000000ff00400 softe: 0 irq_happened: 0x01
> > pid = 1, comm = swapper/0
> > kernel BUG at drivers/cpufreq/powernv-cpufreq.c:134!
> > 1:mon> r
> > R00 = 0000000000000042 R16 = 0000000000000000
> > R01 = c0000007f84835f0 R17 = 0000000000000000
> > R02 = c00000000116c430 R18 = 0000000000000000
> > R03 = ffffffffffffffbe R19 = 0000000000000001
> > R04 = 0000000000000000 R20 = c00000078bd61e58
> > R05 = c00000000114ca78 R21 = c000000001008910
> > R06 = c0000007f84838d0 R22 = c0000000011c1b74
> > R07 = 0000000000000001 R23 = c000000002200030
> > R08 = c0000000011c1910 R24 = 0000000000000001
> > R09 = c000000001f2970c R25 = c000000001008730
> > R10 = 0000000000000001 R26 = c000000001f29478
> > R11 = 0000000000000042 R27 = c0000007f84838d0
> > R12 = 0000000044002084 R28 = c00000000114ca78
> > R13 = c00000000ff00400 R29 = 0000000000000000
> > R14 = c00000000000c4c0 R30 = c0000000010a90f0
> > R15 = 0000000000000000 R31 = c0000007f84838d0
> > pc = c00000000096f32c .pstate_id_to_freq+0x2c/0x50
> > cfar= c00000000096f324 .pstate_id_to_freq+0x24/0x50
> > lr = c00000000096f37c .powernv_read_cpu_freq+0x2c/0x50
> > msr = 9000000000029032 cr = 44002082
> > ctr = c00000000096f350 xer = 0000000020000000 trap = 700
> > 1:mon>
>
> Gavin, in future for a dump like this it's very helpful to see the actual code
> that hit the bug. You can get that with:
>
> 1:mon> di $.pstate_id_to_freq
>
>
> Vaidy, judging by r3 it looks like i became negative. That would obviously
> happen if powernv_pstate_info.max was zero?
yes, negative is ok. Something has gone wrong with the PState
firmware/hardware. A BUG_ON() is too severe for this error. I will
change code to not stop the system for this error and also investigate
what is happening at runtime.
--Vaidy
More information about the Linuxppc-dev
mailing list