什么是DFX技術(shù)?
DFX(Dynamic Function eXchange)的前身是PR(部分可重配置,Partial Reconfiguration)。使用DFX這個名字更能準確描述其功能,即在線切換設(shè)計中某個模塊的功能。我們把這個模塊對應(yīng)的FPGA物理區(qū)域稱之為一個可重配置分區(qū)(RP,ReconfigurablePartition)。同一個RP下可動態(tài)切換的模塊稱之為可重配置模塊(RM,Reconfigurable Module)。一個RP下可以有一個或多個RM。每個RP要通過手工布局(畫Pblock)的方式指定其在FPGA中的具體位置和大?。ㄎ恢眉s束+面積約束)。
DFX對RM有什么要求?
首先,同一個RP下的所有RM必須保證端口一致,即輸入/輸出方向一致、位寬一致。即使某個RM中使用的端口在另一個RM中未被使用,也要在該RM中進行端口聲明。其次,本身DFX設(shè)計對設(shè)計的層次化要求更高,對RM必須采用OOC綜合方式,因此,要避免在RM中使用Parameter(Verilog)或Generic(VHDL)。最后,RM的頂層必須是RTL代碼(可以是BD的wrapper文件),不能是IP或著網(wǎng)表文件,同時RM下不能包含EDIF或DCP等網(wǎng)表文件,但可以包含IP(.xci)文件。
需要對RP進行手工布局嗎?
DFX設(shè)計要求必須對動態(tài)區(qū)也就是RP進行手工布局,即通過Pblock來約束RP的位置和大小,同時Pblock的形狀盡可能為規(guī)則的矩形,避免出現(xiàn)奇形怪狀,這會對布局布線帶來較大壓力。對于靜態(tài)區(qū),則可以不用手工布局。如果對動態(tài)區(qū)沒有做Pblock約束,那么會報如下錯誤:
?
DFX設(shè)計一定要執(zhí)行設(shè)計規(guī)則檢查嗎?
相比于傳統(tǒng)設(shè)計,DFX設(shè)計較為復(fù)雜,無論是從設(shè)計本身(RTL代碼的層次化、約束)的角度看還是工具的使用角度看,都是如此。因此,在綜合后,一定要執(zhí)行設(shè)計規(guī)則檢查,如下圖所示。這樣能盡早發(fā)現(xiàn)設(shè)計可能存在的問題。這里并不需要對所有規(guī)則都做檢查,只需要檢查DFX相關(guān)的規(guī)則即可。這樣可以節(jié)省時間。

可以對同一RP下不同的RM添加不同的約束嗎?
假定RP1下有兩個RM,分別為RM1和RM2,由于RM1和RM2本身功能并不相同,因此可能就存在一些約束層面的差異。例如:在RM1里需要對某些路徑添加set_max_delay約束,在RM2里則需要對一些路徑添加set_false_path約束。這就要求對不同的RM施加不同的約束。對此,Vivado是支持的,無論是Project模式還是Non-Project模式。具體操作可閱讀這篇文章。
如何給每個RM添加約束?
BD可以用作動態(tài)區(qū)的頂層嗎?
這個問題的本質(zhì)是RM是否可以用BD創(chuàng)建。答案是肯定的。只是這時需要將BD設(shè)計轉(zhuǎn)換為BDC(Block Design Container),勾選下圖中的紅色方框所示內(nèi)容即表明該模塊是一個RM。

除了上述幾個問題之外,我們還需要從以下角度來看待DFX設(shè)計。
DFX設(shè)計本質(zhì)上是FPGA內(nèi)嵌入了FPGA,也就是說RP可視為一個內(nèi)嵌的FPGA,那么這個RP的可用邏輯資源、布線資源和IO也就固定了。正因此,RP的Pblock的大小和形狀對設(shè)計性能有較大影響,同時,RM的輸出/輸出端口個數(shù)應(yīng)盡可能少,過多的IO個數(shù)大概率會導(dǎo)致布線擁塞。因此,同樣的設(shè)計,使用DFX和不使用DFX可能會有不同的時序結(jié)果。層次化設(shè)計在DFX設(shè)計中也非常重要,將直接影響合動態(tài)區(qū)和靜態(tài)區(qū)的分割。
審核編輯:劉清
-
FPGA
+關(guān)注
關(guān)注
1663文章
22491瀏覽量
638896 -
VHDL語言
+關(guān)注
關(guān)注
1文章
113瀏覽量
19460 -
RTL
+關(guān)注
關(guān)注
1文章
395瀏覽量
62855 -
DCP
+關(guān)注
關(guān)注
0文章
30瀏覽量
17905 -
dfx設(shè)計
+關(guān)注
關(guān)注
0文章
6瀏覽量
266
原文標題:DFX設(shè)計中的常見問題
文章出處:【微信號:Lauren_FPGA,微信公眾號:FPGA技術(shù)驛站】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
如何對傳統(tǒng)的非DFX設(shè)計進行調(diào)試呢?
DFX設(shè)計如何分析
采用UltraScale/UltraScale+芯片的DFX設(shè)計注意事項
招兼職dfx、dfm培訓(xùn)講師
硬件電路設(shè)計中常見的DFX
硬件電路常見的DFX設(shè)計環(huán)節(jié)詳解
簡述DFX理念與產(chǎn)品研發(fā)(一)
簡要分析DFX實施流程
DFX極大地提高了Xilinx FPGA芯片的靈活性
2021華為開發(fā)者大會亮點 HarmonyOS架構(gòu)演進與關(guān)鍵技術(shù)-HarmonyOS對DFX能力的要求是什么
HarmonyOS對DFX能力的要求
如何在AMD Vivado? Design Tool中用工程模式使用DFX流程?
什么是DFX技術(shù)?DFX設(shè)計一定要執(zhí)行設(shè)計規(guī)則檢查嗎?
評論