1 引言
    32位ARM處理器是英國先進RISC機器公司(ADVANCED RISC Machines,ARM)的產(chǎn)品。隨著嵌入式處理器性能的逐步提高,運算速度越來越快、處理的數(shù)據(jù)量越來越大,傳統(tǒng)的調(diào)試方法如ROM駐留監(jiān)控程序以及串口調(diào)試工具已經(jīng)不能滿足要求。ARM處理器采用一種基于JTAG的ARM的內(nèi)核調(diào)試通道">

欧美成人aaaaa免费视频_亚洲欧美激情小说另类_欧美激情一区二区三区视频_一级在线|欧洲

技術(shù)頻道

基于JTAG的ARM芯片系統(tǒng)調(diào)試

1 引言
32位ARM處理器是英國先進RISC機器公司(ADVANCED RISC Machines,ARM)的產(chǎ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端口與主計算機連接。通過配置支持正常的斷點、觀察點以及處理器和系統(tǒng)狀態(tài)訪問,完成調(diào)試。為了對代碼進行實時跟蹤,ARM的提供了嵌入式跟蹤單元(Embedded Trace Macrocell),對應(yīng)用程序的調(diào)試將更加全面。
2 JTAG邊界掃描原理
“JTAG邊界掃描”或IEEE1149標準[1]是由“測試聯(lián)合行動組”(Joint Test ACTION GROUP,簡稱JTAG)開發(fā)的針對PCB的“標準測試訪問接口和邊界掃描結(jié)構(gòu)”的標準。這個標準是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)機。
2) 指令寄存器。用于存儲JTAG邊界掃描指令,通過它可以串行的輸入并執(zhí)行各種操作指令。
3) 數(shù)據(jù)寄存器。特定芯片的行為由測試指令寄存器的內(nèi)容決定。測試指令寄存器可用來選擇各種不同的數(shù)據(jù)寄存器。
2.2 邊界掃描測試信號
支持這個測試標準的芯片必須提供5個專用信號接口:
 TRST:測試復(fù)位輸入信號,低電平有效,為TAP控制器提供異步初始化信號。
 TCK:JTAG測試時鐘,獨立于任何系統(tǒng)時鐘,為TAP控制器和寄存器提供測試參考。
 TMS:TAP控制器的測試模式選擇信號,控制測試接口狀態(tài)機的操作。
 TDI:JTAG指令和數(shù)據(jù)寄存器的串行輸入端,給邊界掃描鏈或指令寄存器提供數(shù)據(jù)。
 TDO:TAG指令和數(shù)據(jù)寄存器的串行輸出。
2.3 指令
JTAG測試系統(tǒng)是通過向指令寄存器送入指令,然后使用數(shù)據(jù)寄存器進行測試。測試指令說明要進行的測試種類及測試要使用的數(shù)據(jù)寄存器。測試指令分為公開指令和私有指令。公開指令已經(jīng)定義且用于通用測試。私用指令用于片上的專用測試,測試標準沒有規(guī)定如何使用私有指令。測試標準支持的最小集的公開指令有:
 BYPASS:器件將TDI經(jīng)一個時鐘延時連接到TDO,用于同一個測試環(huán)中其它器件的測試。
 EXTEST:將邊界掃描寄存器連接到TDI和TDO之間,用于支持板級連接測試。
 IDCODE:將ID寄存器連接到TDI和TDO之間。通過它可以讀出器件ID(廠家賦與的固定標識,包括產(chǎn)品編號及版本碼)。
 INTEST:將邊界掃描寄存器連接到TDI和TDO之間。
