那些年,流淌著的夢(mèng)想
C++博客
首頁(yè)
新隨筆
聯(lián)系
聚合
管理
<
2025年5月
>
日
一
二
三
四
五
六
27
28
29
30
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
1
2
3
4
5
6
7
隨筆分類
Linux Kernel(1)
(rss)
隨筆檔案
2015年7月 (1)
2013年7月 (1)
2013年5月 (1)
2013年4月 (2)
2012年5月 (1)
2012年4月 (1)
2012年3月 (1)
相冊(cè)
相信永遠(yuǎn)
最新隨筆
1.?can't open /dev/ttyS0: No such file or directory
2.?編譯沒(méi)有圖形界面的 Emacs
3.?在 Emacs 里面使用 Cscope
4.?Oops 定位錯(cuò)誤代碼行
5.?linux 驅(qū)動(dòng)初接觸
6.?SQL 查詢表的外鍵
7.?MFC cdatetimectrl 初始時(shí)間為1970的問(wèn)題
8.?關(guān)于 debug assertion failed, file:dlgdata.cpp,line"43 錯(cuò)誤解析
最新評(píng)論
Oops 定位錯(cuò)誤代碼行
Posted on 2013-04-10 15:16
墨……
閱讀(993)
評(píng)論(0)
編輯
收藏
引用
這幾天一直在調(diào)試atmel at91sam9x25的串口,用著用著總會(huì)導(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)
注意上述紅色的地方。
下面就來(lái)顯示如何定位出出錯(cuò)代碼行:
1.首先,編譯時(shí)打開(kāi)complie with debug info選項(xiàng),步則如下
make ARCH=arm CROSS_COMPILE=arm-none-linux-gnueabi- menuconfig
進(jìn)入 Kernel hacking
選擇
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
對(duì)應(yīng)著Oops 消息里面的這一行
[ 1023.520000] LR is at atmel_tasklet_func+0x10/0x690
在gdb下鍵入命令 :
l *at atmel_tasklet_func+0x10
這樣就找到了出錯(cuò)的代碼行。在這里鄙視一下atmel提供的內(nèi)核,竟然還有bug,fuck it!
從這里可以看出是由于串口的dma導(dǎo)致Oops的,于是我去掉了串口的dma傳輸。方法如下:
去掉之后還沒(méi)有發(fā)現(xiàn)上述的Oops出現(xiàn)。
以上來(lái)自:
http://bbs.chinaunix.net/thread-3744197-1-1.html
用以上的方法也能解決 Oops,但我發(fā)現(xiàn)我的情況是有的串口收發(fā)都可以使用 DMA,而有的就不行,于是我一個(gè)一個(gè)串口的測(cè)試,修改源碼,將不能使用DMA的串口的DMA功能關(guān)閉掉,而不是將所有串口的
DMA 功能都關(guān)閉。
只有注冊(cè)用戶
登錄
后才能發(fā)表評(píng)論。
【推薦】100%開(kāi)源!大型工業(yè)跨平臺(tái)軟件C++源碼提供,建模,組態(tài)!
網(wǎng)站導(dǎo)航:
博客園
IT新聞
BlogJava
博問(wèn)
Chat2DB
管理
常用鏈接
我的隨筆
我的評(píng)論
我參與的隨筆
我參與的團(tuán)隊(duì)
評(píng)論排行榜
1.?關(guān)于 debug assertion failed, file:dlgdata.cpp,line"43 錯(cuò)誤解析(0)
2.?MFC cdatetimectrl 初始時(shí)間為1970的問(wèn)題(0)
3.?SQL 查詢表的外鍵(0)
4.?linux 驅(qū)動(dòng)初接觸(0)
5.?Oops 定位錯(cuò)誤代碼行(0)
閱讀排行榜
1.?can't open /dev/ttyS0: No such file or directory(2182)
2.?關(guān)于 debug assertion failed, file:dlgdata.cpp,line"43 錯(cuò)誤解析(1669)
3.?SQL 查詢表的外鍵(1317)
4.?Oops 定位錯(cuò)誤代碼行(993)
5.?linux 驅(qū)動(dòng)初接觸(912)
posts - 8, comments - 0, trackbacks - 0, articles - 0
Copyright © 墨……
国产成人精品久久二区二区
|
中文字幕精品无码久久久久久3D日动漫
|
久久久久久一区国产精品
|
国产91色综合久久免费
|
久久精品视频网
|
亚洲乱亚洲乱淫久久
|
狠狠色伊人久久精品综合网
|
大香网伊人久久综合网2020
|
狠狠久久综合伊人不卡
|
国内精品伊人久久久久影院对白
|
精品久久久久久国产三级
|
久久久久九九精品影院
|
99久久综合国产精品免费
|
久久精品aⅴ无码中文字字幕不卡
|
午夜肉伦伦影院久久精品免费看国产一区二区三区
|
久久97久久97精品免视看
|
99久久综合国产精品二区
|
久久精品国产99久久丝袜
|
伊人久久精品影院
|
色综合久久久久无码专区
|
久久国产精品国产自线拍免费
|
91精品国产91久久
|
欧美粉嫩小泬久久久久久久
|
久久人人爽人人爽人人AV
|
AAA级久久久精品无码片
|
观看 国产综合久久久久鬼色 欧美 亚洲 一区二区
|
思思久久好好热精品国产
|
久久久久精品国产亚洲AV无码
|
亚洲色欲久久久综合网
|
国产91色综合久久免费
|
综合久久精品色
|
日本精品久久久久中文字幕
|
亚州日韩精品专区久久久
|
亚洲av日韩精品久久久久久a
|
色综合久久无码中文字幕
|
久久美女人爽女人爽
|
久久久久久曰本AV免费免费
|
久久噜噜电影你懂的
|
国产aⅴ激情无码久久
|
精品国产综合区久久久久久
|
人妻精品久久久久中文字幕一冢本
|