CPLD器件的在系統(tǒng)動態(tài)配置_第1頁
CPLD器件的在系統(tǒng)動態(tài)配置_第2頁
CPLD器件的在系統(tǒng)動態(tài)配置_第3頁
CPLD器件的在系統(tǒng)動態(tài)配置_第4頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)

文檔簡介

1、    CPLD器件的在系統(tǒng)動態(tài)配置    CPLD器件的在系統(tǒng)動態(tài)配置    類別:EDA/PLD      微控制器動態(tài)配置cpld器件的方法。將配置文件存放在存儲器中,配置文件中的控制代碼驅(qū)動在微處理器中運行的配置引擎;將配置文件中的配置信息通過jtag口移入cpld,實現(xiàn)器件的動態(tài)配置;通過更換存儲器中配置文件,達(dá)到同一器件實現(xiàn)不同功能的目的。這種方法為嵌入式系統(tǒng)升通讀重構(gòu)提供了一種新的思路,將來一定會得到廣

2、泛應(yīng)用。引言隨著應(yīng)用的不斷深入,嵌入式系統(tǒng)升級的問題擺在了人們面前。在這種背景下isp技術(shù)應(yīng)運而生。在系統(tǒng)可編程isp(in ststem programmability)技術(shù)是指能對器件、電路甚至整個系統(tǒng)進行現(xiàn)場升級和功能重構(gòu)的技術(shù)。這種重構(gòu)可以在實驗開發(fā)過程中、制造過程中,甚至是在交付用戶使用之后進行;而整個在系統(tǒng)可編程設(shè)計的最后一個步驟,也是最關(guān)鍵的步驟,也是最關(guān)鍵的步驟,就是器件的配置。配置過程加載設(shè)計規(guī)定的編程數(shù)據(jù)到器件中,以定義器件內(nèi)部功能塊及其互連,從而實現(xiàn)器件功能的重構(gòu)升級。當(dāng)然isp配置方式是多種多樣的,其中計算機加下載線就是最常見的配置器件的方法;但是這個方法需要計算機配合

3、,對嵌入式系統(tǒng)來說不太實用,因此需要一個更加方便靈活的配置方案。lattice公司cpld器件不僅具有isp功能,同時融合引腳鎖定功能和jtag技術(shù),使得拋棄計算機而使用微控制器在系統(tǒng)配置、修改、升級cpld器件成為可能。特別是引腳鎖定功能,實現(xiàn)了真正意義上的“動態(tài)”配置。采用引腳鎖定技術(shù),將配置前引腳狀態(tài)鎖定,配置完成以后各個引腳仍能保持配置前狀態(tài)。本文介紹一個用微控制器在系統(tǒng)配置lattice mach4000系列cpld器件的方案。圖11 原理isp器件要實現(xiàn)配置,除了isp器件的硬件系統(tǒng)中要提供正確的isp接口以外,還需要有配置文件和配置工具。(1)配置接口lattice公司為器件提供

4、了isp接口和jtag接口。isp接口是lattice公司自行開發(fā)設(shè)計的,具有如下引腳定義:sdi數(shù)據(jù)輸入和狀態(tài)機控制;mode和sdi一起控制狀態(tài)機;mode和sdi一起控制狀態(tài)機;sclk時鐘輸入;sdo數(shù)據(jù)輸出,可選引腳;ispen工作模式和配置模式選擇,同時還有一個isp狀態(tài)機,包含3個狀態(tài),由mode和sdi控制狀態(tài)機所處技術(shù),在shift狀態(tài)通過sdi移入命令,在execute狀態(tài)執(zhí)行命令。聯(lián)合測試行動小組jtag(joint test action group)在20世紀(jì)80年代中期制定了邊界掃描技術(shù),在1990年被修改后成為ieee的一個標(biāo)準(zhǔn)ieee1149.1-1990。這個

5、標(biāo)準(zhǔn)即為jtag。邊界掃描技術(shù)最初發(fā)展鹽業(yè),是為了測試電路各個ic器件之間的互邊是否正確。隨著isp發(fā)展,許多生產(chǎn)廠商利用jtag規(guī)定的四條引腳的測試存取口作為isp的開發(fā)平臺,使得isp也變得有標(biāo)準(zhǔn)可循,給用戶帶來了極大方便,于是jtag在其權(quán)限內(nèi)把isp性能擴充到了ieee1149.1中。發(fā)展到現(xiàn)在可以這樣說,ieee1149.1標(biāo)準(zhǔn)為我們提供了一條簡單的串行接口,將那些具有jtag接口的器件串接在一打掃描鏈中。通過這個接口既能實現(xiàn)isp又能實現(xiàn)測試。ieee1149.1標(biāo)準(zhǔn)對邊界掃描結(jié)構(gòu)的定義包括4個基本單元:4個引腳的測試存取口tap(test access port)、數(shù)據(jù)寄存器、指

