




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
精品文檔-下載后可編輯基于EmJTAG的ARM嵌入式系統(tǒng)調(diào)試工具-基礎(chǔ)電子摘要設(shè)計(jì)實(shí)現(xiàn)一個(gè)適用于基于EmJTAG的ARM嵌入式系統(tǒng)調(diào)試工具。它首先定義了一個(gè)輕量級(jí)的遠(yuǎn)程調(diào)試協(xié)議EmRDI,用于PC機(jī)與基于EmJTAG的ARM目標(biāo)板之間的交互過程;然后描述了用意法半導(dǎo)體公司(ST)的ST72651芯片實(shí)現(xiàn)一個(gè)協(xié)議轉(zhuǎn)換器EmJTAG的技術(shù)細(xì)節(jié)。EmJTAG的功能就是將PC機(jī)的調(diào)試命令轉(zhuǎn)換成目標(biāo)板的JTAG時(shí)序信號(hào),以達(dá)到控制PC機(jī)和調(diào)試目標(biāo)板的目的。關(guān)鍵詞EmRDIEmJTAG邊界掃描遠(yuǎn)程調(diào)試協(xié)議轉(zhuǎn)換器
引言ARM嵌入式系統(tǒng)的大致開發(fā)流程是:先在PC機(jī)上編寫程序源代碼;由ARM的交叉編譯器編譯、鏈接生成一個(gè)目標(biāo)文件;然后將目標(biāo)文件轉(zhuǎn)化成可以到目標(biāo)機(jī)運(yùn)行的二進(jìn)制代碼,在目標(biāo)機(jī)上調(diào)試運(yùn)行;終將調(diào)試成功的二進(jìn)制文件固化在目標(biāo)機(jī)中。這一系列過程中,關(guān)鍵的步驟就是在PC機(jī)上調(diào)試在目標(biāo)機(jī)上運(yùn)行的程序。這就需要采用遠(yuǎn)程調(diào)試的方式,即在PC機(jī)上運(yùn)行調(diào)試器軟件,被調(diào)試程序在目標(biāo)機(jī)上運(yùn)行。本文描述了這樣一個(gè)遠(yuǎn)程調(diào)試系統(tǒng):利用USB批量傳輸?shù)目煽啃?,將遠(yuǎn)程調(diào)試協(xié)議EmRDI的報(bào)文封裝在USB數(shù)據(jù)包中;協(xié)議轉(zhuǎn)換器EmJTAG再根據(jù)接收到的USB數(shù)據(jù)包中的協(xié)議信息,轉(zhuǎn)換成適當(dāng)?shù)腏TAG信號(hào)來控制和調(diào)試ARM核。協(xié)議轉(zhuǎn)換器EmJTAG由ST公司的ST72651芯片外加一片接口驅(qū)動(dòng)芯片74LVC244來實(shí)現(xiàn)。ST72651內(nèi)部集成了USB模塊和數(shù)據(jù)傳輸協(xié)處理器部件(DTC),通過對(duì)DTC的編程來產(chǎn)生控制ARM核的邊界掃描序列,以產(chǎn)生相應(yīng)的JTAG信號(hào)。文章終實(shí)現(xiàn)了PC機(jī)對(duì)ARM核的目標(biāo)機(jī)的調(diào)試功能:PC機(jī)的調(diào)試器軟件可以程序至目標(biāo)機(jī),實(shí)時(shí)控制目標(biāo)機(jī)上代碼的單步/全速運(yùn)行或停止,以及設(shè)置斷點(diǎn)和觀察點(diǎn)、讀寫寄存器/存儲(chǔ)器等。1系統(tǒng)組成及原理如圖1所示,整個(gè)調(diào)試系統(tǒng)包括三部分:PC機(jī)(調(diào)試器)、協(xié)議轉(zhuǎn)換器(EmJTAG)以及目標(biāo)板(基于ARM核)。調(diào)試的目的是實(shí)現(xiàn)在PC機(jī)上控制目標(biāo)板單步或全速運(yùn)行,并可以實(shí)時(shí)地察看或修改寄存器及存儲(chǔ)器的值。系統(tǒng)設(shè)計(jì)實(shí)現(xiàn)了一個(gè)遠(yuǎn)程調(diào)試協(xié)議EmRDI,它采用點(diǎn)對(duì)點(diǎn)的連接方式,以請(qǐng)求響應(yīng)的方式進(jìn)行交互。調(diào)試請(qǐng)求由PC機(jī)上的調(diào)試器軟件發(fā)出,經(jīng)由USB總線傳輸至協(xié)議轉(zhuǎn)換器EmJTAG;EmJTAG解讀該協(xié)議請(qǐng)求,在執(zhí)行相應(yīng)的操作之后,以USB數(shù)據(jù)包的形式發(fā)送回PC機(jī)(即響應(yīng)過程)。EmRDI協(xié)議定義了如下一些調(diào)試請(qǐng)求:讀/寫核寄存器、讀/寫存儲(chǔ)器、設(shè)置/清除硬件斷點(diǎn)、設(shè)置/清除軟件斷點(diǎn)、設(shè)置/清除數(shù)據(jù)觀察點(diǎn)、復(fù)位、停止運(yùn)行、全速/單步運(yùn)行和返回處理器狀態(tài)/設(shè)備標(biāo)識(shí)符。經(jīng)驗(yàn)證,這些請(qǐng)求的組合,可以實(shí)現(xiàn)PC機(jī)對(duì)目標(biāo)機(jī)上ARM核的調(diào)試和控制功能。EmRDI協(xié)議請(qǐng)求格式(16字節(jié))如下:命令前導(dǎo)字節(jié)
(2字節(jié))主命令號(hào)(1字節(jié))次命令號(hào)
(1字節(jié))地址字段或者保留
字段(12字節(jié))0xAAAAEmRDI協(xié)議響應(yīng)格式(8字節(jié))如下:響應(yīng)前導(dǎo)字節(jié)(2字節(jié))主命令號(hào)
(1字節(jié))次命令號(hào)
(1字節(jié))保留位
(2字節(jié))錯(cuò)誤碼
(2字節(jié))0x1111ARM核的芯片基本上都遵循JTAG規(guī)范,并帶有邊界掃描功能,此類芯片內(nèi)集成了一個(gè)JTAG電路結(jié)構(gòu)。JTAG電路由TAP(測(cè)試訪問端口)、TAP控制器、指令寄存器、測(cè)試數(shù)據(jù)寄存器組成。另外,ARM7TDMI核還包含了一個(gè)提供在線調(diào)試支持的EmbeddedICE宏單元。圖1系統(tǒng)框圖EmJTAG和PC機(jī)通過USB總線連接,與目標(biāo)板則遵循JTAG調(diào)試接口標(biāo)準(zhǔn)。JTAG規(guī)范中,使用稱為“邊界掃描單元”的基本結(jié)構(gòu)。邊界掃描單元將JTAG電路與處理器邏輯電路聯(lián)系起來,通過它可以將一個(gè)輸入信號(hào)加載到處理器邏輯中而不影響邏輯的其他電路,也可以將處理器邏輯的輸出信號(hào)采樣到邊界掃描單元中。若干個(gè)邊界掃描單元構(gòu)成邊界掃描寄存器(BSR),也稱為“邊界掃描鏈”。邊界掃描寄存器的數(shù)據(jù)通過JTAG接口的TDI引腳和TDO引腳串行移進(jìn)移出。PC機(jī)上需要實(shí)現(xiàn):EmJTAG的USB驅(qū)動(dòng)程序和調(diào)試器軟件。EmJTAG上需要實(shí)現(xiàn):USB固件程序和用于產(chǎn)生JTAG信號(hào)的邊界掃描程序。2硬件設(shè)計(jì)和實(shí)現(xiàn)系統(tǒng)的硬件部分主要是指協(xié)議轉(zhuǎn)換器EmJTAG的實(shí)現(xiàn)。協(xié)議轉(zhuǎn)換器的功能,就是接收PC機(jī)上調(diào)試器軟件發(fā)送的遠(yuǎn)程調(diào)試協(xié)議信息,將它轉(zhuǎn)換成JTAG時(shí)序信號(hào)發(fā)送到目標(biāo)板,然后把目標(biāo)板的反饋信息或者數(shù)據(jù)返回給PC機(jī)的調(diào)試器軟件。EmJTAG使用意法半導(dǎo)體(ST)公司的ST72651芯片,原理框圖如圖2所示。它集成了1個(gè)全速(12Mbps)USB接口模塊,1個(gè)時(shí)鐘頻率為24MHz的數(shù)據(jù)傳輸協(xié)處理器(DTC),32KB程序存儲(chǔ)空間,5KBRAM,硬件I2C和SPI接口,多達(dá)47個(gè)可編程I/O口;工作電壓為2.7~5.5V,由USB直接供電。圖2EmJTAG原理框圖與PC機(jī)通信方面,USB接口部分只需要將DP腳上拉一個(gè)電阻,使PC機(jī)識(shí)別到USB設(shè)備。DTC模塊產(chǎn)生4個(gè)時(shí)鐘信號(hào)作為JTAG時(shí)鐘信號(hào)(TDI、TDO、TMS和TCK),由I/O口引出,外部再加一個(gè)接口驅(qū)動(dòng)芯片74LVC244,將這4個(gè)信號(hào)連接到標(biāo)準(zhǔn)的JTAG接口上。TAP控制器復(fù)位信號(hào)nTRST和系統(tǒng)復(fù)位信號(hào)nSRST通過I/O邏輯直接控制。EmJTAG采用USB供電方式,同時(shí)在TCK引腳上連接一個(gè)指示燈BUSY,顯示系統(tǒng)是否處于忙狀態(tài)。接口驅(qū)動(dòng)芯片74LVC244由內(nèi)部集成的電壓校準(zhǔn)器產(chǎn)生3.3V來提供電壓。3軟件設(shè)計(jì)和實(shí)現(xiàn)軟件部分主要包括:PC機(jī)上的調(diào)試器軟件,EmJTAG協(xié)議轉(zhuǎn)換器的PC端驅(qū)動(dòng)程序以及EmJTAG中的固件程序。3.1PC機(jī)上的調(diào)試器軟件采用VC++6.0MFC。其主要功能是與EmJTAG的PC端驅(qū)動(dòng)程序通信,將調(diào)試命令通過USB總線發(fā)送至EmJTAG。3.2EmJTAG的PC端驅(qū)動(dòng)程序使用Driverstudio3.1開發(fā)Windows下的USB驅(qū)動(dòng)程序,使EmJTAG和PC機(jī)的應(yīng)用程序可以進(jìn)行數(shù)據(jù)交互。3.3EmJTAG中的固件程序固件程序使用意法半導(dǎo)體(ST)開發(fā)工具STVD7forInDARTSTX進(jìn)行開發(fā)。這一部分也是調(diào)試系統(tǒng)重要的部分,即如何產(chǎn)生JTAG時(shí)序信號(hào)控制ARM核。EmJTAG中的固件分成以下多個(gè)模塊實(shí)現(xiàn)。3.3.1DTC軟件插件程序模塊圖3DTC功能框圖DTC功能框圖如圖3所示。DTC是ST72651內(nèi)部集成的數(shù)據(jù)傳輸協(xié)處理器,也是一個(gè)通用的串行/并行通信接口。通過改變其內(nèi)運(yùn)行的插件程序,DTC可以方便地完成不同的高速數(shù)據(jù)傳輸操作。插件程序(為256字節(jié))開始時(shí)存放在ST72651的Flash中,芯片運(yùn)行的程序會(huì)將插件程序加載到DTCSWRAM中,然后控制DTC運(yùn)行這段插件程序。ST7核也可以讀寫DTC的數(shù)據(jù)傳輸緩沖區(qū),因此需要有一個(gè)仲裁電路用于防止ST7核和DTC訪問該緩沖區(qū)時(shí)發(fā)生沖突。DTC有一套簡單的指令集。ST7核通過DTC控制寄存器DTCCR控制DTC的操作,通過DTC狀態(tài)寄存器DTCSR查詢DTC的狀態(tài),通過DTC指針寄存器DTCPR改變DTC的操作指針。DTC有4種操作狀態(tài):空閑狀態(tài)(IDLE),加載插件程序狀態(tài)(RAMLOAD),運(yùn)行狀態(tài)(RUNNING)和改變操作指針狀態(tài)(POINTERCHANGE)。通過改變DTCCR寄存器的RUN、INIT和LOAD位可以實(shí)現(xiàn)4種狀態(tài)間的轉(zhuǎn)換。將插件程序加載到DTCSWRAM中的步驟如下:◆清除DTCCR寄存器的RUN位,使DTC進(jìn)入IDLE狀態(tài),停止DTC;◆設(shè)置DTCCR寄存器的LOAD位,使DTC進(jìn)入RAMLOAD狀態(tài),以允許寫DTCRAM;◆將插件程序復(fù)制到DTCSWRAM中;◆清除DTCCR寄存器的LOAD位,使DTC返回到IDLE狀態(tài),恢復(fù)DTCRAM寫保護(hù)。使DTC運(yùn)行其RAM(即DTCSWRAM)中的插件程序的步驟如下:◆清除DTCCR寄存器的RUN位,使DTC進(jìn)入IDLE狀態(tài),停止DTC◆將插件程序的起始地址填入DTCPR寄存器中;◆設(shè)置DTCCR寄存器的INIT位,使DTC進(jìn)入POINTERCHANGE狀態(tài),將DTCPR寄存器中的值復(fù)制到DTC中;◆清除DTCCR寄存器的INIT位,使DTC返回到IDLE狀態(tài);◆設(shè)置DTCCR寄存器的RUN位,使DTC進(jìn)入RUNNING狀態(tài),開始運(yùn)行。DTC運(yùn)行的插件程序?qū)崿F(xiàn)的功能是:將數(shù)據(jù)傳輸緩沖區(qū)內(nèi)的數(shù)據(jù)快速移出I/O口,或者從I/O快速移入數(shù)據(jù)到數(shù)據(jù)傳輸緩沖區(qū)中。DTC操作的I/O口作為4個(gè)JTAG信號(hào):TCK、TMS、TDI和TDO。TCK作為移入/移出數(shù)據(jù)的觸發(fā)時(shí)鐘;TDI作為移出數(shù)據(jù)出口;TDO作為移入數(shù)據(jù)進(jìn)口;TMS作為輸入信號(hào),與TCK一起決定TAP控制器狀態(tài)的轉(zhuǎn)移過程。插件程序用DTC匯編指令編寫,然后通過ST公司提供的一個(gè)簡單匯編器將匯編源代碼轉(zhuǎn)化成DTC機(jī)器指令,燒寫到ST72651的Flash存儲(chǔ)器中。3.3.2掃描鏈操作模塊掃描鏈操作模塊調(diào)用DTC軟件插件程序,完成初始化TAP控制器、掃描鏈1操作和掃描鏈2操作。
(1)初始化TAP控制器TAP控制器的基本功能是產(chǎn)生時(shí)鐘信號(hào)和控制信號(hào)。它包括一個(gè)帶有16個(gè)狀態(tài)的有限狀態(tài)機(jī):TestLogicReset狀態(tài)、RunTest/Idle狀態(tài)、SelectDRScan狀態(tài)、SelectIRScan狀態(tài)、CaptureDR狀態(tài)、ShiftDR狀態(tài)、Exit1DR狀態(tài)、PauseDR狀態(tài)、Exit2DR狀態(tài)、UpdateDR狀態(tài)、CaptureIR狀態(tài)、ShiftIR狀態(tài)、Exit1IR狀態(tài)、PauseIR狀態(tài)、Exit2IR狀態(tài)和UpdateIR狀態(tài)。初始化TAP控制器的目的是使TAP控制器進(jìn)入SelectDRScan狀態(tài)。無論當(dāng)前TAP控制器處于什么狀態(tài),只要在TMS為1時(shí)產(chǎn)生5個(gè)TCK信號(hào),TAP控制器就進(jìn)入TestLogicReset狀態(tài)。因此,使TAP控制器進(jìn)入SelectDRScan狀態(tài)的步驟為:首先使TMS為1,產(chǎn)生5個(gè)TCK信號(hào),使TAP控制器進(jìn)入TestLogicReset狀態(tài);然后使TMS為0,產(chǎn)生1個(gè)TCK信號(hào),使TAP控制器進(jìn)入RunTest/Idle狀態(tài);使TMS為1,產(chǎn)生1個(gè)TCK信號(hào),使TAP控制器進(jìn)入SelectDRScan狀態(tài)。(2)掃描鏈1操作掃描鏈1是JTAG電路中的一種測(cè)試數(shù)據(jù)寄存器,主要用于內(nèi)核測(cè)試和調(diào)試過程。掃描鏈1有33位,按掃描先后順序依次為:BREAKPT位(輸入),D31~D0(輸入/輸出)。掃描鏈1操作的目的是移入BREAKPT位,同時(shí)向/從數(shù)據(jù)總線移入/移出32位數(shù)據(jù)。操作步驟如下:◆初始化TAP控制器,使TAP控制器進(jìn)入SelectDRScan狀態(tài);◆使TMS為1,產(chǎn)生1個(gè)TCK信號(hào),使TAP控制器進(jìn)入SelectIRScan狀態(tài);◆使TMS為0,產(chǎn)生2個(gè)TCK信號(hào),使TAP控制器進(jìn)入ShiftIR狀態(tài);◆往TAP控制器的指令寄存器移入JTAG指令SCAN_N(b0010);◆使TAP控制器退出ShiftIR狀態(tài),進(jìn)入ShiftDR狀態(tài);◆往掃描鏈選擇寄存器移入b0001,選擇掃描鏈1;◆使TAP控制器退出ShiftDR狀態(tài),進(jìn)入ShiftIR狀態(tài);◆往TAP控制器的指令寄存器移入JTAG指令I(lǐng)NTEST(b1100);◆使TAP控制器退出ShiftIR狀態(tài),進(jìn)入ShiftDR狀態(tài);◆移入BREAKPT位,移入數(shù)據(jù)D31~D0(或移出數(shù)據(jù)D31~D0);◆使TAP控制器退出ShiftDR狀態(tài),進(jìn)入SelectDRScan狀態(tài)。
(3)掃描鏈2操作掃描鏈2也是一種測(cè)試數(shù)據(jù)寄存器,用于訪問EmbeddedICE宏單元的寄存器。掃描鏈2有38位,按掃描先后順序依次為:EmbeddedICE寄存器的D0~D31,EmbeddedICE寄存器的A0~A4,讀/寫位。掃描鏈2操作的目的是讀寫EmbeddedICE宏單元的寄存器。操作步驟如下:◆初始化TAP控制器,使TAP控制器進(jìn)入SelectDRScan狀態(tài);◆使TMS為1,產(chǎn)生1個(gè)TCK信號(hào),使TAP控制器進(jìn)入SelectIRScan狀態(tài);◆使TMS為0,產(chǎn)生2個(gè)TCK信號(hào),使TAP控制器進(jìn)入ShiftIR狀態(tài);◆往TAP控制器的指令寄存器移入JTAG指令SCAN_N(b0010);◆使TAP控制器退出ShiftIR狀態(tài),進(jìn)入ShiftDR狀態(tài);◆往掃描鏈選擇寄存器移入b0010,選擇掃描鏈2;◆使TAP控制器退出ShiftDR狀態(tài),進(jìn)入ShiftIR狀態(tài);◆往TAP控制器的指令寄存器移入JTAG指令I(lǐng)NTEST(b1100);◆使TAP控制器退出ShiftIR狀態(tài),進(jìn)入ShiftDR狀態(tài);◆移入欲寫的數(shù)據(jù)D0~D31;◆移入欲讀寫的EmbeddedICE寄存器的地址;◆移入讀/寫位(讀為0,寫為1);◆如果為讀,則移出讀到的EmbeddedICE寄存器的值D0~D31;◆使TAP控制器退出ShiftDR狀態(tài),進(jìn)入SelectDRScan狀態(tài)。3.3.3EmbeddedICE寄存器操作模塊EmbeddedICE寄存器的讀寫通過對(duì)掃描鏈2操作實(shí)現(xiàn)。讀時(shí),將欲讀的EmbeddedICE寄存器地址作為參數(shù)調(diào)用掃描鏈2操作函數(shù);寫時(shí),將欲寫的值和EmbeddedICE寄存器地址作為參數(shù)調(diào)用掃描鏈2操作函數(shù)。3.3.4高層調(diào)試命令模塊通過調(diào)用掃描鏈操作模塊和EmbeddedICE寄存器操作模塊,實(shí)現(xiàn)了讀寫核寄存器、讀寫存儲(chǔ)器、斷點(diǎn)及觀察點(diǎn)操作、單步或全速運(yùn)行程序等調(diào)試控制命令。這些命令供主程序狀態(tài)機(jī)模塊調(diào)用。3.3.5USB接口驅(qū)動(dòng)模塊USB接口驅(qū)動(dòng)模塊主要包含5個(gè)函數(shù):函數(shù)InitUSB()用于初始化USB模塊;函數(shù)USB_Polling()處理USB主機(jī)發(fā)來的USB標(biāo)準(zhǔn)設(shè)備請(qǐng)求,實(shí)現(xiàn)USB枚舉階段的傳輸過程,同時(shí)根據(jù)狀態(tài)寄存器的標(biāo)志位調(diào)用相應(yīng)的端點(diǎn)處理函數(shù);CTR(正確傳輸)中斷服務(wù)程序用于處理端點(diǎn)上發(fā)生的各種中斷;函數(shù)B_RecvDataEP2(unsignedchar*dp,uint8len)和USB_SendDataEP2(unsignedchar
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 工程項(xiàng)目合同管理八步走
- 產(chǎn)品使用說明功能操作與維護(hù)指南
- 外墻涂料施工合同書
- Unit1生活中的日常用語:初一英語日常會(huì)話教學(xué)教案
- 2025年大慶c1貨運(yùn)上崗證模擬考試
- 2025年唐山貨運(yùn)上崗證考試題庫答案
- 委托抵押擔(dān)保協(xié)議
- 數(shù)據(jù)安全與隱私保護(hù)作業(yè)指導(dǎo)書
- 合同房地產(chǎn)轉(zhuǎn)讓合同5篇
- 2025年高中化學(xué)新教材同步 必修第一冊(cè) 第2章 階段重點(diǎn)突破練(四)
- 銀行承兌匯票和商業(yè)承兌匯票課件
- 特朗普貿(mào)易戰(zhàn)的基本邏輯、本質(zhì)及其應(yīng)對(duì)
- 經(jīng)口鼻吸痰法護(hù)理課件
- 《園林生態(tài)學(xué)》課件
- 初中化學(xué)實(shí)驗(yàn)報(bào)告單(上)
- 貨物質(zhì)量與安全控制方案
- 高中物理多普勒效應(yīng)練習(xí)題
- 交通事故授權(quán)委托書樣本(通用)
- 鹽酸利多卡因應(yīng)用于無痛導(dǎo)尿術(shù)的臨床效果觀察
- 保障性住房資格申請(qǐng)表
- PEP五年級(jí)上冊(cè)Unit3-字母組合ow的發(fā)音
評(píng)論
0/150
提交評(píng)論