那曲檬骨新材料有限公司

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

如何使用靜態呼叫流瀏覽器更快地對嵌入式設備軟件進行故障排除

星星科技指導員 ? 來源:嵌入式計算設計 ? 作者:Hari Nagalla ? 2022-11-21 14:26 ? 次閱讀

由于具有射頻連接和微控制器內核的低成本集成片上系統設備的進步,物聯網IoT) 設備呈指數級增長。

其中許多設備主要基于Arm? Cortex-M?架構。隨著硬件的進步,嵌入式軟件在跟上新的連接協議、協議棧和框架方面發揮著重要作用。

然而,連接設備的激增給嵌入式軟件工程師帶來了挑戰,尤其是同時在多個設備和框架上工作的應用程序和維護工程師。

了解新設備軟件、框架和協議棧的工作原理可能非常耗時,并且會限制工程師快速解決問題的能力。設計文檔和內聯源代碼注釋可能會有所幫助,但它們可能不容易訪問,并且可能無法全面了解代碼的工作原理。

在這些情況下,工程師依靠他們的獨創性、足智多謀和使用集成開發環境 (IDE) 的源代碼瀏覽。雖然這在嘗試理解軟件代碼流時有所幫助,但這是一個耗時且乏味的過程,并且有更好的方法。

在本文中,我將介紹一種使用現有工具鏈實用程序來生成軟件的靜態函數調用層次結構并更快更好地理解軟件流的新方法。

函數調用跟蹤的常見類型

可以使用函數調用跟蹤來了解代碼流或識別 bug。比較成功和失敗方案之間的程序流(通過函數調用跟蹤)可以幫助您快速識別代碼中存在問題的區域,以便進一步檢查。

函數調用跟蹤補充了基于 IDE 的源代碼瀏覽,以更好地了解整個軟件實現,并且可以分為兩個常見類別:

運行時函數調用跟蹤。這是一個侵入性的過程,需要檢測源代碼。像 GNU Compiler Collection 這樣的工具鏈提供了放置函數調用的檢測,這需要重建代碼來重新生成新的二進制文件,但會導致額外的代碼大小和更長的執行時間。對于缺少內存的資源受限的 IoT 設備,運行時函數調用跟蹤可能不是一個可行的選擇。此外,您無法保證檢測的代碼的行為與未檢測的代碼相同。

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

但是,可以從二進制可執行和可鏈接格式 (ELF) 文件生成靜態調用流瀏覽器,該文件反映了實際的二進制代碼。

使用靜態呼叫流瀏覽器更快地修復軟件

讓我們使用設備的 ELF 二進制映像來生成函數調用引用詳細信息。如圖 1 所示,其思路是獲取 ELF 二進制文件,并通過各種代碼生成工具(如 TI 的目標文件顯示 (armofd) 和拆裝器 (armdis) )傳遞它,以生成函數列表和調用引用數據庫。生成數據庫后,在簡單的樹瀏覽器中顯示調用層次結構和流,以查看函數調用引用。這些靜態調用流圖還可以通過將運行時 ROM 代碼消息日志覆蓋在靜態函數樹的頂部來幫助調試 - 這種組合將提供對運行時代碼流的洞察并幫助您隔離問題。

pYYBAGN7GmKAR_u_AAFtC8PlGFA735.png

圖 1:ELF 文件格式

二進制文件 (ELF) 分析

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

pYYBAGN7GmqALZYUAADzD0d8ZGg045.png

圖2:靜態函數分析的過程

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

編譯器優化可能會通過直接分支到被調用的函數來扭曲某些函數調用。這些函數沒有任何堆棧分配,因此解析引擎需要足夠智能才能檢測這些編譯器優化。

函數瀏覽器

稱為 Java 幀 (JFrames) 的簡單圖形用戶界面 (GUI) 界面為函數調用瀏覽選擇感興趣的函數。選擇一個函數將顯示兩個幀,一個用于“被調用方/被調用函數”,另一個用于“被調用自”函數。這些幀顯示具有進一步節點擴展的分層樹結構,如圖 3、4、5 和 6 所示。

瀏覽器圖形用戶界面

函數列表顯示所有可用函數,使您能夠選擇感興趣的函數來瀏覽參考文獻。

pYYBAGN7GnGAFEtaAAGDeVrYZL4756.png

圖 3:功能列表顯示

可以在樹中進一步向下導航以查看函數調用的可能性。

pYYBAGN7GnmAbdZbAAGZpw-V-lU508.png

圖 4:調用的函數引用

poYBAGN7GoOAOxy6AACo9zMJYR0595.png

圖 5:從引用調用

poYBAGN7GoqAaUSlAAIveYQZPpM392.png

圖 6:功能列表 GUI

簡化軟件

通過使用此方法從二進制映像派生靜態調用流程圖,您現在可以更好地了解軟件功能流,并補充源代碼瀏覽,以更深入地了解軟件實現。最重要的是,這種方法可以加快流程并使故障排除軟件更簡單。

審核編輯:郭婷

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 微控制器
    +關注

    關注

    48

    文章

    7651

    瀏覽量

    152124
  • 嵌入式
    +關注

    關注

    5094

    文章

    19178

    瀏覽量

    307733
  • 物聯網
    +關注

    關注

    2914

    文章

    44940

    瀏覽量

    377104
