日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > 電源 > 數(shù)字電源
[導(dǎo)讀]FPGA配置兩種模式:主動(dòng)配置和被動(dòng)配置方式,采用主動(dòng)配置下,我們就需要一片F(xiàn)LASH來存儲(chǔ)FPGA固件,那么我們?cè)谏?jí)固件寫FLASH的過程中如何避免因意外情況發(fā)生導(dǎo)致升級(jí)失敗

FPGA配置兩種模式:主動(dòng)配置和被動(dòng)配置方式,采用主動(dòng)配置下,我們就需要一片F(xiàn)LASH來存儲(chǔ)FPGA固件,那么我們?cè)谏?jí)固件寫FLASH的過程中如何避免因意外情況發(fā)生導(dǎo)致升級(jí)失敗而使FPGA變磚呢?下面就由筆者帶領(lǐng)大家來挖山掘石、一探究竟。

 

 

本文主要針對(duì)Xilinx的Spartan-6和7-series FPGA。在設(shè)計(jì)FPGA的遠(yuǎn)程升級(jí)功能時(shí),我們要實(shí)現(xiàn)以下兩個(gè)指標(biāo):

1、FPGA具有升級(jí)功能,即在正常工作狀態(tài)下,F(xiàn)PGA可以將新的固件數(shù)據(jù)燒寫到FLASH里面并在下次重啟的時(shí)候能夠正常加載;

2、如果升級(jí)過程中出現(xiàn)意外情況,F(xiàn)LASH里面原有的固件被破壞,那么FPGA能夠從備份固件區(qū)啟動(dòng)配置,即FLASH里要有另外一份沒有問題的固件備份,且FPGA可以自動(dòng)跳轉(zhuǎn)到這個(gè)固件區(qū)讀取固件。

好了,功能需求明確,下面就該潛下心來進(jìn)行框架流程設(shè)計(jì)、時(shí)序設(shè)計(jì)、代碼編寫以及仿真驗(yàn)證了。一番辛苦勞作之后,IP設(shè)計(jì)好了,這個(gè)時(shí)候心里暗暗自喜:應(yīng)該沒問題,只待硬件測(cè)試?yán)?。三下五除二,找了臺(tái)機(jī)器測(cè)試了一遍,發(fā)現(xiàn)能夠正常升級(jí),這個(gè)時(shí)候心里那個(gè)是樂開了花啊,一次搞定,哈哈。

接下來就要進(jìn)行激動(dòng)人心的防磚測(cè)試了,于是你就邀請(qǐng)了周圍的同事來一起見證奇跡,于是測(cè)試開始,于是在升級(jí)運(yùn)行的過程中你自信的斷了電,然后你對(duì)著周圍的同事說:下面就是見證奇跡的時(shí)刻,于是你接通了電源,此時(shí)你笑的是那么春光燦爛。突然,你耳邊傳來一句輕輕的、溫柔的耳語(yǔ):老兄,你的FPGA變磚啦!“怎么可能!”,你不屑的低吼了一句,可是,當(dāng)你看到那顆小小的LED燈安靜的還在沉睡的時(shí)候,你傻眼了,“What the hell is going on!”,看著周圍的同事,我理解你的心情:一種被狠狠打臉的刺痛感襲上了你的心頭。你埋著頭繃著臉,折騰了半天沒找出原因在哪,這到底是怎么回事兒呢?

FPGA升級(jí)防磚也即支持FALLBACK模式,賽靈思官方的指導(dǎo)文檔里也進(jìn)行了相應(yīng)的指導(dǎo)說明。對(duì)于FALLBACK模式,最重要的就是要構(gòu)建起一個(gè)FLASH鏡像文件,該鏡像文件的架構(gòu)如圖1所示。

 

 

圖1 FLASH鏡像文件架構(gòu)

關(guān)于FLASH鏡像架構(gòu)的信息,賽靈思官方的configuraTIon user guide里有詳細(xì)說明。圖中,MulTIboot Header決定了FPGA上電之后要先從哪個(gè)固件區(qū)讀取配置文件以及如果失敗了該跳轉(zhuǎn)到哪個(gè)固件區(qū)讀取備份配置。我們的鏡像里劃分了兩片區(qū)域用于存儲(chǔ)固件,分別為:AcTIve區(qū)和Old(golden)區(qū),我們的升級(jí)指的就是對(duì)AcTIve區(qū)的固件進(jìn)行更新,Header區(qū)和Old區(qū)的信息不改動(dòng);FPGA每次上電先從Active區(qū)讀取配置文件。Old區(qū)是一份固件備份,它的作用就是當(dāng)Active區(qū)因?yàn)樯?jí)意外而固件被破壞的情況下,F(xiàn)PGA能夠從此處啟動(dòng)配置。

