FPGA一體化高級(jí)設(shè)計(jì)方法
隨著 FPGA 技術(shù)逐步延伸至軍事電子系統(tǒng)以及嵌入式電子產(chǎn)業(yè)的幾乎全部領(lǐng)域,能發(fā)揮可編程邏輯優(yōu)勢(shì)的應(yīng)用已經(jīng)占據(jù)主流地位。通信、機(jī)載和控制系統(tǒng)尤其受益于 FPGA 的設(shè)計(jì)靈活性、現(xiàn)場(chǎng)重構(gòu)和并行處理功能。同時(shí),較短的設(shè)計(jì)周期和更加簡(jiǎn)化的驗(yàn)證過(guò)程則有助于加快應(yīng)用投入現(xiàn)場(chǎng)的進(jìn)程。
盡管 FPGA 無(wú)所不在,但能真正全面發(fā)揮FPGA 靈活設(shè)計(jì)潛力的應(yīng)用卻很少。之所以存在這種局限性,原因在于 FPGA 開(kāi)發(fā)很大程度上只是簡(jiǎn)單地疊加,或者最多也只是連接于傳統(tǒng)的軟硬件工作流程上。這個(gè)孤立的 FPGA 開(kāi)發(fā)階段會(huì)導(dǎo)致整個(gè)設(shè)計(jì)流程的復(fù)雜性大幅上升——并最終限制軟硬件領(lǐng)域可用的設(shè)計(jì)選擇范圍。
為了簡(jiǎn)化整體設(shè)計(jì)工作,并豐富設(shè)計(jì)選項(xiàng),硬件設(shè)計(jì)、軟件開(kāi)發(fā)和可編程硬件設(shè)計(jì)等獨(dú)立的設(shè)計(jì)過(guò)程需集成在一起,以作為一個(gè)整體的任務(wù)進(jìn)行處理。只有在基礎(chǔ)層面上讓所有設(shè)計(jì)進(jìn)程都能共享統(tǒng)一的設(shè)計(jì)數(shù)據(jù)庫(kù)和通用的設(shè)計(jì)環(huán)境,F(xiàn)PGA 的可再編程性這一最主要的獨(dú)特優(yōu)勢(shì)才能得到充分發(fā)揮,從而將 FPGA 設(shè)計(jì)推向前所未有的水平。全面發(fā)揮 FPGA 靈活性優(yōu)勢(shì)的關(guān)鍵在于了解其發(fā)展趨勢(shì)及所面臨的設(shè)計(jì)挑戰(zhàn),并掌握如何讓包含 FPGA 系統(tǒng)中的三大設(shè)計(jì)方面(硬件、可編程硬件和軟件)實(shí)現(xiàn)協(xié)調(diào)整合。
FPGA 從膠合邏輯向 SoC 方向發(fā)展
FPGA 剛進(jìn)入嵌入式市場(chǎng)領(lǐng)域時(shí),被認(rèn)為是用于實(shí)施大量簡(jiǎn)單膠合邏輯的方便而有效的替代技術(shù)。在這種應(yīng)用中,嵌入式硬件是主要軟硬件設(shè)計(jì)的附屬部分,其開(kāi)發(fā)過(guò)程不涉及其他組件的設(shè)計(jì)流程,也不需要與這些流程進(jìn)行交互。
不過(guò),現(xiàn)在的 FPGA 器件及其使用方式已經(jīng)在海量數(shù)字邏輯便捷容器概念的基礎(chǔ)上發(fā)生了重大變化。大容量 FPGA 現(xiàn)在能承載整個(gè) SoC 設(shè)計(jì),其中處理器、內(nèi)存以及高速數(shù)據(jù)處理等核心功能元素都在可編程領(lǐng)域?qū)嵤?。在軍用嵌入式系統(tǒng)中,由于受產(chǎn)量相對(duì)較低的影響,很難采用 ASIC 設(shè)計(jì)方案,而 FPGA 則為充分發(fā)揮 SoC 設(shè)計(jì)方案的物理簡(jiǎn)單性和可靠性等優(yōu)勢(shì)提供了一條經(jīng)濟(jì)高效的可行之道。
相對(duì)于簡(jiǎn)單的膠合邏輯設(shè)計(jì)而言,SoC 實(shí)施的一個(gè)重大不同點(diǎn)在于,軟硬件開(kāi)發(fā)現(xiàn)在基本上都是關(guān)聯(lián)于、且依賴于 FPGA 設(shè)計(jì)。這是因?yàn)?FPGA 器件和支持外設(shè)是物理設(shè)計(jì)的中心與核心元素,而嵌入式應(yīng)用軟件也要裝載在 FPGA 上發(fā)揮作用。因此,F(xiàn)PGA 域的任何更改都會(huì)對(duì)軟硬件域造成顯著影響。
受限制的創(chuàng)新
如果將硬件、軟件乃至當(dāng)前的嵌入式硬件等設(shè)計(jì)的各個(gè)部分視作是彼此分開(kāi)、互不關(guān)聯(lián)的任務(wù),則無(wú)論設(shè)計(jì)域之間如何相互依存,F(xiàn)PGA 產(chǎn)品設(shè)計(jì)的常規(guī)開(kāi)發(fā)流程采用的仍然是傳統(tǒng)方案。
某個(gè)設(shè)計(jì)域的變動(dòng)往往會(huì)對(duì)其他域造成具有破壞性影響且耗時(shí)巨大的重新設(shè)計(jì)。也就是說(shuō),必須在設(shè)計(jì)階段早期就做出(并且鎖定)軟硬件分區(qū)等重大決策,這與傳統(tǒng)的非 FPGA 嵌入式設(shè)計(jì)別無(wú)二致。實(shí)際上,F(xiàn)PGA 器件和外設(shè)硬件等物理硬件和隨后的可編程硬件元素在有意義的軟件開(kāi)發(fā)之前都被依次一一鎖定了。
這些最初的決策決定了后續(xù)開(kāi)發(fā)流程的參數(shù)和限制,因此設(shè)計(jì)的可選項(xiàng)會(huì)隨著流程的逐步推進(jìn)而越來(lái)越少。例如,選定的 FPGA 器件(和硬件外設(shè))將定義包括確定采用哪種嵌入式 IP 等在內(nèi)的性能上限,嵌入式硬件設(shè)計(jì)進(jìn)而定義軟件可用的功能?;蛘哒f(shuō),F(xiàn)PGA 器件只能支持該器件廠商提供的軟處理器,這進(jìn)而也定義了應(yīng)用軟件可用的編程選擇。
此外,要想微調(diào)設(shè)計(jì)方案的性能,比如將軟件算法轉(zhuǎn)移到嵌入式硬件中、或者從嵌入式處理器轉(zhuǎn)為硬連接的處理器、抑或是選擇不同的 FPGA 類型等,都會(huì)導(dǎo)致對(duì)硬件、可編程硬件和軟件等所有域
*博客內(nèi)容為網(wǎng)友個(gè)人發(fā)布,僅代表博主個(gè)人觀點(diǎn),如有侵權(quán)請(qǐng)聯(lián)系工作人員刪除。