當(dāng)前位置:首頁 > 工業(yè)控制 > 電子設(shè)計自動化
[導(dǎo)讀]本文將介紹VerilogHDL可綜合設(shè)計需要注意的點,一是邏輯設(shè)計,二是鎖存器,三是設(shè)計思維。

本文將介紹VerilogHDL可綜合設(shè)計需要注意的點,一是邏輯設(shè)計,二是鎖存器,三是設(shè)計思維。

一、邏輯設(shè)計

(1)組合邏輯設(shè)計

下面是一些用Verilog進(jìn)行組合邏輯設(shè)計時的一些注意事項:

①組合邏輯可以得到兩種常用的RTL 級描述方式。第一種是always 模塊的觸發(fā)事件為電平敏感信號列表;第二種就是用assign 關(guān)鍵字描述的數(shù)據(jù)流賦值語句。

②always 模塊的敏感表為電平敏感信號的電路可幾乎可以完成對所有組合邏輯電路的建模。always模塊的敏感列表為所有判斷條件信號和輸入信號,但一定要注意敏感列表的完整性(注意通配符*的使用)。

由于賦值語句有阻塞賦值和非阻塞賦值兩類,建議讀者使用阻塞賦值語句“=”,原因?qū)⒃凇白枞x值和非阻塞賦值”中(現(xiàn)在還沒有寫)進(jìn)行說明。

always 模塊中的信號必須定義為reg 型,不過最終的實現(xiàn)結(jié)果中并沒有寄存器。這是由于在組合邏輯電路描述中,將信號定義為reg 型,只是為了滿足語法要求。

③assign 語句的描述,利用條件符“?”可以描述一些相對簡單的組合邏輯電路,左邊的賦值信號只能被定義為wire 型。當(dāng)組合邏輯比較復(fù)雜時,需要很多條語句assign 語句或者多重嵌套“?”,使得代碼可讀性極差,因此此時推薦always組合邏輯建模方式。

④設(shè)計時要注意不要出現(xiàn)組合邏輯環(huán)路:


不要在組合邏輯中引入環(huán)路,在組合邏輯中引入環(huán)路會導(dǎo)致電路產(chǎn)生振蕩、毛刺以及沖突等問題,從而降低設(shè)計的穩(wěn)定性和可靠性,此外,環(huán)回邏輯的延時完全依靠組合邏輯門延遲和布線延遲。一旦這些傳播時延有所變化,則環(huán)路的整體邏輯將徹底失效。其次,環(huán)路的時序分析是個死循環(huán)過程。目前的EDA 開發(fā)工具為了計算環(huán)路的時序邏輯都會主動割斷時序路徑,引入許多不確定的因素。因此要徹底避免環(huán)路。

(2)時序邏輯設(shè)計

①時序電路的行為決定了其只能通過always 塊語句實現(xiàn),通過關(guān)鍵詞“posedge”和“negedge”來捕獲時鐘信號的上升沿和下降沿。在always 語句塊中可以使用任何可綜合的標(biāo)志符。

②在描述時序電路的always 塊中的reg 型信號都會被綜合成寄存器,這是和組合邏輯電路所不同的。

③時序邏輯中推薦使用非阻塞賦值“《=”,原因?qū)⒑竺嬖敿?xì)說明。

④時序邏輯的敏感信號列表只需要加入所用的時鐘觸發(fā)沿即可,其余所有的輸入和條件判斷信號都不用加入,這是因為時序邏輯是通過時鐘信號的跳變沿來控制的。

二、鎖存器

鎖存器是個“奇葩”的器件,在FPGA邏輯設(shè)計中很避諱;在ASIC設(shè)計中,以前很喜歡(因為面積小),現(xiàn)在不是很喜歡了。在這里就記錄一下關(guān)于鎖存器的一些事項吧。

(1)鎖存器的概述

①鎖存器的詳細(xì)CMOS電路結(jié)果在前面電路基礎(chǔ)章節(jié)中已經(jīng)有描述,這里不詳細(xì)描述它的結(jié)構(gòu),詳情請挫這個鏈接:

②鎖存器是一種對脈沖電平敏感的存儲單元電路,可以在特定輸入脈沖電平作用下改變狀態(tài),其本身也是一類常用的邏輯單元,有著特定的需求。

③鎖存器在數(shù)據(jù)未鎖存時,輸出端的信號隨輸入信號變化,就像信號通過一個緩沖器一樣,一旦鎖存信號有效,則數(shù)據(jù)被鎖住,輸入信號不起作用。因此,鎖存器也被稱為透明鎖存器,指的是不鎖存時輸出對于輸入是透明的。

④鎖存器和寄存器都是數(shù)字電路的基本存儲單元,但鎖存器是電平觸發(fā)的存儲器,觸發(fā)器是邊沿觸發(fā)的存儲器。

