《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 業界動態 > 基于單片機的復雜可編程邏輯器件快速配置方法

基于單片機的復雜可編程邏輯器件快速配置方法

2008-11-17
作者:劉曉明 王 軍 謝明欽

  摘? 要: 介紹基于SRAM的可重配置" title="可重配置">可重配置CPLD的原理,通過對多種串行配置的比較,提出了由單片機和FLASH存儲器組成的串行配置方式" title="配置方式">配置方式,并從系統復雜度、可靠性和經濟性等方面進行了比較和分析。?

??? 關鍵詞: 復雜可編程邏輯器件" title="可編程邏輯器件">可編程邏輯器件? 靜態隨機存儲器? 被動串行" title="被動串行">被動串行?

?

  基于SRAM(靜態隨機存儲器)的可重配置PLD(可編程邏輯器件)的出現,為系統設計者動態改變運行電路中PLD的邏輯功能創造了條件。PLD使用SRAM單元來保存配置數據。這些配置數據決定了PLD內部的互連關系和邏輯功能,改變這些數據,也就改變了器件的邏輯功能。由于SRAM的數據是易失的,因此這些數據必須保存在PLD器件以外的EPROM、EEPROM或FLASH ROM等非易失存儲器內,以便使系統在適當的時候將其下載到PLD的SRAM單元中,從而實現在電路可重配置ICR(In-Circuit Reconfigurability)。?

  本文介紹筆者設計的PLD ICR控制電路,它不但線路結構簡潔、開發容易、體積小、成本低,并且在圖2介紹的ICR控制電路中,其存儲PLD配置數據的FLASH存儲器采用并行總線,交換速度較快。然而PLD配置數據較大,通常都在數十千字節以上。如何提高圖2介紹的ICR控制電路的配置速度,使系統上電" title="上電">上電后在最短的時間內完成配置而進入正常工作狀態,是軟件設計上的一個重點。?

1 基于SRAM的可重配置CPLD的結構與原理?

  早期的可編程邏輯器件大多采用紫外線可擦除只讀存儲器(EPROM)和電可擦除只讀存儲器(EEPROM)方式,如GAL系列、EPF7064、EPF7128等。由于其結構簡單、規模小,只能完成簡單的數字邏輯功能。此后,出現了一類結構上稍復雜的基于SRAM存儲器的可編程芯片,即復雜可編程邏輯器件(CPLD),它能完成各種數字邏輯功能。?

  采用這種結構的可編程邏輯器件有ALTERA公司的FLEX、ACEX、APEX系列,XILINX公司的Spartan、Virtex系列。多年來,ALTERA公司一直致力于CPLD的開發。近幾年,該公司又推出了很有競爭力的CPLD器件,即靈活的邏輯單元陣列FLEX(Flexible Logic Element Matrix)系列產品。相對于其它一些廠家的FPGA產品來說,ALTERA公司的FLEX系列產品有其獨特之處。這主要表現在高密度、在線配置功能、高速度和連續式布線結構等方面。?

  查找表LUT(Look-Up-Table)是基于SRAM的可重配置PLD的一個重要組成部分,LUT本質上就是一個RAM。目前CPLD中多使用4輸入的LUT,所以每一個LUT可以看成一個有4位地址線的16×1bit的RAM。當用戶通過GDF原理圖或VHDL語言描述了一個邏輯電路后,CPLD開發軟件會自動計算邏輯電路的所有可能結果,并把結果事先存入查找表。這樣,當多個信號進行邏輯運算時就等于輸入一個地址進行查表,找出地址所對應的內容,然后將其輸出即可。?

