《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 業界動態 > 采用EEPROM對大容量FPGA芯片數據實現串行加載

采用EEPROM對大容量FPGA芯片數據實現串行加載

2009-03-04
作者:范宏波 李一民 朱紅梅

  摘? 要: 通過對比多種FPGA數據加載方式,從可靠性、經濟性及PCB設計等幾個方面說明了串行加載的優越性,分析了目前串行加載所面臨的問題。為解決串行加載新面臨的問題,提出了采用EEPROM與9500系列CPLD相結合實現串行加載的構想,并通過實際設計,成功地實現了該構想。

  關鍵詞: FPGA? CPLD? EEPROM? 并-串轉換

?

  自大規?,F場可編程邏輯器件問世以來,先后出現了兩類器件,一類是基于SRAM體系結構的FPGA系列,如XILINX公司的4000系列和最新的Virtex系列;另一類是基于fastFLASH技術的CPLD器件,如XILINX公司的9500系列和Lattice公司的ispLSxx系列芯片。FPGA具有容量大、設計資源豐富、片內ROM及RAM設計靈活等特點[1],但是它們需要在每次上電時進行數據加載。目前實現加載的方法有以下三種:①采用PROM并行加載;②采用專用SROM串行加載;③采用單片機控制實現加載。第一種方式需要占用較多的FPGA管腳資源,雖然這些管腳在加載完成后可用作一般I/O口,但在加載時不允許這些管腳有其他任何外來信號源;另外數據存儲器PROM與FPGA之間的大量固定連線如8位數據線以及大量訪問PROM的地址線等,使得PCB設計不便。但是第一種方式有一個有利的方面,即PROM的容量較大、容易購置、價格低、技術支持(編程器)較好。第二種方式情況剛好與第一種方式相反,即占用資源少、PCB布板方便,但是容量小、價格較高、兼容性差。第三種方式采用單片機控制,由PROM中讀取并行數據,然后再串行送出。由于涉及到單片機編程,對于開發者來說較為不便;另外,如果單片機僅用來實現該任務,較為浪費硬件資源。CPLD的一個最大優點是采用計算機專用開發工具,通過JTAG口直接一次性實現編程數據加載,并永久保留,除非進行再次編程(與GAL器件相似)。該類器件比較適合在實驗室內進行現場調試,但是由于其數據的加載必須通過計算機,因此對于從事野外作業者來說會產生不便。

  通過上述比較,并結合實際工作情況,我們認為采用串行數據加載比較方便、可靠(這種可靠性得益于FPGA與SROM之間較少的接口線)。但隨著FPGA規模的不斷升級,其CONFIG數據量越來越大,截止到本文寫作時,CONFIG數據量最大已到6MBIT,雖然XILINX公司有相關的XC17X系列SROM提供使用,但皆為一次性芯片[2]、開發成本較高、代理商供貨周期長、價格較高,這給FPGA的應用及普及帶來很大的障礙。我們曾使用過AT&T公司的ATT17系列電可擦除SROM,但是該類SROM芯片能與XILINX系列FPGA芯片實現接口的種類不多,且容量小。由于種種原因,其價格往往是同樣存儲容量的EEPROM的五、六倍,甚至更高,并且來源困難。那么能不能結合并行加載與串行加載的優點,從而解決大容量FPGA數據加載的問題呢?我們在仔細分析了串行加載機制后,認為采用EEPROM作為數據存儲器,經過可控的并-串轉換,應該可以實現數據加載。下面以XILINX公司Virtex系列XCV100芯片為例,采用ATMEL公司1兆位的AT29C010A進行數據存儲,采用XILINX公司9500系列XC95108芯片作為加載控制器件進行設計。