那么,如何保證當(dāng)Active區(qū)的固件因?yàn)樯?jí)意外被破壞時(shí)FPGA能夠主動(dòng)切換到Old區(qū)域讀取配置文件呢?這就是我們要說明的問題。

FPGA升級(jí)固件的燒寫一般有兩種方式,分別如下:

1、順序燒寫,這是最傳統(tǒng)的燒寫方式,即不對(duì)固件進(jìn)行任何更改直接往FLASH里燒寫;

2、調(diào)整固件燒寫順序,即對(duì)固件進(jìn)行一定的修改,然后分兩次燒寫。

我們?cè)谠O(shè)計(jì)的時(shí)候首先想到的就是第一種方式,況且賽靈思官方文檔也說了在如下情況下FPGA會(huì)跳轉(zhuǎn)到備份區(qū)啟動(dòng)配置:

1、讀取配置文件的同步字超時(shí),此時(shí)會(huì)觸發(fā)跳轉(zhuǎn);

2、檢查到固件CRC出錯(cuò),此時(shí)會(huì)觸發(fā)跳轉(zhuǎn)。

根據(jù)這些說法,采用第一種方式也不會(huì)出問題啊!可是為什么就不行呢?也許細(xì)心測(cè)試的你會(huì)發(fā)現(xiàn),在擦除的過程中斷電的話FPGA能夠從備份區(qū)啟動(dòng),在燒寫的過程中斷電的話FPGA就會(huì)啟動(dòng)失敗,你,有沒有感悟到什么?是不是看到了一絲絲亮光?奧特曼說過:有光的地方就有希望!你可能會(huì)問:為什么有第二種燒寫方式?要怎樣調(diào)整固件呢?為什么要調(diào)整呢?在這里,我先給你肯定答案:采用第二種方式完全不會(huì)出問題?,F(xiàn)在,我們接著往下賣關(guān)子。

既然有上面的一系列疑問,那么我們就需要去研究一下ISE工具在生成固件的時(shí)候是怎樣的一種打包格式。經(jīng)過研究發(fā)現(xiàn)兩個(gè)很重要的信息:

1、配置文件的同步字在固件的首部;

2、CRC檢查命令一般在固件的后部,而FPGA必須在收到CRC檢查命令之后才會(huì)去檢查CRC值。

前面也提到,當(dāng)擦除的時(shí)候斷電FPGA能夠發(fā)生配置跳轉(zhuǎn),當(dāng)燒寫的時(shí)候斷電FPGA無法進(jìn)行配置跳轉(zhuǎn),說到這里再結(jié)合上面的兩條重要的發(fā)現(xiàn),你也許已經(jīng)為自己心中的疑問找到答案了吧?很顯然,因?yàn)楣碳耐阶趾苌伲阅軌蚝芸毂徊脸部梢院芸毂粚懭隖LASH;因此,當(dāng)擦除的時(shí)候斷電了,此時(shí)固件的同步字已經(jīng)破壞,而FPGA讀不到同步字就會(huì)出現(xiàn)看門狗超時(shí),那么此時(shí)FPGA就會(huì)跳轉(zhuǎn)到備份區(qū)讀取配置文件;當(dāng)在燒寫的時(shí)候斷電呢?因?yàn)榇藭r(shí)同步字已經(jīng)被正確寫入,而CRC檢查命令被破壞了,F(xiàn)PGA在配置的時(shí)候會(huì)去讀CRC檢查命令,直到讀到為止,可是CRC檢查命令被破壞了怎么辦呢?沒得辦法啊,F(xiàn)PGA有一種不撞南墻不回頭,撞了南墻依然不回頭的韌勁和堅(jiān)持,它會(huì)一直讀下去,所以它就陷入死循環(huán)了,哎!你說如果愛情里也有這種精神該多好啊!

經(jīng)過上面的解釋,我們會(huì)恍然大悟:原來通過CRC錯(cuò)誤觸發(fā)FPGA配置跳轉(zhuǎn)不靠譜啊!既然如此,我們就只能在固件的同步字上做文章了。好了,不賣關(guān)子了,其實(shí),在固件的同步字上做文章也就對(duì)應(yīng)著升級(jí)固件的燒寫方式2:修改固件并調(diào)整固件的燒寫順序,簡(jiǎn)單解釋如下:

1、把固件的同步字修改掉,第一步燒寫的時(shí)候不燒同步字;

2、當(dāng)固件的其余部分燒寫完畢之后再單獨(dú)把固件的同步字燒寫入原來對(duì)應(yīng)的FLASH位置處。

 

 

這樣做了之后,無論是擦除過程中斷電還是燒寫的過程中斷電,固件的同步字都會(huì)被破壞,那么肯定會(huì)觸發(fā)FPGA的配置跳轉(zhuǎn),即FALLBACK一定會(huì)成功!小小劇透一下:賽靈思官網(wǎng)里的AR問答記錄里也有相應(yīng)的解決方案說明哦,自己去搜吧,祝你好運(yùn)!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

