booting the kernel后无内核启动信息的调试方法
移植内核经常会出现
Uncompressing Linux................................................................ done, booting the kernel.
后无启动信息的状况,此时有下面调试方法:
一. 使用low level debug
1. 内核编译时要打开:kernel hacking->kernel debuging->low level debug(这时要确认下arch/arm/kernel/debug.S(2.6),或debug-armv.S(2.4)里是否有相应MCU的UART实现,没有就移植别的,主要是正确设置UART发送寄存器地址)
示例代码:
1 #if defined(CONFIG_ARCH_MX2ADS)
2 #warning CONFIG_ARCH_IMX21 defined
3 .macro addruart,rx
4 mrc p15, 0, \rx, c1, c0
5 tst \rx, #1 @ MMU enabled?
6 moveq \rx, #0x10000000 @ Physical
7 movne \rx, #0xe4000000 @ Virtual
8 orr \rx, \rx, #0xa000
9 orr \rx, \rx, #0x40
10 .endm
11 .macro senduart,rd,rx
12 str \rd, [\rx] @ TXDATA
13 .endm
14 .macro waituart,rd,rx
15 .endm
16 .macro busyuart,rd,rx
17 1002: ldrb \rd, [\rx, #0x54]
18 @ Check TRDY in USR1_1 (phys=0x1000a094)
19 and \rd, \rd, #0x2000
20 cmp \rd, #0x2000
21 bne 1002b
22 .endm
23 #endif
然后在要调试的地方加上printascii("XXX")进行调试。
二。使用printk buffer
当内核刚启动时,printk还不能将信息输出到串口或LCD,只是将它们记录到log buffer,启始地址为__log_buf(可从System.map得到),然后重启进到uboot,使用md查看buf里的信息。
例如:
System.map
c0363bac b printk_time
c0363bb0 b __log_buf
c0373bb0 b console_cmdline
1 u-boot # md 0xc0363bb0
2 c0363bb0: 4c3a353c 78756e69 72657620 6e6f6973 <5:Linux version
3 c0363bc0: 362e3220 2e35332e 620d3231 682d3174 2.6.35.12.bt1-h
4 c0363bd0: 30353369 30317635 72282030 40746f6f i3505v100 (root@
5 c0363be0: 61636f68 736f686c 6f6c2e74 646c6163 hocalhost.locald
6 c0363bf0: 69614d6f 2820296e 20636167 73726576 oMain) (gac vers
7 c0363c00: 206e6969 2e352e34 53282032 58694e4f iin 4.5.2 (SONiX
8 c0363c10: 43434520 352e342d 5220122e 61656c65 ECC-4.5.. Relea
9 c0363c20: 12206573 2d313130 300d1231 29202936 se .011-1..06) )
10 c0363c30: 32312320 64655720 63654420 20383220 #12 Wed Dec 28
11 c0363c40: 352a3930 38353a33 54520320 31303220 09*53:58 .RT 201
12 c0363c50: 343c0a31 5550433e 5241203a 3632394d 1.<4>CPU: ARM926
13 c0363c60: 532d4a45 31345b20 32393630 205d3536 EJ-S [41069265]
14 c0363c70: 68766572 6e6f6973 28203520 764d5241 revhsion 5 (ARMv
15 c0363c80: 4a415435 63202c29 30303d72 31333530 5TAJ), cr=000531
16 c0363c90: 3c0a3737 50433e34 56003a55 20545649 77.<4>CPU:.VIVT
17 c0363ca0: 61746164 63616320 202c6168 54564956 data cacha, VIVT