2 可編程邏輯器件的配置原理?

  首先在開發軟件MAX+PLUSⅡ的ASSIGN菜單下選擇將要采用的基于SRAM的器件名稱。經過編譯、優化、邏輯綜合、仿真等步驟達到設計要求后,軟件會自動產生一個編程文件(擴展名為.SOF文件)。對于基于SRAM工藝的可編程邏輯器件(如ALTERA的所有FLEX、ACEX、APEX系列,XILINX的Sparten、Vertex系列),由于SRAM存儲器的特點,掉電后數據會消失,因此在調試期間可以采用并口ByteblasteMV下載電纜多次重復配置PLD器件。當電路設計成功,調試完成后,需要將配置數據燒寫固化在一個由ALTERA生產的專用EEPROM(如EPC1441)中。上電時,由這片配置EEPROM先對PLD加載數據,幾十毫秒后,PLD即可正常工作。?

  CPLD器件的工作狀態分為三種:首先是上電配置狀態(Configuration Mode),將編程數據裝入CPLD器件的過程,也可稱之為構造;然后是初始化狀態(Initialization Mode),在配置完成后,CPLD器件復位內部各類寄存器,讓I/O引腳為邏輯器件正常工作做準備;最后是用戶狀態(User Mode),指電路中CPLD器件正常工作時的狀態。?

  ALTERA公司具有ICR功能的PLD器件有FLEX8000、FLEX10K、APEX和ACEX系列,它們的配置方式可分為PS、PPS和JTAG(Joint Test Action Group)等方式。PS方式因PLD與配置電路的互連最簡單,對配置時鐘的最小頻率沒有限制而應用最廣泛,因此在ICR控制電路中通常采用PS配置方式來實現ICR功能。?

  被動串行(PS)配置方式:在該配置方式下,由ByteblasteMV下載電纜產生一個由低到高的跳變送到nCONFIG引腳復位PLD,然后將配置數據送到DATA0引腳,直到CONF_DONE引腳變為高電平。圖1是PS配置方式的時序圖。CONF_DONE變成高電平后,DCLK必須多余十個周期來初始化該器件。器件的初始化由下載電纜自動執行。在PS方式中沒有握手信號,所以配置時鐘的工作頻率必須低于10MHz。在多器件PS配置方式中,第一片PLD的nCEO引腳級聯到下一片PLD的nCE引腳。在配置完第一個器件后,nCEO輸出為低,使第二個PLD器件的nCE有效,開始對第二塊器件進行配置。?

?

?

3 用WINBOND78E58單片機配置可編程邏輯器件?

  用單片機配置可編程邏輯器件與上述PS配置方式原理一致,只需模擬PS配置方式中DATA0、DCLK、nCONFIG、CONF_DONE、nSTATUS引腳的配置時序,將配置數據串行移入PLD。配置引腳的功能如表1所示。?

?

?

3.1 硬件設計?

  用單片機配置PLD,可以使用普通輸入輸出口或串行口。使用普通I/O口(如P1口),向PLD發送1Bit數據至少需要4個指令周期。一個指令給DATA0賦值,兩個指令產生DCLK時鐘,一個指令移位取數據。如果晶振為fosc,一個指令周期為12/fosc,因此它的下載速率為fosc/48。然而如果采用串行口方式0,其下載速率提高為fosc/12。考慮到PLD配置文件數據比較大,通常都在數十千字節以上(其配置文件大小如表2),為了加快配置速度,并適合各種不同規模的PLD,采用了WINBOND78E58單片機。該單片機外接晶振最大頻率為40MHz,它在串行口方式0下波特率可設置為fosc/4。另外通過設置特殊功能寄存器CKCON的MD0、MD1、MD2三位,可以將MOVX、MOVC等指令周期縮短至2個機器周期。與普通單片機相比,可使配置時間大為縮短。WINBOND78E58單片機內部擁有32KB FLASH ROM。由配置文件數據表2可知,只需一片單片機就可以對EPF10K20系列以下的PLD進行配置了。本系統中使用了一片APEX20K300E,因此在硬件電路設計中,擴展了一片WINBOND29C040 FLASH存儲器(容量為512KB),其電路如圖2。DATA0與RXD、DCLK與TXD、nCONF與P15、CONFIG_DONE與P16、nSTATUS與P17分別相連。?

?

?

?

3.2 軟件設計?

  在軟件編程時,使用了串行口移位寄存器輸入輸出方式。本系統只需用到輸出方式,串行數據通過RXD引腳輸出,而在TXD引腳輸出移位時鐘。當一字節數據寫入串行數據緩沖器SBUF時,就開始發送。在此期間,發送控制器送出移位信號,使發送移位寄存器的內容右移一位,直至最高位(D7位)數字移出后,停止發送數據和移位時鐘脈沖。RXD、TXD時序如圖3。由圖3可知,它可以用來模擬配置時序。發送完一字節數據后,硬件置發送標志位TI為1,向CPU申請中斷。若CPU響應中斷,則從0023H單元開始執行串行口中斷服務程序。?

?

?

  為了提高配置速度,單片機程序用匯編語言編寫。單片機上電后使nCONFIG腳由低到高復位待配置PLD;當判斷到nSTATUS為高后,開始從外部FLASH存儲器取數據串行移位。配置過程中,查詢CONF_DONE。一旦為高,配置完成,但還要送40個DCLK脈沖,PLD才能進入用戶工作狀態。?

  用戶設計的PLD程序經MAXPLUSⅡ或QUARTUS編譯后將產生后綴名為.sof的SRAM目標文件。該文件含有除配置數據以外的控制字符,不能直接寫入到PLD中去,需要利用軟件的編程文件轉換功能將該文件轉換成.rbf(Raw Binary File)十六進制文件。把.rbf文件燒寫到存儲器中,單片機通過MOVX指令讀入后,串行移位到PLD。?

??? 部分asm語言源程序如下:?

??? NCONFIG???????????? BIT ??? P1.5?