1 原理設計

  原理性Master Serial模式串行加載時序如圖1所示。在該加載模式中,比較重要的幾個信號為/INIT、CCLK、DATAIN、DONE。/INIT表示FPGA芯片上電時或者當/PROGRAM信號為低時FPGA內部數據初始化過程,并作為外送信號給數據加載控制器件作為復位之用。當/INIT信號躍為高電平時,CCLK開始啟動。加載數據DATAIN在CCLK的上升沿打入,與通用串行通訊相類似,加載數據流也有開始位與結束位,且以數據幀的方式接收。一旦發生錯誤,FPGA立即停止接收數據,并將/INIT信號置為低電平,因此該信號又稱為錯誤指示信號。當數據全部接受并驗證無誤后,FPGA將DONE信號置為“1”[3]。

?

?

  在分析了FPGA加載數據流特性后,可以得出這樣一個結論:保證CCLK與DATAIN之間的嚴格同步與連續性,就可以實現加載?;诖私Y論,在生成加載數據格式時,產生單片SROM串行格式,對于XILINX公司的FPGA系列,該格式為.MCS文件格式;然后用ALL07編程器以INTEL HEX數據格式將其寫入EEPROM中。余下的工作是在CCLK、/INIT、DATAIN的控制下完成并-串轉換。該控制過程采用一片CPLD之95系列XC95108芯片來承擔,在設計容量上采用一片XC9536即可完成,之所以采用XC95108是因為其尚需要完成其他任務。其原理框圖如圖2所示。

?

2 并-串轉換時序設計

  在時序設計上,關鍵在于要保持DATAIN加載數據的連續性、DATAIN與CCLK加載時鐘的同步性以及EEPROM訪問地址的復位問題。對于復位問題,采用上電時FPGA產生的/INIT信號對95108內部的EEPROM地址發生器復位。這樣做的原因是/INIT與FPGA之CCLK時鐘產生有著同步關系,但同時也默認上電加載是一次成功;在考慮串行DATAIN數據的連續性時,采用兩組移位寄存器,設定它們為R_shiftA和R_shiftB,當R_shiftA在進行移位操作時,R_shiftB由EEPROM中讀入八位并行數據,反之亦然;為保持DATAIN與CCLK時鐘的同步性,所有上述操作都以CCLK為同步時鐘,值得注意的是,由于DATAIN串行數據是在CCLK的上升沿打入FPGA,因此我們給予XC95108芯片設計的運轉時鐘是經過反相的CCLK時鐘,這樣就保證了CCLK與DATAIN的時間關系。

  以下是為該加載設計的VHDL硬件編程語言設計程序[4][5],其中的計數器及移位寄存器模塊用F2.1I設計軟件之LogicBlox模塊產生。整個程序經F2.1I開發軟件仿真、編譯成功后,經JTAG編程電纜寫入XC95108芯片。加電后便加載成功,經多次加電實驗,成功率為100%。

  雖然該程序是針對XCV100芯片及AT29C010A EEPROM設計的,但對于其他FPGA及EEPROM芯片同樣適用,不同的是針對不同容量的EEPROM,應改變其地址計數器的位數。

  library IEEE;

  use IEEE.std_logic_1164.all;

  use ieee.std_logic_arith.all;

  use ieee.std_logic_unsigned.all;

  entity v10sload is

?????? port (

?????? pDATA: in STD_LOGIC_VECTOR(7 downto 0);

?????? pADDRESS:inout STD_LOGIC_VECTOR(16

????????????????????????????????????????????downto 0);

????? ???? CCLKIN: in STD_LOGIC;

 ??????? ?RESET:in STD_LOGIC;

?????????? DATAIN:out STD_LOGIC

????????????? );

  end v10sload;

  architecture v10sload_arch of v10sload is

  signal:loadin,CE,nCE,CCLK8,nRESET,nCCLK,aDATAIN,

????????????? bDATAIN:std_logic;

  signal clkenable,CCLK:std_logic;

  signal ppDATA:std_logic_vector(7 downto 0);

  component clk_div8

????????????? PORT(

??? CLOCK,ASYNC_CTRL: IN std_logic;

??? CLK_OUT: OUT std_logic);

end component;

component R_shift8

  PORT(

???  D_IN: IN std_logic_vector(7 DOWNTO 0);

???  LOAD: IN std_logic;

???  CLK_EN: IN std_logic;

???  CLOCK: IN std_logic;

???  LS_OUT: OUT std_logic);

