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

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

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

基于Valgrind和在線調(diào)試器實現(xiàn)Linux應(yīng)用程序調(diào)試系統(tǒng)的設(shè)計

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

1.引言

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

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

2. Valgrind 的工作原理

Valgrind 是運行在Linux 上的多用途代碼剖析和內(nèi)存調(diào)試軟件。主要包括Memcheck、Callgrind、Cachegrind 等工具,每個工具都能完成一項任務(wù)調(diào)試、檢測或分析??梢詸z測內(nèi)存泄露、線程違例和Cache 的使用等。

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

3.Valgrind 在程序排錯中的應(yīng)用

3.1 嵌入式軟件基本開發(fā)流程

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

3.2 調(diào)試過程

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

基于Valgrind和在線調(diào)試器實現(xiàn)Linux應(yīng)用程序調(diào)試系統(tǒng)的設(shè)計

這里假設(shè) PC 機所用的處理器是x86 指令系統(tǒng),目標平臺處理器是ARM 指令系統(tǒng)。基于Valgrind 的嵌式程序調(diào)試過程包括以下幾個步驟:

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

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

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

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

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

(3)啟動Valgrind

其中 –leak-check 參數(shù)表示讓Valgrind 檢查內(nèi)存泄露錯誤,其他更多的參數(shù)項可以參考Valgrind 的相關(guān)文檔。

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

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

以下幾個小節(jié)將通過具體的應(yīng)用技術(shù)來具體說明Valgrind 在嵌入式應(yīng)用程序調(diào)試技術(shù)中的應(yīng)用。

3.3 起重機安全監(jiān)控系統(tǒng)應(yīng)用程序的調(diào)試

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

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

==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.。.”)給出了錯誤的種

類,這里指發(fā)現(xiàn)內(nèi)存泄露錯誤。第二行給出了錯誤發(fā)生的地址,以及相關(guān)函數(shù)。第三行給出了發(fā)生錯誤所在的函數(shù)的名稱。第四行指出發(fā)生錯誤的函數(shù)被調(diào)用的地方在main()函數(shù)中。

應(yīng)用程序使用 Valgrind 進行調(diào)試發(fā)現(xiàn)了所有內(nèi)存泄露的故障,根據(jù)Valgrind 所打印的提示信息到源代碼中相應(yīng)位置進行修改,排除故障,使得應(yīng)用程序的可靠性得到了增強,使得整個起重機安全監(jiān)控系統(tǒng)能夠非常穩(wěn)定、可靠的運轉(zhuǎn)。

4.結(jié)語

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

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

責(zé)任編輯:gt

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

    關(guān)注

    5059

    文章

    18973

    瀏覽量

    302062
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11208

    瀏覽量

    208721
  • 應(yīng)用程序
    +關(guān)注

    關(guān)注

    37

    文章

    3237

    瀏覽量

    57547
收藏 人收藏

    評論

    相關(guān)推薦

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

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

    無法從應(yīng)用程序連接Aurix 387進行調(diào)試,怎么解決?

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

    Aurix development studio是否支持GCC調(diào)試器?

    當(dāng)我嘗試使用 Aurix development studio 調(diào)試 Aurix 示例時,我發(fā)現(xiàn)只有兩個選項 TASKING C/C++ 調(diào)試器 winIDEA 調(diào)試器 我的問題是,GCC 調(diào)
    發(fā)表于 05-20 06:57

    如何自制CAN調(diào)試器?

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

    STM32 SBSFU的APP程序怎么配置在線調(diào)試?

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

    jlink調(diào)試器的工作原理

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

    應(yīng)用單片機開發(fā)的ST LINK調(diào)試器設(shè)計制作

    調(diào)試ST單片機的過程中,ST-LINK是一個很好使用的調(diào)試工具。今天,我們就根據(jù)網(wǎng)絡(luò)上的設(shè)計方案進行簡化,設(shè)計制作一個ST LINK調(diào)試器,用于之后的單片機開發(fā)。
    發(fā)表于 03-06 10:26 ?972次閱讀
    應(yīng)用單片機開發(fā)的ST LINK<b class='flag-5'>調(diào)試器</b>設(shè)計制作

    調(diào)試器連接MCU不穩(wěn)定怎么辦?

    有沒有小伙伴遇到使用GDlink或者Jlink調(diào)試GD32 MCU的時候出現(xiàn)不穩(wěn)定的情況,剛要發(fā)現(xiàn)問題時調(diào)試器和MCU斷開連接了,這個時候可能抓狂的心都有了。今天就教給大家?guī)讉€提高調(diào)試器連接MCU穩(wěn)定性的方法。
    的頭像 發(fā)表于 02-21 09:44 ?844次閱讀
    <b class='flag-5'>調(diào)試器</b>連接MCU不穩(wěn)定怎么辦?

    如何使用linux下gdb來調(diào)試python程序

    如何使用linux下gdb來調(diào)試python程序? 在Linux下,可以使用GDB(GNU調(diào)試器)來調(diào)試
    的頭像 發(fā)表于 01-31 10:41 ?2371次閱讀

    使用Minwiggler調(diào)試器報錯的原因?

    根據(jù)我的理解,我有英飛凌 A2G TC375LK 套件的 aurix 評估板,它內(nèi)置了調(diào)試器。 我正在使用 Minwiggler 調(diào)試器。 但是當(dāng)我嘗試調(diào)試時,它給出了錯誤。 這個調(diào)試器
    發(fā)表于 01-26 07:22

    TLE9869QXA20可以使用ULINK2/ME Cortex調(diào)試器進行調(diào)試嗎?

    我正在使用TLE9869QXA20定制板,它沒有針對我的應(yīng)用程序的內(nèi)部調(diào)試器,我可以使用 ULINK2/ME Cortex 調(diào)試器進行調(diào)試嗎? 如果是,您能否幫助我處理與定制板的接口和
    發(fā)表于 01-23 07:34

    MPLAB? PICkit? 4 在線調(diào)試器用戶指南

    電子發(fā)燒友網(wǎng)站提供《MPLAB? PICkit? 4 在線調(diào)試器用戶指南.pdf》資料免費下載
    發(fā)表于 01-07 10:57 ?6次下載

    斷開調(diào)試器連接的限制添加

    電子發(fā)燒友網(wǎng)站提供《斷開調(diào)試器連接的限制添加.pdf》資料免費下載
    發(fā)表于 12-21 10:24 ?0次下載
    斷開<b class='flag-5'>調(diào)試器</b>連接的限制添加

    USB調(diào)試模式是什么意思?USB調(diào)試模式有什么用?

    上進行諸如安裝應(yīng)用程序、查看設(shè)備日志、調(diào)試應(yīng)用程序等操作。 USB調(diào)試模式有以下幾個主要用途: 1. 應(yīng)用程序開發(fā):開發(fā)人員可以使用USB
    的頭像 發(fā)表于 12-11 11:06 ?1w次閱讀

    下一代調(diào)試器如何加速代碼開發(fā)

    微控制調(diào)試器和相關(guān)工具對于從事嵌入式系統(tǒng)的開發(fā)人員來說至關(guān)重要。它們幫助開發(fā)人員查找和修復(fù)錯誤、測試代碼和優(yōu)化性能。高級調(diào)試功能對生產(chǎn)力產(chǎn)生了重大影響,并可以縮短開發(fā)時間。許多新工具
    的頭像 發(fā)表于 11-23 16:31 ?545次閱讀