新聞中心

EEPW首頁 > EDA/PCB > 設(shè)計應(yīng)用 > 基于FPGA的星載計算機自檢EDAC電路設(shè)計

基于FPGA的星載計算機自檢EDAC電路設(shè)計

作者: 時間:2012-08-30 來源:網(wǎng)絡(luò) 收藏

在本設(shè)計中,我們采用外置的CPU芯片和內(nèi)置的RAM單元,作為自檢電路的硬件平臺 (或環(huán)境、資源)。CPU芯片在這里起到的作用是啟動自檢,處理錯誤中斷,向地面?zhèn)?送錯誤信息,并根據(jù)地面要求對錯誤信息進行處理。

在該設(shè)計中,檢測一個存儲單元地址僅需要4個時鐘周期,如果開啟自糾錯功能,并且 檢測到單比特錯誤,再增加2個時鐘周期用來糾錯。因此如果時鐘為20MHz,并且錯誤數(shù)據(jù)較 少,則更新1M個RAM存儲單元需要的時間約為:4×1M 20MHz = 0.2s。

更重要的是,在這0.2s的時間里,僅在出現(xiàn)錯誤時需要向產(chǎn)生中斷,進行相應(yīng)處 理,對地面進行錯誤報告,因而CPU處理時間很短,節(jié)省了寶貴的CPU資源。

3.3 仿真與驗證

在空間環(huán)境下普遍存在的SEU,在地面環(huán)境下是很難獲得的,為了在地面對該電路 設(shè)計進行驗證,需要采取故障注入手段。由于在本例中RAM存儲單元采用內(nèi)部資源,因 此故障注入變得相對簡單。在進行程序綜合時,可將預(yù)先編制好的RAM存儲單元初始化 文件一起綜合。因此我們可在編制RAM存儲單元初始化文件時,對某些比特位進行修改,以 模擬空間環(huán)境下SEU對RAM存儲單元的影響。

在這里采用Xilinx公司的XQRV300為硬件載體,該型號芯片在航天領(lǐng)域內(nèi)被廣泛使 用。為節(jié)省仿真時間,數(shù)據(jù)RAM存儲單元采用256*8bit,檢驗RAM存儲單元采用25*bit。在 RAM存儲單元初始化文件中,人工加入了12個單比特錯誤,以及1個兩比特錯誤,如下表所示。

為仿真簡便起見,向存儲單元存放的正確數(shù)據(jù)與存儲單元地址相同。

時鐘選擇為20MHz,通過采用ModelSim軟件進行布線后仿真,我們可以得到圖3所示結(jié)果。

圖中: Clk — 系統(tǒng)時鐘;

En — EDAC 模塊使能控制;

Check — 自檢啟動/使能信號(信號上升沿觸發(fā)一次巡檢,信號為低暫停巡檢);

Rw_En — 自糾錯使能信號(為高允許糾錯);

Err — 錯誤中斷(標(biāo)志)信號;

Rw — 自糾錯標(biāo)志信號(為高表示正在進行自糾錯操作);

MErr — 多比特錯誤中斷(標(biāo)志)信號;

Checking — 自檢標(biāo)志(為高表示尚未完成本次巡檢操作);

Err_Sum,Err_A,Err_D,Err_C — 錯誤計數(shù),錯誤地址,原始數(shù)據(jù),原始校驗碼;

D,A,Wr,Rd — 單片機數(shù)據(jù)、地址、寫操作、讀操作信號;



關(guān)鍵詞: FPGA EDAC 星載 計算機

評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