• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Oops 定位錯誤代碼行

            Posted on 2013-04-10 15:16 墨…… 閱讀(1000) 評論(0)  編輯 收藏 引用
            這幾天一直在調(diào)試atmel at91sam9x25的串口,用著用著總會導(dǎo)致Oops,Oops內(nèi)容如下:
            [ 1023.510000] Unable to handle kernel NULL pointer dereference at virtual address 00000000
            [ 1023.520000] pgd = c0004000
            [ 1023.520000] [00000000] *pgd=00000000
            [ 1023.520000] Internal error: Oops: 17 [#1]
            [ 1023.520000] last sysfs file: /sys/devices/virtual/misc/at91flash/dev
            [ 1023.520000] Modules linked in: at91flash at91gpio at91mc323 ds18b20 at91adc
            [ 1023.520000] CPU: 0    Tainted: G        W    (2.6.39 #35)
            [ 1023.520000] PC is at atmel_tasklet_func+0x104/0x690
            [ 1023.520000] LR is at atmel_tasklet_func+0x10/0x690
            [ 1023.520000] pc : [<c01a33ac>]    lr : [<c01a32b8>]    psr: 20000013
            [ 1023.520000] sp : c7825f58  ip : 60000093  fp : 00000000
            [ 1023.520000] r10: 00000006  r9 : 00000000  r8 : 0000000a
            [ 1023.520000] r7 : 00000000  r6 : c7824000  r5 : c78a2484  r4 : c03c0cb8
            [ 1023.520000] r3 : 0000004c  r2 : 0000004c  r1 : 60000013  r0 : 00000001
            [ 1023.520000] Flags: nzCv  IRQs on  FIQs on  Mode SVC_32  ISA ARM  Segment kernel
            [ 1023.520000] Control: 0005317f  Table: 27b40000  DAC: 00000017
            [ 1023.520000] Process ksoftirqd/0 (pid: 3, stack limit = 0xc7824270)
            [ 1023.520000] Stack: (0xc7825f58 to 0xc7826000)
            [ 1023.520000] 5f40:                                                       00000001 c7824000
            [ 1023.520000] 5f60: 00000100 0000000a 00000000 00000006 c7825f8c 00000000 00000001 c7824000
            [ 1023.520000] 5f80: 00000100 0000000a 00000006 c0045cf8 c03b995c c00461d8 c7aa6ae0 00000000
            [ 1023.520000] 5fa0: 60000093 00000000 c7824000 c0046274 00000013 00000000 00000000 c00462e0
            [ 1023.520000] 5fc0: 00000000 c7819f70 00000000 c00570e0 00000000 00000000 00000000 00000000
            [ 1023.520000] 5fe0: c7825fe0 c7825fe0 c7819f70 c0057060 c0030b14 c0030b14 ffffffff ffffffff
            [ 1023.520000] [<c01a33ac>] (atmel_tasklet_func+0x104/0x690) from [<c0045cf8>] (tasklet_action+0x84/0xe
            [ 1023.520000] [<c0045cf8>] (tasklet_action+0x84/0xe from [<c00461d8>] (__do_softirq+0x88/0x124)
            [ 1023.520000] [<c00461d8>] (__do_softirq+0x88/0x124) from [<c00462e0>] (run_ksoftirqd+0x6c/0x12
            [ 1023.520000] [<c00462e0>] (run_ksoftirqd+0x6c/0x12 from [<c00570e0>] (kthread+0x80/0x8
            [ 1023.520000] [<c00570e0>] (kthread+0x80/0x8 from [<c0030b14>] (kernel_thread_exit+0x0/0x
            [ 1023.520000] Code: 1a000002 e59f057c e59f157c ebfa3d49 (e5973000) 
            [ 1023.710000] ---[ end trace 786b41cd25d3b661 ]---
            [ 1023.710000] Kernel panic - not syncing: Fatal exception in interrupt
            [ 1023.720000] [<c0034b10>] (unwind_backtrace+0x0/0xe0) from [<c02a8af8>] (panic+0x50/0x170)
            [ 1023.720000] [<c02a8af8>] (panic+0x50/0x170) from [<c0032e00>] (die+0x184/0x1c4)
            [ 1023.730000] [<c0032e00>] (die+0x184/0x1c4) from [<c0035aa8>] (__do_kernel_fault+0x64/0x84)
            [ 1023.740000] [<c0035aa8>] (__do_kernel_fault+0x64/0x84) from [<c0035c7c>] (do_page_fault+0x1b4/0x1c
            [ 1023.750000] [<c0035c7c>] (do_page_fault+0x1b4/0x1c from [<c002a240>] (do_DataAbort+0x30/0x9
            [ 1023.760000] [<c002a240>] (do_DataAbort+0x30/0x98) from [<c002f86c>] (__dabt_svc+0x4c/0x60)
            [ 1023.770000] Exception stack(0xc7825f10 to 0xc7825f58)
            [ 1023.770000] 5f00:                                     00000001 60000013 0000004c 0000004c
            [ 1023.780000] 5f20: c03c0cb8 c78a2484 c7824000 00000000 0000000a 00000000 00000006 00000000
            [ 1023.790000] 5f40: 60000093 c7825f58 c01a32b8 c01a33ac 20000013 ffffffff
            [ 1023.790000] [<c002f86c>] (__dabt_svc+0x4c/0x60) from [<c01a33ac>] (atmel_tasklet_func+0x104/0x690)
            [ 1023.800000] [<c01a33ac>] (atmel_tasklet_func+0x104/0x690) from [<c0045cf8>] (tasklet_action+0x84/0xe8)
            [ 1023.810000] [<c0045cf8>] (tasklet_action+0x84/0xe8) from [<c00461d8>] (__do_softirq+0x88/0x124)
            [ 1023.820000] [<c00461d8>] (__do_softirq+0x88/0x124) from [<c00462e0>] (run_ksoftirqd+0x6c/0x128)
            [ 1023.830000] [<c00462e0>] (run_ksoftirqd+0x6c/0x128) from [<c00570e0>] (kthread+0x80/0x88)
            [ 1023.840000] [<c00570e0>] (kthread+0x80/0x88) from [<c0030b14>] (kernel_thread_exit+0x0/0x8)
            注意上述紅色的地方。
            下面就來顯示如何定位出出錯代碼行:
            1.首先,編譯時打開complie with debug info選項,步則如下
            make ARCH=arm CROSS_COMPILE=arm-none-linux-gnueabi- menuconfig
            oops1.jpg 
            進(jìn)入 Kernel hacking
            oops2.jpg 
            選擇 Compile the kernel with debug info
            然后,保存,退出。
            接著 make ARCH=arm CROSS_COMPILE=arm-none-linux-gnueabi-
            編譯, 等編譯完成。
            2.利用arm-none-linux-gnueabi-gdb 調(diào)試,如下:
            arm-none-linux-gnueabi-gdb vmlinux
            oops3.jpg 
            對應(yīng)著Oops 消息里面的這一行
            [ 1023.520000] LR is at atmel_tasklet_func+0x10/0x690
            在gdb下鍵入命令 : l *at atmel_tasklet_func+0x10
            oops4.jpg 
            這樣就找到了出錯的代碼行。在這里鄙視一下atmel提供的內(nèi)核,竟然還有bug,fuck it!
            從這里可以看出是由于串口的dma導(dǎo)致Oops的,于是我去掉了串口的dma傳輸。方法如下:
            oops5.jpg 
            去掉之后還沒有發(fā)現(xiàn)上述的Oops出現(xiàn)。

            以上來自: 
            http://bbs.chinaunix.net/thread-3744197-1-1.html

            用以上的方法也能解決 Oops,但我發(fā)現(xiàn)我的情況是有的串口收發(fā)都可以使用 DMA,而有的就不行,于是我一個一個串口的測試,修改源碼,將不能使用DMA的串口的DMA功能關(guān)閉掉,而不是將所有串口的 DMA 功能都關(guān)閉。



            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            posts - 8, comments - 0, trackbacks - 0, articles - 0

            Copyright © 墨……

            久久国产精品无码网站| 国产精品成人99久久久久| 日韩十八禁一区二区久久 | 欧美性大战久久久久久| 久久久中文字幕日本| 精品一二三区久久aaa片| 久久久久亚洲AV无码麻豆| 亚洲伊人久久大香线蕉苏妲己| 久久人人超碰精品CAOPOREN| 日本欧美久久久久免费播放网| 秋霞久久国产精品电影院| 区久久AAA片69亚洲| 久久97精品久久久久久久不卡| 狠狠色丁香久久婷婷综合_中 | 久久亚洲AV成人无码| 国产精品无码久久久久久| 武侠古典久久婷婷狼人伊人| 久久精品欧美日韩精品| 无码精品久久一区二区三区| 久久精品国产亚洲av麻豆蜜芽| 色综合久久综合网观看| 久久精品欧美日韩精品| 97久久国产综合精品女不卡 | 精品精品国产自在久久高清| 亚洲中文字幕无码久久综合网| 激情五月综合综合久久69| 无码人妻久久一区二区三区免费| 日韩电影久久久被窝网| 色综合久久88色综合天天 | 成人a毛片久久免费播放| 2021久久精品国产99国产精品| 久久午夜福利无码1000合集 | 久久天天躁狠狠躁夜夜2020一| 韩国三级中文字幕hd久久精品| 精品综合久久久久久888蜜芽| 国内高清久久久久久| 久久夜色精品国产噜噜亚洲a| 无码精品久久一区二区三区| 久久笫一福利免费导航| 久久亚洲精品国产精品婷婷| 性高湖久久久久久久久|