青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Oops 定位錯誤代碼行

Posted on 2013-04-10 15:16 墨…… 閱讀(1011) 評論(0)  編輯 收藏 引用
這幾天一直在調試atmel at91sam9x25的串口,用著用著總會導致Oops,Oops內容如下:
[ 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 
進入 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 調試,如下:
arm-none-linux-gnueabi-gdb vmlinux
oops3.jpg 
對應著Oops 消息里面的這一行
[ 1023.520000] LR is at atmel_tasklet_func+0x10/0x690
在gdb下鍵入命令 : l *at atmel_tasklet_func+0x10
oops4.jpg 
這樣就找到了出錯的代碼行。在這里鄙視一下atmel提供的內核,竟然還有bug,fuck it!
從這里可以看出是由于串口的dma導致Oops的,于是我去掉了串口的dma傳輸。方法如下:
oops5.jpg 
去掉之后還沒有發現上述的Oops出現。

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

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


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

Copyright © 墨……

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲精品自在久久| 国产欧美日韩在线观看| 亚洲欧美成人精品| 亚洲小视频在线观看| 这里是久久伊人| 亚洲欧美在线一区二区| 亚洲欧美日韩视频一区| 久久精品国产一区二区三| 美女黄毛**国产精品啪啪| 99在线热播精品免费| 日韩视频一区二区在线观看| 一区二区三区日韩欧美| 午夜精品三级视频福利| 久久九九全国免费精品观看| 鲁鲁狠狠狠7777一区二区| 欧美国产日本韩| 国产精品色午夜在线观看| 狠狠做深爱婷婷久久综合一区| 亚洲激情视频网| 夜夜嗨av一区二区三区网页 | 国产精品免费小视频| 国产亚洲激情视频在线| 亚洲人妖在线| 欧美在线亚洲| 亚洲七七久久综合桃花剧情介绍| 亚洲精品美女免费| 欧美在线一二三区| 欧美日韩在线一区| 亚洲电影免费观看高清完整版| 亚洲视频视频在线| 欧美福利一区二区| 午夜精品理论片| 欧美日韩国产综合新一区| 狠狠久久婷婷| 亚洲一区二区三区四区视频| 免费成人在线观看视频| 亚洲视频一区二区免费在线观看| 另类综合日韩欧美亚洲| 国产欧美日韩一区二区三区在线| 亚洲美女视频在线观看| 久久久五月婷婷| 正在播放日韩| 欧美激情国产日韩精品一区18| 国产一区二区三区久久久| 亚洲午夜女主播在线直播| 欧美大片一区| 久久久久久久一区二区| 国产日产欧产精品推荐色 | 亚洲美女中出| 欧美+亚洲+精品+三区| 新67194成人永久网站| 欧美日韩亚洲免费| 日韩亚洲视频| 久久久久久色| 欧美一区二区视频观看视频| 国产精品久久久久久av下载红粉 | 亚洲综合不卡| 欧美日韩免费一区| 欧美激情一区二区在线| 尤物网精品视频| 久久亚洲国产精品日日av夜夜| 亚洲欧美三级在线| 国产区精品在线观看| 午夜精品久久久久久99热软件 | 亚洲电影在线观看| 久久免费黄色| 亚洲国产日本| 欧美1区2区| 欧美 日韩 国产一区二区在线视频| 黄色国产精品一区二区三区| 久久久精品五月天| 久久综合色播五月| 亚洲日本一区二区| 亚洲日本国产| 国产精品海角社区在线观看| 亚洲免费视频中文字幕| 亚洲欧美在线免费观看| 精品动漫3d一区二区三区免费| 欧美成人一二三| 欧美国产日韩一二三区| 一本高清dvd不卡在线观看| 99国产精品久久久久久久成人热 | 国产精品日本欧美一区二区三区| 亚洲综合电影| 欧美在线综合视频| 最新国产乱人伦偷精品免费网站| 亚洲福利视频在线| 欧美日韩国产综合一区二区| 欧美一级播放| 久久免费视频网| 亚洲作爱视频| 午夜久久影院| 亚洲电影免费观看高清| 一本色道久久加勒比88综合| 国产精品揄拍500视频| 免费成人高清在线视频| 欧美吻胸吃奶大尺度电影| 久久精品道一区二区三区| 母乳一区在线观看| 亚洲欧美综合网| 美女91精品| 久久成人国产| 欧美精品国产一区| 久久久久久久久久码影片| 欧美日韩xxxxx| 久久久免费精品| 欧美系列精品| 91久久香蕉国产日韩欧美9色| 国产精品久久久久久久久免费樱桃| 蜜桃精品久久久久久久免费影院| 欧美日韩三级| 亚洲第一区在线观看| 国产麻豆视频精品| a4yy欧美一区二区三区| 亚洲国产精品电影在线观看| 亚洲夜间福利| 在线视频精品一| 久久日韩粉嫩一区二区三区| 亚洲精品婷婷| 亚洲国产精品高清久久久| 亚洲一区二区在线| 日韩午夜免费视频| 久久久高清一区二区三区| 先锋影音久久久| 欧美日韩日本网| 99re6热在线精品视频播放速度 | 亚洲在线观看视频网站| 免费永久网站黄欧美| 久久视频这里只有精品| 国产欧美日韩一区二区三区在线观看 | 久久综合网hezyo| 国产欧美精品一区aⅴ影院| 亚洲精品在线观看免费| 91久久久久久| 欧美成人在线网站| 亚洲成人中文| 亚洲三级视频在线观看| 美女福利精品视频| 亚洲国产人成综合网站| 91久久精品国产91久久| 欧美插天视频在线播放| 91久久精品视频| 99亚洲视频| 欧美三级在线播放| 99re热这里只有精品视频| 亚洲天堂男人| 国产精品美腿一区在线看| 亚洲无限乱码一二三四麻| 亚洲欧美一区二区三区在线| 国产精品丝袜xxxxxxx| 亚洲男人的天堂在线aⅴ视频| 午夜在线不卡| 国产综合香蕉五月婷在线| 久久女同精品一区二区| 亚洲国产日韩欧美在线99| 99成人免费视频| 国产精品久久久久久久9999| 中文无字幕一区二区三区| 欧美一区二区三区视频在线观看| 国产日韩精品在线| 久久影视三级福利片| 欧美高清在线一区| av不卡免费看| 国产农村妇女精品一区二区| 久久久www成人免费毛片麻豆| 欧美激情视频一区二区三区在线播放| 亚洲精品少妇| 国产精品视频免费在线观看| 久久久99精品免费观看不卡| 亚洲国产成人精品女人久久久| 国产精品99久久久久久人| 国产欧美视频一区二区三区| 久久永久免费| 亚洲一区视频在线| 亚洲第一区在线观看| 欧美一级艳片视频免费观看| 亚洲高清自拍| 国产精品午夜电影| 欧美国产日韩一区二区在线观看| 欧美日韩视频不卡| 蜜臀久久久99精品久久久久久 | 在线日本欧美| 国产精品福利片| 久热爱精品视频线路一| 亚洲一区二区三区乱码aⅴ蜜桃女| 玖玖视频精品| 亚洲欧美在线看| 亚洲精品综合| 一区精品久久| 国产精品入口尤物| 欧美日本韩国一区| 免费看的黄色欧美网站| 亚洲女人天堂成人av在线| 91久久精品一区二区别| 老司机67194精品线观看| 欧美一区二区三区在线观看| 一二三区精品福利视频| 在线看片成人| 红桃视频亚洲| 国产亚洲欧美激情|