Hello, all: I am building a Linux kernel module for PPC405EP. My developing board is PPChameleonEVB. I am debugging with BDI2000 and GDB, and my problem is: In GDB, a section of the codes is disassembled to: mfmsr r0 ori r0,r0,32768 mtmsr r0 blr From BDI2000, I have checked that after "ori", GPR0 contains "0x00029030". This value should be written into MSR by "mtmsr" to set EE bit of MSR as 1, but after single step in BDI, "mtmsr" does not work as hoped. MSR becomes "0x00000030", GPR0 becomes some weird number, and there is "Step timeout detected". Meanwhile, the board traps into "Data machine check in kernel mode". I also have tried "wrteei 1" instead of the codes above, but failed again. However, those codes works well in PPC440EP Yosemite board.
405EP>ti Core number : 0 Core state : debug mode Debug entry cause : single step Current PC : 0xc32b1008 Current CR : 0x84000084 Current MSR : 0x00021030 Current LR : 0xc32b46c4 405EP>rd GPR00: 00029030 c1dd9d60 c1fe7bf0 00000000 GPR04: 00000001 00000000 c32b2c8c 00000000 GPR08: c3068000 c3068000 00000001 c3062000 GPR12: 00000000 10019dd8 c32c0000 c32b0000 GPR16: 00000001 c32b0000 00000002 7ff4f670 GPR20: 00000028 c32b0000 c32b0000 10011000 GPR24: c306a000 00000000 00000000 10012c6c GPR28: c18e4000 c32c0000 00000000 00000000 CR : 84000084 MSR: 00021030 405EP>ti Core number : 0 Core state : debug mode Debug entry cause : JTAG stop request Current PC : 0xc000490c Current CR : 0x42000082 Current MSR : 0x00000030 Current LR : 0xc001f1b8 # Step timeout detected 405EP>rd GPR00: 03929800 c02f3e60 c3066000 000102f1 GPR04: 00005424 00000007 c0146f3c c0260000 GPR08: 00000000 c02d0000 c3062000 00000000 GPR12: 00000000 10019dd8 c32c0000 c32b0000 GPR16: 00000001 c32b0000 00000002 7ff4f670 GPR20: 00000028 c32b0000 c32b0000 10011000 GPR24: c306a000 00000000 00000000 10012c6c GPR28: c02f0000 00000152 c3066000 c02f0000 CR : 42000082 MSR: 00000030 ========================================== Data machine check in kernel mode. PLB0: BEAR= 0x03066004 ACR= 0x00000000 BESR= 0x00c00000 PLB0 to OPB: BEAR= 0x04000000 BESR0= 0x00000000 BESR1= 0x00000000 Oops: machine check, sig: 7 [#1] NIP: 00002AD0 LR: 000005A0 CTR: C000CC58 REGS: c02f3f50 TRAP: 0202 Not tainted (2.6.19.2-eldk) MSR: 00021000 <ME> CR: 24000084 XER: 20000000 TASK = c3066000[0] '' THREAD: c02d2000 GPR00: 00029030 C1DD9CA0 C3066000 C1DD9CB0 00000001 00000000 C32B2C8C 00000000 GPR08: C3068000 00000000 00021032 01DD9CA0 030661B0 10019DD8 C32C0000 C32B0000 GPR16: 00000001 C32B0000 00000002 7FF4F670 00000028 C32B0000 C32B0000 10011000 GPR24: C306A000 00000000 00000000 10012C6C C18E4000 C32C0000 00000000 00000000 NIP [00002AD0] 0x2ad0 LR [000005A0] 0x5a0 Call Trace: Instruction dump: XXXXXXXX XXXXXXXX XXXXXXXX XXXXXXXX XXXXXXXX XXXXXXXX XXXXXXXX XXXXXXXX XXXXXXXX XXXXXXXX XXXXXXXX XXXXXXXX XXXXXXXX XXXXXXXX XXXXXXXX XXXXXXXX Kernel panic - not syncing: Attempted to kill the idle task! <0>Rebooting in 180 seconds.. Thanks for advice! Best Regards Evangelion June 26th, 2008 ___________________________________________________________ 雅虎邮箱,您的终生邮箱! http://cn.mail.yahoo.com/ _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@ozlabs.org https://ozlabs.org/mailman/listinfo/linuxppc-dev