在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Linux編程時遇到Oops提示該如何排查?

西西 ? 作者:致遠(yuǎn)電子 ? 2018-11-28 16:52 ? 次閱讀

各位工程師Linux下開發(fā)程序時,有沒有遇到由于系統(tǒng)中存在某些小故障而跳出了“Oops”提示的情況,此時你是如何排查故障?一行行的查看代碼嗎?其實不用那么復(fù)雜,本文將為你介紹一種高效的Linux編程的故障排除方法。

在分析Oops之前,我們先來看以下這么一個例子,使用GPIO的中斷做掉電檢測,參考《嵌入式Linux開發(fā)教程下冊》的驅(qū)動框架,設(shè)計如下程序框圖:

Linux編程時遇到Oops提示該如何排查?

這個框架設(shè)計之初的理想流程為:應(yīng)用啟動-》程序初始化-》應(yīng)用open設(shè)備-》等待中斷事件,但實際項目開發(fā)時,往往發(fā)生許許多多不可預(yù)測的事情。如小王正在調(diào)Qt應(yīng)用,發(fā)現(xiàn)老王的進(jìn)程老在打印,那就不讓老王的進(jìn)程開機自啟動,調(diào)了兩三天后,不定時地提示個Oops提示,小王按照“以前代碼不出現(xiàn),新加的出現(xiàn),那么起因絕對在新代碼內(nèi)”的慣性思維,認(rèn)為是新加的Qt導(dǎo)致的,然后小王就不斷測試,不斷查找bug中。..。..。這樣就過去了十年。

但原因其實是小王沒有open設(shè)備,即驅(qū)動層沒有初始化定時器隊列,那么中斷處理函數(shù)中50ms觸發(fā)的隊列就為一個空值,空指針時Linux內(nèi)核當(dāng)然“哎呦”一下提醒你了,而不定時地提示其實就是因為電源不定時地松動,gpio檢測到掉電了所以觸發(fā)了中斷。

實際上,這樣的案例十分常見,原本想A-》B-》C,實際使用是A-》D-》C,又或者驅(qū)動中有某個變量忘記初始化等等,這時分析Oops就可以十分快速地解決問題。那接下來我們就用Linux中標(biāo)準(zhǔn)驅(qū)動去觸發(fā)一個Oops,對的你沒看錯,Linux內(nèi)核標(biāo)準(zhǔn)源碼也存在這樣的異常,而且我們也可以去修復(fù)這樣的問題。

使用我司的EasyARM-iMX283開發(fā)板,內(nèi)核源碼為光盤內(nèi)的Linux-2.6.35.3.tar.bz2,編譯方法請參考光盤資料,我們需要把lcd的背光驅(qū)動修改為ko模式。

Linux編程時遇到Oops提示該如何排查?

燒錄完新內(nèi)核,加載新編譯出來的drivers/video/backlight/mxs_bl.ko文件就會提示以下Oops信息:

Linux編程時遇到Oops提示該如何排查?

乍看之下,這段信息跟亂碼差不多,但只要你一層層地分析,你就會發(fā)現(xiàn),這些信息已經(jīng)告訴了我們錯誤的原因。接下來就開始我們的Oops分析之旅。

1、主要錯誤信息

Linux編程時遇到Oops提示該如何排查?

用于提示錯誤的類型,這里表示使用空指針。

2、操作入口

Linux編程時遇到Oops提示該如何排查?

用于提示錯誤的操作,這里表示加載mxs_bl模塊時出錯,對應(yīng)于加載操作insmod mxs_bl.ko。

3、PC指針

Linux編程時遇到Oops提示該如何排查?

用于提示出錯時的PC指針位置,PC指針即當(dāng)前程序運行點的地址,這里提示表示錯誤函數(shù)為regulator_set_current_limit,偏移地址為0xc。

4、LR指針

Linux編程時遇到Oops提示該如何排查?

用于提示出錯時的LR指針位置,LR指針即調(diào)用子函數(shù)的上一個函數(shù)名以及入口偏移量,這里表示上一個函數(shù)為set_bl_intensity,偏移地址為0xd8。即set_bl_intensity調(diào)用regulator_set_current_limit時出錯。

5、寄存器

Linux編程時遇到Oops提示該如何排查?

用于記錄出錯時各個寄存器的值,對于匯編比較熟悉的同志們可以研究一下這段信息。

6、出錯進(jìn)程信息

Linux編程時遇到Oops提示該如何排查?

用于提示出錯的進(jìn)程id號與進(jìn)程名稱。出錯進(jìn)程為insmod, PID號2261,對于多任務(wù)系統(tǒng)中,可能存在多個PID調(diào)用同一個接口的情況。

