基于JTAG的ARM芯片系統(tǒng)調(diào)試
隨著嵌入式處理器性能的逐步提高,運(yùn)算速度越來越快、處理的數(shù)據(jù)量越來越大,傳統(tǒng)的調(diào)試方法如ROM駐留監(jiān)控程序以及串口調(diào)試工具已經(jīng)不能滿足要求。ARM處理器采用一種基于JTAG的ARM的內(nèi)核調(diào)試通道,它具有典型的ICE功能,基于ARM的包含有Embedded ICE(嵌入式在線仿真器)模塊的系統(tǒng)芯片通過JTAG端口與主計(jì)算機(jī)連接。通過配置支持正常的斷點(diǎn)、觀察點(diǎn)以及處理器和系統(tǒng)狀態(tài)訪問,完成調(diào)試。為了對(duì)代碼進(jìn)行實(shí)時(shí)跟蹤,ARM的提供了嵌入式跟蹤單元(Embedded Trace Macrocell),對(duì)應(yīng)用程序的調(diào)試將更加全面。
2 JTAG邊界掃描原理
“JTAG邊界掃描”或IEEE1149標(biāo)準(zhǔn)[1]是由“測試聯(lián)合行動(dòng)組”(Joint Test Action Group,簡稱JTAG)開發(fā)的針對(duì)PCB的“標(biāo)準(zhǔn)測試訪問接口和邊界掃描結(jié)構(gòu)”的標(biāo)準(zhǔn)。這個(gè)標(biāo)準(zhǔn)是ARM處理器調(diào)試的基礎(chǔ)。
2.1 硬件電路
JTAG邊界掃描測試接口的一般結(jié)構(gòu)[2]如圖1所示。
JTAG邊界掃描硬件電路主要由三部分構(gòu)成:
1) TAP控制器。測試訪問端口(TAP)控制器,是由TMS控制狀態(tài)轉(zhuǎn)換的狀態(tài)機(jī)。
2) 指令寄存器。用于存儲(chǔ)JTAG邊界掃描指令,通過它可以串行的輸入并執(zhí)行各種操作指令。
3) 數(shù)據(jù)寄存器。特定芯片的行為由測試指令寄存器的內(nèi)容決定。測試指令寄存器可用來選擇各種不同的數(shù)據(jù)寄存器。
2.2 邊界掃描測試信號(hào)
支持這個(gè)測試標(biāo)準(zhǔn)的芯片必須提供5個(gè)專用信號(hào)接口:
·TRST:測試復(fù)位輸入信號(hào),低電平有效,為TAP控制器提供異步初始化信號(hào)。
·TCK:JTAG測試時(shí)鐘,獨(dú)立于任何系統(tǒng)時(shí)鐘,為TAP控制器和寄存器提供測試參考。
·TMS:TAP控制器的測試模式選擇信號(hào),控制測試接口狀態(tài)機(jī)的操作。
·TDI:JTAG指令和數(shù)據(jù)寄存器的串行輸入端,給邊界掃描鏈或指令寄存器提供數(shù)據(jù)。
·TDO:TAG指令和數(shù)據(jù)寄存器的串行輸出。
2.3 指令
JTAG測試系統(tǒng)是通過向指令寄存器送入指令,然后使用數(shù)據(jù)寄存器進(jìn)行測試。測試指令說明要進(jìn)行的測試種類及測試要使用的數(shù)據(jù)寄存器。測試指令分為公開指令和私有指令。公開指令已經(jīng)定義且用于通用測試。私用指令用于片上的專用測試,測試標(biāo)準(zhǔn)沒有規(guī)定如何使用私有指令。測試標(biāo)準(zhǔn)支持的較小集的公開指令有:
·BYPASS:器件將TDI經(jīng)一個(gè)時(shí)鐘延時(shí)連接到TDO,用于同一個(gè)測試環(huán)中其它器件的測試。
·EXTEST:將邊界掃描寄存器連接到TDI和TDO之間,用于支持板級(jí)連接測試。
·IDCODE:將ID寄存器連接到TDI和TDO之間。通過它可以讀出器件ID(廠家賦與的固定標(biāo)識(shí),包括產(chǎn)品編號(hào)及版本碼)。
·INTEST:將邊界掃描寄存器連接到TDI和TDO之間。
3 EmbeddedICE
ARM的EmbeddedICE調(diào)試結(jié)構(gòu)[3]是一種基于JTAG的ARM的內(nèi)核調(diào)試通道,它是基于JTAG測試端口的擴(kuò)展,引入了附加的斷點(diǎn)和觀測點(diǎn)寄存器,這些數(shù)據(jù)寄存器可以通過專用JTAG指令來訪問,一個(gè)跟蹤緩沖器也可用相似的方法訪問。ARM核周圍的掃描路徑可以將指令加入ARM流水線并且不會(huì)干擾系統(tǒng)的其它部分。這些指令可以訪問及修改ARM和系統(tǒng)的狀態(tài)。由于EmbeddedICE條件斷點(diǎn),單步運(yùn)行等功能的實(shí)現(xiàn)是基于片上JTAG測試訪問端口進(jìn)行調(diào)試,芯片不需要增加額外的引腳,避免使用笨重的、不可靠的探針接插設(shè)備完成調(diào)試。芯片中的調(diào)試模塊與外部的系統(tǒng)時(shí)序分開,可以直接運(yùn)行在芯片內(nèi)部的獨(dú)立時(shí)鐘速度。
3.1 硬件結(jié)構(gòu)
EmbeddedICE模塊包括兩個(gè)觀察點(diǎn)寄存器和控制與狀態(tài)寄存器,還包括一個(gè)Debug comms端口。當(dāng)?shù)刂贰?shù)據(jù)和控制信號(hào)與觀察點(diǎn)寄存器的編程數(shù)據(jù)相匹配時(shí),也就是觸發(fā)條件滿足時(shí),觀察點(diǎn)寄存器可以中止處理器。由于比較是在屏蔽控制下進(jìn)行的,因此當(dāng)ROM或RAM中的一條指令執(zhí)行時(shí),任何一個(gè)觀察點(diǎn)寄存器可配置為能夠中止處理器的斷點(diǎn)寄存器。
1) 觀察點(diǎn)
每個(gè)觀察點(diǎn)皆可以觀察ARM地址總線、數(shù)據(jù)總線、和
等信號(hào)的特定組合值。任何一個(gè)組合值與觀察點(diǎn)寄存器值匹配則中止處理器。另外一種方式是把兩個(gè)觀察點(diǎn)鏈接起來,只有第一個(gè)觀察點(diǎn)先匹配了,當(dāng)?shù)诙䝼(gè)觀察點(diǎn)再匹配時(shí)將使處理器中止。
2) 寄存器
EmbeddedICE寄存器通過JTAG測試端口使用專用掃描鏈編程。掃描鏈38位長,包括32個(gè)數(shù)據(jù)位,5個(gè)地址位和一個(gè)控制寄存器是讀還是寫的 位。地址位指定特定的寄存器,地址和寄存器一一對(duì)應(yīng)。
3) Debug comms端口
debug comms端口運(yùn)行在目標(biāo)系統(tǒng)上的軟件可以通過這個(gè)端口與主機(jī)通信。運(yùn)行在目標(biāo)系統(tǒng)上的軟件將comms端口視為一個(gè)6位控制寄存器和32位可讀寫寄存器,可以使用對(duì)協(xié)處理器14的MRC和MCR指令訪問。主機(jī)將這些寄存器視為EmbeddedICE寄存器。
3.2 實(shí)現(xiàn)原理
1) 訪問狀態(tài)
EmbeddedICE模塊允許程序在指定點(diǎn)中止,但不允許直接觀測、修改處理器或系統(tǒng)狀態(tài)。這可以通過屬于JTAG端口訪問的掃描路徑實(shí)現(xiàn)。訪問處理器狀態(tài)的方法是中止處理器,再在處理器指令序列中強(qiáng)制插入一條多寄存器存取指令。然后通過掃描鏈向處理器加入時(shí)鐘,使處理器將寄存器內(nèi)容送到數(shù)據(jù)端口。每個(gè)寄存器的值都可以被掃描鏈采樣并移出。
2) 調(diào)試
基于ARM的包括EmbeddedICE模塊的系統(tǒng)芯片通過JTAG端口和協(xié)議轉(zhuǎn)換器與主計(jì)算機(jī)連接。這種配置支持正常的斷點(diǎn)、觀察點(diǎn)以及處理器和系統(tǒng)狀態(tài)訪問,(除上面介紹的comms端口以外)這是程序設(shè)計(jì)人員在本地或基于ICE的調(diào)試中習(xí)慣采用的方式。采用適當(dāng)?shù)闹鳈C(jī)調(diào)試軟件,以較少的硬件代價(jià)得到完全的源代碼級(jí)調(diào)試功能。
4 ARM的嵌入式跟蹤
EmbeddedICE提供的斷點(diǎn)及觀察點(diǎn)將使處理器偏離正常執(zhí)行序列,破壞了軟件的實(shí)時(shí)行為,它不能完成實(shí)時(shí)操作調(diào)試功能。ARM結(jié)構(gòu)的處理器采用嵌入式跟蹤宏單元ETM很好的解決了系統(tǒng)實(shí)時(shí)調(diào)試的問題。
4.1 硬件電路
EmbeddedICE單元支持?jǐn)帱c(diǎn)和觀察點(diǎn)功能并提供主機(jī)和目標(biāo)軟件的通信通道。ETM單元[5]壓縮處理器接口信息并通過跟蹤端口送到片外。這兩個(gè)單元都由JTAG端口控制。SoC外部的EmbeddedICE控制器用于將主機(jī)系統(tǒng)連接到JTAG端口,跟蹤端口分析器使主機(jī)系統(tǒng)與跟蹤端口對(duì)接。主機(jī)通過一個(gè)網(wǎng)絡(luò)可以與跟蹤端口分析器和EmbeddedICE二者連接。
4.2 實(shí)現(xiàn)原理
由調(diào)試軟件配置并通過標(biāo)準(zhǔn)JTAG接口傳輸?shù)紼TM上。在程序執(zhí)行時(shí)ETM可以通過產(chǎn)生對(duì)處理器地址、數(shù)據(jù)及控制總線活動(dòng)的追蹤(Trace)來獲得處理器的全速操作情況。在實(shí)時(shí)仿真時(shí)外設(shè)和中斷程序依然能夠繼續(xù)運(yùn)行。用戶控制斷點(diǎn)和觀察點(diǎn)的設(shè)置并可以配置各種跟蹤功能。跟蹤觸發(fā)條件可以指定,跟蹤采集可以在觸發(fā)之前、之后或以觸發(fā)為中心可以選擇跟蹤是否包括數(shù)據(jù)訪問。跟蹤采集可以是數(shù)據(jù)訪問的地址、數(shù)據(jù)本身,也可以是兩者兼有。
ETM是使用軟件通過JTAG端口進(jìn)行配置的,所使用的軟件是ARM軟件開發(fā)工具的一個(gè)擴(kuò)展。跟蹤數(shù)據(jù)從跟蹤端口分析儀下載并解壓,較終反鏈接到源代碼。
5 應(yīng)用實(shí)例
下面以S3CEV40開發(fā)板[4]為例,介紹ARM調(diào)試結(jié)構(gòu)應(yīng)用。S3CEV40采用的CPU為Samsung公司的S3C44B0X,是國內(nèi)應(yīng)用廣泛的基于ARM7TDMI內(nèi)核的SoC。其調(diào)試系統(tǒng)的硬件結(jié)構(gòu)如圖2:
計(jì)算機(jī)的并行口和Embest PowerICE for ARM仿真器的DB25接口通過標(biāo)準(zhǔn)的DB25公、母轉(zhuǎn)換電纜連接。Embest PowerICE for ARM仿真器通過一個(gè)的IDC頭的直通電纜(1-1, 2-2,… 20-20)與目標(biāo)板的JTAG接口相連接。20芯的Embest PowerICE for ARM仿真器接口的定義如圖3所示:
S3CEV40所用到的調(diào)試軟件為EmbestIDE集成開發(fā)環(huán)境,它提供源碼級(jí)調(diào)試,提供了圖形和命令行兩種調(diào)試方式,可進(jìn)行斷點(diǎn)設(shè)置、單步執(zhí)行、異常處理,可查看修改內(nèi)存、寄存器、變量等,可查看函數(shù)棧,可進(jìn)行反匯編等。它為用戶提供2種調(diào)試方法:
脫機(jī)調(diào)試:Embest IDE for ARM帶ARM指令集模擬器,用戶能在PC上調(diào)試ARM應(yīng)用軟件。
下載調(diào)試:Embest IDE將程序通過仿真器下載到開發(fā)板,直接進(jìn)行調(diào)試。
Embest IDE的調(diào)試功能包括:斷點(diǎn)功能;程序的單步執(zhí)行;變量監(jiān)視功能,隨程序運(yùn)行同步更新變量,變量值即時(shí)修改;寄存器即時(shí)查看與修改;存儲(chǔ)器查看與修改,存儲(chǔ)器內(nèi)容顯示格式定制;堆棧顯示;同時(shí)提供圖形界面操作和命令行操作方式;支持被調(diào)試代碼的多種顯示模式,能以源碼、匯編、混合等形式來顯示程序;具有與MS Visual Studio類似的調(diào)試菜單功能:Go,Stop,Reset,Step into,Run to Cursor等;程序的上載和下載。
6 結(jié)束語
本文介紹了32位ARM嵌入式處理器的調(diào)試技術(shù)。在JTAG邊界掃描技術(shù)的基礎(chǔ)上介紹了ARM的EmbeddedICE及嵌入式跟蹤并在此基礎(chǔ)上介紹了一個(gè)系統(tǒng)調(diào)試實(shí)例。嵌入式調(diào)試技術(shù)是嵌入式軟硬件開發(fā)中必要的一環(huán),掌握了它能在開發(fā)中起到事半功倍的作用。
嵌入式技術(shù)正在日新月異
相關(guān)閱讀:
- ...2011/11/09 13:45·基于JXTA平臺(tái)的P2P網(wǎng)絡(luò)傳輸方案
- ...·圖文詳解汽車儀表板背后的車規(guī)級(jí)安全設(shè)計(jì)要求
- ...·使用有安全保障的閃存存儲(chǔ)構(gòu)建安全的汽車系統(tǒng)
- ...·反向偏置差分線性傳感器的較新進(jìn)展和應(yīng)用
- ...·艾德克斯測評(píng)某品牌智能插座——待機(jī)功耗篇
- ...·三線電阻式溫度檢測器測量系統(tǒng)中勵(lì)磁電流失配的影響(續(xù))
- ...·三線電阻式溫度檢測器測量系統(tǒng)中勵(lì)磁電流失配的影響
- ...·RTD測量系統(tǒng)中勵(lì)磁電流失配的影響
- ...·藍(lán)牙BR/EDR 和 Bluetooth Smart的十大重要區(qū)別
- ...·IoT網(wǎng)關(guān)平臺(tái)與應(yīng)用
- ...·增強(qiáng)版ARM DesignStart:通向定制化SoC的較快、較低風(fēng)險(xiǎn)之路
- ...·實(shí)體零售轉(zhuǎn)型O2O,倉儲(chǔ)物流的智能化水平從何提升?
- ...·幾種車用LED驅(qū)動(dòng)方案的比較
- ...·藍(lán)牙配對(duì)第二篇:密鑰生成方法
- ...·中電瑞華推出領(lǐng)先的無線數(shù)據(jù)采集解決方案
- ...·安森美半導(dǎo)體配合市場趨勢的無線充電方案
- ...·安森美半導(dǎo)體配合汽車照明設(shè)計(jì)趨勢的解決方案
- ...· “芯創(chuàng)杯”首屆高校未來汽車人機(jī)交互設(shè)計(jì)大賽報(bào)名正式啟動(dòng)
- ...· 探秘第二屆衛(wèi)藍(lán)山鷹“創(chuàng)新·共享”試驗(yàn)技術(shù)論壇!
- ...· “2018中國半導(dǎo)體生態(tài)鏈大會(huì)”在江蘇省盱眙舉行
- ...· 新主題新規(guī)劃,CITE 2019瞭望智慧未來
- ...· 從汽車到工廠,TI毫米波傳感器致力于創(chuàng)造更智能的世界
- ...· 意法半導(dǎo)體(ST)、Cinemo和Valens在CES 2018展上聯(lián)合演示汽車信息娛樂解決方案
- ...· 北京集成電路產(chǎn)業(yè)創(chuàng)新發(fā)展高峰論壇即將在京召開
- ...· 三菱電機(jī)強(qiáng)勢出擊PCIM亞洲2017展
- ...· GPGPU國產(chǎn)替代:中國芯片產(chǎn)業(yè)的空白地帶
- ...· 物聯(lián)網(wǎng)產(chǎn)品設(shè)計(jì)中Wi-Fi連接的四個(gè)關(guān)鍵因素
- ...· 第三屆中國MEMS智能傳感器產(chǎn)業(yè)發(fā)展大會(huì)即將于蚌埠拉開帷幕
- ...· IAIC專項(xiàng)賽演繹“中國芯“應(yīng)用創(chuàng)新,信息安全高峰論壇亮劍海寧
- ...· 智能控制有源鉗位反激
- ...· 解讀5G毫米波OTA 測試技術(shù)
- ...· 多個(gè)市場高速增長推動(dòng)Molex加強(qiáng)汽車領(lǐng)域的發(fā)展
- ...· 中國綠色制造聯(lián)盟成立大會(huì)召開在即 政產(chǎn)學(xué)研用共探綠色發(fā)展新模式
- ...· Efinix® 全力驅(qū)動(dòng)AI邊緣計(jì)算,成功推出Trion™ T20 FPGA樣品, 同時(shí)將產(chǎn)品擴(kuò)展到二十萬邏輯單元的T200 FPGA
- ...· 英飛凌亮相進(jìn)博會(huì),引領(lǐng)智慧新生活
- ...· 三電產(chǎn)品開發(fā)及測試研討會(huì)北汽新能源專場成功舉行
- ...· Manz亞智科技跨入半導(dǎo)體領(lǐng)域 為面板級(jí)扇出型封裝提供化學(xué)濕制程、涂布及激光應(yīng)用等生產(chǎn)設(shè)備解決方案
- ...· 中電瑞華BITRODE動(dòng)力電池測試系統(tǒng)順利交付北汽新能源
- ...· 中電瑞華FTF系列電池測試系統(tǒng)中標(biāo)北京新能源汽車股份有限公司
- ...· 中電瑞華大功率高壓能源反饋式負(fù)載系統(tǒng)成功交付中電熊貓
- ...· 中電瑞華國際在電動(dòng)汽車及關(guān)鍵部件測評(píng)研討會(huì)上演繹先進(jìn)測評(píng)技術(shù)
- ...· 數(shù)據(jù)采集終端系統(tǒng)設(shè)備
- ...· 簡儀科技踏上新征程
- ...· 易靈思® 宣布 AEC-Q100 資質(zhì)認(rèn)證和汽車系列產(chǎn)品計(jì)劃
- ...· 易靈思® 宣布擴(kuò)充高性能 鈦金系列™ FPGA 產(chǎn)品 鈦金系列產(chǎn)品擴(kuò)充至包含 1M 邏輯單元的 FPGA
- ...· 易靈思® 宣布Trion® Titanium 在臺(tái)積電 (TSMC) 16納米工藝節(jié)點(diǎn)流片
- ...· TI杯2019年全國大學(xué)生電子設(shè)計(jì)競賽頒獎(jiǎng)典禮在京舉行
- ...· BlackBerry QNX虛擬機(jī)獲得全球首個(gè)汽車安全完整性等級(jí)(ASIL) ‘D’認(rèn)證
- ...· 威馬汽車選擇BlackBerry助力下一代汽車