end component;

component BUFG

  port(I:in std_logic; O:out std_logic);

end component;

begin

??? -------------------------------????

--data-loading function statements here

nRESET<=not RESET;

init_data:process(RESET)

begin

  if(RESET='0') then

????ppDATA<=″00000000″;

????else ppDATA<=pDATA;

end if;

end process init_data;

L0:BUFG???? port map(I=>CCLKIN,O=>CCLK);

nCCLK<=not CCLK;

L1:counter17? portmap

????(CLOCK=>CCLK8,ASYNC_CTRL=>nRESET,

?????Q_OUT=>pADDRESS);

L2:clk_div8? portmap

?  (CLOCK=>nCCLK,ASYNC_CTRL=>nRESET,

????CLK_OUT=>CCLK8);

nCE<=not pADDRESS(0);

CE<=pADDRESS(0);

clkenable<='1';

L3:R_shift8??? portmap

??? (D_IN=>ppDATA,LOAD=>nCE,CLK_EN=>

????????????? ??? clkenable,CLOCK=>nCCLK,

??? LS_OUT=>aDATAIN);

L4:R_shift8??? portmap

????(D_IN=>ppDATA,LOAD=>CE,CLK_EN=>

????clkenable,CLOCK=>nCCLK,

??? LS_OUT=>bDATAIN);

process(aDATAIN,bDATAIN,CE)

begin

  if(CE='1') then DATAIN<=aDATAIN;

  else DATAIN<=bDATAIN;

end if;

end process;

end v10sload_arch;

?

參考文獻

1 XILINX 公司DATABOOK,1999:54~56

2 XILINX公司網站www.xilinx.com

