《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于CPLD的FPGA快速配置電路的設計
基于CPLD的FPGA快速配置電路的設計
張洪剛, 邢煥革, 王德石
摘要: 介紹了采用CPLD和Flash器件對FPGA實現快速并行配置,并給出了具體的硬件電路設計和關鍵模塊的內部編程思路。
Abstract:
Key words :

  摘 要: 介紹了采用CPLD" title="CPLD">CPLD和Flash" title="Flash">Flash器件對FPGA" title="FPGA">FPGA實現快速并行配置" title="并行配置">并行配置,并給出了具體的硬件電路設計和關鍵模塊的內部編程思路。
  關鍵詞: FPGA 并行配置 Flash CPLD


  基于SRAM工藝的FPGA(現場可編程門陣列)具有集成度高、邏輯功能強等特點;應用FPGA進行數字電路設計,不但能減小電路的體積,提高系統運行的可靠性,而且其先進的開發工具可使電路設計和系統調試周期大大縮短;FPGA可無限次重復擦寫,可使數字系統在線重新配置,設計更加靈活,功能更加強大,且易于更改和升級。由于FPGA中靜態隨機存儲器(SRAM)掉電后數據會丟失,系統每次上電后需重新配置數據,如何快速、高效地將配置數據寫入目標器件,并且保證其在掉電后再次上電能自動可靠地恢復配置,就成為整個系統的關鍵所在。本文就基于CPLD的FPGA并行數據配置方法和配置電路的設計進行初步的研究,并給出具體的硬件電路設計和關鍵模塊的內部編程思路。
1 FPGA數據配置方法比較
  實現FPGA的數據配置方法有很多,但根據器件類型和應用場合,Xilinx公司為其FPGA系列產品提供了多種數據配置方式,歸納起來主要有以下四種[3]:①采用JTAG方式加載;②采用主串方式加載;③采用從串方式加載;④采用并行方式加載。
  JTAG方式數據加載方法是基于IEEE1149.1和IEEE1532的配置模式,通過TDI、TDO、TMS和TCK四根信號線接到FPGA上的相應引腳實現數據加載。這種方式電路結構簡單、工作可靠、無需外接PROM等存儲器件進行數據配置,但需要專用的數據配置電纜,因此該方法適用于數字系統的開發階段。
  主串方式數據加載方法是通過串行方法讀取專用PROM存儲介質中數據,實現FPGA的在線配置的,其配置時鐘由FPGA內部送出。這種方式電路實現較為簡單,但該配置方式必須使用Xilinx公司生產的專用PROM,應用不靈活。
  從串方式數據加載方法類似于主串方式,但配置時鐘由FPGA外部提供,需要設計專用電路控制整個配置過程。
  并行方式數據加載方法是通過并行方法讀取通用Flash或E2PROM等存儲介質中的數據,實現FPGA的在線配置的。由于采用并行方式,八位數據可同時被寫入FPGA,數據配置速度最快。其配置時鐘由外部提供,需要設計專用電路控制整個配置過程。常用的配置控制器可以是各類處理器、微控制器或可編程邏輯器件,目前應用較多的是采用單片機和E2PROM構成控制電路。隨著FPGA規模和性能的不斷提升,其配置文件越來越大,對配置速度的要求也越來越高,所以快速的并行配置方式必將得到越來越廣泛的應用。
2 FPGA并行方式數據配置原理
  采用并行方式進行FPGA數據配置時,其相關配置引腳可分為專用配置引腳和非專用配置引腳。專用配置引腳包括:配置模式引腳M2、M1、M0;配置時鐘引腳CCLK;配置邏輯異步復位引腳;啟動控制引腳DONE。這些引腳只在配置時起作用,配置完成后不能作其它用途。非專用配置引腳包括:數據接口D0~D7、片選信號CS、寫信號、BUSY、等引腳,這些引腳在配置時作為信號通道使用,配置完成后還可作為普通I/O口使用。數據配置時序如圖1所示。當為低電平時,FPGA內部數據初始化,初始化完成后,DONE信號變為低電平,同時信號自動置為低電平,開始清空配置存儲器。配置存儲器清空后,信號重新被置為高電平,同時器件對模式引腳進行采樣,確定以并行方式加載配置數據。當信號都為低電平時,就可以通過數據接口D0~D7進行數據配置。圖1清晰地表明了并行配置的全過程。


