當(dāng)前位置:首頁 > 工業(yè)控制 > 電子設(shè)計(jì)自動化
[導(dǎo)讀]近年來,隨著集成電路技術(shù)的發(fā)展,用傳統(tǒng)的方法進(jìn)行芯片或系統(tǒng)設(shè)計(jì)已不能滿足要求,迫切需要提高設(shè)計(jì)效率。在這樣的技術(shù)背景下,能大大降低設(shè)計(jì)難度的VHDL設(shè)計(jì)方法正越來越廣泛地被采用。但是VHDL設(shè)計(jì)是行為

近年來,隨著集成電路技術(shù)的發(fā)展,用傳統(tǒng)的方法進(jìn)行芯片或系統(tǒng)設(shè)計(jì)已不能滿足要求,迫切需要提高設(shè)計(jì)效率。在這樣的技術(shù)背景下,能大大降低設(shè)計(jì)難度的VHDL設(shè)計(jì)方法正越來越廣泛地被采用。但是VHDL設(shè)計(jì)是行為級的設(shè)計(jì)?所帶來的問題是設(shè)計(jì)者的設(shè)計(jì)思考與電路結(jié)構(gòu)相脫節(jié)。設(shè)計(jì)者主要是根據(jù)VHDL的語法規(guī)則?對系統(tǒng)目標(biāo)的邏輯行為進(jìn)行描述?然后通過綜合工具進(jìn)行電路結(jié)構(gòu)的綜合、編譯、優(yōu)化,通過仿真工具進(jìn)行邏輯功能仿真和系統(tǒng)時(shí)延的仿真。實(shí)際設(shè)計(jì)過程中,由于每個(gè)工程師對語言規(guī)則、對電路行為的理解程度不同,每個(gè)人的編程風(fēng)格不同,往往同樣的系統(tǒng)功能,描述的方式是不一樣的,綜合出來的電路結(jié)構(gòu)更是大相徑庭。因此,即使最后綜合出的電路都能實(shí)現(xiàn)相同的邏輯功能,其電路的復(fù)雜程度和時(shí)延特性都會有很大的差別,甚至某些臃腫的電路還會產(chǎn)生難以預(yù)料的問題。從這個(gè)問題出發(fā),我們就很有必要深入討論在VHDL設(shè)計(jì)中如何簡化電路結(jié)構(gòu),優(yōu)化電路設(shè)計(jì)的問題。1 描述方法對電路結(jié)構(gòu)的影響用VHDL進(jìn)行設(shè)計(jì),其最終綜合出的電路的復(fù)雜程度除取決于設(shè)計(jì)要求實(shí)現(xiàn)的功能的難度外,還受設(shè)計(jì)工程師對電路的描述方法和對設(shè)計(jì)的規(guī)劃水平的影響。最常見的使電路復(fù)雜化的原因之一是設(shè)計(jì)中存在許多本不必要的類似LATCH的結(jié)構(gòu)。而且由于這些結(jié)構(gòu)通常都由大量的觸發(fā)器組成,不僅使電路更復(fù)雜,工作速度降低,而且由于時(shí)序配合的原因而導(dǎo)致不可預(yù)料的結(jié)果。例如對于同一譯碼電路有不同VHDL描述:1: IF INDEX=″00000″ THENSTEPSIZE<=″0000111″?ELSIF INDEX=″00001″ THENSTEPSIZE<=″0001000″?LSIF INDEX=″00010″ THENSTEPSIZE<=″0001001″?……ELSESTEPSIZE<=″0000000″?END IF;2:STEPSIZE<=″0000111″ WHEN INDEX=″00000″ ELSE″0001000″ WHEN INDEX=″00001″ELSE″0001001″WHEN INDEX=″00010″ ELSE……以上兩段程序描述了同一個(gè)譯碼電路。第二段程序由于WHEN .....ELSE的語句不能生成鎖存器的結(jié)構(gòu)且ELSE后一定要有結(jié)果,所以不會有問題,而第一個(gè)程序如果不加ELSE STEPSIZE〈=“0000000”這句,則會生成一個(gè)含有7位寄存器的結(jié)構(gòu),雖然都能實(shí)現(xiàn)相同的譯碼功能。但是電路復(fù)雜度會大增。而由于每個(gè)工程師的寫作習(xí)慣不同,有的喜歡用IF....ELSE的語句,有的喜歡用WHEN.....ELSE的方式,而用IF.....ELSE時(shí),如稍不注意,在描述不需要寄存器的電路時(shí)沒加ELSE,則會引起電路不必要的開銷。所以在VHDL設(shè)計(jì)中要慎用IF ...ELSE這類能描述自身值代入的語句。2 設(shè)計(jì)規(guī)劃的優(yōu)劣直接影響電路結(jié)構(gòu)另一主要引起電路復(fù)雜化的原因是對設(shè)計(jì)規(guī)劃的不合理。雖然VHDL語言能從行為描述生成電路,但一個(gè)完整的設(shè)計(jì)一般來說都不可能由直接描述設(shè)計(jì)的目標(biāo)功能來實(shí)現(xiàn)的??傄言O(shè)計(jì)分成若干部分,每一部分再分別描述其行為。這就涉及到如何劃分功能模塊的問題,要求對設(shè)計(jì)了解的較深入,才能使劃分更有效,才能降低電路的復(fù)雜程度。例如我們設(shè)計(jì)一個(gè)時(shí)鐘源為1kHz,每32秒發(fā)出一組信號(共八組)的簡單的控制器來說。下面有兩種實(shí)現(xiàn)方法:(1)用15位的記數(shù)器實(shí)現(xiàn)把輸入1KHz的時(shí)鐘分頻為1/32Hz,然后用這個(gè)作為時(shí)鐘驅(qū)動一個(gè)3位的記數(shù)器,這個(gè)記數(shù)器的八個(gè)狀態(tài)分別通過一個(gè)3-8譯碼器發(fā)出所要求的信號。(2)直接用18位的記數(shù)器把輸入的1KHz時(shí)鐘進(jìn)行分頻,再利用記數(shù)器的八個(gè)相距32秒的狀態(tài)來推動一個(gè)12-8譯碼器來實(shí)現(xiàn)。對于如此的設(shè)計(jì)要求,VHDL程序分別如下所示:1. 第一種設(shè)計(jì)方法的VHDL源程序process(clk?cclk?count2)beginif(clk='1' and clk'event)thencount2<=count2 + 1?if(count2=″000000000000000″)thencclk<='1'?elsecclk<='0'?end if?end if?end process?process(cclk?count3?ctemp)beginif(cclk='1' and cclk'event)thencount3<=count3 + 1?if(count3=″000″)thenctemp<=″00000001″?elsif(count3=″001″)thenctemp<=″00000010″?elsif(count3=″010″)thenctemp<=″00000100″?elsif(count3=″011″)thenctemp<=″00001000″?elsif(count3=″100″)thenctemp<=″00010000″?elsif(count3=″101″)thenctemp<=″00100000″?elsif(count3=″110″)thenctemp<=″01000000″?elsif(count3=″111″)thenctemp<=″10000000″?elsectemp<=″00000000″?end if?end if?end process?2. 第二種設(shè)計(jì)方法的VHDL源程序process(clk?ctemp?count)beginif(clk='1' and clk'event)thencount<=count + 1?if(count=″00000000000000000″)thenctemp<=″00000001″?elsif(count=″001000000000000000″)thenctemp<=″00000010″?elsif(count=″010000000000000000″)thenctemp<=″00000100″?elsif(count=″011000000000000000″)thenctemp<=″00001000″?elsif(count=″100000000000000000″)thenctemp<=″00010000″?elsif(count=″101000000000000000″)thenctemp<=″00100000″?elsif(count=″110000000000000000″)thenctemp<=″01000000″?elsif(count=″111000000000000000″)thenctemp<=″10000000″?end if?end if?end process?對于第一種的程序可以綜合出的電路如圖1所示。該電路用一個(gè)15位的加法器和寄存器組成一個(gè)15位的記數(shù)器。在記數(shù)器記完一周回到“000000000000000”時(shí),通過后面的15輸入的與非門和一位的觸發(fā)器就可以實(shí)現(xiàn)同步的進(jìn)行215次分頻,同步輸出32Hz的時(shí)鐘CCLK。CCLK再驅(qū)動一8位的移位寄存器,便可實(shí)現(xiàn)每32秒輸出一信號。而用第二種的程序設(shè)計(jì)綜合出的電路如圖2所示。圖2所示的電路用一個(gè)18位的加法器和寄存器組成一個(gè)18位的記數(shù)器。后接了8個(gè)18輸入的邏輯門和8輸入的或門。輸入的1KHz時(shí)鐘經(jīng)過記數(shù)器被分頻,其中有八個(gè)相隔32Hz的記數(shù)狀態(tài),邏輯門就負(fù)責(zé)把這八狀態(tài)譯碼成所需的八組信號。譯碼后的數(shù)據(jù)通過選擇器輸出到8位的觸發(fā)器,以實(shí)現(xiàn)同步輸出。還有個(gè)鎖存器,是用來保持輸出信號不變,在八個(gè)狀態(tài)中的從一個(gè)狀態(tài)變到下一個(gè)之前,保持前一個(gè)的數(shù)值。選擇器當(dāng)邏輯門輸出新的數(shù)據(jù)時(shí)讓其輸出數(shù)據(jù)通過,在新數(shù)據(jù)到來之前輸出鎖存器的數(shù)據(jù)。以上兩種方法都能實(shí)現(xiàn)相同的邏輯功能,但圖2所示的方法由于運(yùn)用了較少位數(shù)的記數(shù)器,所用的邏輯門也較簡單,而且還少用了多路選擇器和鎖存器資源,所以綜合出來的電路較簡單,以XILINXSpartan S05 -3 芯片為例。第一種方法占用芯片CLB的12%,其中FMAPS為9%,最高工作速度為82MHz。而第二種方法占用了15%的CLB,FMAPS占用15%,最高工作速度只有69.9MHz。在這一個(gè)簡單的設(shè)計(jì)之中就能?。玻埃サ碾娐罚岣撸保玻保停龋墓ぷ魉俣?,由此可見科學(xué)的劃分設(shè)計(jì)對降低電路復(fù)雜程度的重要意義。3 邏輯設(shè)計(jì)對電路結(jié)構(gòu)的影響還有一個(gè)使電路復(fù)雜化的原因是邏輯電路的輸入項(xiàng)太多以致需占用過多的面積。我們從圖3和圖4兩個(gè)相同功能的邏輯電路和他們對應(yīng)的VHDL描述來分析。比較兩圖可知,圖3是二級邏輯門,每個(gè)輸入信號與不只一個(gè)邏輯門相連,圖4是三級的邏輯門,每個(gè)輸入信號只與一邏輯門相連。由于級數(shù)少,延時(shí)也較少,因此圖3的速度要比圖4快。然而,由于圖3的輸入項(xiàng)要比圖4大的多(10:5),因此,占用的面積必然也比圖3大。圖4是圖3通過提取公因數(shù)(例中是B和C)得來的,這是把附加的中間項(xiàng)加到結(jié)構(gòu)描述中去的一種過程,它使輸入到輸出中的邏輯級數(shù)增加,犧牲速度換來電路占用面積的減少。對于對延時(shí)要求不高的情況下采用這種方法分解邏輯電路以達(dá)到減少電路復(fù)雜度的目的。通過以上簡單、初步的探討,我們可以知道,用VHDL進(jìn)行集成電路的設(shè)計(jì),牽涉到對VHDL語言的使用方法和對設(shè)計(jì)的理解程度。本文討論了以下幾個(gè)簡化和優(yōu)化電路設(shè)計(jì)的3個(gè)值得注意的方面:(1)在用VHDL進(jìn)行設(shè)計(jì)中要注意避免不必要的寄存器描述。(2)在編寫程序前要先對整個(gè)設(shè)計(jì)進(jìn)行較深入的了解?科學(xué)的劃分設(shè)計(jì),多設(shè)想幾種方案?再進(jìn)行比較?用多個(gè)較少位數(shù)的單元取代較多位數(shù)的單元。(3)在延時(shí)要求不高的情況下,可提取邏輯電路公因子?把它分解成含有中間變量的多級電路。


來源:零八我的愛0次

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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(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ā)耗時(shí)1.5...

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

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

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

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(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)星通信

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

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(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)閉