收藏 人收藏

    評論

    相關推薦

    嵌入式機器學習的應用特性與軟件開發環境

    設備和智能傳感)上,這些設備通常具有有限的計算能力、存儲空間和功耗。本文將您介紹嵌入式機器學習的應用特性,以及常見的機器學習開發軟件與開發
    的頭像 發表于 01-25 17:05 ?174次閱讀
    <b class='flag-5'>嵌入式</b>機器學習的應用特性與<b class='flag-5'>軟件</b>開發環境

    E2000 Speedometer測試瀏覽器性能

    的東西更新到Chrome中,是經過Google進行了封閉、定制和優化的版本。 Chrome 瀏覽器瀏覽器基準測Speedometer中的得分和整體性能出色(如下圖)。 (截圖摘自:11款常用
    發表于 01-10 21:33

    Chrome瀏覽器優化Android性能,驍龍8至尊版表現突出

    谷歌近日對Chrome瀏覽器的最新版本進行了重大更新,特別針對Android設備進行了性能優化,特別是對于搭載驍龍8至尊版處理的旗艦
    的頭像 發表于 12-13 14:44 ?424次閱讀

    AWTK 最新動態:支持瀏覽器控件

    導讀AWTK瀏覽器控件,基于webview項目實現,將瀏覽器嵌入到AWTK應用程序中,讓開發者可以方便的集成在線幫助和調用地圖等功能。awtk-widget-web-view是基于webview實現的AWTK
    的頭像 發表于 11-20 01:05 ?275次閱讀
    AWTK 最新動態:支持<b class='flag-5'>瀏覽器</b>控件

    寫一個Chrome瀏覽器插件

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

    TTL電路的故障排除技巧

    的工作原理有一個清晰的理解。TTL電路的基本單元是邏輯門,包括與門、或門、非門等。了解這些基本單元的工作原理和特性,可以幫助我們更快地定位問題。 2. 視覺檢查 在開始故障排除之前,進行
    的頭像 發表于 11-18 10:35 ?484次閱讀

    電抗故障診斷和排除方法是什么?

    電抗是一種常用于電力系統中以限制電流突變和調整電壓的設備。由于其工作環境的嚴酷性和重要性,故障診斷和排除就顯得尤為重要。以下是干
    發表于 11-13 10:32

    什么是嵌入式?一文讀懂嵌入式主板

    在現代科技浪潮中,嵌入式技術已成為支撐各種智能設備和系統運行的核心力量。那么,究竟什么是嵌入式?嵌入式系統,顧名思義,是將計算機的硬件和軟件
    的頭像 發表于 10-16 10:14 ?1602次閱讀

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

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

    如何用python調用瀏覽器的視頻?

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

    Windows 11預覽版安裝受阻,微軟提示更新設備瀏覽器

    該提示翻譯如下:由于安全性考慮,您的設備瀏覽器未能順利連接至認證服務。若您確非惡意行為者,請嘗試更新相關設備瀏覽器,以獲取完整使用體驗
    的頭像 發表于 03-05 14:29 ?1113次閱讀

    嵌入式工程師需要掌握哪些技術?

    Bluetooth、Wi-Fi和LoRa等的了解也是有益的。 5. 調試和故障排除能力:嵌入式系統開發中經常會遇到各種問題和錯誤。因此,具備良好的調試和故障
    發表于 03-04 16:38

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

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

    嵌入式軟件設計的原則分享

    嵌入式軟件開發如果具有更好的閱讀性、擴展性以及維護性,就需要考慮很多因素。今天給大家分享幾個嵌入式軟件設計的原則。
    發表于 02-25 10:54 ?751次閱讀
    <b class='flag-5'>嵌入式</b><b class='flag-5'>軟件</b>設計的原則分享

    嵌入式軟件開發應該掌握哪些知識?

    兩個部分組成,其中嵌入式軟件是指在嵌入式系統中運行的程序,用于控制硬件并提供特定的功能和服務。嵌入式軟件應用廣泛,包括汽車、醫療
    發表于 02-19 11:23
    郑州百家乐官网高手| 百乐门娱乐| 大发888资讯网007| 大发888游戏好吗| 大发888bet下载| 大发888备用a99.com| 真人斗地主| 周口市| 顺义区| 赌场百家乐官网是如何玩| 百家乐官网娱乐平台会员注册 | 百家乐AG| 百家乐那里最好| 大发888娱乐场大发888娱乐场下载| 博彩e族字谜专区| 馆陶县| 百家乐官网局部| 旺财转运24妙法| 线上百家乐玩法| 百家乐桌子租| 七匹狼娱乐城开户| 皇冠网百家乐官网赢钱| 百家乐官网出千工具价格| 百家乐相对策略| 百家乐官网庄闲和收益| 百家乐开户平台| 澳门百家乐官方网站破解百家乐技巧 | 百家乐在线娱乐场| 大发888开户注册| 昌黎县| 肯博百家乐官网的玩法技巧和规则| 百家乐赌场怎么玩| 大发888真钱娱乐| 莒南县| 红桃K百家乐官网的玩法技巧和规则 | 澳门百家乐官网下注最低| 百家乐官网必胜打| 单机百家乐小游戏| 明升备用| 新百家乐官网的玩法技巧和规则 | 大发888娱乐场骗局|