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

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

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

3天內不再提示

基于Valgrind和在線調試器實現Linux應用程序調試系統的設計

電子設計 ? 來源:微計算機信息 ? 作者:潘竹生,童維勤,周 ? 2020-09-25 10:07 ? 次閱讀

1.引言

隨著嵌入式系統處理能力的顯著提高,系統設計越來越復雜,對軟件調試提出了新的挑戰。傳統的調試技術及工具已經難以滿足嵌入式軟件系統的調試要求。本文介紹了利用工具軟件Valgrind 調試嵌入式Linux 應用程序的技術,嵌入式Linux 繼承了傳統Linux 功能強大、高效穩定等特點,近年來在嵌入式領域取得了飛速的發展,并且成為主流嵌入式操作系統之一。研究嵌入式Linux 應用程序的調試技術,不僅能有效提升系統的穩定性,而且從技術和應用角度而言也具有一定的價值。

嵌入式 Linux 應用程序主要使用c/c++開發,多數語法和語義錯誤可以由編譯器發現,但有些錯誤編譯器無法發現,它們往往在程序運行后表現出來。這些錯誤主要包括:內存泄露、引用未初始化的指針、不恰當釋放內存空間、內存越界訪問以及使用已經釋放的內存空間等等。內存操作在嵌入式編程中大量使用,并且有關內存操作的錯誤經常出現并且難以被發現。這些錯誤都會影響系統性能和穩定性,甚至造成癱瘓,所以必須避免它們在程序中出現。通常采用人工方法查找這些錯誤,當程序規模較大時,工作量將十分巨大,并且效率低下。Valgrind 能夠監視應用程序的運行并且發現上述問題,利用Valgrind 對應用程序進行調試能夠顯著降低人工工作量,提高效率。

2. Valgrind 的工作原理

Valgrind 是運行在Linux 上的多用途代碼剖析和內存調試軟件。主要包括Memcheck、Callgrind、Cachegrind 等工具,每個工具都能完成一項任務調試、檢測或分析。可以檢測內存泄露、線程違例和Cache 的使用等。

Valgrind 基于仿真方式對程序進行調試,它先于應用程序獲取實際處理器的控制權,并在實際處理器的基礎上仿真一個虛擬處理器,并使應用程序運行于這個虛擬處理器之上,從而對應用程序的運行進行監視。應用程序并不知道該處理器是虛擬的還是實際的,已經編譯成二進制代碼的應用程序并不用重新進行編譯,Valgrind 直接解釋二進制代碼使得應用程序基于它運行,從而能夠滴水不漏地檢查內存操作時可能出現的錯誤。在嵌入式應用程序開發中,c 或c++是最為常用的語言,由于這兩種語言非常靈活的特性,使得在編程時很容易出現上述錯誤。因此,為了提高嵌入式系統的可靠性,可以將Valgrind 引入到嵌入式程序的開發過程中,利用它對應用程序進行調試,從而達到高效、準確去除錯誤的目的。

3.Valgrind 在程序排錯中的應用

3.1 嵌入式軟件基本開發流程

嵌入式系統是一個資源受限的系統,直接在嵌入式硬件平臺上進行軟件的開發與調試是不合適的,開發與調試通常需要在PC 機上進行,然后通過交叉編譯,將程序編譯成可以運行在目標平臺上的二進制代碼,最后將代碼下載到目標硬件平臺運行。由于嵌入式Linux 的內核和系統調用與運行在PC 上的Linux 幾乎完全一樣,因此嵌入式Linux應用程序的調試可以在一臺裝有Linux 的PC 機上進行。如果能在PC 機的Linux 系統上正常運行,則在目標平臺上基本也能正常運行。

3.2 調試過程

