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

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

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

如何使用靜態(tài)呼叫流瀏覽器進(jìn)行軟件故障排除

星星科技指導(dǎo)員 ? 來源:嵌入式計(jì)算設(shè)計(jì) ? 作者:Hari Nagalla ? 2022-06-21 09:55 ? 次閱讀

由于具有射頻連接和微控制器內(nèi)核的低成本集成片上系統(tǒng)設(shè)備的進(jìn)步,物聯(lián)網(wǎng)IoT) 設(shè)備呈指數(shù)級增長。

其中許多設(shè)備主要基于 Arm? Cortex?-M 架構(gòu)。隨著硬件的進(jìn)步,嵌入式軟件在跟上新的連接協(xié)議、協(xié)議棧和框架方面發(fā)揮著重要作用。

然而,連接設(shè)備的激增給嵌入式軟件工程師帶來了挑戰(zhàn),尤其是同時(shí)在多個(gè)設(shè)備和框架上工作的應(yīng)用和維護(hù)工程師。

學(xué)習(xí)新設(shè)備軟件、框架和協(xié)議棧的工作方式可能非常耗時(shí),并且會(huì)限制工程師快速解決問題的能力。設(shè)計(jì)文檔和內(nèi)嵌源代碼注釋會(huì)有所幫助,但它們可能不容易訪問,并且可能無法提供代碼工作原理的完整畫面。

在這些情況下,工程師依靠他們的獨(dú)創(chuàng)性、足智多謀和使用集成開發(fā)環(huán)境 (IDE) 瀏覽源代碼。雖然這有助于理解軟件代碼流,但這是一個(gè)耗時(shí)且乏味的過程,但有更好的方法。

在本文中,我將介紹一種使用現(xiàn)有工具鏈實(shí)用程序來生成軟件的靜態(tài)函數(shù)調(diào)用層次結(jié)構(gòu)并更快更好地理解軟件流程的新穎方法。

常見的函數(shù)調(diào)用跟蹤類型

您可以使用函數(shù)調(diào)用跟蹤來了解代碼流或識別錯(cuò)誤。比較成功和失敗場景之間的程序流程(通過函數(shù)調(diào)用跟蹤)可以幫助您快速識別有問題的代碼區(qū)域以進(jìn)行進(jìn)一步檢查。

函數(shù)調(diào)用跟蹤補(bǔ)充了基于 IDE 的源代碼瀏覽,以更好地了解整個(gè)軟件實(shí)現(xiàn),并且可以分為兩種常見的類別:

運(yùn)行時(shí)函數(shù)調(diào)用跟蹤。這是一個(gè)侵入性過程,需要檢測源代碼。像 GNU Compiler Collection 這樣的工具鏈提供了放置函數(shù)調(diào)用的工具,這需要重建代碼以重新生成新的二進(jìn)制文件,但會(huì)導(dǎo)致額外的代碼大小和更長的執(zhí)行時(shí)間。對于缺乏內(nèi)存的資源受限物聯(lián)網(wǎng)設(shè)備,運(yùn)行時(shí)函數(shù)調(diào)用跟蹤可能不是一個(gè)可行的選擇。另外,您無法保證插樁代碼的行為與未插樁代碼的行為相同。

靜態(tài)函數(shù)調(diào)用。對于基于只讀存儲器 (ROM) 的設(shè)備,檢測不是一個(gè)可行的選擇。盡管您可以簡單地使用 Eclipse 或 Source Insight 等 IDE 瀏覽源代碼以了解軟件實(shí)現(xiàn),但這是一個(gè)乏味的過程。一些 IDE(通常是昂貴的商業(yè)版本)可以派生靜態(tài)函數(shù)調(diào)用圖。這些靜態(tài)函數(shù)調(diào)用瀏覽器通常范圍有限,如果源代碼中有條件編譯,則可能無法提供整個(gè)調(diào)用流程的準(zhǔn)確畫面。

但是,可以從反映實(shí)際二進(jìn)制代碼的二進(jìn)制可執(zhí)行和可鏈接格式 (ELF) 文件生成靜態(tài)調(diào)用流瀏覽器。