7、出錯時的堆棧信息

Linux編程時遇到Oops提示該如何排查?

用于提示出錯時堆棧內(nèi)保存的寄存器信息,當(dāng)程序由于中斷發(fā)生或子程序調(diào)用時,會執(zhí)行壓棧操作,即將運行環(huán)境保存到堆棧內(nèi),保證退出中斷或跳出子程序后,運行環(huán)境不發(fā)生改變。

而此處的堆棧信息即記錄了程序運行時的環(huán)境信息。從中我們可以找到許多LR地址,從而分析出函數(shù)調(diào)用關(guān)系,與下一段的信息有類似作用。

8、函數(shù)執(zhí)行的回溯關(guān)系

Linux編程時遇到Oops提示該如何排查?

用于表示函數(shù)的調(diào)用關(guān)系,通過這段信息我們可以知道,函數(shù)的整個執(zhí)行流程,知道它的函數(shù)調(diào)用關(guān)系,最后整理出來的函數(shù)執(zhí)行流程如下:

Linux編程時遇到Oops提示該如何排查?

從中我們看到了熟悉的init函數(shù)、probe函數(shù)、以及清楚probe函數(shù)下執(zhí)行的操作過程是到哪一步出錯的。現(xiàn)在我們知道了代碼的執(zhí)行流程,出錯的PC指針的位置,但還是看不到代碼,出錯指針處我們只看到了一串?dāng)?shù)字,那么接下來我們就操作一下,把pc指針的數(shù)據(jù)變?yōu)橛幸饬x的代碼。

第一步,分辨出錯誤代碼在什么位置

這次實驗涉及的二進(jìn)制文件有內(nèi)核的燒錄固件以及驅(qū)動的ko文件,所以第一步分析就需要確定出錯代碼是在內(nèi)核固件里還是ko文件里。

首先得到內(nèi)核代碼的范圍,用以下命令將內(nèi)核反匯編。

Linux編程時遇到Oops提示該如何排查?

查看這個文件的格式如是:

Linux編程時遇到Oops提示該如何排查?

第一列行數(shù),第二列運行地址,第三列二進(jìn)制碼,第四列匯編代碼,既然第二列為運行地址,即等同于程序運行到這行時,pc指針的值等于這個數(shù)值。這樣只要翻看這個文件的頭部以及尾部,就能知道內(nèi)核代碼的PC指針范圍為:c0008000~c0562338。

根據(jù)前面第5步寄存器值,出錯時PC指針為c02f1878,即在內(nèi)核源碼范圍內(nèi)。

第二步,分析出錯函數(shù)的出錯語句

那么根據(jù)第3步PC指針,得到regulator_set_current_limit的匯編代碼,如下:

Linux編程時遇到Oops提示該如何排查?

函數(shù)入口地址為c02f186c 《regulator_set_current_limit》。

在第3步PC指針指出偏移地址為“PC is at regulator_set_current_limit+0xc”。

PC = 0xc02f1878 = 0xc02f186c + 0xc,符合匯編代碼地址。

第三步,找到出錯函數(shù)的C語言代碼

這步可以說是最困難的,因為內(nèi)核代碼層次多,同名函數(shù)也可能存在許多份,可能幾份編譯進(jìn)內(nèi)核(static聲明的局部函數(shù)),也可能沒編譯進(jìn)內(nèi)核,如何從眾多的代碼中分析出具體哪段呢。

本人就使用了一些小手段,首先給每個同名函數(shù)的入口加段亂碼,讓編譯器篩選出編譯進(jìn)內(nèi)核的文件(因為亂碼,所以編譯會報錯),然后給剩下的函數(shù)加打印語句,通常經(jīng)過第一步之后,可選的目標(biāo)就兩三個,通過打印進(jìn)一步確認(rèn)代碼即可。

以下為篩選出來的C語言代碼。

Linux編程時遇到Oops提示該如何排查?

看到這好像是定位了函數(shù),但對于不熟悉匯編的人來說,C與匯編還是沒有關(guān)聯(lián)起來,好像進(jìn)入了死胡同,但先別氣餒,從上面的匯編代碼中我們知道,函數(shù)名即為函數(shù)的首地址,那么調(diào)用子函數(shù)即需要讓CPU知道子函數(shù)名,那么匯編如何調(diào)用子函數(shù)呢?使用bl指令, bl+子函數(shù)名。既然匯編有這么一個特性,那么我們看匯編代碼。

上面582734行為“bl c0493104 《mutex_lock》”這句調(diào)用了子函數(shù),再看C中調(diào)用此函數(shù)的語句。

