實用技巧:Gdbserver遠端偵錯的具體實現

來源:互聯網
上載者:User

 

採用的是nfs目標板掛載本機目錄的方法,當然首先,你得開通原生nfs共用服務,具體步驟如下:

1、進入/etc目錄,vim exports這個檔案,在裡面添加/home 192.168.0.*(rw,sync)儲存後退出

註:/home 為要共用的檔案夾的名稱,192.168.0.*為本NFS伺服器允許訪問的用戶端ip,若nfs不成功,後面參數rw ro 等標誌對檔案夾操作許可權,sync:資料同步寫入記憶體和硬碟,也可以使用async,此時資料會先暫存於記憶體中,而不立即寫入硬碟。可以將括弧裡面的sync去掉。

2、重新啟動nfs服務,命令為:/sbin/service nfs restart

3、輸入命令route del default來關閉網關(加快mount速度)

4、mount 192.168.0.47(為原生ip):/home /mnt用以測試本機是否開通nfs服務。

cd /mnt目錄下,看mnt下的內容是否與home的內容一致,若一致,表明已經開通nfs服務。

當原生nfs服務開通後,你還需要配置開發板的ip地址,由於各個開發板ip地址配置方法不一樣,所以,假設開發板的ip地址為192.168.2.100.

搭建交叉編譯環境的步驟:

1、一般在安裝linux時候,自動安裝c編譯環境,因此不需要再重新安裝gcc編譯器。

2、安裝交叉編譯器

從ftp://ftp.arm.linux.org.uk/pub/armlinux/toolchain/下載交叉編譯器cross-3.2.tar.bz2, 存放在/usr/local目錄下。

切換致該目錄:

# cd /usr/local

# mkdir arm

然後解壓cross-3.2.tar.bz2:

# tar jxvf cross-3.2.tar.bz2 –C /usr/local/arm

解壓後把/usr/local/arm/usr/local/arm中最後一個arm拷貝到/usr/local,也就是用命令cd /usr/local/arm/usr/local中,用cp -a arm /usr/local把arm拷貝到/usr/local中去。

3、把交叉編譯器的路徑加入到PATH。(兩種方法a,b)

a、# export PATH=$PATH:/usr/local/arm/bin

註:(這隻能在當前的終端下才是有效,)

b、修改/etc/profile 檔案:

# vim /etc/profile

增加路徑設定,在末尾添加如下:

export PATH=$PATH:/usr/local/arm/bin

4、使新的環境變數生效。

# source /etc/profile

5、檢查是否將路徑加入PATH的方法。

# echo $PATH

如果顯示的內容中有/usr/local/arm/bin,說明已經將交叉編譯器的路徑加入PATH。自此,交叉編譯環境安裝完成。

6、測試。

下面我們就來測試一個簡單的例子。

/*Hello.c*/

#include

int main()

{

printf(“hello word!”);

return 0;

}

程式輸好以後確認無誤,儲存。進入程式檔案所在目錄

# arm-linux-gcc hello.c –o hello

(-o 可以理解為“目標為產生”)arm-linux-gcc是第一次出現,有人可能會問這個哪裡來的,不妨開啟剛才安裝的交叉編譯工具目錄/usr/local/arm-linux/arm-linux/bin/可以發現裡面有一個arm-linux-gcc檔案,這個就是針對arm的CPU的gcc編譯器了。以後用其它編譯工具鏈式也可以通過這種方法看看其編譯器是什麼了。編譯好了以後就可以下載到目標機進行測試了。當然也可以先在PC機上測試正誤。用gcc hello.c –o hello就可以產生PC機上程式了,在運行./hello 就可以發現終端顯示hello!字樣。用arm-linux-gcc編譯的程式在PC機上是不能啟動並執行,運行後給出錯誤報表:無法執行二進位檔案。說明經過交叉編譯環境編譯出的檔案是硬體可執行檔二進位代碼檔案.

7、交叉編譯環境搭建成功。

要經行gdbserver遠端偵錯,還必須安裝gdb遠端偵錯工具:

gdb的原始碼包可以從http: //ftp.cs.pu.edu.tw/Linux/sourceware/gdb/releases/下載,最新版本為gdb-6.4。下載到某個目錄,筆者下載到自己的使用者目錄:/home/vicky。

下載完後,進入/home/vicky目錄,配置編譯步驟如下:

#tar jxvf gdb-6.4-tar-bz2

#cd gdb-6.4

#./configure --target=arm-linux --prefix=/usr/local/arm-gdb -v

#make

(這一步的時候可能會有問題,提示一個函數中(具體函數名不記得了)parse error,就是unsigned前邊多了一個”}”,你用vi進入那一行把它刪掉就行了。一般都不會出錯的。)

#make install

#export PATH=$PATH:/usr/local/arm-gdb

進入gdbserver目錄:

#./configure --target=arm-linux –host=arm-linux

#make CC=/usr/local/arm/bin/arm-linux-gcc

(這一步要指定arm-linux-gcc的位置,可能跟你的不一樣)

沒有錯誤的話就在gdbserver目錄下產生gdbserver可執行檔,把它燒寫到flash的根檔案系統分區,或通過nfs mount的方式都可以。只要保證gdbserver能在開發板上運行就行。

下面就可以用gdb+gdbserver調試我們開發板上的程式了。在目標板上運行gdbserver,其實就是在宿主機的minicom下,我的red hat linux裝在vmware下的。我是在minicom下#mount 192.168.2.100:/ /tmp後做的(這裡參數-o nolock可以不加,不加這一步執行得反而更快些),hello和gdbserver都是位於linux根目錄下,把主機根目錄掛在到開發板的/tmp 目錄下。

要進行gdb調試,首先要在目標系統上啟動gdbserver服務。在gdbserver所在目錄下輸入命令:

(minicom下)

#cd /tmp

#./gdbserver 192.168.2.100:2345 hello

192.168.2.100為宿主機IP,在目標系統的2345連接埠開啟了一個調試進程,hello為要調試的程式。

出現提示:

Process /tmp/hello created: pid="80"

Listening on port 2345

(另一個終端下)

#cd /

#export PATH=$PATH:/usr/local/arm-gdb/bin

#arm-linux-gdb hello

(gdb) target remote 192.168.2.223:2345

(192.168.2.223為開發板IP)

出現提示:

Remote debugging using 192.168.2.223:2345

[New thread 80]

[Switching to thread 80]

0x40002a90 in ??()

同時在minicom下提示:

Remot

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.