《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 測(cè)試測(cè)量 > 設(shè)計(jì)應(yīng)用 > FPGA器件的在線配置方法
FPGA器件的在線配置方法
摘要: 多任務(wù)電路結(jié)構(gòu)重配置即將多個(gè)配置文件分區(qū)存儲(chǔ)到外部存儲(chǔ)器中,然后由單片機(jī)接收不同的命令,以選擇讀取不同存儲(chǔ)器區(qū)的數(shù)據(jù)下載到FPGA器件,實(shí)現(xiàn)在線配置成多種不同的工作模式。
關(guān)鍵詞: FPGA 在線配置 ICR AT24C256
Abstract:
Key words :

  引 言

  在當(dāng)今變化的市場(chǎng)環(huán)境中,產(chǎn)品是否便于現(xiàn)場(chǎng)升級(jí),是否便于靈活使用成為產(chǎn)品能否進(jìn)入市場(chǎng)的關(guān)鍵因素。在這種背景下,Altera公司的基于SRAM LUT結(jié)構(gòu)的FPGA器件得到了廣泛的應(yīng)用。雖然這些器件應(yīng)用廣泛,但由于其內(nèi)部采用SRAM工藝,它的配置數(shù)據(jù)存儲(chǔ)在SRAM中。由于SRAM的易失性,每次系統(tǒng)上電時(shí),必須重新配置數(shù)據(jù),即ICR(In-Circuit Reconfigurability),只有在數(shù)據(jù)配置正確的情況下系統(tǒng)才能正常工作。在線配置方式一般有兩類:一是通過下載電纜由計(jì)算機(jī)直接對(duì)其進(jìn)行配置,二是通過配置芯片對(duì)其進(jìn)行配置。通過PC機(jī)對(duì)FPGA進(jìn)行在系統(tǒng)重配置,雖然在調(diào)試時(shí)非常方便,但在應(yīng)用現(xiàn)場(chǎng)是很不現(xiàn)實(shí)的。上電后,自動(dòng)加載配置對(duì)FPGA應(yīng)用來說是必需的。Altera公司提供的配置芯片有一次可編程型和可擦除編程型兩種:一次可編程型芯片只能寫入一次,不適合開發(fā)階段反復(fù)調(diào)試、修改及產(chǎn)品的方便升級(jí);可擦除編程型價(jià)格昂貴,且容量有限,對(duì)容量較大的可編程邏輯器件,需要多片配置芯片組成菊花鏈形進(jìn)行配置,增加系統(tǒng)設(shè)計(jì)的難度。

  為了降低成本,目前在開發(fā)階段多用可擦除型配置芯片;最終產(chǎn)品用不可擦寫的配置芯片,但一次簡單的代碼更換就需要更換一次器件,這在產(chǎn)品升級(jí)時(shí)很不實(shí)用。至今還沒有低成本的配置芯片出現(xiàn),而我們采用的這套配置方案充分考慮了在FPGA實(shí)際使用中,對(duì)設(shè)計(jì)的保密性和設(shè)計(jì)的可升級(jí)的要求,不但可以實(shí)現(xiàn)代替價(jià)格昂貴的不可擦寫和可擦寫配置芯片,而且可以實(shí)現(xiàn)多任務(wù)電路結(jié)構(gòu)重配置。該方案有PC機(jī)控制程序、單片機(jī)和外部串行存儲(chǔ)器組成,只要通過替換外部串行存儲(chǔ)器,就可實(shí)現(xiàn)對(duì)不同容量的多種配置芯片的代替。PC機(jī)是用來將配置數(shù)據(jù)寫入存儲(chǔ)器的,在寫好數(shù)據(jù)后該配置系統(tǒng)不再需要PC機(jī)的控制,在單片機(jī)的控制下實(shí)現(xiàn)ICR或多任務(wù)電路結(jié)構(gòu)重配置。多任務(wù)電路結(jié)構(gòu)重配置即將多個(gè)配置文件分區(qū)存儲(chǔ)到外部存儲(chǔ)器中,然后由單片機(jī)接收不同的命令,以選擇讀取不同存儲(chǔ)器區(qū)的數(shù)據(jù)下載到FPGA器件,實(shí)現(xiàn)在線配置成多種不同的工作模式。

  1 FPGA器件的配置方式和配置文件

  Altera公司生產(chǎn)的具有ICR功能的FPGA器件有FLEX6000、FLEX10K、APEX和ACEX等系列。它們的配置方式可分為PS(被動(dòng)串行)、PPS(被動(dòng)并行同步)、PPA(被動(dòng)并行異步)、PSA(被動(dòng)串行異步)和JTAG(Joint Test Action Group)等五種方式。這五種方式都能適用于單片機(jī)配置。PS方式因電路簡單,對(duì)配置時(shí)鐘的要求相對(duì)較低,而被廣泛應(yīng)用。我們的配置方案也采用PS配置方式來實(shí)現(xiàn)ICR功能,圖1是PS配置方式的時(shí)序圖。

