基于A(yíng)RM+FPGA的重構控制器設計

發(fā)布時(shí)間:2010-3-5 17:09    發(fā)布者:嵌入式公社
關(guān)鍵詞: arm , FPGA , 控制器 , 設計 , 重構
可重構技術(shù)是指利用可重用的軟硬件資源,根據不同的應用需求,靈活地改變自身體系結構的設計方法。常規SRAM工藝的FPGA都可以實(shí)現重構,利用硬件復用原理,本文設計的可重構控制器采用ARM核微控制器作為主控制器,以FPGA芯片作為協(xié)處理器配合主控制器工作。用戶(hù)事先根據需求設計出不同的配置方案,并存儲在重構控制器內部的存儲器中,上電后,重構控制器就可以按需求將不同設計方案分時(shí)定位到目標可編程器件內,同時(shí)保持其他部分電路功能正常,實(shí)現在系統靈活配置,提高系統工作效率。

1 SVF格式配置文件

很多嵌入式系統中都用到了FPGA/CPLD等可編程器件,在這些系統中利用SVF格式配置文件就可以方便地通過(guò)微控制器對可編程器件進(jìn)行重新配置。目前可編程芯片廠(chǎng)商的配套軟件都可以生成可編程器件的SVF格式配置文件,串行矢量格式(SVF)是一種用于說(shuō)明高層IEEE 1149.1(JTAG)總線(xiàn)操作的語(yǔ)法規范。SVF由Texas Instruments開(kāi)發(fā),并已成為數據交換標準而被Teradyne,Tektronix等JTAG測試設備及軟件制造商采用。Xilinx的 FPGA以及配置PROM可通過(guò)JTAG接口中TAP控制器接收SVF格式的編程指令。由于SVF文件由ASCII語(yǔ)句構成,它要求較大的存儲空間,并且存儲效率很低,無(wú)法勝任嵌入式應用。為了在嵌入式系統中充分利用其有限的存儲空間,并不直接利用SVF文件對可編程器件進(jìn)行在系統編程,而是將SVF文件轉換成另一種存儲效率比較高的二進(jìn)制格式的文件,把它存儲在數據存儲器中。Xilinx公司提供用于創(chuàng )建器件編程文件的iMPACT工具,該工具隨附于標準Xilinx ISETM軟件內。iMPACT軟件能自動(dòng)讀取標準的BIT/MCS器件編程文件,并將其轉換為緊湊的二進(jìn)制XSVF格式。

本設計是基于“ARM處理器+FPGA”結構的重構控制器,重構控制器中的FPGA能夠根據ARM處理器傳送來(lái)的命令,對目標可編程器件JTAG接口進(jìn)行控制,并負責解譯XSVF格式的配置文件信息,生成xilinx器件所用的編程指令、數據和控制信號(TMS,TDI,TCK序列)向目標可編程器件的 JTAG TAP控制器提供所需的激勵,從而執行最初在XSVF文件內指定的編程和(可選的)測試操作。使目標可編程器件內的TAP狀態(tài)機進(jìn)行狀態(tài)轉換,將指令和數據掃描到FPGA內部邊界掃描電路指令寄存器和數據寄存器中。完成一次目標可編程器件配置,實(shí)現用戶(hù)此時(shí)所要求功能,在下一時(shí)段,可根據用戶(hù)新的要求,調用重構控制器內部存儲器中不同方案在系統重新配置目標可編程器件,這樣就實(shí)現了硬件復用,減少成本。

2 邊界掃描(JTAG)原理

2.1 JTAG接口基本結構

  JTAG(Joint Test,Action Group,聯(lián)合測試行動(dòng)小組)是一種國際標準測試協(xié)議(IEEE 1149.1兼容),其工作原理是在器件內部定義一個(gè)測試訪(fǎng)問(wèn)端口(TestAccess Port,TAP),通過(guò)專(zhuān)用的JTAG測試工具對內部節點(diǎn)進(jìn)行測試和調試。TAP是一個(gè)通用的端口,外部控制器通過(guò)TAP可以訪(fǎng)問(wèn)芯片提供的所有數據寄存器和指令寄存器,F在JTAG接口還常用于芯片的在線(xiàn)配置(In-System Programmable,ISP),對PLD,FLASH等器件進(jìn)行配置。JTAG允許多個(gè)器件通過(guò)JTAG接口串聯(lián)在一起,形成一個(gè)JTAG鏈,實(shí)現對各個(gè)器件分別測試和在系統配置。

JTAG主要由三部分構成:TAP控制器、指令寄存器和數據寄存器,如圖1所示。標準的JTAG接口有四組輸出線(xiàn):TMS,TCK,TDI,TDO,以及1個(gè)可選信號TRST。