使用靜態(tài)呼叫流瀏覽器更快地修復(fù)軟件

讓我們使用設(shè)備的 ELF 二進(jìn)制圖像來生成函數(shù)調(diào)用參考詳細(xì)信息。如圖 1 所示,其想法是獲取 ELF 二進(jìn)制文件并將其傳遞給各種代碼生成工具,例如 TI 的目標(biāo)文件顯示 (armofd) 和反匯編程序 (armdis),以生成函數(shù)列表和調(diào)用引用數(shù)據(jù)庫。生成數(shù)據(jù)庫后,在簡單的樹形瀏覽器中顯示調(diào)用層次結(jié)構(gòu)和流程,以查看函數(shù)調(diào)用引用。這些靜態(tài)調(diào)用流程圖還可以通過將運(yùn)行時(shí) ROM 代碼消息日志覆蓋在靜態(tài)函數(shù)樹的頂部來幫助調(diào)試——這種組合將提供對運(yùn)行時(shí)代碼流的洞察并幫助您隔離問題。

pYYBAGKxJT6AYoODAAEz7T7ZjmQ760.png

圖 1:ELF 文件格式

二進(jìn)制文件 (ELF) 分析

ELF 文件包含程序頭、節(jié)頭以及代碼和數(shù)據(jù)節(jié)。工具鏈提供了各種工具來檢查和以可讀格式顯示 ELF 二進(jìn)制文件內(nèi)容。在 TI,我們使用 armofd 和 armdis 等實(shí)用程序名稱來獲取 Arm 反匯編中的功能詳細(xì)信息和完整的程序編碼。

pYYBAGKxJUWAVo_jAADO_dMRhsI255.png

圖2:靜態(tài)函數(shù)分析流程

解析引擎遍歷反匯編代碼并通過帶有鏈接的分支 (BL) 和帶有鏈接和交換的分支 (BLX) 指令檢查函數(shù)調(diào)用,找到每個(gè)函數(shù)的所有調(diào)用函數(shù),并填充函數(shù)數(shù)據(jù)庫。數(shù)據(jù)庫本身排列為 Adelson-Velsky 和 Landis 自平衡搜索樹,用于快速搜索和瀏覽。

編譯器優(yōu)化可能會(huì)通過直接分支到被調(diào)用函數(shù)來扭曲某些函數(shù)調(diào)用。這些函數(shù)沒有任何堆棧分配,因此解析引擎需要足夠智能以檢測這些編譯器優(yōu)化。

功能瀏覽器

稱為 Java 框架 (JFrames) 的簡單圖形用戶界面 (GUI) 界面選擇感興趣的函數(shù)以進(jìn)行函數(shù)調(diào)用瀏覽。選擇一個(gè)函數(shù)會(huì)顯示兩個(gè)框架,一個(gè)用于“被調(diào)用者/被調(diào)用函數(shù)”,另一個(gè)用于“調(diào)用自”函數(shù)。這些框架顯示了具有進(jìn)一步節(jié)點(diǎn)擴(kuò)展的分層樹結(jié)構(gòu),如圖 3、4、5 和 6 所示。

瀏覽器圖形用戶界面

函數(shù)列表顯示所有可用函數(shù),使您能夠選擇感興趣的函數(shù)以瀏覽參考文獻(xiàn)。

poYBAGKxJUyAYFzmAAGXx-TUVYQ613.png

圖 3:功能列表顯示

可以進(jìn)一步向下導(dǎo)航樹以查看函數(shù)調(diào)用的可能性。

pYYBAGKxJVSAJmMpAAHSvFCubkc321.png

圖 4:被調(diào)用的函數(shù)引用

pYYBAGKxJVyAaI2HAACzLirU1Uo364.png

圖 5:從引用中調(diào)用

pYYBAGKxJWOAOttZAAIXqLawwTg260.png

圖 6:功能列表 GUI

簡化軟件

