VHDL設(shè)計中電路簡化問題的探討-設(shè)計應(yīng)用_第1頁
VHDL設(shè)計中電路簡化問題的探討-設(shè)計應(yīng)用_第2頁
VHDL設(shè)計中電路簡化問題的探討-設(shè)計應(yīng)用_第3頁
VHDL設(shè)計中電路簡化問題的探討-設(shè)計應(yīng)用_第4頁
VHDL設(shè)計中電路簡化問題的探討-設(shè)計應(yīng)用_第5頁
已閱讀5頁,還剩2頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

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

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論