TCK:JTAG測試時(shí)鐘輸入,當TCK保持在零狀態(tài)時(shí),測試邏輯狀態(tài)應保持不變;

TMS:測試模式選擇,控制JTAG狀態(tài),如選擇寄存器、數據加載、測試結果輸出等,出現在TMS的信號在TCK的上升沿由測試邏輯采樣進(jìn)入TAP控制器;

TDI:測試數據輸入,測試數據在TCK的上升沿采樣進(jìn)入移位寄存器(SR);

TDO:測試數據輸出,測試結果在TCK的下降沿從移位寄存器 (SR)移出,輸出數據與輸入到TDI的數據應不出現倒置;

TRST:可選復位信號,低電平有效。

Xilinx器件接受使用JTAG TAP的編程指令和測試指令。在IEEE 1149.1的標準中,用于CPLD,FPGA以及配置PROM的常見(jiàn)指令有:旁路(BYPASS)指令,通過(guò)用1 b長(cháng)的BYPASS寄存器將TDI與TDO直接連接,繞過(guò)(即旁路)邊界掃描鏈中的某個(gè)器件;EXTEST指令,將器件I/O引腳與內部器件電路分離,以實(shí)現器件間的連接測試,它通過(guò)器件引腳應用測試值并捕獲結果;IDCODE指令,返回用于定義部件類(lèi)型、制造商和版本編號的32位硬件級別的識別碼;HIGHZ指令,使所有器件引腳懸置為高阻抗狀態(tài);CFG_IN/CFG_OUT指令,允許訪(fǎng)問(wèn)配置和讀回所用的配置總線(xiàn);JSTART,當啟動(dòng)時(shí)鐘=JTAGCLK時(shí)為啟動(dòng)時(shí)序提供時(shí)鐘。

2.2 Tap狀態(tài)機時(shí)序介紹

JTAG邊界掃描測試由測試訪(fǎng)問(wèn)端口的TAP控制器管理。TMS,TRST和TCK引腳管理TAP控制器的操作,TDI和TDO位數據寄存器提供串行通道。TDI也為指令寄存器提供數據,然后為數據寄存器產(chǎn)生控制邏輯。對于選擇寄存器、裝載數據、檢測和將結果移出的控制信號,由測試時(shí)鐘(TCK)和測試模式(TMS)選擇兩個(gè)信號控制。測試復位信號 (TRST,一般以低電平有效)一般作為可選的第五個(gè)端口信號。

如圖2所示,所有基于JTAG的操作都必須同步于JTAG時(shí)鐘信號 TCK。所有測試邏輯的變化(例如指令寄存器,數據寄存器等)必須出現在TCK的上升沿或下降沿。關(guān)鍵時(shí)序關(guān)系是:TMS和TDI采樣于TCK的上升邊沿,一個(gè)新的TDO值將于TCK下降邊沿后出現,因此一般情況下JTAG的時(shí)鐘不會(huì )太高。



圖3表示了IEEE 1149.1標準定義的TAP控制器的狀態(tài)圖,TAP控制器是16個(gè)狀態(tài)的有限狀態(tài)機,為JTAG接口提供控制邏輯。TAP狀態(tài)轉移如圖3所示,箭頭上的 1或0,表示TMS在TCK上升沿的值(高電平TMS=1,低電平TMS=0),同步時(shí)鐘TCK上升沿時(shí)刻TMS的狀態(tài)決定狀態(tài)轉移過(guò)程。對于TDI端輸入到器件的配置數據有兩個(gè)狀態(tài)變化路徑:一個(gè)用于移指令到指令寄存器中,另一個(gè)用于移數據到有效的數據寄存器,該寄存器的值由當前執行的JTAG指令決定。當TAP控制器處于指令寄存器移位(SHIFT-IR)狀態(tài)時(shí),對于每一個(gè)TCK的上升沿,連接在TDI和TDO之間的指令寄存器組中的移位寄存器向串行輸出方向移一位。



當TMS保持為高電平時(shí),在TCK的上升沿TAP控制器進(jìn)入到“EXIT1- IR”狀態(tài);當TMS為低電平時(shí),TAP控制器保持在“指令寄存器移位”狀態(tài)。

3 重構控制器設計

3.1硬件系統組成

其主要功能是控制按照用戶(hù)不同需求控制調用不同的方案配置目標可編程器件。它主要包括ARM處理器、FPGA、FLASH存儲器和對外總線(xiàn)接口,各功能部件主要功能如下:

(1)ARM處理器選用AT91FR40162S,其主要功能是控制模擬JTAG接口的FPGA讀取FLASH存儲器中的重構方案,實(shí)現在系統配置;