PS配置方式的時(shí)序圖

  被動(dòng)串行工作過程:當(dāng)nconfig產(chǎn)生下降沿脈沖時(shí)啟動(dòng)配置過程,在dclk上升沿,將數(shù)據(jù)移入目標(biāo)芯片。在配置過程中,系統(tǒng)需要實(shí)時(shí)監(jiān)測(cè),一旦出現(xiàn)錯(cuò)誤,nSTATUS將被拉低,系統(tǒng)識(shí)別到這個(gè)信號(hào)后,立即重新啟動(dòng)配置過程。配置數(shù)據(jù)全部正確地移入目標(biāo)芯片內(nèi)部后,CONF_DONE信號(hào)跳變?yōu)楦撸撕螅珼CLK必須提供幾個(gè)周期的時(shí)鐘(具體周期數(shù)與DCLK的頻率有關(guān)),確保目標(biāo)芯片被正確初始化,進(jìn)入用戶工作模式。

  Altera的MAX+PLUS II或Quartus II開發(fā)工具可以生成多種配置或編譯文件,用于不同配置方法的配置系統(tǒng),而對(duì)于不同系列的目標(biāo)器件配置數(shù)據(jù)的大小也不同,配置文件的大小一般有.rbf文件決定。.rbf文件即二進(jìn)制文件。該文件包括所有的配置數(shù)據(jù),一個(gè)字節(jié)的 .rbf文件有8位配置數(shù)據(jù),每一字節(jié)在配置時(shí)最低位最先被裝載。微處理器可以讀取這個(gè)二進(jìn)制文件,并把它裝載到目標(biāo)器件中。Altera提供的軟件工具不自動(dòng)生成 .rbf文件,須按照下面的步驟生成:① 在MAX+PLUS II編譯狀態(tài),選擇文件菜單的變換SRAM目標(biāo)文件命令; ② 在變換SRAM目標(biāo)文件對(duì)話框,指定要轉(zhuǎn)換的文件并且選擇輸出文件格式為 .rbf(Sequential),然后確定。

  2 配置電路結(jié)構(gòu)和原理

  2.1 串行通信的電路結(jié)構(gòu)和原理

  PC機(jī)與單片機(jī)的接口如圖2所示。AT89C2051單片機(jī)通過串行口直接接收PC機(jī)傳送來的串行數(shù)據(jù),然后把接收到的數(shù)據(jù)存入數(shù)據(jù)存儲(chǔ)器。由于PC機(jī)的串行口都是RS-232C標(biāo)準(zhǔn)的接口,所以,其輸入輸出在電平上和采用TTL電平的AT89C2051在接口時(shí)會(huì)產(chǎn)生電平不同的問題。為了解決這個(gè)問題,在PC機(jī)和單片機(jī)的串行通信電路中加入了MAX232芯片,以實(shí)現(xiàn)TTL電平和RS-232C接口電平之間的轉(zhuǎn)換。這樣PC機(jī)和AT89C2051單片機(jī)進(jìn)行串行通信時(shí)就可以順利進(jìn)行了。除了電路結(jié)構(gòu)之外,要實(shí)現(xiàn)PC機(jī)和AT89C2051之間的通信,還需要有合適的通信軟件。

PC機(jī)與單片機(jī)的接口

  2.2 ICR控制電路原

 

  ICR電路原理如圖3所示。AT24C256用來存儲(chǔ)FPGA的配置數(shù)據(jù)。