在數(shù)字化浪潮席卷全球的今天,F(xiàn)PGA技術(shù)正成為驅(qū)動(dòng)創(chuàng)新的核心引擎。2025年8月21日,深圳將迎來一場(chǎng)聚焦FPGA技術(shù)與產(chǎn)業(yè)應(yīng)用的盛會(huì)——2025安路科技FPGA技術(shù)沙龍。本次沙龍以“定制未來 共建生態(tài)”為主題,匯聚行業(yè)...

關(guān)鍵字: FPGA 核心板 開發(fā)板

在現(xiàn)代電子系統(tǒng)中,現(xiàn)場(chǎng)可編程門陣列(FPGA)憑借其開發(fā)時(shí)間短、成本效益高以及靈活的現(xiàn)場(chǎng)重配置與升級(jí)等諸多優(yōu)點(diǎn),被廣泛應(yīng)用于各種產(chǎn)品領(lǐng)域。從通信設(shè)備到工業(yè)控制,從汽車電子到航空航天,F(xiàn)PGA 的身影無處不在。為了充分發(fā)揮...

關(guān)鍵字: 可編程門陣列 FPGA 數(shù)字電源

2025年8月4日 – 提供超豐富半導(dǎo)體和電子元器件?的業(yè)界知名新品引入 (NPI) 代理商貿(mào)澤電子 (Mouser Electronics) 即日起開售Altera?的Agilex? 3 FPGA C系列開發(fā)套件。此開...

關(guān)鍵字: FPGA 邊緣計(jì)算 嵌入式應(yīng)用

內(nèi)窺鏡泛指經(jīng)自然腔道或人工孔道進(jìn)入體內(nèi),并對(duì)體內(nèi)器官或結(jié)構(gòu)進(jìn)行直接觀察和對(duì)疾病進(jìn)行診斷的醫(yī)療設(shè)備,一般由光學(xué)鏡頭、冷光源、光導(dǎo)纖維、圖像傳感器以及機(jī)械裝置等構(gòu)成。文章介紹了一款基于兩片圖像傳感器和FPGA組成的微型3D內(nèi)...

關(guān)鍵字: 微創(chuàng) 3D內(nèi)窺鏡 OV6946 FPGA

運(yùn)用單片機(jī)和FPGA芯片作為主控制器件 , 單片機(jī)接收從PC機(jī)上傳過來的顯示內(nèi)容和顯示控制命令 , 通過命令解釋和數(shù)據(jù)轉(zhuǎn)換 , 生成LED顯示屏所需要的數(shù)據(jù)信號(hào)和同步的控制信號(hào)— 數(shù)據(jù)、時(shí)鐘、行同步和面同步 。FPGA芯...

關(guān)鍵字: 單片機(jī) FPGA LED顯示屏

在異構(gòu)計(jì)算系統(tǒng)中,ARM與FPGA的協(xié)同工作已成為高性能計(jì)算的關(guān)鍵架構(gòu)。本文基于FSPI(Fast Serial Peripheral Interface)四線模式,在150MHz時(shí)鐘頻率下實(shí)現(xiàn)10.5MB/s的可靠數(shù)據(jù)...

關(guān)鍵字: ARM FPGA FSPI

在全球FPGA市場(chǎng)被Xilinx(AMD)與Intel壟斷的格局下,國(guó)產(chǎn)FPGA廠商高云半導(dǎo)體通過構(gòu)建自主IP核生態(tài)與智能時(shí)序約束引擎,走出差異化高端化路徑。本文深入解析高云半導(dǎo)體FPGA工具鏈的兩大核心技術(shù)——全棧IP...

關(guān)鍵字: FPGA 高云半導(dǎo)體

2025年6月12日,由安路科技主辦的2025 FPGA技術(shù)沙龍?jiān)谀暇┱秸匍_,深圳市米爾電子有限公司(簡(jiǎn)稱:米爾電子)作為國(guó)產(chǎn)FPGA的代表企業(yè)出席此次活動(dòng)。米爾電子發(fā)表演講,并展出米爾基于安路飛龍派的核心板和解決方案...

關(guān)鍵字: FPGA 核心板 開發(fā)板

高 I/O、低功耗及先進(jìn)的安全功能,適用于成本敏感型邊緣應(yīng)用

關(guān)鍵字: FPGA I/O 機(jī)器視覺

本文討論如何為特定應(yīng)用選擇合適的溫度傳感器。我們將介紹不同類型的溫度傳感器及其優(yōu)缺點(diǎn)。最后,我們將探討遠(yuǎn)程和本地檢測(cè)技術(shù)的最新進(jìn)展如何推動(dòng)科技進(jìn)步,從而創(chuàng)造出更多更先進(jìn)的溫度傳感器。

關(guān)鍵字: 溫度傳感器 CPU FPGA
關(guān)閉