3 EmbeddedICE
ARM的EmbeddedICE調(diào)試結(jié)構(gòu)[3]是一種基于JTAG的ARM的內(nèi)核調(diào)試通道,它是基于JTAG測試端口的擴展,引入了附加的斷點和觀測點寄存器,這些數(shù)據(jù)寄存器可以通過專用JTAG指令來訪問,一個跟蹤緩沖器也可用相似的方法訪問。ARM核周圍的掃描路徑可以將指令加入ARM流水線并且不會干擾系統(tǒng)的其它部分。這些指令可以訪問及修改ARM和系統(tǒng)的狀態(tài)。由于EmbeddedICE條件斷點,單步運行等功能的實現(xiàn)是基于片上JTAG測試訪問端口進行調(diào)試,芯片不需要增加額外的引腳,避免使用笨重的、不可靠的探針接插設(shè)備完成調(diào)試。芯片中的調(diào)試模塊與外部的系統(tǒng)時序分開,可以直接運行在芯片內(nèi)部的獨立時鐘速度。
3.1 硬件結(jié)構(gòu)
EmbeddedICE模塊包括兩個觀察點寄存器和控制與狀態(tài)寄存器,還包括一個Debug comms端口。當?shù)刂贰?shù)據(jù)和控制信號與觀察點寄存器的編程數(shù)據(jù)相匹配時,也就是觸發(fā)條件滿足時,觀察點寄存器可以中止處理器。由于比較是在屏蔽控制下進行的,因此當ROM或RAM中的一條指令執(zhí)行時,任何一個觀察點寄存器可配置為能夠中止處理器的斷點寄存器。
1) 觀察點
每個觀察點皆可以觀察ARM地址總線、數(shù)據(jù)總線、和等信號的特定組合值。任何一個組合值與觀察點寄存器值匹配則中止處理器。另外一種方式是把兩個觀察點鏈接起來,只有第一個觀察點先匹配了,當?shù)诙€觀察點再匹配時將使處理
器中止。
2) 寄存器
EmbeddedICE寄存器通過JTAG測試端口使用專用掃描鏈編程。掃描鏈38位長,包括32個數(shù)據(jù)位,5個地址位和一個控制寄存器是讀還是寫的 位。地址位指定特定的寄存器,地址和寄存器一一對應(yīng)。
3) Debug comms端口
debug comms端口運行在目標系統(tǒng)上的軟件可以通過這個端口與主機通信。運行在目標系統(tǒng)上的軟件將comms端口視為一個6位控制寄存器和32位可讀寫寄存器,可以使用對協(xié)處理器14的MRC和MCR指令訪問。主機將這些寄存器視為EmbeddedICE寄存器。
3.2 實現(xiàn)原理
1) 訪問狀態(tài)
EmbeddedICE模塊允許程序在指定點中止,但不允許直接觀測、修改處理器或系統(tǒng)狀態(tài)。這可以通過屬于JTAG端口訪問的掃描路徑實現(xiàn)。訪問處理器狀態(tài)的方法是中止處理器,再在處理器指令序列中強制插入一條多寄存器存取指令。然后通過掃描鏈向處理器加入時鐘,使處理器將寄存器內(nèi)容送到數(shù)據(jù)端口。每個寄存器的值都可以被掃描鏈采樣并移出。
2) 調(diào)試
基于ARM的包括EmbeddedICE模塊的系統(tǒng)芯片通過JTAG端口和協(xié)議轉(zhuǎn)換器與主計算機連接。這種配置支持正常的斷點、觀察點以及處理器和系統(tǒng)狀態(tài)訪問,(除上面介紹的comms端口以外)這是程序設(shè)計人員在本地或基于ICE的調(diào)試中習(xí)慣采用的方式。采用適當?shù)闹鳈C調(diào)試軟件,以較少的硬件代價得到完全的源代碼級調(diào)試功能。
4 ARM的嵌入式跟蹤
EmbeddedICE提供的斷點及觀察點將使處理器偏離正常執(zhí)行序列,破壞了軟件的實時行為,它不能完成實時操作調(diào)試功能。ARM結(jié)構(gòu)的處理器采用嵌入式跟蹤宏單元ETM很好的解決了系統(tǒng)實時調(diào)試的問題。
4.1 硬件電路
EmbeddedICE單元支持斷點和觀察點功能并提供主機和目標軟件的通信通道。ETM單元[5]壓縮處理器接口信息并通過跟蹤端口送到片外。這兩個單元都由JTAG端口控制。SoC外部的EmbeddedICE控制器用于將主機系統(tǒng)連接到JTAG端口,跟蹤端口分析器使主機系統(tǒng)與跟蹤端口對接。主機通過一個網(wǎng)絡(luò)可以與跟蹤端口分析器和EmbeddedICE二者連接。
4.2 實現(xiàn)原理
由調(diào)試軟件配置并通過標準JTAG接口傳輸?shù)紼TM上。在程序執(zhí)行時ETM可以通過產(chǎn)生對處理器地址、數(shù)據(jù)及控制總線活動的追蹤(Trace)來獲得處理器的全速操作情況。在實時仿真時外設(shè)和中斷程序依然能夠繼續(xù)運行。用戶控制斷點和觀察點的設(shè)置并可以配置各種跟蹤功能。跟蹤觸發(fā)條件可以指定,跟蹤采集可以在觸發(fā)之前、之后或以觸發(fā)為中心可以選擇跟蹤是否包括數(shù)據(jù)訪問。跟蹤采集可以是數(shù)據(jù)訪問的地址、數(shù)據(jù)本身,也可以是兩者兼有。
ETM是使用軟件通過JTAG端口進行配置的,所使用的軟件是ARM軟件開發(fā)工具的一個擴展。跟蹤數(shù)據(jù)從跟蹤端口分析儀下載并解壓,最終反鏈接到源代碼。
5 應(yīng)用實例
下面以S3CEV40開發(fā)板[4]為例,介紹ARM調(diào)試結(jié)構(gòu)應(yīng)用。S3CEV40采用的CPU為Samsung公司的S3C44B0X,是國內(nèi)應(yīng)用廣泛的基于ARM7TDMI內(nèi)核的SoC。
計算機的并行口和Embest PowerICE for ARM仿真器的DB25接口通過標準的DB25公、母轉(zhuǎn)換電纜連接。Embest PowerICE for ARM仿真器通過一個的IDC頭的直通電纜(1-1, 2-2,… 20-20)與目標板的JTAG接口相連接。20芯的Embest PowerICE for ARM仿真器接口的定義如圖3所示:
S3CEV40所用到的調(diào)試軟件為EmbestIDE集成開發(fā)環(huán)境,它提供源碼級調(diào)試,提供了圖形和命令行兩種調(diào)試方式,可進行斷點設(shè)置、單步執(zhí)行、異常處理,可查看修改內(nèi)存、寄存器、變量等,可查看函數(shù)棧,可進行反匯編等。它為用戶提供2種調(diào)試方法:

 脫機調(diào)試:Embest IDE for ARM帶ARM指令集模擬器,用戶能在PC上調(diào)試ARM應(yīng)用軟件。
 下載調(diào)試:Embest IDE將程序通過仿真器下載到開發(fā)板,直接進行調(diào)試。