ICR電路原理

  ICR控制電路的工作過程為:經(jīng)MAXPLUS II編譯生產(chǎn)的配置文件(.sof)通過格式轉(zhuǎn)換成為 (.rbf)。然后,利用PC機(jī)端的控制程序,通過PC機(jī)的串行通信口,經(jīng)U1存儲(chǔ)在U2中。U1再根據(jù)系統(tǒng)的要求,通過P1.2、P1.3、P1.4、P3.0和P3.1等5個(gè)I/O口,將其存儲(chǔ)在U2中的配置數(shù)據(jù)下載到電路中的FPGA器件中去。

  因作者設(shè)計(jì)電路中的FPGA是Altera公司的FLEX系列的EPF10K10,其配置文件的容量為15KB,故電路中采用1片AT24C128就可存儲(chǔ)EPF10K10的配置數(shù)據(jù)。我們選用AT24C256器件可以存儲(chǔ)兩個(gè)配置文件,是為了實(shí)現(xiàn)多任務(wù)電路重構(gòu),此時(shí)整個(gè)ICR控制電路只有2片IC。可以說,它是目前結(jié)構(gòu)最簡單、成本最低的ICR控制電路。如果配置的FPGA是EPF10K30或更大門數(shù)的器件,則需要大容量的存儲(chǔ)器件或多片AT24C256。(在兩線串行總線上最多可接4片AT24C256。)

  3 軟件設(shè)計(jì)

  在該配置方案中,軟件包括在PC機(jī)端的控制軟件和在AT89C2051端的控制軟件兩部分。PC機(jī)端的軟件采用Visual Basic語言編程,而AT89C2051采用匯編語言進(jìn)行編程。

  3.1 PC機(jī)端的軟件

  PC機(jī)端的軟件采用Visual Basic語言編程。VB支持面向?qū)ο蟮某绦蛟O(shè)計(jì),具有結(jié)構(gòu)化的事件驅(qū)動(dòng)編程模式,而且可以十分簡便地作出良好的人機(jī)界面。PC機(jī)端的控制程序主要實(shí)現(xiàn)讀取.rbf文件并將其通過串口送出的功能。讀取文件時(shí),主要使用讀取二進(jìn)制文件命令。在串口通信方面,使用VB提供的具有強(qiáng)大功能的串口通信控件MSCOMM。該控件可設(shè)置串口狀態(tài)及串口通信的信息格式和協(xié)議。

  在實(shí)際工作中,要實(shí)現(xiàn)AT89C2051和PC機(jī)之間的有效通信,必須使其具有相同的波特率和相同的通信協(xié)議。作者采用了9600bps的波特率和N.8.1幀結(jié)構(gòu)。N.8.1幀結(jié)構(gòu)表示1幀串行數(shù)據(jù)有10位:起始位占用1位(低電平),用來表示字符開始;后8位為數(shù)據(jù)編碼,無奇偶校驗(yàn)位;最后為停止位(高電平),用來表示字符傳送結(jié)束。單片機(jī)的串行口工作在方式1。方式1是標(biāo)準(zhǔn)的10位異步通信方式,10位數(shù)據(jù)和PC機(jī)的標(biāo)準(zhǔn)串口相對(duì)應(yīng),傳送的波特率由單片機(jī)工作時(shí)鐘和T1的溢出率共同決定。

  3.2 ICR控制電路軟件

  在圖3介紹的ICR控制電路中,其存儲(chǔ)FPGA配置數(shù)據(jù)的存儲(chǔ)器 AT24C256采用I2C串行總線進(jìn)行數(shù)據(jù)交換。其數(shù)據(jù)交換速度較慢,而FPGA配置數(shù)據(jù)又比較大,因此如何提高圖3介紹的ICR控制電路的配置速度將是軟件設(shè)計(jì)上的一個(gè)重點(diǎn)。限制速度的瓶頸主要是從AT24C256讀取數(shù)據(jù)和將數(shù)據(jù)寫入FPGA器件中。從AT24C256讀取數(shù)據(jù),有讀當(dāng)前地址、隨機(jī)讀和順序讀三種方式。這三種方式中,順序讀最簡單、速度最快。因?yàn)樵谕黄珹T24C256中,僅需要寫入一次讀命令就可以按順序從0地址開始直至讀完整片AT24C256中的全部數(shù)據(jù)。向FPGA器件寫數(shù)據(jù)時(shí),可以使用串行口的移位寄存器工作方式,即方式0。方式0數(shù)據(jù)的傳送以8位為1幀,無論是發(fā)送或是接收都是最低有效位居先。這和FPGA對(duì)數(shù)據(jù)的要求一致,傳送的波特率固定為振蕩頻率的1/12。本系統(tǒng)只需用到輸出方式,串行數(shù)據(jù)通過RXD端輸出,而用TXD端輸出移位脈沖。當(dāng)1字節(jié)數(shù)據(jù)寫入串行數(shù)據(jù)緩沖器SBUF時(shí),就開始發(fā)送。在此期間,發(fā)送控制器送出移位信號(hào),使發(fā)送移位寄存器的內(nèi)容右移1位,直至最高位(D7位)移出后,停止發(fā)送數(shù)據(jù)和移位時(shí)鐘脈沖。發(fā)送完1字節(jié)數(shù)據(jù)后,硬件置發(fā)送標(biāo)志位TI為1,通過判斷TI的狀態(tài)決定是否向SBUF寫入數(shù)據(jù)。采用這種方式比采用普通(I/O)口要快很多。

  4 結(jié) 論

  我們?cè)O(shè)計(jì)的基于微控制器的FPGA器件的 ICR控制系統(tǒng),具有線路結(jié)構(gòu)簡單、開發(fā)容易、體積小、成本低的優(yōu)點(diǎn);可以支持3.3V和5V系統(tǒng)的配置;適用于需要ICR功能的電子裝置中。該ICR控制電路是為配置Altera公司FLEX系列的FPGA器件而設(shè)計(jì)的,稍加修改也適用于其它系列的FPGA器件。這個(gè)配置電路的主要弱點(diǎn)在于配置速率較慢,只能適用于配置速率要求不高的應(yīng)用。

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美在线三区| 99视频国产精品免费观看| 亚洲国产精品一区二区三区 | 欧美日本亚洲视频| 蜜桃av久久久亚洲精品| 久久偷窥视频| 久久蜜臀精品av| 久久久久九九九九| 久久久精品一区二区三区| 欧美在线视频观看| 欧美制服第一页| 久久不射中文字幕| 久久国产精品久久精品国产| 香蕉亚洲视频| 欧美一区二区视频观看视频| 欧美一区二区三区啪啪| 欧美一区久久| 久久国产精品黑丝| 久久精品在线| 老司机一区二区三区| 麻豆成人在线播放| 欧美精品乱码久久久久久按摩| 欧美精品久久久久久| 欧美日韩精品中文字幕| 欧美亚一区二区| 国产精品乱码妇女bbbb| 国产午夜精品理论片a级大结局| 国产一区二区无遮挡| 原创国产精品91| 亚洲人成网站影音先锋播放| av成人免费| 亚洲免费一级电影| 欧美综合二区| 亚洲欧洲日本国产| 99热免费精品| 亚洲女同在线| 久久久精品国产免大香伊| 免费视频久久| 欧美日韩理论| 国产欧美午夜| 在线观看欧美黄色| 亚洲欧洲一区二区天堂久久| 国产精品99久久久久久久女警| 亚洲中午字幕| 亚洲黄页视频免费观看| 夜夜爽99久久国产综合精品女不卡| 亚洲一区一卡| 久久婷婷国产麻豆91天堂| 欧美绝品在线观看成人午夜影视| 欧美视频在线观看免费网址| 国产视频一区在线观看一区免费| 在线免费高清一区二区三区| 9l视频自拍蝌蚪9l视频成人| 性欧美长视频| 日韩一级在线观看| 午夜在线视频观看日韩17c| 久热re这里精品视频在线6| 欧美日韩国产成人在线91| 国产精品日韩在线观看| 永久555www成人免费| 99精品99久久久久久宅男| 午夜精品理论片| 亚洲黄色免费电影| 性欧美1819性猛交| 美国三级日本三级久久99| 国产精品久久久久99| 精品1区2区3区4区| 99视频精品| 亚洲国产精品精华液2区45| 亚洲深夜福利视频| 久久人人看视频| 国产精品成人一区二区艾草| 黄页网站一区| 亚洲一区二区三区免费在线观看| 亚洲第一综合天堂另类专| 亚洲自拍电影| 欧美第十八页| 国产亚洲成av人片在线观看桃| 亚洲毛片一区| 亚洲国产欧美一区二区三区同亚洲| 亚洲字幕在线观看| 欧美激情欧美狂野欧美精品| 国产午夜久久久久| 亚洲视频在线观看三级| 亚洲看片一区| 久久综合狠狠综合久久综合88| 欧美午夜在线观看| 亚洲国内精品在线| 久久av二区| 性欧美长视频| 欧美午夜免费| 亚洲精品国产精品乱码不99 | 免费亚洲电影| 国产亚洲视频在线观看| 亚洲网站视频| 正在播放亚洲一区| 欧美大片在线看| 精品福利免费观看| 欧美一区二区三区日韩视频| 亚洲女与黑人做爰| 欧美性大战久久久久久久| 亚洲日本乱码在线观看| 亚洲国产欧美一区二区三区久久 | 欧美极品欧美精品欧美视频| 国产在线视频欧美一区二区三区| 亚洲一区二区三区精品在线| 亚洲性感激情| 欧美日韩国产综合视频在线观看| 在线观看亚洲视频啊啊啊啊| 欧美一区不卡| 久久精品综合网| 国产日韩欧美成人| 亚洲欧美不卡| 欧美一区二区三区在| 国产精品视频自拍| 亚洲尤物视频网| 羞羞漫画18久久大片| 国产精品三区www17con| 亚洲午夜一区| 香蕉国产精品偷在线观看不卡| 国产精品福利在线观看网址| 亚洲天堂av在线免费观看| 亚洲自拍偷拍麻豆| 国产精品每日更新在线播放网址| 一区二区三区高清在线| 亚洲午夜免费福利视频| 国产精品v欧美精品v日韩| 亚洲午夜在线| 欧美伊人久久久久久久久影院| 国产精品夜夜夜一区二区三区尤| 亚洲综合三区| 久久精品国产2020观看福利| 国产日产亚洲精品系列| 久久黄金**| 免费观看成人| 亚洲精品乱码久久久久久蜜桃麻豆 | 亚洲一区二区3| 欧美日精品一区视频| 一区二区三区成人| 午夜精品在线看| 国产欧美在线| 亚洲国产精选| 欧美激情第9页| 亚洲最新在线视频| 亚洲欧美日韩区| 国产日产精品一区二区三区四区的观看方式 | 亚洲三级观看| 欧美日韩一区三区四区| 亚洲天堂av图片| 久久精品视频导航| 亚洲国产天堂久久综合网| 一区二区三欧美| 国产精品日韩一区二区| 久久成人人人人精品欧| 免费在线亚洲欧美| 99精品视频一区| 久久精品五月| 亚洲精品免费在线| 香蕉久久夜色| 亚洲第一在线视频| 亚洲一区精品视频| 国产亚洲毛片在线| 亚洲美女在线看| 国产精品视频自拍| 最新国产成人在线观看| 国产精品久久国产精麻豆99网站| 欧美综合77777色婷婷| 欧美日韩国产一区二区三区地区| 亚洲一级二级在线| 嫩草成人www欧美| 亚洲一区二区三区中文字幕| 久久亚洲综合色| 中文日韩在线视频| 久热精品视频在线观看| 一片黄亚洲嫩模| 久久久人成影片一区二区三区 | 在线观看日韩av| 亚洲欧美久久久久一区二区三区| 韩国免费一区| 亚洲一二三级电影| 一区二区亚洲精品国产| 亚洲淫片在线视频| 亚洲国产二区| 久久成人免费| 亚洲精品乱码久久久久久久久| 久久精品国产亚洲a| 亚洲免费观看高清完整版在线观看熊| 久久精品一区二区| 亚洲视频综合在线| 欧美大片免费观看在线观看网站推荐| 亚洲一区成人| 欧美精品少妇一区二区三区| 欧美一站二站| 国产精品扒开腿做爽爽爽软件| 91久久国产综合久久| 国产欧美日韩综合精品二区| 中文久久精品| 在线看片欧美| 久久精品国产免费| 亚洲综合激情|