• <li id="00i08"><input id="00i08"></input></li>
  • <sup id="00i08"><tbody id="00i08"></tbody></sup>
    <abbr id="00i08"></abbr>
  • 關 閉

    新聞中心

    EEPW首頁 > 工控自動化 > 設計應用 > 基于ARM+FPGA的重構控制器設計

    基于ARM+FPGA的重構控制器設計

    作者: 時間:2010-03-24 來源:網絡 收藏

    摘要:為滿足可重配置系統的靈活性要求,介紹了一種“處理器+”結構的,提出由微處理器通過模擬JTAG接口的在系統配置目標可編程器件的方法。給出系統的硬件結構,并詳細介紹了JTAG在系統配置的時序要求,以及在此結構中如何利用IEEE JTAG1149.1邊界掃描測試技術和描述JTAG總線標準的XSVF格式配置文件來實現對目標可編程器件進行在系統配置。
    關鍵詞:JTAG接口;FPGA;;XSVF格式

    本文引用地址:http://www.czjhyjcfj.com/article/163191.htm

    技術是指利用可重用的軟硬件資源,根據不同的應用需求,靈活地改變自身體系結構的方法。常規SRAM工藝的FPGA都可以實現重構,利用硬件復用原理,本文設計的可重構采用核微作為主控制器,以FPGA芯片作為協處理器配合主控制器工作。用戶事先根據需求設計出不同的配置方案,并存儲在重構控制器內部的存儲器中,上電后,重構控制器就可以按需求將不同設計方案分時定位到目標可編程器件內,同時保持其他部分電路功能正常,實現在系統靈活配置,提高系統工作效率。

    1 SVF格式配置文件
    很多嵌入式系統中都用到了FPGA/CPlD等可編程器件,在這些系統中利用SVF格式配置文件就可以方便地通過微控制器對可編程器件進行重新配置。目前可編程芯片廠商的配套軟件都可以生成可編程器件的SVF格式配置文件,串行矢量格式(SVF)是一種用于說明高層IEEE 1149.1(JTAG)總線操作的語法規范。SVF由Texas Instruments開發,并已成為數據交換標準而被Teradyne,Tektronix等JTAG測試設備及軟件制造商采用。Xilinx的FPGA以及配置PROM可通過JTAG接口中TAP控制器接收SVF格式的編程指令。由于SVF文件由ASCII語句構成,它要求較大的存儲空間,并且存儲效率很低,無法勝任嵌入式應用。為了在嵌入式系統中充分利用其有限的存儲空間,并不直接利用SVF文件對可編程器件進行在系統編程,而是將SVF文件轉換成另一種存儲效率比較高的二進制格式的文件,把它存儲在數據存儲器中。Xilinx公司提供用于創建器件編程文件的iMPACT工具,該工具隨附于標準Xilinx ISETM軟件內。iMPACT軟件能自動讀取標準的BIT/MCS器件編程文件,并將其轉換為緊湊的二進制XSVF格式。
    本設計是“ARM處理器+FPGA”結構的重構控制器,重構控制器中的FPGA能夠根據ARM處理器傳送來的命令,對目標可編程器件JTAG接口進行控制,并負責解譯XSVF格式的配置文件信息,生成Xilinx器件所用的編程指令、數據和控制信號(TMs,TDI,TCK序列)向目標可編程器件的JTAG TAP控制器們提供所需的激勵,從而執行最初在XSVF文件內指定的編程和(可選的)測試操作。使目標可編程器件內的TAP狀態機進行狀態轉換,將指令和數據掃描到FPGA內部邊界掃描電路指令寄存器和數據寄存器中。完成一次目標可編程器件配置,實現用戶此時所要求功能,在下一時段,可根據用戶新的要求,調用重構控制器內部存儲器中不同方案在系統重新配置目標可編程器件,這樣就實現了硬件復用,減少成本。

    2 邊界掃描(JTAG)原理
    2.1 JTAG接口基本結構
    JTAG(Joint Test Action Group,聯合測試行動小組)是一種國際標準測試協議(IEEE 1149.1兼容),其工作原理是在器件內部定義一個測試訪問端口(TestAccess Port,TAP),通過專用的JTAG測試工具對內部節點進行測試和調試。TAP是一個通用的端口,外部控制器通過TAP可以訪問芯片提供的所有數據寄存器和指令寄存器?,F在JTAG接口還常用于芯片的在線配置(In-System Prograromable,ISP),對PLD,FLASH等器件進行配置。JTAG允許多個器件通過JTAG接口串聯在一起,形成一個JTAG鏈,實現對各個器件分別測試和在系統配置。


    上一頁 1 2 3 下一頁

    評論


    相關推薦

    技術專區

    關閉
    主站蜘蛛池模板: 麟游县| 虞城县| 休宁县| 丹寨县| 中牟县| 阳山县| 西丰县| 新沂市| 蕲春县| 锦屏县| 保靖县| 灌南县| 双桥区| 吉安县| 丁青县| 南岸区| 霍林郭勒市| 淳安县| 荔波县| 潞城市| 营山县| 玉田县| 青海省| 香河县| 宿州市| 阿荣旗| 瑞安市| 吉隆县| 肥东县| 房山区| 甘洛县| 法库县| 台山市| 台北市| 罗定市| 山西省| 瑞安市| 淳安县| 方正县| 许昌县| 五寨县|