本質(zhì)上,鎖存器和D 觸發(fā)器的邏輯功能是基本相同的,都可存儲數(shù)據(jù),且鎖存器所需的門邏輯更少,具備更高的集成度。

⑤鎖存器具備下列三個缺點:

·對毛刺敏感,不能異步復(fù)位,因此在上電后處于不確定的狀態(tài)。

·鎖存器會使靜態(tài)時序分析變得非常復(fù)雜,不具備可重用性。

·在FPGA/CPLD芯片中,基本的單元是由查找表和觸發(fā)器組成的,若生成鎖存器反而需要更多的資源。

(2)鎖存器的產(chǎn)生

①鎖存器產(chǎn)生于組合邏輯的設(shè)計中,在基于always的組合邏輯描述語句中,可能產(chǎn)生鎖存器的情況具體可分為兩種:其一是在if 語句中,另一種是在case 語句中。

②在always 塊中使用if 語句,但缺乏else 分支而造成鎖存器。

③在always 塊中使用case 語句,由于缺乏default 分支而造成鎖存器。

④如果用到if 語句,最好有else 分支;如果用到case 語句,最好有default 語句。即使需要鎖存器,也通過else 分支或default 分支來顯式說明。

(3)鎖存器的應(yīng)用

①在總線應(yīng)用上,鎖存器能提高驅(qū)動能力、隔離前后級。

②地址鎖存器、數(shù)據(jù)鎖存器、復(fù)位信號鎖存器;門控時鐘鐘的應(yīng)用等等。

三、設(shè)計思維

這個設(shè)計思維本來屬于設(shè)計技巧里面的,放在這里說明,是為了告訴自己,在進(jìn)行電路描述的時候, 是基于這些準(zhǔn)則的,在設(shè)計時能夠根據(jù)這些基本準(zhǔn)則進(jìn)行優(yōu)化電路。下面是常見的設(shè)計思維,主要是基于FPGA的,關(guān)于ASIC其他設(shè)計技巧或者設(shè)計思維,我記錄在了“技巧”篇。

(1)速度面積互換準(zhǔn)則

①速度與面積是設(shè)計時??紤]的的一個問題,因此在設(shè)計的時候要考慮怎么在這二者之間的權(quán)衡。當(dāng)然,現(xiàn)在功耗也與速度、面積成為需要考慮的重大因素之一。

②面積和速度互換的具體操作很多,比如模塊復(fù)用、乒乓操作、串并轉(zhuǎn)換以及流水線操作等。在設(shè)計技巧策略和技巧那一章節(jié)中將會進(jìn)行敘述。

③串并轉(zhuǎn)換乘法器:假設(shè)數(shù)據(jù)速率是乘法器模塊處理速度的3 倍,那么由于乘法器模塊的數(shù)據(jù)吞吐量滿足不了要求,在這種情況下,就利用面積換速度的思想,復(fù)制3 個乘法器模塊。首先將輸入數(shù)據(jù)進(jìn)行串并轉(zhuǎn)換,然后利用這3 個模塊并行處理所分配到的數(shù)據(jù),最后將處理結(jié)果并串轉(zhuǎn)換,達(dá)到數(shù)據(jù)速率的要求。

如下圖所示:


(2)FPGA中的設(shè)計思維

①信號反相的處理策略

在處理反相信號時,設(shè)計時應(yīng)盡可能地遵從分散反相原則。即應(yīng)使用多個反相器分別反相,每個反相器驅(qū)動一個負(fù)載,這個原則無論對時鐘信號還是對其它信號都是適用的。

因為在FPGA設(shè)計中,反相是被吸收到CLB或IOB中的,使用多個反相器并不占用更多的資源,而使用一個反相器將信號反相后驅(qū)動多個負(fù)載卻往往會多占資源,而且延遲也增加了。

②首先,如果輸入信號需要反相,則應(yīng)盡可能地調(diào)用輸入帶反相功能的符號,而不是用分離的反相器對輸入信號進(jìn)行反相。

因為在使用自帶反相功能的器件中,由于函數(shù)發(fā)生器用查表方式實現(xiàn)邏輯,反相操作是不占資源的,也沒有額外延遲;而分開使用不同邏輯使用反相操作實現(xiàn),從而消耗額外的資源,增加額外的延遲。

③其次,如果一個信號反相后驅(qū)動了多個負(fù)載,則應(yīng)將反相功能分散到各個負(fù)載中實現(xiàn),而不能采用傳統(tǒng)TTL電路設(shè)計,采用集中反相驅(qū)動多個負(fù)載來減少所用的器件的數(shù)量。

因為在FPGA設(shè)計中,集中反相驅(qū)動多個負(fù)載往往會多占一個邏輯塊或半個邏輯塊,而且延遲也增加了。分散信號的反相往往可以與其它邏輯在同一單元內(nèi)完成而不消耗額外的邏輯資源。

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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