基于軟件測(cè)試技術(shù)的FPGA測(cè)試研究
現(xiàn)場(chǎng)可編程門(mén)陣列(FPGA)的出現(xiàn)大大壓縮了電子產(chǎn)品研發(fā)的周期和成本,由于FPGA器件具有高密度、低功耗、高速、高可靠性等優(yōu)點(diǎn),在航空、航天、通信、工業(yè)控制等方面得到了大量應(yīng)用。隨著FPGA應(yīng)用領(lǐng)域的擴(kuò)展以及重要性和復(fù)雜程度的提高,其可靠性問(wèn)題變得越來(lái)越突出,因此對(duì)FPGA系統(tǒng)的測(cè)試需求變得尤為迫切。
目前FPGA測(cè)試技術(shù)的研究主要集中于對(duì)FPGA芯片資源的測(cè)試,通過(guò)編程覆蓋FPGA所有的邏輯資源[1,2]和連接資源[3],驗(yàn)證每個(gè)單元基本邏輯功能的正確性,而無(wú)法對(duì)電路的整體行為進(jìn)行有效的驗(yàn)證。硬件描述語(yǔ)言(HDL)是FPGA電路設(shè)計(jì)的主要實(shí)現(xiàn)方式,和軟件一樣,HDL也是人腦思維的邏輯產(chǎn)物,同樣存在著不希望或不可接受的人為錯(cuò)誤。隨著設(shè)計(jì)復(fù)雜程度的提高,由HDL引入的缺陷成為影響FPGA可靠運(yùn)行的關(guān)鍵因素,對(duì)FPGA電路行為的測(cè)試成為提高系統(tǒng)質(zhì)量和可靠性的重要環(huán)節(jié)。
MIN Y.H.提出了在FPGA系統(tǒng)中進(jìn)行高層測(cè)試的必要性[4]。高層測(cè)試即任何高于門(mén)級(jí)的測(cè)試,考慮的是高層描述,如HDL、狀態(tài)圖、功能塊圖等,通過(guò)高層測(cè)試發(fā)現(xiàn)設(shè)計(jì)中的缺陷,并在系統(tǒng)的開(kāi)發(fā)階段充分考慮測(cè)試需求,指導(dǎo)系統(tǒng)設(shè)計(jì)。以此為基礎(chǔ),先后提出了一系列具體的實(shí)施方法,如層次化的測(cè)試方法、基于電路功能或結(jié)構(gòu)的測(cè)試方法、基于模擬的測(cè)試方法等。
1 研究背景
1.1 軟件測(cè)試技術(shù)概述
在IEEE的軟件工程標(biāo)準(zhǔn)術(shù)語(yǔ)中,軟件測(cè)試定義為使用人工和自動(dòng)手段來(lái)運(yùn)行或測(cè)試某個(gè)系統(tǒng)的過(guò)程,其目的在于檢驗(yàn)它是否滿(mǎn)足規(guī)定的需求或找出預(yù)期結(jié)果與實(shí)際結(jié)果之間的差別。
按照測(cè)試級(jí)別,軟件測(cè)試包括單元測(cè)試、部件測(cè)試、配置項(xiàng)測(cè)試、系統(tǒng)測(cè)試等;按照測(cè)試方法,軟件測(cè)試可分為動(dòng)態(tài)測(cè)試和靜態(tài)測(cè)試,動(dòng)態(tài)測(cè)試又可分為黑盒測(cè)試和白盒測(cè)試。靜態(tài)測(cè)試包括了代碼審查、靜態(tài)分析、代碼走查等測(cè)試類(lèi)型;動(dòng)態(tài)測(cè)試包括邏輯測(cè)試、功能測(cè)試、性能測(cè)試、接口測(cè)試等測(cè)試類(lèi)型。白盒測(cè)試通常采用以邏輯覆蓋衡量的結(jié)構(gòu)性測(cè)試技術(shù);黑盒測(cè)試通常采用包括功能分解、等價(jià)類(lèi)劃分、邊界值分析等在內(nèi)的功能性測(cè)試技術(shù)[5]。
1.2 FPGA系統(tǒng)的特點(diǎn)
FPGA作為可編程邏輯器件,通過(guò)編程的方式(如HDL)將通用芯片配置成用戶(hù)需要的硬件數(shù)字電路,F(xiàn)PGA和軟件系統(tǒng)具有相似的結(jié)構(gòu)和開(kāi)發(fā)方式,HDL與軟件都是人腦思維邏輯的產(chǎn)物,具有相似的語(yǔ)法和失效機(jī)理。因此,將軟件測(cè)試的成熟技術(shù)用于FPGA測(cè)試,在理論和操作上均具有可行性。
但是,由于軟硬件系統(tǒng)本質(zhì)上的不同,F(xiàn)PGA和軟件系統(tǒng)在測(cè)試要求上存在一定的差異,表1從開(kāi)發(fā)方式、代碼執(zhí)行順序、受硬件影響程度、執(zhí)行結(jié)果的隨機(jī)性以及應(yīng)用領(lǐng)域等方面,歸納了FPGA和軟件系統(tǒng)的不同之處。
2 FPGA特有測(cè)試要求
針對(duì)FPGA和軟件系統(tǒng)的差異,存在不同于軟件測(cè)試特有的測(cè)試要求,包括HDL代碼檢測(cè)要求、測(cè)試級(jí)別要求和時(shí)序測(cè)試用例設(shè)計(jì)要求等。
2.1 HDL代碼檢測(cè)要求
由于HDL代碼并行執(zhí)行并存在硬件環(huán)境的影響以及競(jìng)爭(zhēng)、冒險(xiǎn)等不確定結(jié)果,在白盒測(cè)試中具有不同于軟件測(cè)試的要求。一方面,不同于軟件的控制流和數(shù)據(jù)流,并行程序的時(shí)序和信號(hào)流是一對(duì)相互依存的信息,程序的邏輯狀態(tài)由二者共同確定。這就要求在測(cè)試中,既要依據(jù)信號(hào)流圖對(duì)組合邏輯進(jìn)行驗(yàn)證,還要依據(jù)時(shí)序圖分析時(shí)變信號(hào)的時(shí)序一致性。另一方面,硬件特征對(duì)運(yùn)行結(jié)果的影響也是代碼檢測(cè)中需要考慮的因素[6]。在編碼規(guī)范的制定上,應(yīng)當(dāng)充分考慮并行程序的特點(diǎn),正確處理與硬件資源之間的關(guān)系,避免競(jìng)爭(zhēng)、冒險(xiǎn)等不確定結(jié)果的產(chǎn)生。
2.2 測(cè)試級(jí)別的要求
與傳統(tǒng)自底向上的電子設(shè)計(jì)技術(shù)不同,F(xiàn)PGA采用與軟件開(kāi)發(fā)相同的自頂向下的設(shè)計(jì)方法。一個(gè)項(xiàng)目的開(kāi)發(fā)過(guò)程,從系統(tǒng)的分解、RTL模型的建立、門(mén)級(jí)模型的產(chǎn)生,到最終的可以物理布線(xiàn)實(shí)現(xiàn)的底層電路,是一個(gè)從高抽象級(jí)別到低抽象級(jí)別的開(kāi)發(fā)周期。在開(kāi)發(fā)過(guò)程中,需要在每一階段分別進(jìn)行行為仿真、功能仿真、門(mén)級(jí)時(shí)序仿真等仿真驗(yàn)證,而在測(cè)試階段需要自底向上依次從門(mén)級(jí)、元件功能級(jí)到系統(tǒng)行為級(jí)進(jìn)行測(cè)試。
2.3 時(shí)序測(cè)試用例設(shè)計(jì)要求
FPGA的并行運(yùn)算和高響應(yīng)速度的特性,使其在對(duì)高速時(shí)序邏輯的處理中得到廣泛應(yīng)用。因此對(duì)FPGA系統(tǒng)功能、性能的測(cè)試中,不能僅僅局限于對(duì)穩(wěn)態(tài)輸入輸出的驗(yàn)證,還需要驗(yàn)證系統(tǒng)對(duì)時(shí)序信號(hào)的響應(yīng)及輸出量隨時(shí)間變化正確性的判斷。因此在測(cè)試用例的設(shè)計(jì)中,需要對(duì)系統(tǒng)輸入、輸出的時(shí)間變化趨勢(shì)進(jìn)行規(guī)定,并提供動(dòng)態(tài)輸出信號(hào)的判斷準(zhǔn)則,同時(shí)需要開(kāi)發(fā)時(shí)序測(cè)試環(huán)境支持測(cè)試用例的執(zhí)行。
3 FPGA測(cè)試技術(shù)框架
3.1 測(cè)試級(jí)別
把抽象的實(shí)體結(jié)合成單個(gè)或統(tǒng)一實(shí)體的過(guò)程稱(chēng)為綜合,F(xiàn)PGA系統(tǒng)的每一步開(kāi)發(fā)過(guò)程都可以稱(chēng)為一個(gè)綜合環(huán)節(jié),即將自然語(yǔ)言表示經(jīng)過(guò)自然語(yǔ)言綜合轉(zhuǎn)換為HDL算法表示,再通過(guò)行為綜合轉(zhuǎn)換在寄存器傳輸(RTL)級(jí),進(jìn)一步通過(guò)邏輯綜合轉(zhuǎn)換為邏輯門(mén)的表示,最終通過(guò)結(jié)構(gòu)綜合轉(zhuǎn)換為版圖表示。對(duì)于每一個(gè)綜合環(huán)節(jié),都對(duì)應(yīng)響應(yīng)的測(cè)試級(jí)別,F(xiàn)PGA測(cè)試的“V”模型如圖1所示。
評(píng)論