3 王小軍.VHDL 簡明教程.北京:清華大學出版社,1997

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲一区二区高清| 久久综合九色综合网站| 欧美一级精品大片| 亚洲图片欧洲图片日韩av| 好吊妞这里只有精品| 国产日韩精品一区| 国产精品日韩在线| 国产精品进线69影院| 欧美日韩一区在线| 欧美三区美女| 欧美日韩综合| 欧美视频一区二区三区…| 欧美日韩免费一区| 欧美日韩一卡| 欧美午夜视频在线观看| 欧美日韩一区二区在线观看视频| 欧美精品一区二区三区一线天视频| 欧美gay视频激情| 欧美风情在线| 欧美日韩第一区日日骚| 欧美色大人视频| 欧美午夜精品电影| 国产精品家教| 国产日本精品| 狠狠色丁香婷婷综合| 亚洲第一成人在线| 亚洲人人精品| 这里只有精品丝袜| 亚洲欧美在线高清| 欧美专区在线观看| 亚洲欧洲午夜| 一区二区三区精品在线| 亚洲嫩草精品久久| 久久精品视频在线看| 裸体歌舞表演一区二区| 欧美女激情福利| 国产精品亚洲人在线观看| 国产综合网站| 亚洲国产精品悠悠久久琪琪 | 国产伦精品一区二区三区视频孕妇 | 国产精品99免费看| 国产精品伊人日日| 黑人操亚洲美女惩罚| 亚洲激情视频在线播放| 亚洲视频一区在线| 久久精品卡一| 一区二区三区四区五区精品| 欧美怡红院视频| 免费观看成人www动漫视频| 欧美精品一区二区三区在线看午夜| 欧美视频福利| 国产一区高清视频| 亚洲精品在线看| 午夜在线精品偷拍| 亚洲美女啪啪| 欧美专区日韩视频| 欧美日韩成人在线播放| 国产午夜精品一区二区三区视频| 在线日韩成人| 亚洲天天影视| 91久久精品国产| 午夜一区在线| 欧美高清不卡| 国产午夜精品久久久| 亚洲精品社区| 欧美专区在线| 亚洲专区国产精品| 欧美成人一区二区三区在线观看 | 国产精品国产福利国产秒拍| 国产亚洲精品一区二555| 亚洲精品一区二区三区不| 小处雏高清一区二区三区| 日韩亚洲欧美一区二区三区| 亚久久调教视频| 欧美日本高清| 激情综合久久| 亚洲一区在线观看免费观看电影高清| 亚洲韩国一区二区三区| 午夜一区二区三区在线观看| 欧美激情精品久久久久久免费印度 | 欧美在线精品免播放器视频| 一区二区三区日韩欧美| 美女国产一区| 国产精品揄拍500视频| 亚洲美女av电影| 亚洲精品韩国| 快射av在线播放一区| 国产精品一区二区女厕厕| 99国产精品视频免费观看一公开| 亚洲国产99| 久久久久久穴| 国产麻豆日韩| 亚洲无玛一区| 99re这里只有精品6| 老司机午夜精品视频| 国产情侣久久| 亚洲综合色在线| 亚洲性感美女99在线| 欧美激情免费在线| 精品动漫av| 欧美在线3区| 久久福利精品| 国产欧美日韩综合| 亚洲欧美日产图| 亚洲欧美日韩中文播放| 欧美精品在线视频| 亚洲激情第一区| 亚洲精品色婷婷福利天堂| 久久尤物电影视频在线观看| 国产欧美一区二区三区久久| 中文久久乱码一区二区| 艳女tv在线观看国产一区| 欧美激情第五页| 亚洲第一在线| 最新国产精品拍自在线播放| 久久综合电影| 国产在线不卡| 亚洲福利在线看| 久久精品视频亚洲| 国产一区亚洲一区| 香蕉国产精品偷在线观看不卡| 欧美一级艳片视频免费观看| 国产精品午夜在线| 性刺激综合网| 久久精品国产2020观看福利| 国产人久久人人人人爽| 午夜免费日韩视频| 久久精品99国产精品| 国产一区二区三区不卡在线观看| 午夜精品在线看| 久久久久久有精品国产| 国产亚洲精品7777| 久久爱另类一区二区小说| 久久久久久久综合日本| 今天的高清视频免费播放成人| 亚洲成人资源网| 你懂的视频欧美| 亚洲国产精品尤物yw在线观看| 亚洲精品资源美女情侣酒店| 欧美黄色视屏| 99re8这里有精品热视频免费 | 亚洲国产成人av好男人在线观看| 老司机午夜精品视频在线观看| 亚洲国产精品一区| 亚洲网址在线| 国产欧美一区二区色老头| 欧美一区二区视频在线观看| 另类天堂av| 亚洲精品偷拍| 午夜精品久久一牛影视| 国产亚洲va综合人人澡精品| 亚洲国产成人不卡| 欧美精品在欧美一区二区少妇| 99精品热6080yy久久 | 一区二区三区欧美日韩| 国产精品福利网| 欧美一级在线播放| 欧美成人激情视频免费观看| 洋洋av久久久久久久一区| 午夜电影亚洲| 悠悠资源网亚洲青| 亚洲香蕉伊综合在人在线视看| 国产精品视频免费在线观看| 欧美在线视频免费观看| 欧美国产日韩在线| 亚洲视频一二三| 老色鬼久久亚洲一区二区| 亚洲精品网址在线观看| 性做久久久久久久久| 在线观看91精品国产入口| 亚洲自拍16p| 一区二区在线观看视频| 一区二区三区久久精品| 国产日韩精品在线| 亚洲六月丁香色婷婷综合久久| 国产精品久久看| 亚洲区免费影片| 国产精品国产三级国产专区53| 久久精品男女| 国产精品v欧美精品v日韩| 亚洲电影在线看| 国产精品分类| 亚洲经典三级| 国产精品一区二区久久精品| 91久久久久久久久| 国产欧美一二三区| 99精品欧美一区| 国产一区二区三区四区| 一本色道久久99精品综合| 国产性做久久久久久| 一区二区三区波多野结衣在线观看| 国产视频久久久久久久| 亚洲视频免费观看| 在线视频国产日韩| 欧美在线视频不卡| av不卡免费看| 你懂的视频一区二区| 亚洲欧洲av一区二区三区久久| 欧美理论视频| 亚洲激情偷拍|