6、令寄存器和tap控制器。tap引腳定義如下:tck為測試時鐘輸入,tdi為測試數(shù)據(jù)輸入,tdo為測試數(shù)據(jù)輸出,tms為測試模式選擇。數(shù)據(jù)寄存器包含兩種bypass寄存器和bsr(boundary scan register)寄存器,其中bsr由bsc(boundary scan cell)串聯(lián)而成,正是通過bsc才把來自于tap的數(shù)據(jù)移入isp芯片內(nèi)部邏輯。另外tap控制器作為一個有限狀態(tài)機,共有16個狀態(tài)。它控制著測試存取口、指令寄存器和數(shù)據(jù)寄存器。tap控制器如圖1所示。通過tck、tms控制tap控制器的狀態(tài)。當(dāng)tap控制器處于shift-ir狀態(tài)時,tdi口進入的指令被移進指令寄存器;

7、當(dāng)tap控制器入于update-ir狀態(tài)時,指令寄存器的指令有效。根據(jù)這個原理,通過控制此狀態(tài)機,將配置信息移入器件內(nèi)。另外,tap測試存取口4個引腳有嚴(yán)格的時序要求,如圖2所示。其中tms、tdi在tck上升沿有效,tdo在tck下降沿有效。要想通過jtag口實現(xiàn)isp或者測試,都必須遵守這些時序要求。通過對兩種接口的研究發(fā)現(xiàn),它們均能實現(xiàn)isp,然而jtag口的測試功能以及與其它具有jtag口器件之間的靈活的連接性顯得更有優(yōu)勢,這也使得lattice公司認(rèn)識到了isp接口的局限,因此在它后來開發(fā)生產(chǎn)的新器件中都采用了jtag。在本方案中用到的latticemach4000系列cpld器件,

8、運行頻率最高達(dá)400mhz,待機電流僅為20a,宏單元數(shù)目最高達(dá)1024個,引腳到引腳延時2.5ns,在系統(tǒng)配置要用jtag接口。圖2    (2)配置文件在進行配置前需要得到一個jed文件,也就是我們所說的熔絲圖文件。在這個文件里包含了相應(yīng)器件的配置信息,即該器件內(nèi)部互連邏輯。在開發(fā)環(huán)境isplever3.0里按照自上而下的順序進行邏輯設(shè)計,經(jīng)過行為仿真和時序仿真后,開發(fā)環(huán)境將生成這個熔絲圖文件。除了jed文件,另外還需要一個能說明菊花花鏈組成順序的.xcf文件。特別是當(dāng)系統(tǒng)中有多個isp器件且組成菊花鏈進行配置時,通過這個文件將分散在各個器件內(nèi)部的j

9、tag鏈按照先后順序組成一條系統(tǒng)級的掃描鏈,下載工具通過這個文件里的信息決定當(dāng)前tdi上的數(shù)據(jù)是哪個器件的數(shù)據(jù)。有了這2個文件以后就可以通過下載工具進行器件配置了。(3)配置工具lattice公司在pc和workstation平臺提供的下載工具叫ispvm。通過這個下載軟件加上下載線可以實現(xiàn)器件配置。另外,lattice在業(yè)界首創(chuàng)的利用系統(tǒng)板上的微控制器或微處理器進行編程的嵌入式、多供應(yīng)商、單鏈、在系統(tǒng)可編程工具ispvm embedded,作為一種軟件實現(xiàn),一旦在微控制器或處理器安裝成功,系統(tǒng)將有能力直接通過電路板上的處理器對板上所有可編程邏輯器件進行編程或再編程,而無需使用下載電費或人工干

10、預(yù)。當(dāng)然,為了使用這種軟件,必須將jed文件轉(zhuǎn)化成該軟件支持的文件格式vme。vme作為專門支持ispvm embedded的文件,里面除了包括來自于jed和xcf的配置信息以外,不覺包括了能驅(qū)動ispvm embedded配置引擎的控制信息。正是這些控制信息使tap狀態(tài)機進入相應(yīng)狀態(tài),從而將配制信息移入器件內(nèi)。需要注意的是,如果要將vme存儲在存儲器上,還需要將其轉(zhuǎn)化成hex格式。本方案將在msp430單片機上實現(xiàn)ispvm embedded,從而提供一種嵌入式系統(tǒng)升級方案。2 方案設(shè)計系統(tǒng)硬件電路如圖3所示。msp430單片機p2口作為配置接口,接到lattice mach4128v的jt

11、ag口上,外掛一個e2prom,用來存儲hex格式的vme文件。整個過程是,通過串口接收來自計算機的配置文件,放到e2prom,接收完畢以后,單片機運行配置引擎,讀取e2prom,配置指令通過jtag口對lattice mach 4128v進行配置。需要指出的是,lattice mach 4128v并沒有用專門的引腳來控制進入配置模式或退出配置模式,而僅僅是通過tap控制所處狀態(tài)來決定的。ieee1149.1標(biāo)準(zhǔn)中規(guī)定:器件加電時或應(yīng)用中不利用邊界掃描邏輯,強迫tap控制器處于test-logic-reset狀態(tài),因此在通過程序控制jtag進行器件配置結(jié)束時,一定要通過軟件方式強迫tap控制器