Linux編程時遇到Oops提示該如何排查?

那么結(jié)果顯而易見,不可能定義個變量都報錯吧,所以唯一可能錯誤的語句就是struct regulator_dev *rdev = regulator-》rdev,同理,這句的前半部也只是定義一個rdev的變量,再結(jié)合內(nèi)核給出來的提示——空指針,所以錯誤就是regulator-》rdev是一個空指針。

最終的問題就歸結(jié)于,為什么regulatar-》rdev為空指針。這部分的查閱代碼以及推理需要更深層次地挖掘,工作量也非本文能說清的,故作者在這里就大膽地推測與上面的A-》B-》C模型類似。所以我們就需要在這個資源存在的時刻,調(diào)用它之前給它賦值。

這時侯,我們就需要拿出第8步函數(shù)執(zhí)行的回溯關(guān)系圖,既然知道這個圖中最后的函數(shù)的輸入?yún)?shù)regulator的rdev為空,那么我們就關(guān)心regulator結(jié)構(gòu)體以及它的意義。從結(jié)構(gòu)體的意義我們才能知道如何給它賦值。

Linux編程時遇到Oops提示該如何排查?

在相關(guān)的代碼文件中搜索關(guān)鍵字”regulator”或”regulator =”(建議搜這個,因為這種才是賦值語句)得到如下代碼。

Linux編程時遇到Oops提示該如何排查?

分析這個函數(shù)可知,regulator實際是pdata的一個成員,他需要data來初始化,那么接下來的事情就簡單了,在回溯關(guān)系中找一個位置把data的數(shù)據(jù)塞入pdata中,剛好這段函數(shù)就是初始化的regulator的,那就直接拿去用吧。

把這段添加到probe函數(shù)內(nèi)的這個位置,實現(xiàn)了在mxsbl_probe和mxsbl_do_probe之間賦值此變量。

Linux編程時遇到Oops提示該如何排查?

這樣重新編譯后即可正常加載ko文件。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11479

    瀏覽量

    213058
  • 編程
    +關(guān)注

    關(guān)注

    88

    文章

    3686

    瀏覽量

    94966
  • Oops
    +關(guān)注

    關(guān)注

    0

    文章

    4

    瀏覽量

    3353