本文提出了一種利用Valgrind和在線調試器配合使用的嵌入式程序調試方法,利用它可以結合兩種不同軟件調試工具的特點,對復雜的嵌入式軟件系統進行調試。圖1 是嵌入式軟件開發與調試的過程。軟件設計人員利用已有的開發工具編寫源代碼,通過編譯器、匯編器、鏈接實時運行庫文件,生成目標代碼。Valgrind 對目標代碼進行仿真執行,調用相關工具進行調試、分析和監測;調試器通過調試器的JTAG 調試接口下載代碼,同時對微處理器進行控制,設置軟件斷點,單步運行等功能查看程序的運行情況。

基于Valgrind和在線調試器實現Linux應用程序調試系統的設計

這里假設 PC 機所用的處理器是x86 指令系統,目標平臺處理器是ARM 指令系統?;赩algrind 的嵌式程序調試過程包括以下幾個步驟:

(1)在一臺裝有Linux 操作系統的PC 機上安裝ValgrindValgrind

是一個遵循GPL 條例的開源項目,用戶獲取到它的源程序后自行編譯安裝。

獲取到源程序包后,使用“cd”命令進入包含源代碼的目錄;然后輸入“。/configure”進行配置;配置完畢后輸入“make”對源程序進行編譯;編譯完成后執行“make install”將編譯好的程序和一些數據文件安裝到系統的相應位置。至此,Valgrind 安裝完成。

(2)將嵌入式程序的源代碼編譯成運行于x86 處理器的代碼格式

使用當前 PC 機Linux 系統中附帶的gcc 或g++編譯器對源程序進行編譯,如果程序較大,擁有較多源代碼文件,可以通過編寫makefile 文件的方式來對文件進行組織,使用make命令對源程序進行編譯。編譯時給編譯器加上-g 參數,使得編譯器添加調試信息到代碼中。

(3)啟動Valgrind

其中 –leak-check 參數表示讓Valgrind 檢查內存泄露錯誤,其他更多的參數項可以參考Valgrind 的相關文檔。

(4)根據Valgrind 的檢查結果修改源程序

(5)調試完畢后用ARM 編譯器編譯成ARM 處理器的代碼格式

以下幾個小節將通過具體的應用技術來具體說明Valgrind 在嵌入式應用程序調試技術中的應用。

3.3 起重機安全監控系統應用程序的調試

起重機安全監控系統使用 Linux2.6 內核作為操作系統,應用程序使用C++語言開發,通過圖形界面向用戶提供起重機的各種工作情況,如吊臂姿態,吊載重量等等。圖形界面使用Qt 圖形系統開發。程序源代碼*有超過200 處的地方進行了動態內存分配。

將應用程序編譯成可以運行在 x86 平臺上的二進制代碼后,啟動Valgrind 執行應用程序,在執行過程中如果發現錯誤,Valgrind 會將有關信息打印在屏幕上,信息的格式如下所示:

==13380== 40 bytes in 1 blocks are definitely lost in loss record 1 of 1

==13380== at 0x40046EE: malloc (vg_replace_malloc.c:149)

==13380== by 0x804838B: f1 (aaa.c:4)

==13380== by 0x80483FB: main (aaa.c:20)

“==13380==”表示進程號,一般不用考慮;第一行(“Invalid write.。.”)給出了錯誤的種

類,這里指發現內存泄露錯誤。第二行給出了錯誤發生的地址,以及相關函數。第三行給出了發生錯誤所在的函數的名稱。第四行指出發生錯誤的函數被調用的地方在main()函數中。

應用程序使用 Valgrind 進行調試發現了所有內存泄露的故障,根據Valgrind 所打印的提示信息到源代碼中相應位置進行修改,排除故障,使得應用程序的可靠性得到了增強,使得整個起重機安全監控系統能夠非常穩定、可靠的運轉。

4.結語

本文介紹了一個功能強大的工具軟件 Valgrind,它可以檢測多種內存方面的錯誤。內存錯誤是嵌入式程序設計中最常見的錯誤,使用Valgrind 對基于嵌入式Linux 的應用程序進行錯誤檢測,可以迅速準確的檢查出各種致命錯誤,確保及時得到改正,避免在投入運行后出現故障,極大的提高了調試效率。調試工作在PC 機上進行,調試完畢后使用目標平臺處理器的編譯器對源代碼進行交叉編譯,從而生成可以運行在目標硬件平臺上的二進制代碼,整個調試過程非常方便。在資源消耗方面,由于Valgrind 采用虛擬處理器方式運行應用程序,并且使用了V-bit 對每一位數據進行監視,因此使用Valgrind 調試程序時會大量占用內存,并且程序的運行速度要比在實際處理器上運行時的速度慢20 到30 倍。