3 系統設計
3.1 系統組成

  并行方式的FPGA數據配置系統由上位機、可編程邏輯器件(CPLD)、Flash、FPGA等組成,其結構如圖2所示。控制器件對整個系統的性能具有重要影響,低成本的處理器、微控制器工作頻率較低,在對速度要求較高的場合,會成為系統速度的瓶頸,不能發揮并行配置的速度優勢,而且僅作為配置控制器使用又造成資源的浪費。采用CPLD作為控制器,Flash作為存儲器件,不僅能滿足速度和功能的要求,而且硬件電路更為簡潔。


  并行數據配置系統的上位機可以選用PC機、工控機等,主要對CPLD進行簡單的功能控制,并對系統數據進行處理。CPLD是整個系統設計的核心,其主要功能是進行配置控制和地址生成。Flash閃存是配置文件的存儲器件,由專用開發工具生成FPGA配置文件,預先燒寫進Flash中。FPGA是系統中配置的目標器件,本系統采用六片Spartan II" title="Spartan II">Spartan II系列中的Xilinx XC2S200。
3.2 硬件設計
3.2.1 芯片選型
  配置電路中CPLD采用XC9500系列中的XC9536芯片,宏單元數目為36個,采用快閃存儲技術,最高工作頻率可達100MHz。PC44封裝的XC9536包括時鐘端口在內共有34個通用I/O口,可以滿足系統的要求。配置存儲器采用Winbond公司的W29C040-90,其512K×8bit的容量可以依次存放三個不同的配置文件,存取周期可達90ns。Spartan II系列FPGA的配置時鐘最高可達66 MHz,但考慮到閃存的存取時間限制,配置晶振采用8MHz有源晶振。
3.2.2 原理圖
  配置電路接口如圖3所示,并行配置的多片FPGA的控制信號CCLK、、DONE、和BUSY以及數據線DATA(7:0)并行連接,通過分別設置片選信號CS(0:5)實現各器件的依次配置,直到所有FPGA都配置完成后才進入START-UP階段,經過八個時鐘周期延遲后一起進入工作狀態。


  圖中Flash的存儲區被分配成三個區域,分別存儲不同的配置文件。其使能信號和地址信號由CPLD提供,當EN為高時,在時鐘信號的下降沿對應A(18:0)的八位數據就出現在數據線D(7:0)上。CPLD的作用主要是:①實現與上位機通訊,接收指令并將工作狀態反饋到上位機;②通過置PROG低電平控制FPGA的初始化過程;③初始化完成后,控制各FPGA的配置過程。
  在數據配置過程中,相應FPGA的信號應置低電平,若CS信號已被設置,則的狀態就不能改變,否則將引起一個Abort過程[1],使配置過程中斷。為確保在CCLK上升沿采到正確的數據,在CCLK下降沿改變數據線D(7:0)上的數據。在CCLK的上升沿,若BUSY信號為低電平,數據在此時鐘周期內被接收;若BUSY為高電平,數據不能被接收,直到BUSY變低后的第一個時鐘周期才能繼續接收數據。因此,這時的配置數據需要一直保持。
  需要注意的是,多片FPGA的START-UP過程是同時進行的,為實現這一功能,在由Xilinx的開發工具ISE[4]中生成配置文件時,需要修改相應的屬性。
