應(yīng)用PlanAhead工具提高設(shè)計(jì)效率
設(shè)計(jì)問題尤其涉及到那些大型高性能計(jì)劃,最有效的解決方法就是首先對問題詳盡分析,然后將大問題分解成易于管理的小問題。觀察近年來可編程器件的發(fā)展過程,fpga在尺寸和復(fù)雜性方面有巨大的提高,但pld eda工具卻相對沒有多少變化。在傳統(tǒng)的扁平設(shè)計(jì)流程中,每個設(shè)計(jì)更改都意味著要對整個設(shè)計(jì)重新綜合、重新實(shí)現(xiàn)。對于要在幾百萬門的器件上實(shí)現(xiàn)的復(fù)雜設(shè)計(jì)來說,即使是一個微小的更改也會導(dǎo)致長時間的令人無法接受的布局布線(par),更不要說典型設(shè)計(jì)中從ptl 到par的反復(fù)操作所導(dǎo)致的時間耗費(fèi)。
本文引用地址:http://2s4d.com/article/21024.htm很少有設(shè)計(jì)團(tuán)隊(duì)能夠容忍超過預(yù)期時間設(shè)計(jì)仍得到出乎意料的低性能,更別說隨之而來的挫折感和壓力。此外,這可能還意味著較低的fpga利用率,甚至錯過產(chǎn)品面市機(jī)會。
planahead 工具
越來越多的客戶在賽靈思 planahead 設(shè)計(jì)分析工具提供的層次化設(shè)計(jì)方法學(xué)中找到解決方案。planahead 軟件為 fpga 設(shè)計(jì)流程增加了可視性和可控性。通過解決物理方面(介于邏輯綜合和實(shí)現(xiàn)工藝之間)的問題,可在設(shè)計(jì)結(jié)果中實(shí)現(xiàn)性能的提高。
雖然先進(jìn)的 fpga 綜合產(chǎn)品為幾百萬門設(shè)計(jì)提供極高的自動優(yōu)化水平,許多設(shè)計(jì)者仍需要具有更多啟發(fā)性的技術(shù),以達(dá)到最佳性能目標(biāo)。通過提供早期分析和布局規(guī)劃 (floorplanning)功能,planahead 設(shè)計(jì)工具可以施加物理約束,以幫助控制設(shè)計(jì)的初始實(shí)現(xiàn)。實(shí)現(xiàn)后,planahead 軟件可以分析布局和時序結(jié)果,以改進(jìn)用于完成設(shè)計(jì)的布局規(guī)劃??梢允褂脕碜詫?dǎo)入結(jié)果的物理約束,在后續(xù)實(shí)現(xiàn)嘗試期間鎖定布局。這些約束用于創(chuàng)建可重用 ip,連同鎖定布局,一同用于其它設(shè)計(jì)。
planahead 設(shè)計(jì)方法提供了性能、生產(chǎn)率以及結(jié)果的可重復(fù)性。憑借其層次化設(shè)計(jì)流程,planahead 軟件可減少運(yùn)行 par 然后返回 rtl 與綜合的反復(fù)次數(shù)。反之,可以分析設(shè)計(jì)并在實(shí)現(xiàn)之前解決物理方面的問題。
速度更快,性能更好
planahead 用戶通??梢詫?shí)現(xiàn) 10-15% 的性能提升,有些用戶甚至可以更高。此外,設(shè)計(jì)者可以在一個緊湊的器件中額外加入 10% 的邏輯。更快的性能與更高利用率的結(jié)合意味著可以使用尺寸更小、成本更低的器件,或者以更低的速度等級實(shí)現(xiàn)設(shè)計(jì)目標(biāo)。
planahead 設(shè)計(jì)工具可在縮短總設(shè)計(jì)時間的同時,在結(jié)果中增加一定的一致性。通過利用以前的布局規(guī)劃或增量設(shè)計(jì)技術(shù),可以以更少的時間執(zhí)行設(shè)計(jì)反復(fù),實(shí)現(xiàn)可重復(fù)的結(jié)果。還可以利用成功結(jié)果,將它們鎖定下來或在其它設(shè)計(jì)中重用。
解決真正棘手的性能問題所需要的絕不僅僅是增加新的菜單項(xiàng)或腳本能力。planahead 軟件通過使用各種視圖(見圖 1)展示設(shè)計(jì)數(shù)據(jù),提供了一個完整的環(huán)境,使該層次化方法實(shí)現(xiàn)交互并易于使用。這些獨(dú)立的視圖可以相互結(jié)合使用,從而允許快速識別和瀏覽關(guān)鍵設(shè)計(jì)對象和信息。
還可顯示時鐘區(qū),并在布局規(guī)劃時使用它來優(yōu)化各個時鐘或最大程度地降低器件中的功耗。通過將時鐘隔離到專門的時鐘區(qū),它們可以運(yùn)行得更快,并消除了為其它時鐘區(qū)供電的需要。
在設(shè)計(jì)過程中的各個階段均可使用 planahead 設(shè)計(jì)工具的分析和探測環(huán)境。甚至,可以在實(shí)現(xiàn)之前分析設(shè)計(jì)。
planahead 軟件提供了一個靜態(tài)時序引擎 timeahead,用于研究設(shè)計(jì)在時序方面的可行性。還可以通過調(diào)整純邏輯延遲,在不進(jìn)行互連的情況下,使用估計(jì)的布線延遲執(zhí)行分析。這可以看清楚設(shè)計(jì)中存在多大的時序容差。
可視化
planahead 環(huán)境通過顯示 i/o 互連和物理塊(pblock)網(wǎng)束 (net bundle),提供洞察設(shè)計(jì)數(shù)據(jù)流的能力??梢愿鶕?jù)信號數(shù)量控制網(wǎng)束的顏色和線厚,方便地在貫穿設(shè)計(jì)的整個數(shù)據(jù)流中確定具有大量連接的 pblock。然后采取校正措施,避開布線擁塞故障點(diǎn),并將具有大量連接的 pblock 相近放置或?qū)⑺鼈兒喜ⅰ?/p>
可在 planahead 環(huán)境中編輯和精調(diào)時序約束,相同的分析結(jié)果可以幫助確定哪些邏輯應(yīng)組合在一起并進(jìn)行布局規(guī)劃。針對布局規(guī)劃,可對路徑進(jìn)行邏輯排序、組合和選擇,還可以使用同一 timeahead 環(huán)境處理從 trce 導(dǎo)入的時序結(jié)果,trce 是賽靈思 ise軟件中的時序評估工具。
可以查看和修改為設(shè)計(jì)指定的時序約束。并可以在編輯器中將所有 ise 時序約束定義為新約束。這可以使約束指定變得更容易,不必再記住專門的約束格式??梢栽谶\(yùn)行任何 ise 實(shí)現(xiàn)工具之前,將其與 timeahead 一起使用以驗(yàn)證和優(yōu)化約束集。
planahead設(shè)計(jì)工具提供了可視輔助,以幫助理解物理實(shí)現(xiàn)結(jié)果。設(shè)計(jì)規(guī)則檢查 (drc) 功能有助于及早捕獲錯誤。它還會對未正確利用某些器件資源(如 virtex-4 fpga 中的 xtremedsp切片或 ram)的設(shè)計(jì)進(jìn)行標(biāo)記。
通過將問題區(qū)域可視化,可以在 rtl 側(cè)或物理實(shí)現(xiàn)側(cè)快速解決問題,而不必繼續(xù)重復(fù)進(jìn)行 rtl 與綜合??梢詫Ω鱾€邏輯模塊進(jìn)行選擇性地高亮顯示,以更好地了解它們放置的位置以及創(chuàng)建在邏輯最集中區(qū)域的pblock。此外,可以高亮顯示故障時序路徑,以可視化和了解設(shè)計(jì)中發(fā)生了什么物理問題。
planahead 軟件包含量度圖 (metric map),以快速確定設(shè)計(jì)的故障區(qū)域(見圖 2)。
這可能與時序或利用率有關(guān),有助于在試圖確定設(shè)計(jì)中要關(guān)注的區(qū)域以實(shí)現(xiàn)邏輯壓縮或時序連接性。
planahead 設(shè)計(jì)工具允許研究設(shè)計(jì)中的連接性。在設(shè)計(jì)中選擇一個特定的網(wǎng)絡(luò)、pblock 或?qū)嵗螅ㄟ^單擊鼠標(biāo)高亮顯示所有連接到選定元素的網(wǎng)絡(luò)。
在選擇一個實(shí)例或 pblock 后,所有連接到該元素的網(wǎng)絡(luò)都將被高亮顯示。這一過程可以繼續(xù),以選擇和擴(kuò)展邏輯錐形。運(yùn)行"顯示連接性"將高亮顯示連接到選定實(shí)例的下一級網(wǎng)絡(luò)。這是一種選擇從某個特定實(shí)例或 i/o 端口開始的邏輯錐區(qū)的簡易方法,從而可真正實(shí)現(xiàn)對設(shè)計(jì)層次優(yōu)勢的利用。
解決性能問題
整個方案是要提供一個綜合環(huán)境,以分析時序問題并輕松約束邏輯以避免或糾正問題??墒褂脕碜?timeahead 或 trce 的時序結(jié)果進(jìn)行布局規(guī)劃,通過幫助確定哪些邏輯應(yīng)組合在一起并進(jìn)行布局規(guī)劃進(jìn)行更好的性能設(shè)計(jì)。
關(guān)鍵路徑通常穿越邏輯層次。planahead 軟件支持獨(dú)立于邏輯層次的物理層次,從而使您可將設(shè)計(jì)中任意位置的邏輯組合在一起并有效地進(jìn)行布局規(guī)劃。
planahead 軟件還提供了資源利用估算功能,以幫助確定 pblock 的尺寸和形狀。同樣這些統(tǒng)計(jì)資料還可報(bào)告時鐘信息、供應(yīng)鏈和 prm 適應(yīng)尺寸以及各種其它信息。
planahead 設(shè)計(jì)工具提供了自動布局能力,如基于邏輯層次的自動分區(qū)和自動 pblock 尺寸確定與放置。由于使用單個 pblock 矩形來包含所需的器件資源通常很困難,因此可以使用多個矩形創(chuàng)建非矩形-線性形狀。planahead 軟件還允許在 pblock 內(nèi)創(chuàng)建 pblock,或創(chuàng)建"子"pblock,以幫助更好地維護(hù)設(shè)計(jì)層次。
器件容量可通過壓縮 pblock 的邏輯進(jìn)行提高。一種方法是使用稱為 compression 的賽靈思 area_group 屬性。area_group 是一種設(shè)計(jì)實(shí)現(xiàn)約束,支持將設(shè)計(jì)分成用于映射、打包、布局和布線的物理區(qū)域。使用 compression 屬性將導(dǎo)致 ise mapper 將無關(guān)的邏輯打包成未使用的 clb 站。使用它時請小心,因?yàn)樗鼤r序產(chǎn)生副作用。 改善性能的最佳策略是壓縮非時序關(guān)鍵型邏輯,從而在器件中騰出更多空間用于時序關(guān)鍵型邏輯。第二種選項(xiàng)是使用 planahead 功能在 pblock 上獨(dú)立運(yùn)行 par。 可以持續(xù)縮減 pblock 尺寸,直到 par 失敗。這將盡可能緊密地壓縮和打包塊內(nèi)邏輯,以騰出器件空間。
一個 virtex-4 布局規(guī)劃示例
planahead 設(shè)計(jì)工具可輕松地導(dǎo)入布局和時序結(jié)果。通過該信息,可以查看和排序時序報(bào)告中的關(guān)鍵路徑,并使用原理圖或器件視圖對路徑進(jìn)行可視化顯示。一旦確定故障路徑,可以高亮顯示布局規(guī)劃中的所有路徑實(shí)例,以確定原理圖視圖中的所有路徑實(shí)例。
在顯示中,高亮顯示了一條特定路徑上未能滿足時序要求的觸發(fā)器。由于它們在器件中分布太廣,設(shè)計(jì)實(shí)現(xiàn)產(chǎn)生了無法接受的長延遲。由于在 virtex-4
fpga 中存在大量的時序域,因此這是一種普遍情況。
通過選擇這些觸發(fā)器中的每個觸發(fā)器,并將它們限制到單個 pblock 中,可以調(diào)節(jié)和優(yōu)化該 pblock的尺寸和位置,從而縮短關(guān)鍵路徑的延遲,如圖 4 所示。
圖 4 在對與該路徑相關(guān)的 所有基元進(jìn)行約束后, 您可以對 pblock 進(jìn)行 優(yōu)化,以使該路徑達(dá)到 所需的時序要求
必要時,甚至可以創(chuàng)建嵌套 pblock,從而創(chuàng)建一種子/主層次來進(jìn)一步約束子模塊,以獲得額外的性能提升。根據(jù)捕獲邏輯的資源需求,可以將關(guān)鍵邏輯鎖定位置,以實(shí)現(xiàn)對必要資源的最佳訪問。
評論