太空中存在大量的宇宙射線和高能帶電粒子,它們對星載電子系統(tǒng)的照射會導(dǎo)致系統(tǒng)出錯,甚至永久損壞。其所造成的輻射效應(yīng)主要有位移損傷效應(yīng)、電離輻射總劑量效應(yīng)、瞬時電離輻射效應(yīng)、單粒子效應(yīng)等。而且由于器件集成度高,每個記憶單元的尺寸小,引起翻轉(zhuǎn)所需的臨界電荷也小,所以SEU的問題在空間器件上越來越嚴(yán)重。
現(xiàn)場可編程門陣列(FPGA,F(xiàn)ield Programmable Gate Array)靈活、可重構(gòu)的特性,對于克服器件設(shè)計錯誤和后天所導(dǎo)致的故障有效?;诳蓜討B(tài)可重構(gòu)FPGA,動態(tài)容錯技術(shù)在理論上已得到發(fā)展,并出現(xiàn)了多種方法,其基本原理都是將備用的配置文件重新裝載到FPGA上,以消除原有的暫態(tài)錯誤或者繞過故障區(qū)。
但在實際應(yīng)用過程中涉及到許多問題。容錯粒度的大小選擇,是其中較突出的一個,這會影響到重構(gòu)文件的大小、動態(tài)容錯時隙的長短、資源利用率、實現(xiàn)的復(fù)雜度等方面。另外模塊間通信方式、檢錯與定位的實現(xiàn)、冗余資源的比例與布局、暫態(tài)與永久錯誤的處理與分析都是有待深入研究的問題,很多方法過于復(fù)雜不容易實現(xiàn)或者過于簡單而容錯性能得不到保障,并且對以上這些問題分析不充分。
本文基于多種具體的實現(xiàn)方法,對這些問題進(jìn)行了全面的分析與研究,并權(quán)衡各個方面,提出了基于算法和資源多級分塊的方法,對其性能進(jìn)行了分析。
這種方法中粒度、冗余資源比例等多項參數(shù)可以選擇,重構(gòu)時沒有模塊間布線的要求,能有效保障系統(tǒng)工作頻率。
1 基于動態(tài)可重構(gòu)FPGA的幾種容錯技術(shù)
1.1 基于Retiming理論的方法及分析
重定時(Retimg)技術(shù)的應(yīng)用是建立在容錯粒度較小的基礎(chǔ)上的一種容錯方法。它最初是針對靜態(tài)電路以優(yōu)化系統(tǒng)時鐘為目的,且在整個電路設(shè)計過程中只使用一次?,F(xiàn)在通過在FPGA中多次使用,改變觸發(fā)器的位置以及增減觸發(fā)器的數(shù)量可以達(dá)到重構(gòu)的目的,并保證整個系統(tǒng)的功能穩(wěn)定以及工作時序的協(xié)調(diào)。使用這種方法時,先根據(jù)約束條件生成一個Retiming矩陣,這個矩陣決定了觸發(fā)器(FF)可能的各種布局。當(dāng)電路出現(xiàn)故障時,通過調(diào)用矩陣的信息重新定位不同的FF以使電路恢復(fù)正常。
這種方法主要的特點就是不改變系統(tǒng)的功能而改變系統(tǒng)的結(jié)構(gòu)特性,重構(gòu)策略簡單。如果結(jié)合可進(jìn)化算法,處理器可以實時地計算得到有效的FF的重新布局。基于Retiming的實時重構(gòu)可以有效地降低暫態(tài)故障的影響,尤其是SEU。同時這種方法配置文件量比較小,粒度水平高,重構(gòu)過程系統(tǒng)開銷小。
但是由于這種方法對電路的重構(gòu)能力有限,所以容錯能力得到一定的限制,尤其對于永久故障則容錯率較低。其次,當(dāng)完成FF的重新配置后,電路需要一個初始化時間,這個時間隨著電路規(guī)模的增大而增大,當(dāng)電路的規(guī)模和復(fù)雜度增大時這種方式的重構(gòu)將導(dǎo)致較大的系統(tǒng)開銷,這樣電路規(guī)模受到限制并且對接口布線要求較高。圖1所示給出了以相關(guān)器為例的兩種可能的重構(gòu)結(jié)構(gòu),其中小方塊為FF。
1.2 基于STARs的方法及分析
基于移動自檢測區(qū)域(STARs)的動態(tài)容錯技術(shù),是一種基于FPGA的具有多種容錯級別的在線容錯技術(shù)。它不僅可以進(jìn)行邏輯工作區(qū)域的容錯,也可以進(jìn)行布線區(qū)域的容錯。
基于STARs的方法,F(xiàn)PGA被劃分為系統(tǒng)工作區(qū)和檢測區(qū),在檢測區(qū)中進(jìn)行內(nèi)建自測試。若當(dāng)前的被檢測區(qū)完成被檢測后STAR和相鄰工作區(qū)的Slice交換位置,這樣依次進(jìn)行,最終STAR可以覆蓋整個FPGA。其優(yōu)勢是,檢測診斷總是在STAR中進(jìn)行,不影響系統(tǒng)的工作,可以有充足的時間來進(jìn)行精確的診斷和生成針對故障區(qū)的配置文件,并實現(xiàn)冗余。
這種方法采用了動態(tài)系統(tǒng)時鐘的概念。系統(tǒng)初始工作在最大時鐘頻率下,當(dāng)部分重構(gòu)使得某些部分的延時增加,那么根據(jù)布線的時序分析結(jié)果,通過周期可編程的時鐘產(chǎn)生器降低時鐘頻率,以滿足系統(tǒng)工作要求。這克服了一般容錯方法中系統(tǒng)在整個壽命期工作在較低時鐘頻率下的缺點。
基于STARs的方法主要是針對永久性錯誤,包括配置存儲器中的錯誤。STARs提供了一個相對于持續(xù)運行的工作區(qū)的離線區(qū)域。通過FPGA的邊界檢測接口可以使STAR中測試文件的配置動態(tài)進(jìn)行而不影響系統(tǒng)工作。由于STARs的存在,工作區(qū)或者是連續(xù)的,或者是被STARs分割成不相連的區(qū)域,系統(tǒng)可以分別使用水平布線和垂直布線穿過V-STAR和H-STAR以實現(xiàn)通信。
這種方法采用了可編程邏輯塊(PLB)重用技術(shù)。PLB重用是指以一種沒有出錯的模式來使用出錯的PLB,即對在出故障的PLB中實現(xiàn)的功能來說這個PLB是沒有出故障的。這有兩種情況,一是故障PLB中的損壞部分并沒有參與實現(xiàn)這個PLB內(nèi)的功能單元,此時無需進(jìn)行重新配置。第二種情況的一個簡單例子是,當(dāng)一個LUT的某個存儲單元由于出錯而固定置為0,且這個LUT用來實現(xiàn)一個組合邏輯,而此組合邏輯的這個存儲單元恰要求被設(shè)置為0,那么這個錯誤就不需要進(jìn)行冗余。由于PLBs的重用,冗余資源的利用率得到提高,容錯量增大,系統(tǒng)壽命得到延長。另外這還使得損壞的PLB利用較遠(yuǎn)距離的冗余資源來重構(gòu)而避開故障區(qū)的情況減少,所以,隨著故障區(qū)增多,系統(tǒng)的時鐘頻率不會明顯降低。
當(dāng)STAR位置改變時,系統(tǒng)時鐘必須停止以使STAR完成移動。系統(tǒng)時鐘停止時,系統(tǒng)的工作狀態(tài)必須被存儲,并在系統(tǒng)時鐘重新啟動前被復(fù)制到新的工作區(qū)域。從STAR離開當(dāng)前這個區(qū)域到下一次再檢測這個區(qū)域的時間內(nèi),工作區(qū)電路可能出錯,這個時間稱為最壞的錯誤駐留時間。雖然基于STARs的方法,檢測、診斷以及重構(gòu)過程在理論上可以不影響系統(tǒng)工作,然而這也是它的缺點,不能對隨時出現(xiàn)的錯誤進(jìn)行容錯。因此,必須考慮最壞的錯誤駐留時間,應(yīng)該提高檢測速度,而檢測速度的提高會使STARs的移動速度提高。這導(dǎo)致檢測區(qū)和工作區(qū)的交換頻率增加,進(jìn)而影響系統(tǒng)工作的連續(xù)性。
1.3 基于遺傳算法及設(shè)計空間搜索的容錯方法與分析
在重構(gòu)容錯的過程中,由于技術(shù)的多樣性,同時會有多種可行的方案,而這很難通過人工來分析比較得到最優(yōu)的解決方法。同時設(shè)計好的系統(tǒng)中必須有足夠的存儲量來存儲針對不同故障的重構(gòu)文件。因此文獻(xiàn)提出了基于遺傳算法的空間搜索技術(shù)。
首先用硬件設(shè)計語言描述系統(tǒng)功能,當(dāng)設(shè)計完成后,對其實現(xiàn)功能進(jìn)行分析并產(chǎn)生一個向量圖,節(jié)點表示功能單元,有向線段代表他們之間的鏈接。同時,對源文件進(jìn)行綜合來識別其資源使用量(包括Slice數(shù)量,塊RAN數(shù)量等)和各個功能單元的特征,最終形成一個功能單元庫。這個庫里面也包含一些標(biāo)準(zhǔn)器件和一些基本單元。另外在設(shè)計過程中還需要生成以下3個庫:
器件特征庫:存儲對FPGA特征的描述,包括可用資源容量,基本重構(gòu)單元大小,重構(gòu)區(qū)域形狀約束。
技術(shù)庫:包含了部分重構(gòu)技術(shù)的模型。
參數(shù)庫:包含一些指導(dǎo)重構(gòu)過程并衡量重構(gòu)效果的參數(shù)。
系統(tǒng)工作時,先將原功能模塊分成不同的組。然后根據(jù)參數(shù)要求在每一組內(nèi)使用在技術(shù)庫里選擇的方法。遺傳算法用來產(chǎn)生不同的可行的染色體,而染色體代表不同的處理方法。這種算法與TMR結(jié)合的例子如圖4所示。
基于遺傳算法的設(shè)計空間搜索方法需要設(shè)計者在前期作出大量工作,例如,遺傳算法的設(shè)計,約束條件以及各庫的形成。其中遺傳算法的設(shè)計和參數(shù)設(shè)定是關(guān)鍵,同時系統(tǒng)需要較強(qiáng)的計算能力,系統(tǒng)開銷較大。不過其所需配置文件存儲量較小,解決方法多樣,能產(chǎn)生出最優(yōu)的解決方案。而且基于硬件遺傳算法具有廣闊的應(yīng)用前景。
2 基于算法和資源多級分塊的容錯結(jié)構(gòu)
2.1 方法的提出
動態(tài)容錯粒度的選取是一個關(guān)鍵問題,如果粒度過小,則對錯誤的檢測定位能力要求較高,而且配置文件復(fù)雜,如果在線生成配置文件,則需要較強(qiáng)的系統(tǒng)計算能力,這顯然會增大系統(tǒng)的開銷,破壞系統(tǒng)的連續(xù)性,而且布線復(fù)雜。如果粒度過大,那么冗余資源的利用率降低,配置文件增大,這削弱了系統(tǒng)的容錯能力,且需要較大的存儲資源。另外,對冗余資源比例的選擇必須要考慮到系統(tǒng)布線難度,而布線所造成的延遲是不可預(yù)知的,所以系統(tǒng)工作頻率也難以保證。上面這幾種方法粒度水平不易改變,布線難度大,系統(tǒng)時鐘性能不高,而且后兩種實現(xiàn)難度較大。
現(xiàn)在采取算法和資源多級分塊的方法進(jìn)行系統(tǒng)的容錯??梢栽诓桓姆椒ǖ那闆r下,通過對算法和資源不同次數(shù)、不同大小的劃分達(dá)到不同的粒度水平,進(jìn)而滿足容錯需要。因為以算法模塊為單位進(jìn)行重構(gòu),且保證重構(gòu)前后模塊之間接口不變,那么模塊外部無需重新布線,這樣就削減了容錯時系統(tǒng)開銷,不會降低時鐘頻率。
先將整個系統(tǒng)在減少模塊間布線難度的情況下按照算法分塊。然后將每個模塊所使用的資源在有2/9以9等分為例,冗余資源的情況下進(jìn)行9等分,這為第二級劃分。如圖5所示。現(xiàn)在需要解決的是配置文件的設(shè)計以及布局的問題。設(shè)計時,對實現(xiàn)相同功能的每—個算法模塊進(jìn)行多種不同的布局,每—個布局都留出其中2/9的冗余資源。當(dāng)然其算秸結(jié)構(gòu)可以不同,而實現(xiàn)相同功能的不同算法也可能會達(dá)到容錯的效果,這將提高系統(tǒng)的容錯能力。相同功能算法的不同布局結(jié)構(gòu)如圖6所示。
基于算法和資源兩級分塊的容錯結(jié)構(gòu),在系統(tǒng)出現(xiàn)異常的情況下,首先采用相同的配置文件對電路進(jìn)行重構(gòu)。重構(gòu)后如果異常消除,那么容錯過程完成,而且出現(xiàn)的錯誤屬于暫態(tài)錯誤。在系統(tǒng)工作的過程中,需要周期性地記錄電路的狀態(tài),當(dāng)出現(xiàn)故障然并進(jìn)行重構(gòu)后應(yīng)該將記錄的狀態(tài)進(jìn)行裝載,以保持系統(tǒng)連續(xù)性及電路工作的正確性。如果這樣的重構(gòu)仍然沒有解決問題,那么改變配置文件,利用布局不同的配置文件進(jìn)行部分動態(tài)重構(gòu),用以解決永久性的故障。重構(gòu)前后算法的功能應(yīng)該保持不變,通過不同布局的重構(gòu)使電路可以繞開硬件故障區(qū),達(dá)到容錯的目的。
為解決重構(gòu)前后的通信問題,采取類似總線宏(Bus Macro)的通信結(jié)構(gòu),保持模塊間重構(gòu)前后通信布線不變。而且每一次重構(gòu),必須保證4個方向的通信端口和內(nèi)部模塊連接也不變,重構(gòu)后的電路都接在原有對外接口上??偩€宏只能用于相鄰的兩個模塊間的通信,對于不相鄰的模塊間的通信,采用稱作可重構(gòu)多路總線(Recongigurable Multiple Bus)的動態(tài)開關(guān)信號的通信結(jié)構(gòu)。以一維結(jié)構(gòu)為例,即現(xiàn)有模塊分布在一條線上。當(dāng)一個模塊Mk需要和另一個不與自己相鄰的模塊通信時,它向與自己相鄰的且與要通信的模塊在相同方向上的模塊Mk+1發(fā)出請求,Mk+1再向Mk+2發(fā)出請求,如是依次下去直到需要通信的模塊Mk+i收到信號,接著它以相反的路徑返回一個應(yīng)答信號,當(dāng)Mk收到應(yīng)答信號后,兩者開始通信。
2.2 方法分析
假設(shè)在第二級劃分時將每一個模塊所占用的資源分成N2等分,稱N為等分?jǐn)?shù),冗余資源為N-1,每一個資源單位出錯概率為P(N),則系統(tǒng)正常工作的概率為
由仿真結(jié)果可知,隨著每一個模塊所占資源等分?jǐn)?shù)的增加,系統(tǒng)容錯能力提高,而同時冗余資源所占的比例卻下降??梢钥吹?,基于算法和資源的兩級分塊容錯結(jié)構(gòu),相對于以往基于模塊的重構(gòu)方法,進(jìn)一步降低了系統(tǒng)的容錯粒度,提高了系統(tǒng)的容錯率和冗余資源的使用效率,而且在容錯的同時起到了檢錯和定位的作用。省去了實際用于檢錯和定位的硬件或軟件開銷,而且系統(tǒng)也不需要在線計算配置文件等,提高了系統(tǒng)的連續(xù)性和可靠性。
由于重構(gòu)前后模塊對外功能接口都不變,相當(dāng)于一個電路黑盒子,節(jié)省了外部布局布線的時間和計算時間,系統(tǒng)容錯時開銷降低。其他的一些冗余方法,例如以CLB為最小單元,每次利用冗余資源繞過故障區(qū)需要復(fù)雜的布局布線,而這樣的布局布線所造成的延遲是難以避免的,只有通過降低芯片工作頻率來保證系統(tǒng)時序的穩(wěn)定。而現(xiàn)在所采取的結(jié)構(gòu)雖然在布局上進(jìn)行了兩次劃分,但是對于每一個模塊的外部仍然是基于功能模塊的容錯,每次都是以經(jīng)過測試的成熟的功能算法為單元的,不存在算法內(nèi)部重新布線后造成延遲的問題,保證了系統(tǒng)的高速運行,這也是本方法的主要特點。
采用逐級劃分的方法可以合理的選擇所需的容錯粒度,以及容錯能力??墒请S著級數(shù)和對每一個模塊等分?jǐn)?shù)目的增加,預(yù)編譯的配置文件數(shù)量將增大,這樣系統(tǒng)需要較多的存儲資源來存儲這些文件。如果采用遺傳算法,根據(jù)硬件資源與工作模塊的分級分塊結(jié)構(gòu)進(jìn)行在線計算,那么這個問題將得到解決。
3 結(jié)束語
文章對基于FPGA的動態(tài)可重構(gòu)技術(shù)在容錯領(lǐng)域的應(yīng)用進(jìn)行了研究。針對重構(gòu)文件的大小,動態(tài)容錯時隙的長短、資源利用率、實現(xiàn)的復(fù)雜性、模塊間通信方式、冗余資源的比例與布局等方面的問題分析了一些方法的優(yōu)缺點,針對突出的問題,提出了一種基于算法和資源多級分塊的容錯方法,可以在不影響系統(tǒng)工作的情況下完成基于動態(tài)重構(gòu)的容錯。這種方法結(jié)構(gòu)簡單,多項參數(shù)可以選擇,尤其是粒度的可變性。冗余資源比例較低,重構(gòu)時沒有對模塊外進(jìn)行布線的要求,不會因重構(gòu)造成延遲而降低系統(tǒng)的工作頻率。
評論
查看更多