新聞中心

EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 具有低功耗意識(shí)的FPGA設(shè)計(jì)方法

具有低功耗意識(shí)的FPGA設(shè)計(jì)方法

作者: 時(shí)間:2011-01-13 來(lái)源:網(wǎng)絡(luò) 收藏

 工業(yè)、汽車電子、軍事, 甚至商業(yè)類客戶都會(huì)對(duì)系統(tǒng)的溫度和運(yùn)行模式的概況有規(guī)定。這些概況指引我們?cè)?a class="contentlabel" href="http://butianyuan.cn/news/listbylabel/label/設(shè)計(jì)">設(shè)計(jì)時(shí)要注意哪些地方以及精力該如何分配。IGLOO器件的低工藝和硅片由Actel來(lái)保證,用戶所要關(guān)注的是:關(guān)心器件的選型、掌握所使用的的架構(gòu)、掌握PCB的板級(jí)布局(主要是電容及I/O的走線)。

本文引用地址:http://butianyuan.cn/article/151091.htm

  對(duì)于同一系列的器件來(lái)說(shuō),器件的die越小,器件的也會(huì)越小。也就是說(shuō),在選用器件的時(shí)候,應(yīng)該盡量選擇規(guī)模小的器件。選定器件后,可以在過(guò)程中,通過(guò)一些技巧盡可能的少占用資源,比如通過(guò)時(shí)分復(fù)用的方式少占用I/O,共享加法、乘法等算法邏輯,共享RAM等,同時(shí)也有必要了解所選用的的架構(gòu)。

  用戶需要在和速度之間做平衡,在對(duì)速度性能要求不高的時(shí)候,盡量使用低的核電壓和低電壓的I/O接口標(biāo)準(zhǔn)。根據(jù)設(shè)計(jì)工作的實(shí)際狀況,在某些時(shí)候?qū)?dāng)前不工作的資源關(guān)掉,比如通過(guò)控制SRAM的LP或BLK引腳,使其在不工作的時(shí)候可以被關(guān)斷,或者是通過(guò)Flash Freeze端口進(jìn)入Fresh Frezee模式以降低靜態(tài)功耗。在PLL不需要工作的時(shí)候,通過(guò)Power Down引腳將其關(guān)掉,不過(guò)需要注意的是,需要考慮重新開(kāi)啟以后,PLL的鎖定時(shí)間對(duì)系統(tǒng)是不是有影響。關(guān)掉沒(méi)有輸入總線的I/O Bank。

  注意,不要濫用上拉/下拉電阻。在活動(dòng)模式下,如果總線被反向模式驅(qū)動(dòng)(如上拉的被“0”驅(qū)動(dòng),或下拉的被“1”驅(qū)動(dòng)),那么每個(gè)I/O上的電流會(huì)增加。要預(yù)防被驅(qū)動(dòng)的總線進(jìn)入3態(tài)狀態(tài)。除非的工作時(shí)間確實(shí)短,否則建議跟板子設(shè)計(jì)者溝通以確保對(duì)輸入進(jìn)行持續(xù)的驅(qū)動(dòng)。

  要降低設(shè)計(jì)的動(dòng)態(tài)功耗,首先要了解影響動(dòng)態(tài)功耗的因素。動(dòng)態(tài)功耗通常和電壓、信號(hào)翻轉(zhuǎn)頻率、容性負(fù)載正相關(guān),設(shè)計(jì)所占用的邏輯資源越多、時(shí)鐘頻率越高、I/O和RAM越多,動(dòng)態(tài)功耗就越大。同時(shí)也需要分析設(shè)計(jì)的動(dòng)態(tài)功耗概況。

  確定要降低的動(dòng)態(tài)功耗的目標(biāo),如果要降低的動(dòng)態(tài)功耗的目標(biāo)是目前整個(gè)系統(tǒng)動(dòng)態(tài)功耗的20%,那么選用Actel的IGLOO器件或許就可以實(shí)現(xiàn)所要達(dá)到的目標(biāo)。如果目標(biāo)是80%,那么除了選用IGLOO器件外,還需要從系統(tǒng)和架構(gòu)上去考慮。

  針對(duì)不同的系統(tǒng)功耗的概況,梳理動(dòng)態(tài)功耗的重點(diǎn),見(jiàn)圖1。針對(duì)Case1中動(dòng)態(tài)功耗的示意圖,我們可以看出其功耗主要分布在邏輯、存儲(chǔ)和時(shí)鐘方面,這樣我們的精力就不能放在如何降低I/O的功耗上去,而針對(duì)Case3這種情況,如果要降低動(dòng)態(tài)功耗,就必須要解決I/O上的功耗問(wèn)題。

 不同系統(tǒng)的動(dòng)態(tài)功耗在線座談精華