(2)  FPGA協(xié)處理器選用Xilinx公司SPARTEN3AN系列的XC3S700AN-FGG484,是基于非易失性存儲的FPGA,自身帶有PROM,它作為外部總線(xiàn)和ARM控制器之間的雙端口,主要功能是模擬JTAG接口實(shí)現TAP控制器時(shí)序,完成配置方案數據的并串轉換并輸出至外部總線(xiàn);

(3)FLASH 存儲器容量為32M×16 b,用于處理器的上電引導、存放多種重構配置方案。由于要求的存儲容量較大,采用SPANSION公司S29GL512P(32M×16 b)的存儲空間,訪(fǎng)問(wèn)速度為110 ns,可以達到25 ns快速頁(yè)存取和相應的90 ns隨機存取時(shí)間,FBGA封裝;

(4)外部總線(xiàn)接口,可采用1路RS 232驅動(dòng)接收器,實(shí)現和外部通信的接口;

(5)測試線(xiàn)TCK,TMS,TDI和TDO,是重構控制器向目標可編程器件提供所需的JTAG TAP激勵,分別控制目標多個(gè)FPGA的重構配置和反饋重構信息。

3.2重構控制器工作原理

ARM 執行的初始化工作包括程序更新加載運行,FPGA參數設定等;FPGA設定內部寄存器和邏輯狀態(tài)的初始值、內部緩沖區數據清零等。

重構控制器示意圖如圖4所示。圖中ARM處理器一方面通過(guò)ARM總線(xiàn)讀取外部FLASH中的配置方案,對其進(jìn)行并串轉化操作,將其存儲到FLASH存儲器中;另一方面重構控制器中模擬TAP控制器的FPGA,從ARM內置的FLASH存儲器中讀取配置文件,并執行ARM處理器發(fā)出的指令解譯該文件,重構控制器解釋二進(jìn)制文件方法如下:在A(yíng)RM處理器的控制下,從裝載配置文件的FLASH中讀出一個(gè)字節,判斷是哪條JTAG指令,然后根據指令的格式作具體的處理,產(chǎn)生TCK,TMS,TDI和TDO信號,作為目標可編程器件的JTAG接口激勵,與目標可編程器件的JTAG口串聯(lián)成菊花鏈,在A(yíng)RM處理器的控制下,對目標可編程器件進(jìn)行在系統編程。被重構的FPGA由支持局部動(dòng)態(tài)重構的Xilinx公司的Virtex-4系列FPGA來(lái)實(shí)現。



4  結語(yǔ)

本文介紹的重構控制器既具有ARM微控制器所擁有的高速處理器核、體積小、集成度高、運算速度快、存儲器容量大、功耗低等特點(diǎn),又具有FPGA強大的并行計算能力和方便靈活的動(dòng)態(tài)可重構性,使硬件信息 (可編程器件的配置信息)像軟件程序一樣被動(dòng)態(tài)調用或修改。對于特定的目標FPGA芯片,在一定控制邏輯的驅動(dòng)下,對芯片的全部或部分邏輯資源重新進(jìn)行動(dòng)態(tài)配置,從而實(shí)現硬件的時(shí)分復用,靈活快速地改變系統功能,節省邏輯資源,滿(mǎn)足大規模應用需求。

作者:未知 來(lái)源:中電網(wǎng) 2010-2
本文地址:http://selenalain.com/thread-8936-1-1.html     【打印本頁(yè)】

本站部分文章為轉載或網(wǎng)友發(fā)布,目的在于傳遞和分享信息,并不代表本網(wǎng)贊同其觀(guān)點(diǎn)和對其真實(shí)性負責;文章版權歸原作者及原出處所有,如涉及作品內容、版權和其它問(wèn)題,我們將根據著(zhù)作權人的要求,第一時(shí)間更正或刪除。
hidden
游客 發(fā)表于 2010-3-5 17:38:47
不錯
推薦個(gè)學(xué)習嵌入式的網(wǎng)站,
嵌入式學(xué)習網(wǎng)
http://www.embedstudy.com/
超多嵌入式專(zhuān)業(yè)教程,也有超多嵌入式資料下載

還有嵌入式學(xué)習論壇
您需要登錄后才可以發(fā)表評論 登錄 | 立即注冊

相關(guān)在線(xiàn)工具

相關(guān)視頻

關(guān)于我們  -  服務(wù)條款  -  使用指南  -  站點(diǎn)地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網(wǎng) © 版權所有   京ICP備16069177號 | 京公網(wǎng)安備11010502021702
快速回復 返回頂部 返回列表
午夜高清国产拍精品福利|亚洲色精品88色婷婷七月丁香|91久久精品无码一区|99久久国语露脸精品|动漫卡通亚洲综合专区48页