收藏 人收藏

    評論

    相關(guān)推薦
    熱點推薦

    Linux系統(tǒng)CPU占用率100%的排查思路

    今天浩道跟大家分享linux硬核干貨,工作中當(dāng)你服務(wù)器CPU達(dá)到100%時,干著急是沒有用的,查問題還得自己去查。本文將給大家羅列排查異常故障思路,并且文末附上相關(guān)shell腳本,去實際一番,你會發(fā)現(xiàn)原來解決問題的方法如此之簡
    的頭像 發(fā)表于 01-23 10:26 ?6637次閱讀
    <b class='flag-5'>Linux</b>系統(tǒng)CPU占用率100%的<b class='flag-5'>排查</b>思路

    linux運維怎么排查

    linux運維排查常用命令(開發(fā)專享)
    發(fā)表于 11-11 06:34

    內(nèi)核oops的根本原因是什么?我們?nèi)绾握{(diào)試內(nèi)核oops

    Broadcom 交換機設(shè)備連接到我們主板上帶有 PCIe 的 T1042。開關(guān)工作在 EP 模式。linux內(nèi)核版本是4.14。在檢測到 pcie 錯誤的現(xiàn)場卡中引發(fā)內(nèi)核 oops。但是這個
    發(fā)表于 04-20 06:19

    LINUX網(wǎng)絡(luò)編程

    linux開發(fā)編程教程資料——LINUX網(wǎng)絡(luò)編程,感興趣的小伙伴們可以看一看。
    發(fā)表于 08-23 16:23 ?0次下載

    Linux網(wǎng)絡(luò)編程

    linux開發(fā)編程教程資料——Linux網(wǎng)絡(luò)編程,感興趣的小伙伴們可以看一看。
    發(fā)表于 08-23 16:23 ?0次下載

    LINUX系統(tǒng)教程之如何在Linux系統(tǒng)下進(jìn)行編程

    本文檔的主要內(nèi)容詳細(xì)介紹的是LINUX系統(tǒng)教程之如何在Linux系統(tǒng)下進(jìn)行編程主要內(nèi)容包括了:程序開發(fā)過程 ,Linux編程環(huán)境和開發(fā)工具
    發(fā)表于 12-18 19:09 ?9次下載

    linux內(nèi)核中的Oops

    gdb來分析問題。?開發(fā)內(nèi)核驅(qū)動的過程中可能遇到的問題是千奇百怪的,調(diào)試的方法也是多種多樣,OopsLinux內(nèi)核給我們的提示,我們要用好它。
    發(fā)表于 04-02 14:31 ?658次閱讀

    當(dāng)STM32遇到Linux = STM32MP1

    當(dāng)STM32遇到Linux = STM32MP1
    的頭像 發(fā)表于 03-01 13:37 ?2441次閱讀

    STM32 MPU6050 使用DMP遇到的問題-提示Product ID read as 0 indicates device is either incomp

    STM32 MPU6050 使用DMP遇到的問題-提示Product ID read as 0 indicates device is either incomp
    發(fā)表于 12-06 15:36 ?44次下載
    STM32 MPU6050 使用DMP<b class='flag-5'>遇到</b>的問題-<b class='flag-5'>提示</b>Product ID read as 0 indicates device is either incomp

    內(nèi)核oops錯誤原因及處理方法

    最近在調(diào)試設(shè)備時,遇到了一個偶發(fā)的開機死機問題。通過查看輸出日志,發(fā)現(xiàn)內(nèi)核報告了oops錯誤,如下所示(中間省略了部分日志,以......代替)。
    的頭像 發(fā)表于 05-12 16:20 ?8770次閱讀

    如何解讀內(nèi)核的oops

    96000045表示錯誤碼。后面[]內(nèi)的數(shù)值是與頁面有關(guān)的oops信息被顯示的次數(shù)。之后顯示內(nèi)核的重要特性SMP和PREEMPT被顯示的配置情況。這條信息所在的內(nèi)核啟用了SMP支持,所以只顯示SMP。
    的頭像 發(fā)表于 10-21 12:39 ?2100次閱讀

    怎么解讀內(nèi)核的oops

    Oops的錯誤代碼根據(jù)錯誤的原因會有不同的定義,如果發(fā)現(xiàn)自己遇到Oops和下面無法對應(yīng)的話,最好去內(nèi)核代碼里查找
    的頭像 發(fā)表于 02-17 16:08 ?1709次閱讀

    Linux服務(wù)器常見的網(wǎng)絡(luò)故障排查方法

    日常工作中我們有時會遇到服務(wù)器網(wǎng)絡(luò)不通問題,導(dǎo)致服務(wù)器無法正常運行。要想解決服務(wù)器網(wǎng)絡(luò)故障問題,通常要先進(jìn)行網(wǎng)絡(luò)故障排查,這里以Linux服務(wù)器為例來看下常用的網(wǎng)絡(luò)故障排查方法介紹。
    的頭像 發(fā)表于 04-14 15:47 ?3308次閱讀

    常用linux網(wǎng)絡(luò)排查命令

    今天浩道跟大家分享linux網(wǎng)絡(luò)運維中常見的命令,掌握好這些命令,在排查故障時將會游刃有余!
    發(fā)表于 06-25 10:49 ?960次閱讀

    Linux應(yīng)用編程的基本概念

    Linux應(yīng)用編程涉及到在Linux環(huán)境下開發(fā)和運行應(yīng)用程序的一系列概念。以下是一些涵蓋Linux應(yīng)用編程的基本概念。
    的頭像 發(fā)表于 10-24 17:19 ?599次閱讀
    主站蜘蛛池模板: 色婷婷亚洲精品综合影院 | 李老汉的性生生活1全部 | 欧美日本不卡 | 色骚综合 | 国产精品久久久久久久久免费观看 | 国产一级簧片 | 午夜影视啪啪免费体验区深夜 | 91中文字幕视频 | 视频在线免费观看 | 女人张开腿 让男人桶个爽 免费观看 | 免费播放特黄特色毛片 | 亚洲一区免费观看 | 四虎永久地址4hu紧急入口 | 福利99| 色播丁香| 手机福利片| 一级特黄牲大片免费视频 | 日韩美女拍拍免费视频网站 | 清冷双性被cao的合不拢腿 | 欧美成人在线网站 | 九月婷婷亚洲综合在线 | 日韩天堂在线观看 | 成人夜夜 | 免费黄色地址 | 午夜精品久久久久蜜桃 | 免费一级欧美片片线观看 | 狠狠色狠狠色综合久久一 | 么公的好大好硬好深好爽在线视频 | 69国产成人综合久久精品 | 国产妇女在线 | 美女黄页在线观看 | 女女综合网 | www.亚洲天堂.com | 日韩欧美在线中文字幕 | aaaa级日本片免费视频 | 天堂网2021天堂手机版丶 | 正在播放91| www.91在线播放| 欧美满足你的丝袜高跟ol | 白嫩美女在线啪视频观看 | 日韩欧美卡通动漫在线观看 |