本文作者的創新點:將Valgrind 工具引入到嵌入式軟件調試中,和常用的嵌入式軟件調試設備有機地結合成一體,能夠迅速準確的查出各種致命的軟件錯誤,提高調試效率,加快產品上市,節省了開發成本,帶來實在的經濟效益。

責任編輯:gt

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

    關注

    5092

    文章

    19177

    瀏覽量

    307686
  • Linux
    +關注

    關注

    87

    文章

    11345

    瀏覽量

    210398
  • 應用程序
    +關注

    關注

    38

    文章

    3292

    瀏覽量

    57917
收藏 人收藏

    評論

    相關推薦

    ?IAR C-SPY為VS Code社區樹立調試新標準

    全球領先的嵌入式系統開發軟件解決方案供應商IAR宣布,對VS Code中的調試擴展IAR C-SPY調試器進行了重大升級。此次升級引入了IAR的Listwindow技術,進一步提升了調試
    的頭像 發表于 12-06 10:27 ?269次閱讀

    MSP調試器用戶指南

    電子發燒友網站提供《MSP調試器用戶指南.pdf》資料免費下載
    發表于 12-05 14:56 ?0次下載
    MSP<b class='flag-5'>調試器</b>用戶指南

    嵌入式工程師都在找的【Linux內核調試技術】建議收藏!

    Linux內核調試器(KDB) KDB是Linux內核的一個補丁,提供了一種在系統運行時對內核內存和數據結構進行檢查的方法。 它允許開發者設置斷點、檢查內存值、單步執行等,從
    發表于 11-28 15:37

    使用Trace32 (Lauterbach) 作為調試器,無法在電路板中獨立運行怎么解決?

    我們使用 Aurix studio 進行開發,使用 Trace32 (Lauterbach) 作為調試器。 現在,當調試器出現時,程序正在運行。 重置電源后,它無法工作。
    發表于 07-04 08:19

    TC3XX只能在連接調試器時啟動,為什么?

    在 AP32555 中,有一章:\"\"當調試器被移除時,設備無法啟動 \"描述了與 BMHD 有關的內容,我發現如果將十六進制文件編入一個沒有 UCB_BMHD 的空
    發表于 07-03 06:53

    做了個DAPLink調試器,最高支持1500V隔離!靜電多不了一點!

    工程名稱:基于AT32F415的隔離DAP-Link調試器前言做了一款隔離DAPLink調試器,最高支持1500V隔離(不接入隔離電源情況下可以達到5KV)。能隔離大部分靜電!基于AT32F415
    的頭像 發表于 06-06 08:05 ?261次閱讀
    做了個DAPLink<b class='flag-5'>調試器</b>,最高支持1500V隔離!靜電多不了一點!

    STM32F103用CAN調試器接到該板子后給其發消息,調試器會顯示總線數據錯誤的原因?

    項目里有個CAN收發相關的板子,用的是STM32F103芯片。在與上位機的CAN交互過程中經常會出現通訊錯誤的情況,表現在上位機發送報文后沒有收到回復。用CAN調試器接到該板子后給其發消息,調試器會顯示總線數據錯誤
    發表于 05-27 07:42

    無法從應用程序連接Aurix 387進行調試,怎么解決?

    你好,我無法從應用程序工作室啟動連接 Aurix 387 進行調試調試器以下列信息結束:Loading failde:在嘗試中化目標內存時發生未知錯誤有人知道嗎?
    發表于 05-21 07:48

    Aurix development studio是否支持GCC調試器?

    當我嘗試使用 Aurix development studio 調試 Aurix 示例時,我發現只有兩個選項 TASKING C/C++ 調試器 winIDEA 調試器 我的問題是,GCC 調
    發表于 05-20 06:57

    如何自制CAN調試器

    candleLight固件還支持BUSMASTER(這個也就很厲害了,用過的都懂),BUSMASTER是一款功能強大的專業級CAN總線調試軟件,不僅能夠應對一般的CAN調試開發,還一個用于設計,監測,分析與模擬CAN網絡的開源的開放式總線PC軟件。
    的頭像 發表于 04-15 11:18 ?1034次閱讀
    如何自制CAN<b class='flag-5'>調試器</b>?

    STM32 SBSFU的APP程序怎么配置在線調試?

    STM32SBSFU的APP程序怎么配置在線調試 目前SBSFU的APP程序都是串口燒錄,直接調試會有異常
    發表于 04-10 06:01

    PLC系統的安裝與調試流程

    ,并對現場經常出現的安裝、調試相關問題,提出探討意見和解決方案。? CRT激光焊接示教系統 合理安排系統安裝與調試程序,是確保高效優質地完成安裝與調
    的頭像 發表于 03-27 17:08 ?921次閱讀
    PLC<b class='flag-5'>系統</b>的安裝與<b class='flag-5'>調試</b>流程

    jlink調試器的工作原理

    我們平時使用的jlink調試器就是使用JTAG接口,JTAG以前是用于測試芯片的一種通信方式,現在部分ARM或者DSP等都存在JTAG接口,這樣我們就可以通過JTAG接口訪問CPU以及其內部狀態信息等。
    的頭像 發表于 03-08 12:32 ?3322次閱讀
    jlink<b class='flag-5'>調試器</b>的工作原理

    應用單片機開發的ST LINK調試器設計制作

    調試ST單片機的過程中,ST-LINK是一個很好使用的調試工具。今天,我們就根據網絡上的設計方案進行簡化,設計制作一個ST LINK調試器,用于之后的單片機開發。
    發表于 03-06 10:26 ?1263次閱讀
    應用單片機開發的ST LINK<b class='flag-5'>調試器</b>設計制作

    調試器連接MCU不穩定怎么辦?

    有沒有小伙伴遇到使用GDlink或者Jlink調試GD32 MCU的時候出現不穩定的情況,剛要發現問題時調試器和MCU斷開連接了,這個時候可能抓狂的心都有了。今天就教給大家幾個提高調試器連接MCU穩定性的方法。
    的頭像 發表于 02-21 09:44 ?1016次閱讀
    <b class='flag-5'>調試器</b>連接MCU不穩定怎么辦?
    主站蜘蛛池模板: 欧美人成网站免费大全 | 亚洲 欧美 综合 | 国产 麻豆 欧美亚洲综合久久 | 国产yw855.c免费观看网站 | 人成xxxwww免费视频 | 国产床戏无遮掩视频播放 | 国内视频一区 | 黄网站在线观看高清免费 | 一区二区三区网站 | 啪啪免费小视频 | 美国色天使 | 四虎影院国产精品 | 天堂在线国产 | 福利在线观看 | 两性色午夜视频免费国产 | 午夜视频在线网站 | 美妇乱人伦性 | 亚洲精品久久久久午夜福 | 99草精品视频 | 国产精品爽爽影院在线 | 午夜伦伦 | 高清视频 一区二区三区四区 | 日本又粗又长一进一出抽搐 | 色噜噜噜噜噜 | 亚洲福利视频一区二区 | 窝窝午夜看片成人精品 | 久久婷婷综合五月一区二区 | 666精品国产精品亚洲 | 看片地址 | 色天天综合久久久久综合片 | 日日操操干干 | 天天干视频网站 | 岛国毛片一级一级特级毛片 | 在线看视频你懂的 | 一级做a爱免费观看视频 | 手机看片a永久免费看大片 手机毛片 | 九九久久国产精品大片 | 222在线视频免费观看 | 久久精品亚洲 | 亚洲国产成人精品女人久久久 | 久久精品国产亚洲综合色 |