3.3 軟件設計
  CPLD的設計是本系統中最重要的部分,它所實現的功能模塊包括接口模塊、控制模塊、地址發生器模塊。接口模塊實現與上位機的通信,接收上位機的指令并作相應處理,同時將工作狀態反饋給上位機;控制模塊提供控制時序命令,操縱整個配置過程;地址發生器模塊為讀取閃存數據提供數據地址。內部各功能模塊采用VHDL硬件描述語言實現,控制主程序用mealy狀態機實現。控制主程序的狀態轉移圖如圖4所示,其中狀態Start是初始狀態,Init是初始化過程,Clear RAM過程清空配置存儲器,Config是配置過程,Wait過程是配置多片FPGA的中間過程。


  控制模塊根據上位機的控制指令完成FPGA的初始化、配置等過程,并將運行結果回傳給上位機。由VHDL硬件描述語言生成的原理圖符號如圖5所示,其中,CLK是配置時鐘,RESET是啟動信號,DONE、是FPGA的反饋信號,CEND是地址發生器模塊計數結束標志,EN是計數允許信號;是控制信號,TRUE、FALSE是狀態信號,反饋給上位機;CS(0:3)是多片FPGA的片選信號。控制模塊的ModelSim仿真結果如圖6所示。

 


參考文獻
1 Xilinx Spartan II 2.5V FPGA Complete Data Sheet. Xilinx,2004
2 王道憲.CPLD/FPGA可編程邏輯器件應用與開發[M].北京:國防工業出版社, 2004
3 任曉東,文博.CPLD/FPGA高級應用開發指南[M]. 北京:電子工業出版社, 2003
4 王誠.FPGA/CPLD設計工具Xilinx ISE 5.X使用詳解[M]. 北京:人民郵電出版社, 2003
5 房 磊,張煥春. FPGA的配置及接口電路[J]. 世界電子元器件, 2003(11):55~57

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲一区国产视频| 99国产精品一区| 亚洲日本成人| 激情av一区| 国产在线拍偷自揄拍精品| 国产精品三级久久久久久电影| 欧美日韩亚洲网| 欧美日本一区| 欧美理论电影在线播放| 欧美福利视频在线| 欧美不卡视频一区发布| 农村妇女精品| 欧美韩国在线| 欧美日韩免费在线视频| 欧美日韩一区二区三区四区五区 | 欧美成人四级电影| 免费成人av在线看| 欧美高清视频一区二区| 欧美精品一区二区精品网| 欧美日韩国产系列| 欧美性感一类影片在线播放| 欧美天堂亚洲电影院在线观看| 欧美日本不卡| 欧美日韩视频免费播放| 欧美午夜一区| 国产美女一区二区| 精品成人一区二区三区| 伊人久久大香线蕉综合热线| 尤物九九久久国产精品的分类| 在线看片第一页欧美| 亚洲精品国产精品国自产在线| 日韩视频在线一区二区| 在线视频欧美一区| 午夜视频久久久久久| 久久精品国产亚洲5555| 亚洲精品国久久99热| 中文一区二区| 欧美一区二区三区在| 美女脱光内衣内裤视频久久网站| 欧美国产一区二区| 国产精品久久影院| 依依成人综合视频| 一本不卡影院| 久久成人免费电影| 夜夜嗨一区二区三区| 欧美一级视频精品观看| 免费看亚洲片| 国产精品久久久久永久免费观看| 国产亚洲精品久久久久动| 91久久国产自产拍夜夜嗨| 中文国产一区| 久久精品青青大伊人av| 亚洲视频在线观看视频| 久久激情视频免费观看| 欧美精品一区二区精品网 | 亚洲最新视频在线播放| 欧美一区二区三区的| 欧美高清在线播放| 国产欧美成人| 亚洲毛片av在线| 久久精品国产99国产精品| 中文高清一区| 久久在线免费| 国产精品免费小视频| 在线看欧美视频| 亚洲一区二区三区四区视频| 91久久一区二区| 亚洲欧美日韩在线观看a三区| 欧美a级在线| 国产精品一区2区| 亚洲美女区一区| 久久精品99国产精品日本| 亚洲午夜一区二区| 奶水喷射视频一区| 国产女人精品视频| 99精品视频免费在线观看| 亚洲第一中文字幕在线观看| 午夜精品美女自拍福到在线| 欧美美女福利视频| 国内揄拍国内精品少妇国语| 亚洲在线电影| 亚洲午夜视频| 欧美巨乳波霸| 在线成人激情| 欧美一区二区在线观看| 亚洲欧美激情视频| 欧美精品97| 1024欧美极品| 亚洲电影在线免费观看| 欧美一级二区| 国产精品成人免费视频| 亚洲免费精彩视频| 亚洲青涩在线| 可以免费看不卡的av网站| 国产人妖伪娘一区91| 在线午夜精品| 亚洲图片在线观看| 欧美精品在线网站| 亚洲高清视频一区| 亚洲国产成人精品视频| 久久久噜噜噜久噜久久| 国产私拍一区| 欧美一级视频精品观看| 欧美一级久久久久久久大片| 欧美午夜欧美| 一区二区三区免费观看| 亚洲午夜久久久| 欧美色区777第一页| 亚洲美女淫视频| 日韩视频一区二区三区在线播放免费观看| 久久综合五月天婷婷伊人| 国产一区观看| 亚洲第一毛片| 欧美14一18处毛片| 1024成人网色www| 最近看过的日韩成人| 蜜臀a∨国产成人精品| 一区久久精品| 亚洲精品欧美日韩| 欧美精品偷拍| 99精品久久久| 亚洲免费一在线| 国产精品一区三区| 欧美一区二区日韩| 久久一区二区精品| 亚洲大胆av| 日韩天堂av| 欧美视频在线观看视频极品| 中日韩美女免费视频网址在线观看| 亚洲天堂激情| 国产精品最新自拍| 久久精彩视频| 欧美www视频| 亚洲美女一区| 性xx色xx综合久久久xx| 国产情侣一区| 亚洲国产经典视频| 欧美激情女人20p| 9i看片成人免费高清| 香蕉成人久久| 好看的亚洲午夜视频在线| 亚洲人成人77777线观看| 欧美日本亚洲| 亚洲一区中文字幕在线观看| 久久久在线视频| 亚洲国产精品女人久久久| 中文久久精品| 国产日韩欧美制服另类| 91久久精品美女高潮| 欧美日韩成人一区二区| 亚洲一二三区精品| 久久五月婷婷丁香社区| 亚洲福利国产精品| 亚洲婷婷综合色高清在线 | 亚洲大黄网站| 欧美日韩久久| 香蕉av777xxx色综合一区| 麻豆成人在线观看| 日韩亚洲欧美在线观看| 久久aⅴ国产欧美74aaa| 亚洲国产岛国毛片在线| 亚洲一区三区视频在线观看| 国产主播精品| 中文一区二区| 黄色国产精品| 亚洲一区精彩视频| 伊人色综合久久天天五月婷| 亚洲一区二区三区久久| 狠狠色丁香婷综合久久| 中文久久精品| 好吊色欧美一区二区三区视频| 夜夜嗨av色一区二区不卡| 国产亚洲精品久| 中文精品视频一区二区在线观看| 国产日韩在线看片| 一本久久青青| 韩国精品一区二区三区| 亚洲午夜极品| 在线看片欧美| 欧美中文字幕视频| 日韩午夜激情av| 噜噜噜91成人网| 午夜激情综合网| 欧美日韩国产一区精品一区| 欧美影视一区| 国产精品成人aaaaa网站| 亚洲精品国产精品久久清纯直播| 国产精品毛片大码女人| 亚洲精品久久久一区二区三区| 国产美女精品视频免费观看| 一本久久a久久精品亚洲| 国内外成人在线| 香蕉久久夜色精品国产| 亚洲精品日韩在线| 久久资源av| 亚洲欧美日韩中文播放| 欧美系列电影免费观看| 日韩午夜电影av| 在线成人av.com| 久久久久久久一区|