<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 基于ARM+FPGA的重構(gòu)控制器設(shè)計(jì)

          基于ARM+FPGA的重構(gòu)控制器設(shè)計(jì)

          作者: 時(shí)間:2012-05-25 來源:網(wǎng)絡(luò) 收藏

          技術(shù)是指利用可重用的軟硬件資源,根據(jù)的應(yīng)用,地改變自身體系結(jié)構(gòu)的方法。常規(guī)SRAM工藝的實(shí)現(xiàn),利用硬件復(fù)用原理,本文的可采用ARM核微,以芯片協(xié)處理器配合主控制器工作。用戶事先根據(jù)的配置方案,并存儲在重構(gòu)控制器內(nèi)部的存儲器中,上電后,重構(gòu)控制器就設(shè)計(jì)方案分時(shí)定位到目標(biāo)可編程器件內(nèi),同時(shí)保持其他部分電路功能正常,實(shí)現(xiàn)在配置,提高工作效率。

          本文引用地址:http://www.ex-cimer.com/article/148981.htm

          1 SVF格式配置文件

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

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

          2邊界掃描(JTAG)原理

          2.1 JTAG接口基本結(jié)構(gòu)

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

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

          1.jpg

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

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

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

          TDO:測試數(shù)據(jù)輸出,測試結(jié)果在TCK的下降沿從移位寄存器(SR)移出,輸出數(shù)據(jù)與輸入到TDI的數(shù)據(jù)應(yīng)不出現(xiàn)倒置;

          TRST:可選復(fù)位信號,低電平有效。

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


          上一頁 1 2 3 下一頁

          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();