Embest IDE的調(diào)試功能包括:斷點功能;程序的單步執(zhí)行;變量監(jiān)視功能,隨程序運行同步更新變量,變量值即時修改;寄存器即時查看與修改;存儲器查看與修改,存儲器內(nèi)容顯示格式定制;堆棧顯示;同時提供圖形界面操作和命令行操作方式;支持被調(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ǔ)上介紹了一個系統(tǒng)調(diào)試實例。嵌入式調(diào)試技術(shù)是嵌入式軟硬件開發(fā)中必要的一環(huán),掌握了它能在開發(fā)中起到事半功倍的作用。
嵌入式技術(shù)正在日新月異的發(fā)展著,嵌入式調(diào)試技術(shù)也不是一成不變的,它必將隨著高速、低功耗Soc的發(fā)展而進步。


文章版權(quán)歸西部工控xbgk所有,未經(jīng)許可不得轉(zhuǎn)載。

欧美成人aaaaa免费视频_亚洲欧美激情小说另类_欧美激情一区二区三区视频_一级在线|欧洲

      亚洲色诱最新| 午夜精品一区二区在线观看| 精品动漫一区二区| 在线观看日韩精品| 国产亚洲精品7777| 欧美视频一区在线观看| 久久这里只有精品视频首页| 亚洲一区在线视频| 一本色道久久综合亚洲精品婷婷 | 亚洲狼人精品一区二区三区| 国产一区二区三区不卡在线观看 | 夜夜嗨av一区二区三区网页| 激情综合视频| 国产一区清纯| 国产日韩综合一区二区性色av| 欧美日产国产成人免费图片| 蜜桃av一区二区三区| 国产精品网站在线观看| 黄色日韩网站| 亚洲一区精品在线| 欧美另类99xxxxx| 制服丝袜激情欧洲亚洲| 夜夜夜久久久| 夜夜嗨av一区二区三区网页| 亚洲国产日韩一区| 亚洲人成高清| 亚洲黄色一区| 91久久黄色| 亚洲裸体在线观看| 99re66热这里只有精品3直播| 亚洲高清久久| 亚洲美女中文字幕| 宅男噜噜噜66一区二区| 亚洲一区不卡| 欧美一区二视频| 久久久亚洲精品一区二区三区 | 国产精品麻豆va在线播放| 亚洲成人在线| 久久久之久亚州精品露出| 欧美日韩一二三区| 国产欧美日韩视频一区二区| 国产亚洲精久久久久久| 伊伊综合在线| 一区二区国产日产| 香港久久久电影| 久久久国产一区二区| 美女久久网站| 国产精品v日韩精品| 国产美女在线精品免费观看| 黄色成人小视频| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 香蕉乱码成人久久天堂爱免费| 欧美伊人久久久久久久久影院 | 久久综合亚洲社区| 一区二区三区日韩| 亚洲人成在线播放网站岛国| 亚洲视频在线观看一区| 欧美在线不卡视频| 欧美精品系列| 国产亚洲欧洲| 亚洲网址在线| 欧美激情国产高清| 国精品一区二区三区| 亚洲欧洲视频| 欧美在线看片a免费观看| 欧美大胆人体视频| 国产区亚洲区欧美区| 9久草视频在线视频精品| 欧美一区二区三区啪啪| 欧美国产在线电影| 狠狠色伊人亚洲综合成人| 中文日韩在线视频| 欧美高清视频一区二区| 韩国亚洲精品| 午夜欧美视频| 欧美日韩一区免费| 最新日韩av| 久久视频国产精品免费视频在线 | 国产精品二区在线观看| 亚洲欧洲精品一区二区三区波多野1战4 | 亚洲国产毛片完整版| 欧美在线精品免播放器视频| 国产精品乱码| 一区二区三区日韩欧美| 欧美国产日产韩国视频| 一区二区三区自拍| 久久久午夜精品| 红桃av永久久久| 久久精彩免费视频| 国产一区激情| 久久精品亚洲一区二区| 国产亚洲a∨片在线观看| 午夜伦欧美伦电影理论片| 国产精品久久久久影院色老大| 亚洲精品在线免费观看视频| 欧美aaa级| 91久久综合| 欧美国产第一页| 日韩午夜在线电影| 欧美三级小说| 亚洲小说欧美另类婷婷| 国产精品chinese| 亚洲天堂网站在线观看视频| 欧美色区777第一页| 亚洲女性裸体视频| 国产毛片一区二区| 亚洲免费小视频| 国产免费观看久久| 欧美在线影院| 有坂深雪在线一区| 欧美激情视频在线免费观看 欧美视频免费一| 亚洲第一福利在线观看| 欧美激情一区二区三区在线视频| 亚洲精品一二| 国产乱码精品一区二区三区五月婷 | 韩国精品久久久999| 久久成人精品| 国产精品a久久久久| 一区二区三区国产精华| 美女黄毛**国产精品啪啪| 国产香蕉97碰碰久久人人| 性欧美1819sex性高清| 狠狠久久婷婷| 欧美日韩国产综合在线| 午夜精品视频| 亚洲欧洲日产国产网站| 国产精品久久久久久影院8一贰佰| 午夜精品久久久久影视| 亚洲国产精品国自产拍av秋霞| 欧美日韩伦理在线免费| 久久免费视频在线| 亚洲小说欧美另类社区| 激情综合电影网| 国产精品蜜臀在线观看| 另类激情亚洲| 性刺激综合网| 亚洲视频精品| 亚洲高清在线播放| 国产精品一区久久| 欧美激情精品久久久久久久变态| 亚洲欧美视频在线| 在线视频一区二区| 91久久国产精品91久久性色| 国产精品一区在线观看| 欧美日本一区二区视频在线观看| 久久黄色小说| 亚洲网站视频| 亚洲美女精品久久| 亚洲国产成人久久综合| 国产真实乱偷精品视频免| 欧美视频网站| 欧美日韩亚洲在线| 欧美看片网站| 欧美精品自拍| 欧美日韩国产三区| 欧美精品国产精品| 欧美大片在线看免费观看| 久久美女性网| 久久精选视频| 欧美在线一二三| 久久不射网站| 午夜精品久久久久久久99樱桃| 亚洲午夜激情在线| 亚洲素人在线| 亚洲欧美日韩精品久久久| 亚洲私人影吧| 午夜精品久久久久久久| 亚洲精品在线免费| 日韩视频在线一区二区| av成人国产| 亚洲性感美女99在线| 中文一区二区| 亚洲男人第一网站| 欧美在线精品一区| 久久久久久久国产| 欧美成人a∨高清免费观看| 裸体丰满少妇做受久久99精品| 美女精品网站| 欧美日韩八区| 国产欧美日韩精品在线| 国内揄拍国内精品久久| 亚洲成人在线观看视频| 亚洲精品日产精品乱码不卡| 中国女人久久久| 亚洲女人天堂av| 久久久久久免费| 欧美日本网站| 国产一区二三区| 亚洲激情在线视频| 亚洲资源av| 美女视频黄免费的久久| 欧美精品大片| 国产视频精品免费播放| 黄色成人小视频| 中文国产成人精品久久一| 久久国产精品电影| 欧美日韩四区| 国产一区二区久久| 日韩一区二区电影网| 久久精品国产亚洲a|