通過使用這種方法從二進(jìn)制圖像中導(dǎo)出靜態(tài)調(diào)用流程圖,您現(xiàn)在可以更好地了解軟件功能流程并補(bǔ)充您的源代碼瀏覽,從而更深入地了解軟件實(shí)現(xiàn)。最重要的是,這種方法可以加快流程并使故障排除軟件更簡單。

審核編輯:郭婷

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

    關(guān)注

    134

    文章

    9104

    瀏覽量

    367805
  • ROM
    ROM
    +關(guān)注

    關(guān)注

    4

    文章

    572

    瀏覽量

    85804
  • 物聯(lián)網(wǎng)
    +關(guān)注

    關(guān)注

    2909

    文章

    44704

    瀏覽量

    374014
收藏 人收藏

    評論

    相關(guān)推薦

    訊飛星火瀏覽器插件全新升級

    時(shí)刻陪伴,星火插件讓你的瀏覽器變成真正的生產(chǎn)力工具。
    的頭像 發(fā)表于 12-25 09:48 ?212次閱讀

    Chrome瀏覽器優(yōu)化Android性能,驍龍8至尊版表現(xiàn)突出

    谷歌近日對Chrome瀏覽器的最新版本進(jìn)行了重大更新,特別針對Android設(shè)備進(jìn)行了性能優(yōu)化,特別是對于搭載驍龍8至尊版處理的旗艦設(shè)備而言。 自Chrome M112版本以來,An
    的頭像 發(fā)表于 12-13 14:44 ?288次閱讀

    AWTK 最新動(dòng)態(tài):支持瀏覽器控件

    導(dǎo)讀AWTK瀏覽器控件,基于webview項(xiàng)目實(shí)現(xiàn),將瀏覽器嵌入到AWTK應(yīng)用程序中,讓開發(fā)者可以方便的集成在線幫助和調(diào)用地圖等功能。awtk-widget-web-view是基于webview實(shí)現(xiàn)的AWTK瀏覽器控件,使得AW
    的頭像 發(fā)表于 11-20 01:05 ?211次閱讀
    AWTK 最新動(dòng)態(tài):支持<b class='flag-5'>瀏覽器</b>控件

    寫一個(gè)Chrome瀏覽器插件

    一、什么是瀏覽器插件 瀏覽器插件是依附于瀏覽器,用來拓展網(wǎng)頁能力的程序。插件具有監(jiān)聽瀏覽器事件、獲取和修改網(wǎng)頁元素、攔截網(wǎng)絡(luò)請求、添加快捷菜單等功能。使用
    的頭像 發(fā)表于 11-18 17:12 ?378次閱讀
    寫一個(gè)Chrome<b class='flag-5'>瀏覽器</b>插件

    跨域問題是由瀏覽器的同源策略造成的

    瀏覽器
    jf_62215197
    發(fā)布于 :2024年08月27日 07:51:42

    不只是前端,后端、產(chǎn)品和測試也需要了解的瀏覽器知識(二)

    過程中不斷創(chuàng)新,推動(dòng)產(chǎn)品性能、用戶體驗(yàn)的提升,來實(shí)現(xiàn)業(yè)務(wù)的增長,創(chuàng)造可持續(xù)的價(jià)值 。 一、 業(yè)務(wù)系統(tǒng)呈現(xiàn)給用戶的節(jié)點(diǎn) 當(dāng)用戶訪問我們的業(yè)務(wù)系統(tǒng)時(shí),瀏覽器和服務(wù)之間會(huì)進(jìn)行一系列復(fù)雜的交互過程。
    的頭像 發(fā)表于 08-12 14:32 ?359次閱讀
    不只是前端,后端、產(chǎn)品和測試也需要了解的<b class='flag-5'>瀏覽器</b>知識(二)

    不只是前端,后端、產(chǎn)品和測試也需要了解的瀏覽器知識

    一、我們?yōu)槭裁匆私?b class='flag-5'>瀏覽器? 1. 對于前端開發(fā)者 1.瀏覽器是用戶體驗(yàn)的第一線。我們需要了解瀏覽器的工作原理,才能有效地設(shè)計(jì)和實(shí)現(xiàn)用戶界面,確保良好的用戶體驗(yàn)。 2.好的產(chǎn)品需要考慮瀏覽器
    的頭像 發(fā)表于 07-01 18:03 ?480次閱讀
    不只是前端,后端、產(chǎn)品和測試也需要了解的<b class='flag-5'>瀏覽器</b>知識

    如何用python調(diào)用瀏覽器的視頻?

    linda 我想用python調(diào)用瀏覽器的視頻。 我使用cv2調(diào)用視頻,但是失敗了。 URL=\"http://192.168.4.1/face_stream\" cap = cv2.VideoCapture(URL) print(cap.isOpened()) 輸出了
    發(fā)表于 06-26 08:15

    Opera瀏覽器引領(lǐng)潮流,全球首接端側(cè)AI大模型

    昆侖萬維旗下海外平臺Opera宣布,其旗艦瀏覽器Opera One和游戲瀏覽器Opera GX將正式接入端側(cè)AI大模型,成為全球首個(gè)實(shí)現(xiàn)這一突破的主流瀏覽器。
    的頭像 發(fā)表于 06-03 09:18 ?744次閱讀

    微軟Edge瀏覽器新增文本編輯功能:引入Compose和數(shù)字書寫功能

    除此之外,Edge 瀏覽器也對 Windows Ink 的手寫體驗(yàn)進(jìn)行了優(yōu)化提升。現(xiàn)在,用戶可在瀏覽器地址欄、文本區(qū)及“contenteditable”屬性的區(qū)域內(nèi)使用數(shù)字書寫功能。
    的頭像 發(fā)表于 04-24 15:26 ?684次閱讀

    Edge瀏覽器關(guān)閉Microsoft Rewards擴(kuò)展原因揭曉

    據(jù)報(bào)道,近期德國等地的Microsoft Edge瀏覽器用戶發(fā)現(xiàn),安裝或啟動(dòng)Microsoft Rewards擴(kuò)展后,會(huì)出現(xiàn)“右上角擴(kuò)展被Edge瀏覽器禁用以保障您的瀏覽器安全”的提醒窗口。
    的頭像 發(fā)表于 04-10 09:55 ?836次閱讀

    Mozilla Firefox瀏覽器推出Text Fragments功能,提升用戶體驗(yàn)

    早在2020年,谷歌即在Chrome瀏覽器中推出了“Scroll to Text Fragments”功能,而Edge、Opera、Brave、Vivaldi以及蘋果Safari等基于Chromium的瀏覽器也已支持這一便捷特性。
    的頭像 發(fā)表于 04-08 10:21 ?636次閱讀

    鴻蒙實(shí)戰(zhàn)開發(fā):【瀏覽器制作】

    使用[@ohos.systemparameter]接口和[Web組件]展示了一個(gè)瀏覽器的基本功能,展示網(wǎng)頁,根據(jù)頁面歷史棧前進(jìn)回退等。
    的頭像 發(fā)表于 03-19 17:47 ?600次閱讀
    鴻蒙實(shí)戰(zhàn)開發(fā):【<b class='flag-5'>瀏覽器</b>制作】

    如何通過瀏覽器訪問Web頁面進(jìn)行固件更新的方法?

    如果電腦沒有安裝 TIA PORTAL 軟件,但是 CPU 之前激活了 Web 服務(wù)功能,可以通過電腦聯(lián)網(wǎng) CPU,然后打開瀏覽器瀏覽到 CPU 的方式
    的頭像 發(fā)表于 02-25 14:51 ?1605次閱讀

    昆侖萬維旗下Opera將推出全球首款非WebKit內(nèi)核的iOS瀏覽器

    近日,昆侖萬維旗下的國際知名瀏覽器品牌Opera宣布,將針對歐洲的iPhone和iPad用戶推出一款全新的AI瀏覽器——Opera One。這款瀏覽器最大的亮點(diǎn)在于,它基于Opera自研的引擎,而非通常的WebKit內(nèi)核,這在全
    的頭像 發(fā)表于 02-06 16:40 ?5754次閱讀