??? CONFDONE??????????? BIT P1.6?

??? NSTATUS???????????? BIT P1.7?

??? ORG 000h?

??? ……?

??? CLR SM0?

??? CLR SM1 ?????? ;SM0,SM1為0,串口工作于方式0?

??? CLR SM2 ?????? ;串口波特率為fosc/4?

??? CLR REN?

??? ANL 8EH,#0f8h?????????? ;地址8EH是CKCON單元,MD0、MD1、MD2清0?

??? CLR EA?

WJRESTART:CLR NCONFIG?

??? SETB NCONFIG??? ? ????? ;上升沿復位PLD?

WAIT: JNB NSTATUS,WAIT? ;NSTATUS為高,可進行配置?

??????????????????????????????? ??

WJPEIZHI:MOV P1,COUNTER3?

??? MOV DPH,COUNTER2?

??? MOV DPL,COUNTER1??????? ;配置數據大,需3個單元作地址記數?

??? MOVX A,@DPTR?

??? MOV SBUF,A????????????? ;串行移位?

??? NOP ?

??? NOP ?? ??;采用填充2個空指令,正好使一個字節發送完成,可發送下一字節?

??? INC COUNTER1??????????? ;地址加?

??? MOV A,COUNTER1?

??? JB CONFDONE,WJEND1?

??? CJNE A,#0,WJPEIZHI?

??? INC COUNTER2?

??? MOV A,COUNTER2?

??? CJNE A,#0,WJPEIZHI?

??? INC COUNTER3?

??? LJMP WJPEIZHI?

WJEND1:MOV R0,#60?

WJEND:MOV A,#55H?

??? ……?

????MOV SBUF,A? ;由此產生40個?DCLK時鐘?

??? DJNZ R0,WJEND?

??? HERE:?? LJMP HERE??? ;配置完成,進入用戶工作模式?

??? 使用OTP(One Time Programming)器件配置CPLD具有一定的冒險性,一次簡單的代碼更換就可能意味著更換OTP器件,并重新開始所有的程序。被動串行微處理器(Passive Serial With Processor)配置方式以EEPROM為基礎,允許對這些存儲器進行多次編程,所有其它芯片都無需從已裝配的印制電路板上拆卸下來。高速讀寫周期的FLASH存儲器能確保1萬次編程,而且能對任何以SRAM為基礎的PLD下載。該方式除了在加電期間能承載配置數據外,還有許多方便之處。例如,用戶可以將多個配置文件.rbf分區編程到外部存儲器的未用區段,通過單片機讀取不同存儲區可以將可編程邏輯器件在線配置成多種不同的工作模式。?

參考文獻?

1 宋萬杰,羅 豐,吳順君.CPLD技術及其應用. 西安:西安電子科技大學出版社,2000?

2 候伯亨,顧 新.VHDL硬件描述語言與數字邏輯電路設計.西安:西安電子科技大學出版社,1999?

3 蔡美琴,張為民,沈新群,張榮娟. MCS-51系列單片機系統及其應用.北京:高等教育出版社,1992?

4 APPLICATION NOTE 116 OF CONFIGURING APEX20K,FLEX10K&FLEX6000 DEVICES.12.1999,VER 1.02 FROM ALTERA WEB SITE
本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
主站蜘蛛池模板: 欧美乱淫 | 91久久偷偷做嫩草影院免 | 一个人的免费影院 | 亚洲第四页 | 精品欧美成人bd高清在线观看 | 日韩精品福利在线 | 波多野结衣在线视频观看 | 波多野结衣在线免费观看视频 | 2015永久免费观看平台 | 伊人天堂在线 | 好吊色视频在线观看 | 午夜影院毛片 | 国产成人在线免费观看 | 精品国产成人 | 12345国产精品高清在线 | 亚洲欧美日韩高清一区二区三区 | 天天干天天做 | 欧美日韩在线精品成人综合网 | 羞羞网页| 国产高清天干天天美女 | 夜夜狠狠狠狠 | 国产一区二区自拍视频 | 国产青草视频 | 国产操操操 | 最近中文字幕无吗 | 色综合天天综合网国产人 | 国美女福利视频午夜精品 | 欧美大交乱xxxxxbbb | 又色又爽又黄的三级视频在线观看 | 老妇女黄色片 | 日本三级带日本三级带黄国产 | 128tv在线观看| 免费日韩一级片 | 乱人伦中文字幕视频 | 最近中文2019字幕在线观看 | 天天操天天爽天天射 | 新一级毛片国语版 | 日日噜噜夜夜狠狠久久aⅴ 日日噜噜夜夜狠狠久久丁香七 | 黄色免费的网站 | 亚洲aⅴ久久久噜噜噜噜 | 国产精品免费视频一区一 |