圖1 不同系統(tǒng)的動(dòng)態(tài)功耗在線座談精華

  要減少RAM的功耗,除了對(duì)RAM的控制和時(shí)鐘信號(hào)進(jìn)行門控制以外,還需要知道RAM的讀和寫分別對(duì)功耗的影響有多少。地址變化、讀寫順序、RAM級(jí)聯(lián)方式對(duì)功耗的影響。

  對(duì)RAM進(jìn)行讀操作涉及到:控制所存地址和控制鎖存、行的預(yù)譯碼電路、讀的列譯碼電路、行的最終譯碼電路、讀的列譯碼控制、傳感放大器、數(shù)據(jù)輸出選擇和鎖存電路、Sense enable logic、讀控制電路、Bit-line預(yù)充電電路等十個(gè)相關(guān)電路。而對(duì)RAM進(jìn)行寫操作需要涉及到的電路有:地址和控制鎖存、行的預(yù)譯碼電路、寫的列譯碼電路、行的最終解碼控制、寫的列譯碼控制、寫驅(qū)動(dòng)電路和Bit Line預(yù)充電電路。因此,相比較而言,讀操作會(huì)比寫操作消耗更多的功耗。

 RAM的讀寫地址改變的方式,也會(huì)對(duì)功耗有不同的影響。連續(xù)操作地址之間的漢明距離越小,產(chǎn)生的功耗也越小。反之亦然。也就是說(shuō)當(dāng)前操作的地址和上次操作的地址之間變化的位數(shù)越少,所產(chǎn)生的功耗也會(huì)越小。

  讀寫間隔操作和連續(xù)讀、連續(xù)寫操作相比,要產(chǎn)生多一些的功耗。從圖2中分別對(duì)12塊RAM、16塊RAM和24塊RAM做的測(cè)試結(jié)果看,同樣的操作條件下,RAM塊數(shù)越多,連續(xù)操作地址之間的漢明距離越長(zhǎng),功耗就越大。同樣的塊數(shù)和連續(xù)操作之間的漢明距離,寫-讀三次會(huì)比三次寫三次讀消耗的功耗要大。

寫讀操作順序vs

圖2 寫讀操作順序vs.讀序列后跟寫序列操作

  通過(guò)前面所述,我們可以通過(guò)調(diào)整RAM的訪問(wèn)順序降低RAM的功耗??赡艿脑挘瑢?duì)RAM少進(jìn)行讀操作,盡可能一次多讀一些數(shù)據(jù)或者多寫一些數(shù)據(jù),少一些讀寫操作之間的切換。如果在連續(xù)相同操作的地址之間,漢明距離能保持最小的話更好。也可以考慮在反向時(shí)鐘沿上對(duì)RAM進(jìn)行讀寫操作,以降低RAM的峰值功耗。

  不同的RAM級(jí)聯(lián)架構(gòu)所產(chǎn)生的功耗也不同。如果想獲得一個(gè)4K×4的RAM,有許多不同的實(shí)現(xiàn)方式。從圖3中可以看出,根據(jù)這些不同的實(shí)現(xiàn)方式,對(duì)每塊RAM的讀寫時(shí)鐘控制,進(jìn)行門控制所產(chǎn)生的功耗是最低的。

根時(shí)鐘vs

圖3 根時(shí)鐘vs.葉時(shí)鐘vs.門控允許


上一頁(yè) 1 2 3 下一頁(yè)

評(píng)論


相關(guān)推薦

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

關(guān)閉