《電子技術應用》
您所在的位置:首頁 > 通信與網絡 > 設計應用 > 在VIM中的嵌入式軟件調試
在VIM中的嵌入式軟件調試
電子市場
摘要: GNU免費提供了一整套工具鏈,為嵌入式Linux程序的開發和調試提供了完整的支持。其強大的gdb調試工具可以方便地對嵌入式平臺上的程序進行跟蹤調試;而Linux下強悍的VIM編輯器,不僅可以方便地調用make文件對代碼進行編譯,而且通過腳本的配置還可輕松地成為高效的代碼編輯環境。流傳著這樣一種說法,“世界上的程序員分三種,一種使用Emacs,一種使用VIM,剩余的是其他。”不去辯論這句話的對與錯,單純從字面意義上來理解,也足見VIM的魅力了。因此,在VIM中實現對嵌入式軟件的調試,我們便得到了一個高效、穩定的嵌入式Linux的開發環境。
關鍵詞: GNU 嵌入式 Linux VIM
Abstract:
Key words :

   引言

  GNU免費提供了一整套工具鏈,為嵌入式Linux程序的開發和調試提供了完整的支持。其強大的gdb調試工具可以方便地對嵌入式平臺上的程序進行跟蹤調試;而Linux下強悍的VIM編輯器,不僅可以方便地調用make文件對代碼進行編譯,而且通過腳本的配置還可輕松地成為高效的代碼編輯環境。流傳著這樣一種說法,“世界上的程序員分三種,一種使用Emacs,一種使用VIM,剩余的是其他。”不去辯論這句話的對與錯,單純從字面意義上來理解,也足見VIM的魅力了。因此,在VIM中實現對嵌入式軟件的調試,我們便得到了一個高效、穩定的嵌入式Linux的開發環境。

  1  gdb對嵌入式軟件的調試模式

  許多非Linux的嵌入式系統已經在使用gdb與gdb stub對目標板進行遠程“交叉調試”;然而,因為Linux內核實現了ptrace()系統調用,所以在對嵌入式應用程序進行調試的時候并不需要gdb stub,而采用gdb套件提供的gdb服務器來對目標板上的嵌入式應用程序進行調試。

  目標板上的gdb服務端gdbserver與主機上的gdb調試器的通信方式主要有兩種:使用串口通信的“交叉串行連接”和使用網口的“TCP/IP”聯機。鑒于PC端的方便性以及串口資源有限,尤其是現在的筆記本電腦甚至已經不存在串口,所以,大多采用TCP/IP方式,即PC主機與目標板通過網線直連或者PC機與目標板通過路由或者hub等組成局域網通信。這種調試模式如圖1所示。

  2  在VIM中實現對嵌入式軟件的調試

  我們知道,gdb的功能雖然強大,但由于其基于命令行的操作,所以調試過程不直觀,而且Windows下的調試環境集調試與代碼編輯為一體,當出現bug的時候,可以方便地對源代碼進行修改,相比而言,gdb在這方面又有些失色。既然VIM和gdb的功能如此強大,又完全免費,而且完全適合嵌入式這種特殊的開發模式,那么有沒有將二者強強聯合的方法呢?有,那就是vimgdb。

  vimgdb是給VIM提供一個可選特性的補丁。它可以在VIM編輯器里提供完整的gdb調試器支持,比如設置斷點、查看變量值、gdb命令補全等等,并且這些操作可以在VIM中直觀地顯示出來。下面闡述在VIM中實現對嵌入式軟件調試的具體過程。

  2.1  系統環境及所用軟件包版本

  PC操作系統:Ubuntu8.10。

  PC編譯器:GNU gcc4.3.1。

  圖1  TCP/IP聯機的嵌入式軟件調試模式

  PC調試器:GNU gdb6.8。

  目標板Linux內核:2.6.13。

  目標板CPU:S3C2440(ARM9架構)。

  交叉編譯器:armlinuxgcc3.4.1。

  交叉調試器:自編譯GNU gdb6.8。

  目標板gdb服務端:自編譯 GNU gdbserver6.8。

  跨平臺開發工具路徑:~/buildtools/armlinux,且已經設置好系統路徑變量。

  測試代碼及程序路徑:~/test,包含程序代碼test.c及Makefile。

  所用軟件包存放路徑:~/down。

  所用軟件包:VIM編輯器源碼vim7.1.tar.bz2、vimgdb711.13.tar.gz、GNU gdb源碼gdb6.8.tar.bz2。

  2.2  對VIM源碼打vimgdb補丁并編譯安裝

  ① 運行下面的命令,解壓VIM源碼及vimgdb補丁文件,并對VIM源碼打補丁:

  cd ~/down

  tar jxvf vim7.1.tar.bz2

  tar zxvf vimgdb711.13.tar.gz

  patch d vim71 backup p0 < vimgdb/vim71.diff

  ② 運行下面命令,對VIM編譯器進行編譯和安裝:

  cd ~/down/vim71/src

  make

  make install

  執行完上述操作后,VIM將會被安裝在/usr/local路徑下。如果想修改安裝路徑,可在上述的編譯安裝前,打開~/down/vim71/src/Makefile文件的862行安裝路徑選項并修改。如將VIM安裝在/usr路徑下,則將 862 #prefix = $(HOME)修改為862 prefix = /usr。

  ③ 安裝vimgdb的runtime文件,運行下面的命令:

  cd ~/down/vimgdb

  tar zxfv vimgdb_runtime.tgz C /usr/share/vim/vimfiles

  2.3  建立交叉調試嵌入式軟件的gdb組件

  ① 編譯嵌入式gdb調試器服務端gdbserver,運行如下的命令:

  cd ~/down/gdb6.8/gdb/gdbserver

  ./cONfigurehost=armlinux target=armlinux

  CC=armlinuxgcc make

  將當前目錄下的gdbserver拷貝到目標板文件系統的/bin目錄下,以備交叉調試用。

  ② 編譯安裝交叉調試器gdb,運行如下命令:

  cd ~/down/gdb6.8

  ./configure target=armlinux prefix=/home/popeye/buildtools/armlinux/

  注意,這里的prefix的值必須填寫絕對路徑,而不能用“ ~”來替代用戶路徑/home/popeye,否則會提示prefix路徑賦值錯誤。然后運行:

  make

  這個過程中,可能會出現圖2所示的錯誤。

  出現這種情況的原因是,編譯規則中選擇了警告選項“Werror”。它會將所有的警告轉變為錯誤,而且出現的有關“getwd”函數的提示信息表明,這里編譯器檢測到的應該是一個“警告”,而不是真正的語法錯誤。所以,需改正編譯選項:

  cd~/down/gdb6.8/gdb

  gedit Makefile

  注意,此處的Makefile是在執行完上述的make命令后才產生的,在最初的代碼包里不含有這個文件。對文件的145行進行修改,去掉WERROR_CFLAGS的賦值,即將“145 WERROR_CFLAGS = Werror”修改成“145 WERROR_CFLAGS =”。然后:

  cd ~/down/gdb6.8

  make

  make install

  圖2  make過程中的錯誤提示

  最后進入~/buildtools/armlinux/bin中,發現交叉調試器armlinuxgdb已經存在了。

  2.4  在VIM中實現對嵌入式軟件調試前的準備

  在嵌入式軟件開發過程中的習慣做法是: 首先,在PC機上編譯調試程序,如果在PC機上運行正常,再進行交叉編譯。然后,將軟件移植到目標板上,如果在目標板上出現bug,再用交叉調試器armlinuxgdb進行調試。

  簡而言之,對嵌入式軟件的調試過程包含兩個部分:PC機上調試部分和嵌入式平臺上的調試部分。在這個過程中,可能既用到PC機上的調試器gdb,又用到交叉調試器armlinuxgdb,而對應的是同一個源代碼程序和運行在不同平臺上的兩個可執行程序。同時涉及兩個調試器轉換的問題,但vimgdb只能對字符串為“gdb”的系統命令進行調用。

  下面,將這個比較困難的問題簡單化:

  ① 編輯適用的Makefile,控制生成對應不同平臺的可執行程序:

  cd ~/test

  其中,test.c為實驗代碼,Makefile為編譯規則,我們簡單編寫Makefile的內容為:

  testpc: test.c

  gcc g Wall o testpc test.c

  testem: test.c

  armlinuxgcc g Wall o testem test.C

  當執行“make testpc”命令時,就會生成可運行在PC機上的可執行程序;執行“make testem”則生成可運行在嵌入式目標板上的可執行程序。

  ② 修改vimgdb的快捷鍵映射腳本,在VIM中實現PC調試器與交叉調試器的輕松切換。

  首先,針對vimgdb只能對字符串為“gdb”的系統命令進行調用,做如下的工作:

  mv /usr/bin/gdb /usr/bin/gdbpc

  cd ~/buildtools/armlinux/bin

  ln s /usr/bin/gdbpc gdb

  由于已經將~/buildtools/armlinux/bin添加到了系統路徑里面,所以執行完上述操作后,在任何時候,運行“gdb”命令時,真正運行的調試器取決于這里gdb所連接的調試器。

  其次,編輯文件/etc/vim/macros/gdb_mappings.vim。主要修改和添加的部分為:

  a. 添加調試器轉換函數,并設置轉換開關為大寫“E”鍵(Shift+E實現):

  let s:emOS_k = 1

  nmap E :call emOS()

  function! s:emOS()

  if s:emOS_k

  let s:emOS_k = 0

  exec ":!ln sf ~/buildtools/armlinux/bin/armlinuxgdb ~/buildtools/armlinux/bin/gdb"

  echohl ErrorMsg

  echo "NOW! Gdb is ready for Embedded System !!!"

  echohl None

  else

  let s:emOS_k = 1

  exec ":!ln sf /usr/bin/gdbpc ~/buildtools/armlinux/bin/gdb"

  echohl ErrorMsg

  echo "Gdb is ready for PC,, Now"

  echohl None

  endif

  Endfunction

  b. 在語句if s:gdb_k行下添加代碼:

  nmap :bel 25vsplit gdbvariables

  nunmap E

  即在進入調試狀態后,屏蔽掉調試器轉換快捷鍵E,并設置快捷鍵F8來顯示變量值監測窗口。

  c. 在let s:gdb_k = 1行下添加代碼:

  exec ":!ln sf /usr/bin/gdbpc ~/buildtools/armlinux/bin/gdb"

  nmap E :call emOS()

  即在退出調試狀態后,還原gdb命令為gdbpc的調用,并還原“E”的調試器轉換開關作用。

  d. 在/etc/vim/vimrc中添寫語句:

  run macros/gdb_mappings.vim

  使得啟動vim后,便會在vim中啟動對gdb進行調用的快捷鍵映射。

  至于在gdb_mappings.vim中具體設定的其他快捷鍵,由讀者自己分析或設定即可。

  2.5  在VIM中對嵌入式軟件進行調試

  下面設定目標板上的嵌入式軟件調試時所用的快捷鍵: E為調試器轉換開關;F9為進入調試模式;F8為開啟變量監視窗口;空格鍵為開啟命令行輸入窗口;調試模式為PC通過超級終端對嵌入式目標板進行輸入輸出,Ubuntu8.10通過TCP/IP方式對嵌入式軟件進行調試;PC機Linux IP為222.31.51.147;目標板IP為222.31.51.180;調試連接端口為1234。

  ① 用VIM打開~/test/test.c,運行命令“:make testem”,將生成的testem文件拷貝到嵌入式平臺的文件系統下,并在嵌入式平臺運行命令,指定等待連接的交叉調試器地址、連接端口以及要調試的嵌入式程序:

  gdbserver 222.31.51.147:1234 testem

  嵌入式端會出現如下的類似提示信息,進入等待連接狀態:

  Process testem created; pid = 801

  Listening on port 1234

  ② 按下大寫“E”鍵(Shift+按鍵E),根據VIM窗口下方的提示信息,確定所選調試器。

  提示信息為“NOW! Gdb is ready for Embedded System!!!”或者“Gdb is ready for PC,, Now”。

  ③ 按下F9,在出現的命令窗口輸入命令“file testem”后,會在VIM中的另一個窗口出現以下類似的調試信息:

  GNU gdb 6.8

  Copyright (C) 2008 Free Software Foundation, Inc.

  ……

  This GDB was configured as "host=i686pclinuxgnu target=armlinux".

  (gdb) file testem

  Reading symbols from /home/popeye/test/testem…done.

  (gdb)

  可以發現,在VIM中已經成功調用交叉調試器armlinuxgdb了。以后的調試命令,都是通過先按下空格鍵,調出命令窗口,輸入命令,回車后傳遞給調試器。

  按下空格,在命令窗口輸入命令,連接嵌入式目標板端:

  target remote 222.31.51.180:1234

  此時,VIM中的調試信息窗口出現信息:

  (gdb) target remote 222.31.51.180:1234

  Remote debugging using 222.31.51.180:1234

  [New Thread 801]

  0x40000dd0 in ?? () from /lib/ldlinux.so.2

  (gdb)

  而在嵌入式端出現提示信息:

  ProcESS testem created; pid = 801

  Listening on port 1234

  Remote debugging from host 222.31.51.147

  至此,PC交叉調試器與嵌入式軟件的連接完成,現在可以在VIM中對程序運行進行例如斷點一類的設置動作;而嵌入式軟件的輸入輸出,需要在嵌入式端來完成。這里先通過命令對代碼設置斷點,然后用命令continue繼續程序運行(注意,這里不用run開始,因為當調試器與嵌入式端連接完成時,被調試的嵌入式軟件已經開始運行),用命令next對程序實現步進調試。調試過程中的VIM如圖3所示。

  圖3  正在進行交叉調試的VIM

  圖中測試代碼要實現的是讓用戶輸入5個數,然后經過排序后輸出。對應的輸入輸出在嵌入式端體現出來。對應圖3,此時在嵌入式端需要進行輸入動作:

  Listening on port 1234

  Remote debugging from host 222.31.51.147

  Enter 10 numbers:

  a[0]=25

  a[1]=56

  a[2]=……

  從圖3中可以直觀地看清斷點設置在哪里,程序現在步進到哪里。當程序第一次運行到圖3中的17行時,按下F8鍵,開啟變量值觀測窗口,然后先后執行3個命令“cr i”、“cr j”、“cr a[i]”,這樣,就可以在變量觀測窗口實時地監測變量的數值了,如圖4所示。

  圖4  帶實時變量值監測窗口的VIM

  這種調試方式提供對gdb所有命令功能的支持,而且當發現bug時,可以通過q命令終止調試,然后按F9跳出調試模式,就可以繼續對源代碼進行修改。

  至于在這之前的嵌入式軟件在本地PC機上的調試,其過程比起調試運行在嵌入式設備上的軟件來講,只少了個遠程連接的過程,其余調試過程都一樣。至此,實現了在VIM中對嵌入式軟件的調試。

  3 結語

  嵌入式Linux系統的廣泛應用,對嵌入式軟件開發和調試環境的效率提出了更高的要求。GNU所提供的支持交叉編譯與調試的工具鏈是一個很好的選擇,尤其是其中的gdb調試工具完全滿足嵌入式軟件“交叉編譯”的這種特殊需要;而且,功能強大的VIM編輯器又可實現對gdb調試器的整合,從而在VIM中實現了對嵌入式軟件的調試功能。通過上面的實例可以看到,在VIM中對嵌入式軟件進行調試更加直觀和高效,從而也促使嵌入式軟件的開發效率得到了質的提高。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