12、回到test-logic-reset狀態(tài),下面提到的ispvmend()函數(shù)實現(xiàn)的就是這個功能。另外,當(dāng)通過jtag口完成器件配置或測試以后,tms、tdi引腳器件內(nèi)部上拉。雖然如此,為了防止tck可能出現(xiàn)的信號使jtag狀態(tài)機離開test-logic-reset狀態(tài),或者因為上電瞬間可能產(chǎn)生的tck信號導(dǎo)致狀態(tài)機進入未知狀態(tài),設(shè)計電路時必須在tms引腳加4.7k下拉電阻。另外,電路中vcc=3.3v。3 軟件介紹軟件部分包括pc機程序和msp430單片機程序。其中pc機程序?qū)ex格式的vme文件通過串口傳送給單片機;msp430單片機程序包括ispvm embedded,串口讀寫和e2pr

13、om讀寫部分。作為整個配置的核心,ispvm embedded主要由存儲在e2prom的vme文件驅(qū)動,從而將配置信息串行移入lattice mach 4128中。整個過程如下:首先,驗證vme文件的版本,只有相應(yīng)版本的ispvm embedded才能解釋同樣版本的vme文件,ispvmstart()函數(shù)強迫tap狀態(tài)機進入配置主引擎ispvmcode(),來自于vfme中的控制代碼將驅(qū)動這個引擎執(zhí)行相應(yīng)操作,其中3個控制代碼最為常見的state、sir、sdr和state代碼控制tap狀態(tài)機進入聲明的狀態(tài),如shift-dr、shift-ir等。sir代碼表明將向器件中移入指令流,sdr代碼

14、表明將向器件中移入數(shù)據(jù)流。通過這種方式,配置主引擎ispvmcode()將vme中包含的配置信號器件從而完成配置,配置完成ispvmcode()返回一個配置成功與否的代碼。最后ispvmend()強迫tap狀態(tài)機進入test-logic-reset狀態(tài)。void ispvmend(void)ispvmstatemachine(reset);/tap狀態(tài)機進入test-logic-reset狀態(tài)/ispvmdelay(1);/一段延時后,器件由配置模式切換到運行模式/事實上,作為專門針對嵌入式平臺的配置工具ispvm embedded并不依賴于特定的硬件或系統(tǒng)平臺,所以可以很容易地往用戶自己的系

15、統(tǒng)上移植。3個與硬件相關(guān)的函數(shù)需要用戶自己改寫,readprot()從輸入引腳讀一個字節(jié),writeport()通過輸出引腳向外發(fā)送一個字節(jié),ispvmdelay()系統(tǒng)延時。在msp430上的實現(xiàn)如下:#define pintdi 0x02 /定義p2.1為tdi#define pintdo 0x08 /定義p2.3為tdoshort int isp_pins用來存放當(dāng)前jtag口的引腳信號unsigned char readport(void)unsigned char portval;portval=p2in; /讀取p2口return (unsigned char)(portval &

16、amp;pintdo)?0x01:0x00);/返回tdo引腳信號void writeport(unsigned char pins,unsigned char value)if(value)isp_pins=pinsisp_pins;/把isp-pins引腳置高elseisp_pins=pins&isp_pins;/把isp-pins引腳置低p2out=isp_pins;void ispvmdeay(unsigned short int delay_time)/delay_time來自于配置文件,通過它告訴配置引擎具體需要延時多久if(delay_time &0xa000)/

17、ms級延時delay_time &=0xa000;else if(delay_time>=1000)/如果是s級,轉(zhuǎn)換成ms級延時delay_time=delay_time/1000;elsedelay_time=1;/延時小于1ms時,就延時1msps1ms=delay_time;cctl0=ccie; /開定時while(ps1ms);/在中斷ps1mscctl0&=ccie; /關(guān)定時有一點需要指出,ispvm embedded要求將已轉(zhuǎn)化成hex格式的vme作為程序的一部分固化在單片機里。很顯然,要想更換配置文件,就必須連同單片機程序一同換掉。這對實現(xiàn)動態(tài)配置是不

18、利的,也是為什么在本方案中外加e2prom的原因。這樣無須更改程序,只換掉e2pro中的配置文件即可。因此還需要更改getbyte()函數(shù)。    對24c512的操作應(yīng)該遵循i2c總線協(xié)議,而在msp430中沒有i2c總線硬件,所以本方案中用軟件方法模擬。由于i2c串行總線數(shù)據(jù)交換速度較慢,因而當(dāng)從e2prom中讀出數(shù)據(jù)再往cpld中移入時,形成了配置過程的速度瓶頸。在解決這個問題時,我們充分利用了msp430149單片機內(nèi)部2kb ram,采用e2prom最快的讀取方式順序讀,將配置數(shù)據(jù)預(yù)先讀入到ram中,getbyte()函數(shù)直接從ram中讀取數(shù)據(jù)。這種方法在一定程度上提高了配置速度。我們改寫的getbyte()函數(shù)是這樣的:unsigned char getbyte() unsigned char data;static unsigned short i

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論