今天的高清视频免费播放成人| 亚洲福利视频网站| 久久亚洲一区| 性伦欧美刺激片在线观看| 中文久久精品| 野花国产精品入口| 日韩亚洲欧美成人| 亚洲美洲欧洲综合国产一区| 亚洲欧洲日夜超级视频| 亚洲国产精品国自产拍av秋霞| 久久av免费一区| 欧美在线视频观看免费网站| 欧美一级免费视频| 欧美中文在线观看| 久久精品二区三区| 亚洲国产精品精华液网站| 亚洲国产高潮在线观看| 亚洲第一福利在线观看| 91久久久久久| 日韩视频免费| 中文精品一区二区三区| 亚洲字幕在线观看| 欧美在线国产| 久久免费高清视频| 欧美成人在线免费观看| 欧美大片va欧美在线播放| 欧美韩日一区二区三区| 欧美日韩一区二区三区四区在线观看 | 免费观看久久久4p| 欧美精品色网| 国产精品www| 国产美女精品视频免费观看| 国产一区二区福利| 亚洲国产色一区| 99国产一区二区三精品乱码| 亚洲婷婷综合色高清在线 | 亚洲精品中文在线| 亚洲一本大道在线| 欧美在线一二三四区| 另类酷文…触手系列精品集v1小说| 欧美成人午夜影院| 国产精品国产三级国产a| 国产麻豆综合| 亚洲国产精品黑人久久久| 一区二区三区精品久久久| 小黄鸭精品aⅴ导航网站入口| 亚洲第一在线综合网站| 中文国产成人精品| 久久精品一区二区三区不卡牛牛| 欧美成人按摩| 国产精品国产三级国产aⅴ入口| 国产一区二区三区久久悠悠色av| 在线观看欧美激情| 亚洲特级毛片| 亚洲区在线播放| 午夜激情亚洲| 欧美jjzz| 国产精品丝袜白浆摸在线| 亚洲二区在线视频| 亚洲天堂av在线免费| 亚洲第一精品福利| 亚洲女女女同性video| 久久综合婷婷| 国产精品网站在线播放| 永久域名在线精品| 亚洲字幕在线观看| 日韩午夜免费| 久久久噜噜噜久久中文字幕色伊伊| 欧美日韩精品免费观看视一区二区 | 午夜综合激情| 亚洲视频你懂的| 免费短视频成人日韩| 国产精品一区三区| 日韩午夜在线电影| 久久精品99| 午夜精品久久久久| 欧美日韩国产首页| 激情综合色综合久久| 亚洲少妇最新在线视频| 亚洲三级网站| 久久久久青草大香线综合精品| 欧美性一二三区| 91久久在线观看| 亚洲国产精品www| 欧美在线免费观看| 欧美日韩一区二区高清| 亚洲国产高清一区| 亚洲第一黄网| 久久激情综合| 国产精品区一区二区三区| 91久久综合亚洲鲁鲁五月天| 亚洲国产成人在线| 久久精品国产精品| 国产精品视频网| 一区二区av在线| 99国内精品久久| 欧美国产综合一区二区| 在线成人av| 久久成人18免费观看| 欧美在线1区| 国产精品久久久久久久电影| 久久精品一区二区三区不卡牛牛| 亚洲天堂黄色| 亚洲精品国产视频| 老司机免费视频一区二区| 国产麻豆精品视频| 亚洲图片自拍偷拍| 亚洲性色视频| 欧美日韩免费观看一区=区三区| 亚洲精品欧美极品| 亚洲精品自在久久| 欧美黑人国产人伦爽爽爽| 在线观看av不卡| 亚洲高清电影| 久久这里只有| 伊人久久av导航| 亚洲电影免费在线观看| 久久久综合网站| 国内激情久久| 亚洲激情一区二区| 欧美r片在线| 亚洲国产精品一区二区第四页av| 国产精品视频免费在线观看| 亚洲一区二区三区影院| 午夜激情久久久| 国产美女精品视频免费观看| 国产一区在线播放| 在线中文字幕一区| 亚洲女性喷水在线观看一区| 国产精品大片免费观看| 亚洲激情视频在线| 亚洲免费视频中文字幕| 国产精品久久久久影院色老大| 亚洲伊人色欲综合网| 欧美中文日韩| 尤物九九久久国产精品的特点| 亚洲人成绝费网站色www| 欧美国产日韩亚洲一区| 日韩亚洲欧美一区二区三区| 亚洲欧美另类中文字幕| 国产欧美日韩三级| 久久精品首页| 欧美激情一区二区在线| 99视频有精品| 久久av免费一区| 极品少妇一区二区三区| 亚洲免费成人| 国产精品久久久亚洲一区 | 亚洲精品乱码久久久久久日本蜜臀 | 亚洲国产高清一区二区三区| 9久草视频在线视频精品| 欧美性感一类影片在线播放| 亚洲欧美日韩电影| 美女精品在线观看| 一本久久a久久精品亚洲| 篠田优中文在线播放第一区| 国一区二区在线观看| 99ri日韩精品视频| 国产精品资源在线观看| 亚洲激情影院| 国产精品成人一区二区三区吃奶 | 亚洲国产精品免费| 亚洲伊人观看| 一区三区视频| 亚洲一区二区三区视频播放| 国内自拍亚洲| 亚洲一区二区三区高清| 好吊一区二区三区| 亚洲亚洲精品三区日韩精品在线视频 | 亚洲主播在线| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲伦理精品| 久久精品综合网| 99re66热这里只有精品3直播| 久久精品30| 日韩视频精品在线观看| 久久精品一区二区三区中文字幕| 亚洲精品一区二| 久久久在线视频| 亚洲视频电影在线| 欧美777四色影视在线| 亚洲亚洲精品在线观看 | 欧美日韩三级一区二区| 久久av在线看| 国产精品v欧美精品∨日韩| 亚洲韩国一区二区三区| 国产精品蜜臀在线观看| 亚洲人成在线观看| 国产视频一区二区三区在线观看| 一区二区欧美国产| 一区二区在线免费观看| 性亚洲最疯狂xxxx高清| 亚洲精品国精品久久99热| 久久久亚洲综合| 亚洲一区二区三区在线| 欧美日韩视频一区二区三区| 久久精品亚洲| 国产日韩在线播放| 亚洲在线成人精品| 亚洲人成人99网站|