版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1EDA技術(shù)及VHDL語言介紹1.1概述EDA是電子設(shè)計(jì)自動(dòng)化(ElectronicDesignAutomation)縮寫,是90年代初從CAD(計(jì)算機(jī)輔助設(shè)計(jì))、CAM(計(jì)算機(jī)輔助制造)、CAT(計(jì)算機(jī)輔助測試)CAE(計(jì)算機(jī)輔助工程)的概念發(fā)展而來的。EDA技術(shù)是以計(jì)算機(jī)為工具,根據(jù)硬件描述語言HDL(HardwareDescriptionlanguage)完成的設(shè)計(jì)文件,自動(dòng)地完成邏輯編譯、化簡、分割、綜合及優(yōu)化、布局布線、仿真以及對于特定目標(biāo)芯片的適配編譯和編程下載等工作。典型的EDA工具中必須包含兩個(gè)特殊的軟件包,即綜合器和適配器。綜合器的功能就是將設(shè)計(jì)者在EDA平臺上完成的針對某個(gè)系統(tǒng)項(xiàng)目的HDL、原理圖或狀態(tài)圖形描述,針對給定的硬件系統(tǒng)組件,進(jìn)行編譯、優(yōu)化、轉(zhuǎn)換和綜合,最終獲得我們欲實(shí)現(xiàn)功能的描述文件。綜合器在工作前,必須給定所要實(shí)現(xiàn)的硬件結(jié)構(gòu)參數(shù),它的功能就是將軟件描述與給定的硬件結(jié)構(gòu)用一定的方式聯(lián)系起來。也就是說,綜合器是軟件描述與硬件實(shí)現(xiàn)的一座橋梁。綜合過程就是將電路的高級語言描述轉(zhuǎn)換低級的、可與目標(biāo)器件FPGA/CPLD相映射的網(wǎng)表文件。適配器的功能是將由綜合器產(chǎn)生的王表文件配置與指定的目標(biāo)器件中,產(chǎn)生最終的下載文件,如JED文件。適配所選定的目標(biāo)器件(FPGA/CPLD芯片)必須屬于在綜合器中已指定的目標(biāo)器件系列。硬件描述語言HDL是相對于一般的計(jì)算機(jī)軟件語言,如:C、PASCAL而言的。HDL語言使用與設(shè)計(jì)硬件電子系統(tǒng)的計(jì)算機(jī)語言,它能描述電子系統(tǒng)的邏輯功能、電路結(jié)構(gòu)和連接方式。設(shè)計(jì)者可利用HDL程序來描述所希望的電路系統(tǒng),規(guī)定器件結(jié)構(gòu)特征和電路的行為方式;然后利用綜合器和適配器將此程序編程能控FPGA和CPLD部結(jié)構(gòu),并實(shí)現(xiàn)相應(yīng)邏輯功能的的門級或更底層的結(jié)構(gòu)網(wǎng)表文件或下載文件。目前,就FPGA/CPLD開發(fā)來說,比較常用和流行的HDL主要有ABEL-HDL、AHDL和VHDL。[1]1.2EDA技術(shù)1.2.1EDA技術(shù)的發(fā)展與應(yīng)用電子設(shè)計(jì)技術(shù)的核心就是EDA技術(shù),EDA是指以計(jì)算機(jī)為工作平臺,融合應(yīng)用電子技術(shù)、計(jì)算機(jī)技術(shù)、智能化技術(shù)最新成果而研制成的電子CAD通用軟件包,主要能輔助進(jìn)行三方面的設(shè)計(jì)工作,即IC設(shè)計(jì)、電子電路設(shè)計(jì)和PCB設(shè)計(jì)。EDA技術(shù)已有30年的發(fā)展歷程,大致可分為三個(gè)階段。70年代為計(jì)算機(jī)輔助設(shè)計(jì)(CAD)階段,人們開始用計(jì)算機(jī)輔助進(jìn)行IC版圖編輯、PCB布局布線,取代了手工操作。80年代為計(jì)算機(jī)輔助工程(CAE)階段。與CAD相比,CAE除了有純粹的圖形繪制功能外,又增加了電路功能設(shè)計(jì)和結(jié)構(gòu)設(shè)計(jì),并且通過電氣連接網(wǎng)絡(luò)表將兩者結(jié)合在一起,實(shí)現(xiàn)了工程設(shè)計(jì)。CAE的主要功能是:原理圖輸入,邏輯仿真,電路分析,自動(dòng)布局布線,PCB后分析。90年代為電子系統(tǒng)設(shè)計(jì)自動(dòng)化(EDA)階段。1.2.2EDA技術(shù)的基本特征EDA代表了當(dāng)今電子設(shè)計(jì)技術(shù)的最新發(fā)展方向,它的基本特征是:設(shè)計(jì)人員按照“自頂向下”的設(shè)計(jì)方法,對整個(gè)系統(tǒng)進(jìn)行方案設(shè)計(jì)和功能劃分,系統(tǒng)的關(guān)鍵電路用一片或幾片專用集成電路(ASIC)實(shí)現(xiàn),然后采用硬件描述語言(HDL)完成系統(tǒng)行為級設(shè)計(jì),最后通過綜合器和適配器生成最終的目標(biāo)器件,這樣的設(shè)計(jì)方法被稱為高層次的電子設(shè)計(jì)方法。下面介紹與EDA基本特征有關(guān)的幾個(gè)概念。第一,“自頂向下”的設(shè)計(jì)方法10年前,電子設(shè)計(jì)的基本思路還是選用標(biāo)準(zhǔn)集成電路“自底向上”地構(gòu)造出一個(gè)新的系統(tǒng),這樣的設(shè)計(jì)方法就如同一磚一瓦建造金字塔,不僅效率低、成本高而且容易出錯(cuò)。高層次設(shè)計(jì)是一種“自頂向下”的全新設(shè)計(jì)方法,這種設(shè)計(jì)方法首先從系統(tǒng)設(shè)計(jì)入手,在頂層進(jìn)行功能方框圖的劃分和結(jié)構(gòu)設(shè)計(jì)。在方框圖一級進(jìn)行仿真、糾錯(cuò),并用硬件描述語言對高層次的系統(tǒng)行為進(jìn)行描述,在系統(tǒng)一級進(jìn)行驗(yàn)證。然后,用綜合優(yōu)化工具生成具體門電路的網(wǎng)絡(luò)表,其對應(yīng)的物理實(shí)現(xiàn)級可以是印刷電路板或?qū)S眉呻娐?。由于設(shè)計(jì)的主要仿真和調(diào)試過程是在高層次上完成的,這既有利于早期發(fā)現(xiàn)結(jié)構(gòu)設(shè)計(jì)上的錯(cuò)誤,避免設(shè)計(jì)工作的浪費(fèi),又減少了邏輯功能仿真的工作量,提高了設(shè)計(jì)的一次成功率。第二,ASIC設(shè)計(jì)現(xiàn)代電子產(chǎn)品的復(fù)雜度日益提高,一個(gè)電子系統(tǒng)可能由數(shù)萬個(gè)中小規(guī)模集成電路構(gòu)成,這就帶來了體積大、功耗大、可靠性差的問題。解決這一問題的有效方法就是采用ASIC芯片進(jìn)行設(shè)計(jì)。ASIC按照設(shè)計(jì)方法的不同可分為全定制ASIC、半定制ASIC和可編程ASIC(也稱為可編程邏輯器件)。設(shè)計(jì)全定制ASIC芯片時(shí),設(shè)計(jì)師要定義芯片上所有晶體管的幾何圖形和工藝規(guī)則,最后將設(shè)計(jì)結(jié)果交由IC廠家去進(jìn)行掩模制造,做出產(chǎn)品。這種設(shè)計(jì)方法的優(yōu)點(diǎn)是芯片可以獲得最優(yōu)的性能,即面積利用率高、速度快、功耗低,而缺點(diǎn)是開發(fā)周期長,費(fèi)用高,只適合大批量產(chǎn)品開發(fā)。半定制ASIC芯片的版圖設(shè)計(jì)方法分為門陣列設(shè)計(jì)法和標(biāo)準(zhǔn)單元設(shè)計(jì)法,這兩種方法都是約束性的設(shè)計(jì)方法,其主要目的就是簡化設(shè)計(jì),以犧牲芯片性能為代價(jià)來縮短開發(fā)時(shí)間。可編程邏輯芯片與上述掩模ASIC的不同之處在于:設(shè)計(jì)人員完成版圖設(shè)計(jì)后,在實(shí)驗(yàn)室就可以燒制出自己的芯片,無須IC廠家的參與,大大縮短了開發(fā)周期。可編程邏輯器件自70年代以來,經(jīng)歷了PAL、GAL、CPLD、FPGA幾個(gè)發(fā)展階段,其中CPLD/FPGA屬高密度可編程邏輯器件,目前集成度已高達(dá)200萬門/片,它將掩模ASIC集成度高的優(yōu)點(diǎn)和可編程邏輯器件設(shè)計(jì)生產(chǎn)方便的特點(diǎn)結(jié)合在一起,特別適合于樣品研制或小批量產(chǎn)品開發(fā),使產(chǎn)品能以最快的速度上市,而當(dāng)市場擴(kuò)大時(shí),它可以很容易地轉(zhuǎn)由掩模ASIC實(shí)現(xiàn),因此開發(fā)風(fēng)險(xiǎn)也大為降低。上述ASIC芯片,尤其是CPLD/FPGA器件,已成為現(xiàn)代高層次電子設(shè)計(jì)方法的實(shí)現(xiàn)載體。第三,EDA系統(tǒng)框架結(jié)構(gòu)EDA系統(tǒng)框架結(jié)構(gòu)(Framework)是一套配置和使用EDA軟件包的規(guī)。目前主要的EDA系統(tǒng)都建立了框架結(jié)構(gòu),如Cadence公司的DesignFramework,Mentor公司的FalconFramework,而且這些框架結(jié)構(gòu)都遵守國際CFI組織制定的統(tǒng)一技術(shù)標(biāo)準(zhǔn)??蚣芙Y(jié)構(gòu)能將來自不同EDA廠商的工具軟件進(jìn)行優(yōu)化組合,集成在一個(gè)易于管理的統(tǒng)一的環(huán)境之下,而且還支持任務(wù)之間、設(shè)計(jì)師之間以及整個(gè)產(chǎn)品開發(fā)過程中的信息傳輸與共享,是并行工程和自頂向下設(shè)計(jì)方法的實(shí)現(xiàn)基礎(chǔ)。1.2.3EDA技術(shù)的基本設(shè)計(jì)方法EDA技術(shù)的每一次進(jìn)步,都引起了設(shè)計(jì)層次上的一次飛躍,物理級設(shè)計(jì)主要IC版圖設(shè)計(jì),一般由半導(dǎo)體廠家完成,對電子工程師沒有太大的意義,因此本文重點(diǎn)介紹電路級設(shè)計(jì)和系統(tǒng)級設(shè)計(jì)。第一,電路級設(shè)計(jì)電路級設(shè)計(jì)工作流程:電子工程師接受系統(tǒng)設(shè)計(jì)任務(wù),首先確定設(shè)計(jì)方案,并選擇能實(shí)現(xiàn)該方案的合適元器件,然后根據(jù)具體的元器件設(shè)計(jì)電路原理圖。接著進(jìn)行第一次仿真,其中包括數(shù)字電路的邏輯模擬、故障分析,模擬電路的交直流分析、瞬態(tài)分析。在進(jìn)行系統(tǒng)仿真時(shí),必須要有元件模型庫的支持,計(jì)算機(jī)上模擬的輸入輸出波形代替了實(shí)際電路調(diào)試中的信號源和示波器。這一次仿真主要是檢驗(yàn)設(shè)計(jì)方案在功能方面的正確性。仿真通過后,根據(jù)原理圖產(chǎn)生的電氣連接網(wǎng)絡(luò)表進(jìn)行PCB板的自動(dòng)布局布線。在制作PCB板之前還可以進(jìn)行PCB后分析,其中包括熱分析、噪聲及竄擾分析、電磁兼容分析、可靠性分析等,并可將分析后的結(jié)果參數(shù)反標(biāo)回電路圖,進(jìn)行第二次仿真,也稱為后仿真。后仿真主要是檢驗(yàn)PCB板在實(shí)際工作環(huán)境中的可行性。由此可見,電路級的EDA技術(shù)使電子工程師在實(shí)際的電子系統(tǒng)產(chǎn)生前,就可以全面地了解系統(tǒng)的功能特性和物理特性,從而將開發(fā)風(fēng)險(xiǎn)消滅在設(shè)計(jì)階段,縮短了開發(fā)時(shí)間,降低了開發(fā)成本。第二,系統(tǒng)級設(shè)計(jì)進(jìn)入90年代以來,電子信息類產(chǎn)品的開發(fā)明顯呈現(xiàn)兩個(gè)特點(diǎn):一是產(chǎn)品復(fù)雜程度提高;二是產(chǎn)品上市時(shí)限緊迫。然而,電路級設(shè)計(jì)本質(zhì)上是基于門級描述的單層次設(shè)計(jì),設(shè)計(jì)的所有工作(包括設(shè)計(jì)輸入、仿真和分析、設(shè)計(jì)修改等)都是在基本邏輯門這一層次上進(jìn)行的,顯然這種設(shè)計(jì)方法不能適應(yīng)新的形勢,一種高層次的電子設(shè)計(jì)方法,也即系統(tǒng)級設(shè)計(jì)方法,應(yīng)運(yùn)而生。高層次設(shè)計(jì)是一種“概念驅(qū)動(dòng)式”設(shè)計(jì),設(shè)計(jì)人員無須通過門級原理圖描述電路,而是針對設(shè)計(jì)目標(biāo)進(jìn)行功能描述。由于擺脫了電路細(xì)節(jié)的束縛,設(shè)計(jì)人員可以把精力集中于創(chuàng)造性的方案與概念的構(gòu)思上,一旦這些概念構(gòu)思以高層次描述的形式輸入計(jì)算機(jī),EDA系統(tǒng)就能以規(guī)則驅(qū)動(dòng)的方式自動(dòng)完成整個(gè)設(shè)計(jì)。這樣,新的概念就能迅速有效地成為產(chǎn)品,大大縮短了產(chǎn)品的研制周期。不僅如此,高層次設(shè)計(jì)只是定義系統(tǒng)的行為特性,可以不涉及實(shí)現(xiàn)工藝,因此還可以在廠家綜合庫的支持下,利用綜合優(yōu)化工具將高層次描述轉(zhuǎn)換成針對某種工藝優(yōu)化的網(wǎng)絡(luò)表,使工藝轉(zhuǎn)化變得輕而易舉。首先,工程師按照“自頂向下”的設(shè)計(jì)方法進(jìn)行系統(tǒng)劃分。其次,輸入VHDL代碼,這是高層次設(shè)計(jì)中最為普遍的輸入方式。此外,還可以采用圖形輸入方式(框圖,狀態(tài)圖等),這種輸入方式具有直觀、容易理解的優(yōu)點(diǎn)。第三步是,將以上的設(shè)計(jì)輸入編譯成標(biāo)準(zhǔn)的VHDL文件。第四步是進(jìn)行代碼級的功能仿真,主要是檢驗(yàn)系統(tǒng)功能設(shè)計(jì)的正確性。這一步驟適用大型設(shè)計(jì),因?yàn)閷τ诖笮驮O(shè)計(jì)來說,在綜合前對源代碼仿真,就可以大大減少設(shè)計(jì)重復(fù)的次數(shù)和時(shí)間。一般情況下,這一仿真步驟可略去。第五步是,利用綜合器對VHDL源代碼進(jìn)行綜合優(yōu)化處理,生成門級描述的網(wǎng)絡(luò)表文件,這是將高層次描述轉(zhuǎn)化為硬件電路的關(guān)鍵步驟。綜合優(yōu)化是針對ASIC芯片供應(yīng)商的某一產(chǎn)品系列進(jìn)行的,所以綜合的過程要在相應(yīng)的廠家綜合庫支持下才能完成。第六步是,利用產(chǎn)生的網(wǎng)絡(luò)表文件進(jìn)行適配前的時(shí)序仿真,仿真過程不涉及具體器件的硬件特性,是較為粗略的。一般的設(shè)計(jì),也可略去這一仿真步驟。第七步是利用適配器將綜合后的網(wǎng)絡(luò)表文件針對某一具體的目標(biāo)器件進(jìn)行邏輯映射操作,包括底層器件配置、邏輯分割、邏輯優(yōu)化、布局布線。第八步是在適配完成后,產(chǎn)生多項(xiàng)設(shè)計(jì)結(jié)果:(1)適配報(bào)告,包括芯片部資源利用情況,設(shè)計(jì)的布爾方程描述情況等;(2)適配后的仿真模型;(3)器件編程文件。根據(jù)適配后的仿真模型,可以進(jìn)行適配后的時(shí)序仿真,因?yàn)橐呀?jīng)得到器件的實(shí)際硬件特性(如時(shí)延特性),所以仿真結(jié)果能比較精確地預(yù)期未來芯片的實(shí)際性能。如果仿真結(jié)果達(dá)不到設(shè)計(jì)要求,就需要修改VHDL源代碼或選擇不同速度和品質(zhì)的器件,直至滿足設(shè)計(jì)要求;最后一步是將適配器產(chǎn)生的器件編程文件通過編程器或下載電纜載入到目標(biāo)芯片F(xiàn)PGA或CPLD中。如果是大批量產(chǎn)品開發(fā),則通過更換相應(yīng)的廠家綜合庫,輕易地轉(zhuǎn)由ASIC形式實(shí)現(xiàn)。綜上所述,EDA技術(shù)是電子設(shè)計(jì)領(lǐng)域的一場革命,目前正處于高速發(fā)展階段,每年都有新的EDA工具問世。廣大電子工程人員掌握這一先進(jìn)技術(shù),這不僅是提高設(shè)計(jì)效率的需要,更是我國電子工業(yè)在世界市場上生存、競爭與否的關(guān)鍵。[2]1.2.4EDA的發(fā)展趨勢第一,.從目前的EDA技術(shù)來看,其發(fā)展趨勢是政府重視、使用普及、應(yīng)用廣泛、工具多樣、軟件功能強(qiáng)大。中國EDA市場已漸趨成熟,不過大部分設(shè)計(jì)工程師面向的是PCB制板和小型ASIC領(lǐng)域,僅有小部分(約11%)的設(shè)計(jì)人員開發(fā)復(fù)雜的片上系統(tǒng)器件。為了與和美國的設(shè)計(jì)工程師形成更有力的競爭,中國的設(shè)計(jì)隊(duì)伍有必要引進(jìn)和學(xué)習(xí)一些最新的EDA技術(shù)。在信息通信領(lǐng)域,要優(yōu)先發(fā)展高速寬帶信息網(wǎng)、深亞微米集成電路、新型元器件、計(jì)算機(jī)及軟件技術(shù)、第三代移動(dòng)通信技術(shù)、信息管理、信息安全技術(shù),積極開拓以數(shù)字技術(shù)、網(wǎng)絡(luò)技術(shù)為基礎(chǔ)的新一代信息產(chǎn)品,發(fā)展新興產(chǎn)業(yè),培育新的經(jīng)濟(jì)增長點(diǎn)。要大力推進(jìn)制造業(yè)信息化,積極開展計(jì)算機(jī)輔助設(shè)計(jì)(CAD)、計(jì)算機(jī)輔助工程(CAE)、計(jì)算機(jī)輔助工藝(CAPP)、計(jì)算機(jī)機(jī)輔助制造(CAM)、產(chǎn)品數(shù)據(jù)管理(PDM)、制造資源計(jì)劃(MRPII)及企業(yè)資源管理(ERP)等。有條件的企業(yè)可開展“網(wǎng)絡(luò)制造”,便于合作設(shè)計(jì)、合作制造,參與國和國際競爭。開展“數(shù)控化”工程和“數(shù)字化”工程。自動(dòng)化儀表的技術(shù)發(fā)展趨勢的測試技術(shù)、控制技術(shù)與計(jì)算機(jī)技術(shù)、通信技術(shù)進(jìn)一步融合,形成測量、控制、通信與計(jì)算機(jī)(M3C)結(jié)構(gòu)。在ASIC和PLD設(shè)計(jì)方面,向超高速、高密度、低功耗、低電壓方面發(fā)展。第二,外設(shè)技術(shù)與EDA工程相結(jié)合的市場前景看好,如組合超大屏幕的相關(guān)連接,多屏幕技術(shù)也有所發(fā)展。中國自1995年以來加速開發(fā)半導(dǎo)體產(chǎn)業(yè),先后建立了幾所設(shè)計(jì)中心,推動(dòng)系列設(shè)計(jì)活動(dòng)以應(yīng)對亞太地區(qū)其它EDA市場的競爭。在EDA軟件開發(fā)方面,目前主要集中在美國。但各國也正在努力開發(fā)相應(yīng)的工具。日本、國都有ASIC設(shè)計(jì)工具,但不對外開放。集成電路設(shè)計(jì)中心,也提供IC設(shè)計(jì)軟件,但性能不是很強(qiáng)。相信在不久的將來會有更多更好的設(shè)計(jì)工具在各地開花并結(jié)果。據(jù)最新統(tǒng)計(jì)顯示,中國和印度正在成為電子設(shè)計(jì)自動(dòng)化領(lǐng)域發(fā)展最快的兩個(gè)市場,年夏合增長率分別達(dá)到了50%和30%。[3]EDA技術(shù)發(fā)展迅猛,完全可以用日新月異來描述。EDA技術(shù)的應(yīng)用廣泛,現(xiàn)在已涉及到各行各業(yè)。EDA水平不斷提高,設(shè)計(jì)工具趨于完美的地步。EDA市場日趨成熟,但我國的研發(fā)水平仍很有限,尚需迎頭趕上。1.3硬件描述語言VHDL1.3.1VHDL的簡介硬件描述語言(HDL)是一種用于設(shè)計(jì)硬件電子系統(tǒng)的計(jì)算機(jī)語言,它用軟件編程的方式來描述電子系統(tǒng)的邏輯功能、電路結(jié)構(gòu)和連接形式,與傳統(tǒng)的門級描述方式相比,它更適合大規(guī)模系統(tǒng)的設(shè)計(jì)。例如一個(gè)32位的加法器,利用圖形輸入軟件需要輸人500至1000個(gè)門,而利用VHDL語言只需要書寫一行“A=B+C”即可。而且VHDL語言可讀性強(qiáng),易于修改和發(fā)現(xiàn)錯(cuò)誤。早期的硬件描述語言,如ABEL、HDL、AHDL,由不同的EDA廠商開發(fā),互不兼容,而且不支持多層次設(shè)計(jì),層次間翻譯工作要由人工完成。為了克服以上不足,1985年美國國防部正式推出了高速集成電路硬件描述語言VHDL,1987年IEEE采納VHDL為硬件描述語言標(biāo)準(zhǔn)(IEEESTD-1076)。VHDL是一種全方位的硬件描述語言,包括系統(tǒng)行為級。寄存器傳輸級和邏輯門級多個(gè)設(shè)計(jì)層次,支持結(jié)構(gòu)、數(shù)據(jù)流和行為三種描述形式的混合描述,因此VHDL幾乎覆蓋了以往各種硬件俄語言的功能,整個(gè)自頂向下或由底向上的電路設(shè)計(jì)過程都可以用VHDL來完成。VHDL還具有以下優(yōu)點(diǎn):(1)VHDL的寬圍描述能力使它成為高層進(jìn)設(shè)計(jì)的核心,將設(shè)計(jì)人員的工作重心提高到了系統(tǒng)功能的實(shí)現(xiàn)與調(diào)試,而花較少的精力于物理實(shí)現(xiàn)。(2)VHDL可以用簡潔明確的代碼描述來進(jìn)行復(fù)雜控制邏輯艄設(shè)計(jì),靈活且方便,而且也便于設(shè)計(jì)結(jié)果的交流、保存和重用。(3)VHDL的設(shè)計(jì)不依賴于特定的器件,方便了工藝的轉(zhuǎn)換。(4)VHDL是一個(gè)標(biāo)準(zhǔn)語言,為眾多的EDA廠商支持,因此移植性好。用VHDL語言編程實(shí)現(xiàn)數(shù)字電子系統(tǒng)硬件設(shè)計(jì)容易做到技術(shù)共享。他人用VHDL語言實(shí)現(xiàn)了IP模塊和軟核(softcore),程序包(package)和設(shè)計(jì)庫(library)很容易移植到自己的系統(tǒng)設(shè)計(jì)中。許多設(shè)計(jì)不用從頭開始,少花錢辦快事,縮短產(chǎn)品設(shè)計(jì)周期,加速產(chǎn)品更新,提高設(shè)計(jì)效益,這也是VHDL語言得到廣泛應(yīng)用的重要原因。值得指出的是:Verilog-HDL等硬件描述語言獲得較為廣泛的應(yīng)用。但最適合于用CPLD&VHDL等器件實(shí)現(xiàn)數(shù)字電子系統(tǒng)設(shè)計(jì)的硬件描述語言當(dāng)屬于VHDL。1.3.2VHDL的設(shè)計(jì)方法傳統(tǒng)的硬件電路設(shè)計(jì)方法是采用自下而上的設(shè)計(jì)方法,即根據(jù)系統(tǒng)對硬件的要求,詳細(xì)編制技術(shù)規(guī)格書,并畫出系統(tǒng)控制流圖;然后根據(jù)技術(shù)規(guī)格書和系統(tǒng)控制流圖,對系統(tǒng)的功能進(jìn)行細(xì)化,合理地劃分功能模塊,并畫出系統(tǒng)的功能框圖;接著就進(jìn)行各功能模塊的細(xì)化和電路設(shè)計(jì);各功能模塊電路設(shè)計(jì)、調(diào)試完成后,將各功能模塊的硬件電路連接起來再進(jìn)行系統(tǒng)的調(diào)試,最后完成整個(gè)系統(tǒng)的硬件設(shè)計(jì)。采用傳統(tǒng)方法設(shè)計(jì)數(shù)字系統(tǒng),特別是當(dāng)電路系統(tǒng)非常龐大時(shí),設(shè)計(jì)者必須具備較好的設(shè)計(jì)經(jīng)驗(yàn),而且繁雜多樣的原理圖的閱讀和修改也給設(shè)計(jì)者帶來諸多的不便。當(dāng)電路系統(tǒng)采用VHDL語言設(shè)計(jì)其硬件時(shí),與傳統(tǒng)的電路設(shè)計(jì)方法相比較,具有如下的特點(diǎn):第一,采用自上而下的設(shè)計(jì)方法。即從系統(tǒng)總體要求出發(fā),自上而下地逐步將設(shè)計(jì)的容細(xì)化,最后完成系統(tǒng)硬件的整體設(shè)計(jì)。在設(shè)計(jì)的過程中,對系統(tǒng)自上而下分成三個(gè)層次進(jìn)行設(shè)計(jì):第一層次是行為描述。所謂行為描述,實(shí)質(zhì)上就是對整個(gè)系統(tǒng)的數(shù)學(xué)模型的描述。一般來說,對系統(tǒng)進(jìn)行行為描述的目的是試圖在系統(tǒng)設(shè)計(jì)的初始階段,通過對系統(tǒng)行為描述的仿真來發(fā)現(xiàn)設(shè)計(jì)中存在的問題。在行為描述階段,并不真正考慮其實(shí)際的操作和算法用何種方法來實(shí)現(xiàn),而是考慮系統(tǒng)的結(jié)構(gòu)及其工作的過程是否能到達(dá)系統(tǒng)設(shè)計(jì)的要求。第二層次是RTL方式描述。這一層次稱為寄存器傳輸描述(又稱數(shù)據(jù)流描述)。如前所述,用行為方式描述的系統(tǒng)結(jié)構(gòu)的程序,其抽象程度高,是很難直接映射到具體邏輯元件結(jié)構(gòu)的。要想得到硬件的具體實(shí)現(xiàn),必須將行為方式描述的VHDL語言程序改寫為RTL方式描述的VHDL語言程序。也就是說,系統(tǒng)采用RTL方式描述,才能導(dǎo)出系統(tǒng)的邏輯表達(dá)式,才能進(jìn)行邏輯綜合。第三層次是邏輯綜合。即利用邏輯綜合工具,將RTL方式描述的程序轉(zhuǎn)換成用基本邏輯元件表示的文件(門級網(wǎng)絡(luò)表)。此時(shí),如果需要,可將邏輯綜合的結(jié)果以邏輯原理圖的方式輸出。此后可對綜合的結(jié)果在門電路級上進(jìn)行仿真,并檢查其時(shí)序關(guān)系。第二,應(yīng)用邏輯綜合工具產(chǎn)生的門級網(wǎng)絡(luò)表,將其轉(zhuǎn)換成PLD的編程碼點(diǎn),即可利用PLD實(shí)現(xiàn)硬件電路的設(shè)計(jì)。由自上而下的設(shè)計(jì)過程可知,從總體行為設(shè)計(jì)開始到最終的邏輯綜合,每一步都要進(jìn)行仿真檢查,這樣有利于盡早發(fā)現(xiàn)設(shè)計(jì)中存在的問題,從而可以大大縮短系統(tǒng)的設(shè)計(jì)周期。第三,系統(tǒng)可大量采用PLD芯片。由于目前眾多制造PLD芯片的廠家,其工具軟件均支持VHDL語言的編程。所以利用VHDL語言設(shè)計(jì)數(shù)字系統(tǒng)時(shí),可以根據(jù)硬件電路的設(shè)計(jì)需要,自行利用PLD設(shè)計(jì)自用的ASIC芯片,而無須受通用元器件的限制。第四,采用系統(tǒng)早期仿真。從自上而下的設(shè)計(jì)過程中可以看到,在系統(tǒng)設(shè)計(jì)過程中要進(jìn)行三級仿真,即行為層次仿真、RTL層次仿真和門級層次仿真。這三級仿真貫穿系統(tǒng)設(shè)計(jì)的全過程,從而可以在系統(tǒng)設(shè)計(jì)的早期發(fā)現(xiàn)設(shè)計(jì)中存在的問題,大大縮短系統(tǒng)設(shè)計(jì)的周期,節(jié)約大量的人力和物力。自頂而下的設(shè)計(jì)方法使系統(tǒng)被分解為各個(gè)模塊的集合之后,可以對設(shè)計(jì)的每個(gè)獨(dú)立模塊指派不同的工作小組,這些工作小組可以工作在不同地點(diǎn),甚至可以分屬于不同的單位,最后將不同的模塊集成為最終的系統(tǒng)模型,并對其進(jìn)行綜合測試和評價(jià)。[4]其自頂而下的設(shè)計(jì)流程如圖1-1所示:前端功能仿真設(shè)計(jì)說明書 結(jié)構(gòu)綜合邏輯綜合建立VHDL行為
門級時(shí)序VHDL行為仿真測試向量生成硬件測試VHDL-RTL 級 功能仿真 設(shè)計(jì)完成1-1自頂而下的設(shè)計(jì)流程1.4Max+PullII開發(fā)平臺系統(tǒng)1.4.1MaxPullII簡介MaxPullII的全稱是MultipleArrayandProgrammableLogicUseSystem2(多陣列矩陣及可編程邏輯用戶系統(tǒng)2),是Altera公司的全集成化可編程邏輯設(shè)計(jì)環(huán)境。從最初的第一代A+PLUS,第二代MAX+PLUS,發(fā)展到第三代MAX+PLUSII,Altera公司的開發(fā)工具軟件在發(fā)展中不斷完善。MAX+PLUSII的版本不升級,功能也越來越強(qiáng)大,目前發(fā)行的MAX+PLUSII已經(jīng)到了10。1版。MaxPullII的界面友好,在線幫助完備,初學(xué)者也可以很快學(xué)習(xí)掌握。完成高性能的設(shè)計(jì)。其次,在進(jìn)行原理圖輸入時(shí),可以直接放置74系列邏輯芯片,所以對于普通愛好者來說,即使不使用Altera的可編程器件,也可以把MAX+PLUS作為邏輯仿真工具,另外,不用搭建硬件電路,即可對自己的設(shè)計(jì)進(jìn)行調(diào)試,支持Altera公司不同結(jié)構(gòu)的可編程邏輯器件,能滿足用戶各種各樣的設(shè)計(jì)需要。MAX+plusII具有突出的靈活性與高效性,為設(shè)計(jì)者提供了多種可自由選擇的設(shè)計(jì)方法和工具。1.4.2MaxPullII的特點(diǎn)1.MAX+PLUSII的編譯核心支持Altera的FLEX10K、FLEX8K、MAX9000、MAX7000、FLASHlogic、MAX5000、Classic系列可編程邏輯器件;2.MAX+PLUSII的設(shè)計(jì)輸入、處理與校驗(yàn)功能一起提供了全集成化的一套可編程邏輯開發(fā)工具,可加快動(dòng)態(tài)調(diào)試,縮短開發(fā)周期;3.MAX+PLUSII支持各種HDL設(shè)計(jì)輸入,包括VHDL、Verilog和Altera的AHDL;4.MAX+PLUSII可與其他工業(yè)標(biāo)準(zhǔn)設(shè)計(jì)輸入、綜合與校驗(yàn)工具。與CAE工具的接口符合EDIF200和209、參數(shù)化模塊庫(LPM)、Verilog、VHDL及其它標(biāo)準(zhǔn)。設(shè)計(jì)者可使用Altera或標(biāo)準(zhǔn)CAE設(shè)計(jì)輸入工具去建立邏輯設(shè)計(jì),使用MAX+PLUS編譯器對Altera器件設(shè)計(jì)進(jìn)行編譯,并使用Altera或其它CAE校驗(yàn)工具進(jìn)行器件或板級仿真。MAX+PLUSII支持與Synopsys、Viewlogic、MentorGraphics、Cadence、Exemplar、DataI/O、Intergraph、Minc、OrCAD等公司提供的工具接口。利用MAX+PLUSII軟件平臺進(jìn)行設(shè)統(tǒng)設(shè)計(jì)。[5]具體的設(shè)計(jì)流程圖如圖1-2所示:設(shè)設(shè)設(shè)設(shè)器在系計(jì)計(jì)計(jì)計(jì)件線統(tǒng)要輸編校編校產(chǎn)求入譯驗(yàn)程驗(yàn)品設(shè)計(jì)修改1-2MAX+PLUSII軟件的設(shè)計(jì)流程圖交通燈系統(tǒng)設(shè)計(jì)2.1交通燈設(shè)計(jì)背景及方案隨著城市汽車保有量的越來越多,城市的交通擁擠問題正逐漸引起人們的注意。交通燈是交管部門管理城市交通的重要工具。提高十字路口的通行效率,對緩解交通阻塞具有十分重要的現(xiàn)實(shí)意義。實(shí)現(xiàn)路口交通燈系統(tǒng)控制的方法很多,可以用標(biāo)準(zhǔn)邏輯器件、可編程序控制器PLC、單片機(jī)等方案來實(shí)現(xiàn)。但是這些控制方法的功能修改及調(diào)試都需要硬件電路的支持,在一定程度上增加了設(shè)計(jì)難度。采用EDA技術(shù)。應(yīng)用VHDL硬件電路描述語言實(shí)現(xiàn)變通燈系統(tǒng)控制器的設(shè)計(jì),利用MAX+PLUSⅡ集成開發(fā)環(huán)境進(jìn)行綜合、仿真,并下載到CPLD可編程邏輯器件中,完成系統(tǒng)的控制作用。該燈控制邏輯可實(shí)現(xiàn)3種顏色燈的交替點(diǎn)亮、時(shí)間的倒計(jì)時(shí)、轉(zhuǎn)向問題,指揮車輛和行人安全通行。2.2交通燈設(shè)計(jì)要求按照路口交通運(yùn)行的實(shí)際情況,在本系統(tǒng)中,設(shè)定系統(tǒng)的工作情況如下:A方向和B方向各設(shè)紅(R)、黃(Y)、綠(G)和左拐(L)四盞燈按合理的順序亮滅,并能將燈亮的時(shí)間以倒計(jì)時(shí)的形式顯示出來。兩個(gè)方向各種燈亮的時(shí)間應(yīng)該能夠非常方便地進(jìn)行設(shè)計(jì)和修改,此外假設(shè)A方向是主干道,車流量大,因此A方向通行的時(shí)間應(yīng)比B方向長一些。其示意圖如圖2-1所示。G2Y2R2L2 A方向 G1 Y1 R1 L1方向2-1交通路口指示燈示意圖交通燈控制器的狀態(tài)轉(zhuǎn)換如表1所示。表中1表示燈亮,0表示燈滅。A方向和B方向的紅、黃、綠和左拐燈分別用R1、Y1、G1、L1和R2、Y2、G2、L2來表示。從狀態(tài)轉(zhuǎn)換表中可以看出,每個(gè)方向四種燈依次按如下綠燈→黃燈→左拐燈→黃燈→紅燈。并且每個(gè)方向紅燈亮的時(shí)間應(yīng)該與另一方向綠、拐、黃燈亮的時(shí)間相等。黃燈所起的作用是用來在綠燈和左拐燈后進(jìn)行緩沖,以提醒行人該方向馬上要禁行了。例如A方向的控制程序描述如表2-1所示:表2-1交通燈控制器狀態(tài)轉(zhuǎn)換A方向B方向綠燈黃燈左拐紅燈綠燈黃燈左拐紅燈G1Y1燈L1R1G2Y2燈L2R210000001010000010010000101000001000110000001010000010010000101002.3交通燈控制器的VHDL設(shè)計(jì)使用MAX+PLUSII進(jìn)行設(shè)計(jì)包括四個(gè)階段:設(shè)計(jì)輸入、設(shè)計(jì)處理、設(shè)計(jì)驗(yàn)證和器件編程。根據(jù)程序要求完成VHDL語言設(shè)計(jì)后,可形成頂層文件。在MAX+PLUSⅡ環(huán)境下進(jìn)行編譯與仿真直,至各個(gè)模塊全部完成仿真實(shí),現(xiàn)各自的功能。在本設(shè)計(jì)通燈控制器由七個(gè)模塊構(gòu)成:消振模塊,分頻器模塊、交通燈控制器模塊、計(jì)數(shù)器塊、計(jì)數(shù)器控制模塊、閃爍模塊、譯碼器模塊。VHDL語言對各個(gè)模塊進(jìn)行編程,最后形成頂層文件,在MAX+PLUSⅡ環(huán)境下進(jìn)行編譯與仿真,檢查所編程序是否運(yùn)行正確。如果出現(xiàn)錯(cuò)誤,需要進(jìn)行修改,直到完全通過為止。需要說明的是,在進(jìn)行程序編譯時(shí),要先從底層程序開始,所有底層程序都正確后,才能開始頂層程序的編譯。這是因?yàn)轫攲映绦蚴菍Φ讓映绦虻母爬ǎ前训讓映绦蚋鱾€(gè)模塊連接起來,相當(dāng)于把每個(gè)模塊的功能匯聚到一起,實(shí)現(xiàn)整個(gè)系統(tǒng)的控制功能,所以底層程序的正確與否關(guān)系到頂層程序的運(yùn)行。[6]2.3.1分頻器模塊2.3.1.1原理及功能分頻器通常用來對某個(gè)給定的頻率進(jìn)行分頻,以得到需要的頻率。整數(shù)分頻器非常簡單,可采用標(biāo)準(zhǔn)的計(jì)數(shù)器,也可采用可編程邏輯器件設(shè)計(jì)實(shí)現(xiàn)。分頻器可為后續(xù)模塊提供低頻的時(shí)鐘信號,分頻器采用上升沿計(jì)數(shù)來實(shí)現(xiàn)分頻。當(dāng)輸入端采集到了高頻的時(shí)鐘信號的上升沿時(shí),計(jì)數(shù)加一,當(dāng)?shù)竭_(dá)設(shè)定值時(shí),分頻器輸出一個(gè)脈沖。本設(shè)計(jì)中用到的就是簡單的分頻器,即計(jì)數(shù)器,計(jì)算器控制器,交通燈控制器提供時(shí)鐘信號,并且為閃爍模塊提供閃爍時(shí)鐘信號。該功能模塊有兩個(gè)輸入,兩個(gè)輸出:reset是部初始化信號輸入端,clk1k是高頻的時(shí)鐘信號,clk是整個(gè)系統(tǒng)的時(shí)鐘信號,clk_flash是閃爍模塊閃爍時(shí)鐘信號。2.3.1.2時(shí)序仿真圖2-2分頻器模塊的時(shí)序仿真波形時(shí)序仿真說明:(1).reset=1,則clk_cnt1、clk_cnt2、clk_s1、clk_s2、clk_f清零。reset=0,clk_1k為上升沿觸發(fā)時(shí),如果clk_cnt1大于或等于5時(shí),清零clk_cnt1,并且clk_s1輸出1。否則clk_cnt1加一,clk_s1等于0。3.reset=0,clk_1k為上升沿觸發(fā)并且clk_s1=1時(shí),如果clk_cnt2大于或等于200時(shí),clk_cnt2清零,輸出clk_s2=1,取反clk_f。否則clk_cnt2加一,clk_s2,clk_f保持不變。其中clk-flash是clk頻率的1/2倍,它是通過部信號與運(yùn)算的得來,即clk_flash<=clk_s1andclk_s2andclk_f;2.3.2計(jì)數(shù)器模塊2.3.2.1原理及功能計(jì)數(shù)器是對一個(gè)輸入脈沖進(jìn)行計(jì)數(shù),如果輸入脈沖的頻率一定,則記錄一定個(gè)數(shù)的脈沖,其所需的時(shí)間是一定的。計(jì)數(shù)器可分為加法和減法計(jì)數(shù)器兩種,所以計(jì)數(shù)器可實(shí)現(xiàn)倒記時(shí),因此可用在交通燈時(shí)間的控制。正常情況時(shí),計(jì)數(shù)器采集到交通燈控制器的信號recount,輸出倒計(jì)時(shí)間;緊急情況時(shí),計(jì)數(shù)器采集到禁止信號,時(shí)鐘停止計(jì)數(shù),時(shí)間不再倒記時(shí),只有采集到計(jì)數(shù)器控制器的下一個(gè)狀態(tài)的計(jì)數(shù)值,計(jì)數(shù)器才會進(jìn)行正常的減計(jì)數(shù),并輸出給譯碼器,顯示在顯示屏上。當(dāng)計(jì)數(shù)器計(jì)數(shù)到3時(shí),還要產(chǎn)生一個(gè)閃爍信號給閃爍模塊,控制其交通指示燈閃爍,告訴給行人時(shí)間到了需要減速停止。當(dāng)計(jì)數(shù)器計(jì)數(shù)到零時(shí),會反饋給交通燈控制器一個(gè)計(jì)數(shù)到零的信號next_state,告訴交通燈控制器需要進(jìn)入下一個(gè)狀態(tài)。本設(shè)計(jì)中主要程序段elsifclk'eventandclk='1'then ――時(shí)鐘信號ifhold='1'then --禁止信號cnt1<=cnt1;cnt2<=cnt2;elsifrecount='1'then ――采集到的交通燈控制信號,采集下cnt1<=din1; 一個(gè)計(jì)數(shù)值。cnt2<=din2;elset1<=cnt1-1; ――減計(jì)數(shù)cnt2<=cnt2-1;endif;2.3.2.2時(shí)序仿真圖2-3計(jì)數(shù)器模塊的時(shí)序仿真波形時(shí)序仿真說明:1.reset=1,清零cnt1、t2、next_s、last_f。2.reset=0,clk為上升沿觸發(fā)時(shí),如果hold=1時(shí),計(jì)數(shù)器處于禁止?fàn)顟B(tài),cnt1,cnt2保持不變,輸出不變。3.reset=0,clk為上升沿觸發(fā)時(shí),且hold=0,那么如果recount=1時(shí),則采集下一個(gè)計(jì)數(shù)數(shù)值。4.reset=0,clk為上升沿觸發(fā)時(shí),且hold=0,recount=0時(shí),cnt1,cnt2進(jìn)行減一運(yùn)算,并dout=cnt輸出。5.當(dāng)cnt1=0或cnt2=0時(shí),則next_sa<='1'。否則next_sa<='0。6.當(dāng)cnt1=3或cnt2=3時(shí),則last_f<='1'。否則last_f<='0'。2.3.3計(jì)數(shù)器控制器模塊2.3.3.1原理及功能計(jì)數(shù)器控制器通過給計(jì)數(shù)器賦值,控制計(jì)數(shù)器實(shí)現(xiàn)減計(jì)數(shù),從而達(dá)到倒記時(shí)的目的,同時(shí)和計(jì)數(shù)器配合控制閃爍模塊。計(jì)數(shù)器控制器是通過硬件描述語言case語句來實(shí)現(xiàn)不同狀態(tài)的選擇控制。計(jì)數(shù)器控制器模塊有三個(gè)輸入,端子recount是交通燈控制器控制計(jì)數(shù)器控制器是否進(jìn)行計(jì)數(shù)狀態(tài)轉(zhuǎn)換的信號,reset是部復(fù)位信號,用來復(fù)位部信號。sign_s是狀態(tài)選擇控制端。輸出端Load賦值給計(jì)數(shù)器計(jì)數(shù)值。flash_addr和計(jì)數(shù)器的flash共同作用控制閃爍模塊的閃爍功能。[7]2.3.3.2時(shí)序仿真圖2-4計(jì)數(shù)器控制器模塊時(shí)序仿真波形時(shí)序仿真說明:1.reset=1,則load1、load2清零。2.reset=0,clk為上升沿觸發(fā),且recount=1時(shí):(1)若sign_s=1,則load1<=conv_std_logic_vector(27,8);load2<=conv_std_logic_vector(27,8);flash_addr<="00";(2)若sign_s=1,則load1<=conv_std_logic_vector(23,8)load2<=conv_std_logic_vector(23,8);flash_addr<="00";(3)若sign_s=0,則load1<=conv_std_logic_vector(18,8);load2<=conv_std_logic_vector(18,8);flash_addr<="00";(4)若sign_s=0,則load1<=conv_std_logic_vector(35,8);load2<=conv_std_logic_vector(35,8)flash_addr<="00";2.3.4交通燈控制器的設(shè)計(jì)2.3.4.1原理及功能交通燈控制器控制過程分為八個(gè)階段,對應(yīng)的有四個(gè)狀態(tài),分別用a、b、c、表示。狀態(tài):A方向的綠燈亮,左轉(zhuǎn)燈,紅燈,黃燈都滅,B方向的紅燈亮,綠燈,黃燈,左轉(zhuǎn)燈都滅。此時(shí),A方向上的車輛可直行或者各自右轉(zhuǎn),行人可以橫穿B路口,B方向上車和行人禁止通行。直到計(jì)數(shù)器計(jì)數(shù)時(shí)間到,由a狀態(tài)轉(zhuǎn)b狀態(tài)。狀態(tài):A方向的黃燈亮,綠燈,左轉(zhuǎn)燈,紅燈滅,B方向的交通燈保持原狀態(tài)。此時(shí),A方向上的車輛要開始停止通行,行人可繼續(xù)穿行,B方向的車輛行人保持原狀態(tài)。直到計(jì)數(shù)器計(jì)時(shí)時(shí)間到,由b狀態(tài)轉(zhuǎn)到c狀態(tài)。態(tài):A方向的左轉(zhuǎn)燈亮,綠燈,黃燈,紅燈滅,B方向的交通燈保持原狀態(tài)。此時(shí),A方向上的車輛各自左轉(zhuǎn),直行和右轉(zhuǎn)車輛禁止通行,行人可繼續(xù)穿行,B方向的車輛和行人保持原狀態(tài)。直到計(jì)數(shù)器計(jì)時(shí)時(shí)間到,由c狀態(tài)轉(zhuǎn)到d狀態(tài)。狀態(tài):A方向上的黃燈亮,綠燈,左轉(zhuǎn)燈,紅燈滅,B方向的交通燈保持原狀態(tài)。此時(shí),A方向上的車輛和行人要開始停止通行,B方向的車輛行人保持原狀態(tài)。直到計(jì)數(shù)器計(jì)時(shí)時(shí)間到,由d態(tài)轉(zhuǎn)到下個(gè)狀態(tài)。到此,B方向上的交通燈開始變化,依次重復(fù)A方向上a、b、c、d四個(gè)狀態(tài)的轉(zhuǎn)換。當(dāng)B方向上的四個(gè)狀態(tài)循環(huán)完成后,A方向再次重復(fù)A方向上a、b、c、d四個(gè)狀態(tài)的轉(zhuǎn)換。交通燈主要控制程序?yàn)椋簑hena=>ifa_m='1'then
――交通燈處于自動(dòng)狀態(tài)時(shí)ifnext_state='1'then
――采集到計(jì)數(shù)器計(jì)數(shù)到零時(shí)反饋信號recount<='1';state<=b;sign_state<="1";elserecount<='0';state<=a;endif;elsifa_m='0'then
――交通燈處于手動(dòng)狀態(tài)時(shí)ifh_butt='1'then
――手動(dòng)狀態(tài)轉(zhuǎn)換控制信號recount<='1';state<=b;sign_state<="1";elserecount<='0';state<=a;endif;endif;2.3.4.2時(shí)序仿真圖2-5交通燈控制器模塊時(shí)序仿真波形時(shí)序仿真說明1.Reset=1,則state<=a;sign_state<="1";recount<='1';2.Reset=0,clk為上升沿觸發(fā),如果hold=1,則交通燈控制器出與禁止?fàn)顟B(tài),此時(shí)所有路口的紅綠燈都為紅燈。否則,交通燈處于正常的顯示狀態(tài)。3.Reset=0,clk為上升沿觸發(fā),且hold=0,如果state為a狀態(tài)時(shí),如果a_m=1且next_state='1'則recount=1,state<=b;sign_state<="1";否則recount<='0';state<=a;如果為手動(dòng)狀態(tài)a_m=0且h_butt='1則recount<='1';state<=b;sign_state<="1";否則recount<='0',state<=a;4.Reset=0,clk為上升沿觸發(fā),且hold=0,如果state為b狀態(tài)時(shí),如果a_m=1且next_state='1'則recount=1,state<=c;sign_state<="0";否則recount<='0';state<=b;如果為手動(dòng)狀態(tài)a_m=0且h_butt='1則recount<='1';state<=c;sign_state<="0";否則recount<='0',state<=b5.Reset=0,clk為上升沿觸發(fā),且hold=0,如果state為c狀態(tài)時(shí),如果a_m=1且next_state='1'則recount=1,state<=d;sign_state<="1";否則recount<='0';state<=c;如果為手動(dòng)狀態(tài)a_m=0且h_butt='1則recount<='1';state<=d;sign_state<="1";否則recount<='0',state<=c6.Reset=0,clk為上升沿觸發(fā),且hold=0,如果state為d狀態(tài)時(shí),如果a_m=1且next_state='1'則recount=1,state<=e;sign_state<="1";否則recount<='0';state<=d;如果為手動(dòng)狀態(tài)a_m=0且h_butt='1則recount<='1';state<=d;sign_state<="1";否則recount<='0',state<=d7.Reset=0,clk為上升沿觸發(fā),且hold=0,如果state為e狀態(tài)時(shí),如果a_m=1且next_state='1'則recount=1,state<=e;sign_state<="1";否則recount<='0';state<=d;如果為手動(dòng)狀態(tài)a_m=0且h_butt='1則recount<='1';state<=fsign_state<="1";否則recount<='0',state<=e8.Reset=0,clk為上升沿觸發(fā),且hold=0,如果state為f狀態(tài)時(shí),如果a_m=1且next_state='1'則recount=1,state<=a;sign_state<="1";否則recount<='0';state<=f;如果為手動(dòng)狀態(tài)a_m=0且h_butt='1則recount<='1';state<=asign_state<="1";否則recount<='0',state<=f。2.3.5閃爍電路模塊的設(shè)計(jì)2.3.5.1原理及功能閃爍模塊一般用來提醒或者引起致意,有時(shí)又希望能關(guān)斷某一路的顯示。本設(shè)計(jì)中采用關(guān)斷某個(gè)一個(gè)LED的方法,利用一個(gè)低頻(2Hz左右)的時(shí)鐘與全部的輸入信號都做與運(yùn)算,然后在送到LED的輸入端口,這樣就會實(shí)現(xiàn)該低頻時(shí)鐘的頻率閃爍功能。閃爍模塊控制交通燈閃爍通過與運(yùn)算其實(shí)現(xiàn)功能主要程序?yàn)椋篹lsifclk_flash='1'then ――閃爍模塊閃爍時(shí)鐘ifflash_addr="01"andflash='1'then ――控制交通指示燈t<="0";cnt_flash<=dinsxort;
――異或運(yùn)算elset_flash<=dins;endif;elsifflash_addr="11"andflash='1'thent<="1";cnt_flash<=dinsxort;elset_flash<=dins;endif;其中clk_flash(2hz)是低頻閃爍信號,clk是系統(tǒng)時(shí)鐘信號,clk_flash是低頻閃爍時(shí)鐘信號,flash,flash_addr是交通燈控制器和計(jì)數(shù)器控制器產(chǎn)生的控制信號,它們共同作用判別是否關(guān)斷、關(guān)開LED交通燈。2.3.5.2時(shí)序仿真圖2-6閃爍電路模塊時(shí)序仿真波形時(shí)序仿真說明:1.reset=1,則cnt_flash清零。2.reset=0,clk為上升沿觸發(fā),如果hold=1時(shí),cnt_flash=dins,即保持不變,輸入等于輸出。3.reset=0,clk為上升沿觸發(fā),且hold=0,如果clk_flash='1'且flash_addr="01"andflash='1'則cnt=0,cnt_flash<=dinsxort;。否則cnt_flash<=dins;4.reset=0,clk為上升沿觸發(fā),且hold=0,如果clk_flash='1且,flash_addr="11"andflash='1'則cnt<="1";t_flash<=dinsxort。否則cnt_flash<=dins;2.3.6消振模塊設(shè)計(jì)2.3.6.1原理及功能交通燈出現(xiàn)緊急情況或需要交通人員進(jìn)行手動(dòng)控制時(shí),需要手動(dòng)操作按鍵,由于按鍵被按下和按鍵彈起時(shí)都有抖動(dòng),造成控制器采集到多個(gè)信號信息,使得計(jì)數(shù)器產(chǎn)生一些誤操作,控制器誤判概率增加。消振功能模塊通過采用延時(shí)響應(yīng)原理來消除抖動(dòng)和誤操作,模塊利用方波上升延采集信號,當(dāng)采集到信號時(shí),進(jìn)行計(jì)數(shù),計(jì)數(shù)直到設(shè)定值時(shí),系統(tǒng)才認(rèn)為此信號為有用信息,進(jìn)行響應(yīng)輸出控制信號。否則,屏蔽掉此信號,不響應(yīng)執(zhí)行輸出。[8]在本模塊中有五個(gè)輸入端,resetr是部初始化信號,當(dāng)模塊采集到初始化信號時(shí),置零部信號,clkr是模塊時(shí)鐘信號,其它三個(gè)是手動(dòng)按鍵輸入端,手動(dòng)轉(zhuǎn)化控制按鈕a_mr,手動(dòng)轉(zhuǎn)換按鈕h_buttonr,緊急情況禁止按鈕holdr。模塊采用clkr1KHZ的方波作為時(shí)鐘信號,模塊每1um采集一次信息,當(dāng)采集到十個(gè)上升延時(shí)響應(yīng)操作,輸出一個(gè)1um的控制信號。主要程序如下:。elsifclkr'eventandclkr='1'ifholdr='1'thenift2>="0111"thent2<="0000";hoq<='1';elset2<=cnt2+1;hoq<='0';endif;endif;2.3.6.2時(shí)序仿真
then ――1khz的時(shí)鐘信號--采集到手動(dòng)信息――計(jì)數(shù)判斷――加計(jì)數(shù)圖2-7消震模塊時(shí)序仿真波形時(shí)序仿真說明:1.resetr=1,則t1,cnt2,cnt3清零。2.resetr=0,clk為上升沿觸發(fā),當(dāng)holdr=1時(shí),cnt1的值大于等于10時(shí),則清零cnt1,令hoq=1,否則cnt1加一,hoq=0不變。3.resetr=0,clk為上升沿觸發(fā),當(dāng)a_mr=1時(shí),cnt2的值大于等于10時(shí),則清零cnt2,令aq=1,否則cnt2加一,aq=0不變。4.resetr=0,clk為上升沿觸發(fā),當(dāng)h_buttonr=1時(shí),cnt3的值大于等于10時(shí),則清零cnt3,令hq=1,否則cnt2加一,hq=0不變。2.3.7譯碼器設(shè)計(jì)2.2.3.7.1原理及功能用來實(shí)現(xiàn)將二進(jìn)制碼或二——十進(jìn)制碼,譯成一組與輸入代碼一一對應(yīng)的高、低電平信號的電路就是譯碼器。它是一個(gè)多輸入、多輸出電路,它的輸入是二進(jìn)制代碼或二——十進(jìn)制代碼,輸出是代碼所代表的字符。本設(shè)計(jì)中采用七段顯示譯碼器來顯示交通燈上的倒記時(shí)。2.3.7.2時(shí)序仿真圖2-8譯碼器模塊時(shí)序仿真波形2.3.8總體電路設(shè)計(jì)電路由從總體上是由各個(gè)功能的電路模塊組成。通過元件例化語句調(diào)用低層次的當(dāng)前設(shè)計(jì)實(shí)體。(程序見附錄P9)圖2-9總體電路的時(shí)序仿真波形2.4實(shí)驗(yàn)平臺的引腳配置及下載測試2.4.1實(shí)驗(yàn)平臺介紹2.4.1.1實(shí)驗(yàn)系統(tǒng)主板提供的基本功能說明:個(gè)按鍵:即九個(gè)琴鍵按鍵(按住琴鍵,對應(yīng)輸出指示的紅色二極管亮,表示輸出高電平,松開琴鍵,對應(yīng)輸出指示的紅色二極管滅,表示輸出為低電平)。五個(gè)電平按鍵(按下鍵,對應(yīng)輸出指示的紅色二極管亮,表示輸出高電平,再按下鍵,對應(yīng)輸出指示的紅色二極管滅,表示輸出為低電平)。一個(gè)脈沖模式按鍵:當(dāng)按下此按鍵,對應(yīng)輸出20ms的脈沖電平。各按鍵均已用軟件消抖。8個(gè)共陰數(shù)碼管,其中7個(gè)作為數(shù)碼顯示用(顯示采用掃描和自動(dòng)滅零技術(shù),當(dāng)輸入的四位二進(jìn)制數(shù)大于1001時(shí),滅燈),通過跳線選擇供CPLD/FPGA或單片機(jī)使用。6個(gè)共陰數(shù)碼管,其中6個(gè)作為數(shù)碼顯示用(自動(dòng)滅零技術(shù),當(dāng)輸入的四位二進(jìn)制數(shù)大于1001時(shí),滅燈),直接與CPLD/FPGA連接。用戶直接提供6個(gè)數(shù)碼管的4位BCD碼輸入,共24位。8個(gè)發(fā)光二極管(輸入高電平時(shí),二極管發(fā)亮)。4組時(shí)鐘輸入(時(shí)鐘頻率從50MHz到2Hz)即CLK1,CLK2,CLK3,CLK4。其中任何一組只能用一個(gè)跳線帽接通時(shí)鐘信號,結(jié)對不能在一組上插兩個(gè)或兩個(gè)以上的跳線帽接通兩個(gè)以上的時(shí)鐘。一個(gè)蜂鳴器和一個(gè)喇叭(由跳線K1接通);一個(gè)串行通信接口,通過跳線選擇供CPLD/FPGA或單片機(jī)使用。電源輸入電壓:交流220V+-10V。電源輸出電壓:+5V(2A)和+-12V(0.5A)。+5V的地和12V地。2.4.1.2跳線說明Jump1:(1,2)對XILINX的CPLD/FPGA進(jìn)行配置。(3,4)對LATTICE的CPLD進(jìn)行配置。(5,6)對ALTERA的CPLD/FPGA進(jìn)行配置。(7,8)對89S5X進(jìn)行配置。2-2Jump1端口配置75318642Jump2:(2,4)(5,7)單片機(jī)串口與RS232的端口相連。(1,3)(6,8)CPLD/FPGA串行信號與RS232端口相連。(1,2)(7,8)單片機(jī)與CPLD/FPGA的串口對連。2-3Jump2端口配置24681357Jump3:(1,2)提供USB外設(shè)的電源2-4Jump3端口配置2Jump4:(1,2)選通AS0809(2,3)停用08092-5Jump4端口配置123Jump5:(1,2)選通AD0832(3,4)停用08322-6Jump5端口配置123MCUJP1:全接左:由CPLD/FPGA控制掃描數(shù)碼管顯示全接右:由單片機(jī)控制掃描數(shù)碼管顯示MCUJP2:按下:單片機(jī)下載狀態(tài)彈上:單片機(jī)運(yùn)行狀態(tài)MCUJP3:全接左:使用IIC端口連接全接右:使用掃描鍵盤MCUJP4:全接左:由CPLD/FPGA控制步進(jìn)電機(jī)驅(qū)動(dòng)信號全接右:由單片機(jī)控制步進(jìn)電機(jī)驅(qū)動(dòng)信號ALTERA公司的EP1K30芯片的下載實(shí)驗(yàn)板的引腳分配表2-2下載實(shí)驗(yàn)板1K30的引腳與實(shí)驗(yàn)系統(tǒng)的連接關(guān)系[9]功能腳號功能腳號功能腳號功能腳號Clk155A1低118SL(A/D)95雙口RAMClk254B1121R(A/D)92Clk359C1120EN(A/D)91CE113Clk456D1高128D7(A/D)82WR112蜂鳴器64A2122D6(A/D)81RD111喇叭65B2131D5(A/D)86D796琴鍵144C2130D4(A/D)83D698琴鍵246D2133D3(A/D)88D597琴鍵347A3132D2(A/D)87D4100琴鍵448B3136D1(A/D)90D399琴鍵549C3135D0(A/D)89D2102琴鍵651D3138WR(A/D)67D1101琴鍵760A4137D7(A/D)80D0110琴鍵862B4141D6(A/D)79A10109琴鍵963C4140D5(A/D)78VGA電平137D4143D4(A/D)73RED119電平238A5142D3(A/D)72RED020電平339B57D2(A/D)70GRN122電平441C5144D1(A/D)69GRN021電平542D59D0(A/D)68BLU126脈沖43A68RxD29BLU023LED818B611TxD30VG1328LED714C610PS132VG1427LED617D613PS531LED512LED2117T1LED4119LED1114LED31162.4.2引腳配置及下載測試按表2-2可對管腳重新分配和定位進(jìn)行硬件測試,為后面的器件下載和硬件實(shí)現(xiàn)提供保障。管腳配置定位如圖2-10所示:圖2-10管腳的配置定位交通燈的硬件實(shí)現(xiàn)3.1顯示實(shí)現(xiàn)本設(shè)計(jì)中要現(xiàn)兩個(gè)方面的顯示,即各個(gè)路口的時(shí)間和指示燈的狀態(tài),對于路口時(shí)間顯示可以采用LED七段數(shù)碼管實(shí)現(xiàn),方向指示可以采用LED點(diǎn)陣顯示器來實(shí)現(xiàn)。LED七段數(shù)碼管有共陰極和共陽極兩種接法,本設(shè)計(jì)電路中采用共陰極數(shù)碼管,即把七段數(shù)碼管的所有發(fā)光二極管的陰極都接地時(shí),數(shù)碼管才能被點(diǎn)亮。LED點(diǎn)陣顯示器亦稱LED矩陣板,以發(fā)光二極管為象素,按行與列順序顯示,彩色LED顯示以三色二極管作為象素點(diǎn)來顯示:紅光,綠光,澄光(復(fù)合光紅燈和綠燈同時(shí)亮),它們分別代表交通燈控制電路中的紅燈,綠燈和黃燈三個(gè)指示燈。此外在設(shè)計(jì)電路時(shí),在七段數(shù)碼管和點(diǎn)陣顯示器的每一段串聯(lián)510Ω的電阻,以限制流經(jīng)每一段的電流,否則電流太大,容易燒毀發(fā)光二極管。[10]3.2芯片的實(shí)現(xiàn)該設(shè)計(jì)采用的是EP1K30TC144-3芯片,首先對通過對各個(gè)模塊的編譯和排錯(cuò)形成工程文件,然后進(jìn)行編譯,設(shè)置成工程,編譯綜合到仿真測試,通過后以備后用,最后將頂層文件設(shè)置為工程,統(tǒng)一處理,這時(shí)頂層文件會自動(dòng)根據(jù)元件例化語句調(diào)用底層編譯好的設(shè)計(jì)文件,在設(shè)定好頂層文件后,底層設(shè)計(jì)好的文件元件型號和引腳鎖定信息會自動(dòng)失效。元件型號的選定和引腳鎖定情況始終以工程文件(頂層文件)的設(shè)定為準(zhǔn)。同樣,仿真結(jié)果也是針對工程文件的,所以在對最后的頂層文件處理時(shí),仍然應(yīng)該對它重新設(shè)定元件型號和引腳鎖定。圖2-11部控制芯片的連接3.3外圍電路的實(shí)現(xiàn)根據(jù)交通燈系統(tǒng)的控制要求,下圖所示為本系統(tǒng)的硬件電路圖。該電路包含了1CPLD芯片,4個(gè)七段LED數(shù)碼顯示器,12個(gè)分別表示各個(gè)方向上的紅、黃、綠燈,以及相應(yīng)的限流電阻。圖2-12外圍電路的連接結(jié)論從開始接到論文題目到系統(tǒng)的實(shí)現(xiàn),再到論文文章的完成,每走一步對我來說都是新的嘗試與挑戰(zhàn),這也是我在大學(xué)期間獨(dú)立完成的最大的項(xiàng)目。在這段時(shí)間里,我學(xué)到了很多知識,也有很多感受,從對VHDL語言、MAX+PLUSII軟件操作平臺等相關(guān)技術(shù)很不大了解的狀態(tài),我開始了獨(dú)立的學(xué)習(xí)和試驗(yàn),查看相關(guān)的資料和書籍,讓自己頭腦中模糊的概念逐漸清晰,使自己對硬件描述語言VHDL應(yīng)用系統(tǒng)有了更深一步的了解,也更為熟悉MAX+PLUSII軟件系統(tǒng)的設(shè)計(jì)流程,每一次改進(jìn)都是我學(xué)習(xí)的收獲。EDA技術(shù)是一種實(shí)現(xiàn)電子系統(tǒng)或電子產(chǎn)品自動(dòng)化設(shè)計(jì)的技術(shù)。它是為了適應(yīng)現(xiàn)代電子產(chǎn)品設(shè)計(jì)的要求,伴隨著計(jì)算機(jī)、集成電路、電子系統(tǒng)設(shè)計(jì)的發(fā)展,吸收眾多學(xué)科的成果而逐步形成的一門新技術(shù)。在本設(shè)計(jì)中主要實(shí)現(xiàn)了在十字路口交通燈的燈色變化和計(jì)時(shí)變化。通過VHDL語言編譯軟件程序,在MAX+PLUSII軟件平臺上進(jìn)行VHDL代碼設(shè)計(jì),目標(biāo)器件選擇,編譯,仿真,引腳配置,編程下載,硬件測試,對交通燈的設(shè)計(jì)進(jìn)行現(xiàn)實(shí)模擬仿真,通過波形圖分析電路。這樣做可實(shí)現(xiàn)模擬運(yùn)行,出錯(cuò)時(shí)可隨時(shí)修改,而且可以根究不同的實(shí)際情況修改完善程序,節(jié)約項(xiàng)目開發(fā)資金。由于我所學(xué)的知識不夠全面,設(shè)計(jì)中存在不足和需要改進(jìn)的地方,例如:對于系統(tǒng)性能提高的諸如面積優(yōu)化,邏輯優(yōu)化設(shè)計(jì),速度優(yōu)化并未涉及,PAL、GAL以至FPGA等一些較新技術(shù),在本實(shí)際中就沒有顯現(xiàn)出來。通過這次畢業(yè)設(shè)計(jì)的完成使得我對自己所學(xué)的專業(yè)知識又有了更深一步的了解,開拓了個(gè)人的視野,在相關(guān)的知識和技巧方面也有了提高。但是個(gè)人所學(xué)是有限的,難免有疏漏的地方,通過這次設(shè)計(jì)希望有所改善,讓所學(xué)的專業(yè)知識從理論運(yùn)用到實(shí)際工作和生活中。致參考文獻(xiàn)擦光輝.《CPLD/TPGA的開發(fā)與應(yīng)用[M]》.:電于工業(yè),2002.[2]杜玉遠(yuǎn).《EDA設(shè)計(jì)快速入門圓》.電子世界.2004,(1):24ALTERA公司.《DATABOOK[M]》.:清華大學(xué),1998ALTERA公司.《ADHL語言[M]》.:清華大學(xué),1998寶琴.ALTERA.《可編程邏輯器件及其應(yīng)用[M]》.:清華大學(xué).1995.宋萬杰.羅豐.吳順君.《CPLD技術(shù)及零應(yīng)用[M]》.:電子科技大學(xué).1999.科技.《CPLD/FPGA應(yīng)用開發(fā)技術(shù)與工程實(shí)踐》.人民郵電.2005.1寶琴.《ALTERA可編程邏輯器件及其應(yīng)用》.清華大學(xué).1995.松.《VHDL實(shí)用教程》.電子科技大學(xué).2000.3馬淑華.高原.《電子設(shè)計(jì)自動(dòng)化》.郵電大學(xué).2006.9附錄分頻器程序libraryieee;useieee.std_logic_1164.all;useieee.std_logic_unsigned.all;entityfpqisport(clk_1k,reset:instd_logic;clk,clk_flash:outstd_logic);end;architectureartoffpqissignalclk_cnt1:std_logic_vector(3downto0);signalclk_cnt2:std_logic_vector(7downto0);signalclk_s1,clk_s2,clk_f:std_logic;beginprocess(reset,clk_1k)beginifreset='1'thenclk_cnt1<="0000";clk_s1<='0';elsifclk_1k'eventandclk_1k='1'thenifclk_cnt1>="0101"thenclk_cnt1<="0000";clk_s1<='1';elseclk_cnt1<=clk_cnt1+1;clk_s1<='0';endif;endif;endprocess;process(reset,clk_1k,clk_s1)beginifreset='1'thenclk_cnt2<="00000000";clk_s2<='0';clk_f<='0';elsifclk_1k'eventandclk_1k='1'thenifclk_s1='1'thenifclk_cnt2>="00000010"thenclk_cnt2<="00000000";clk_s2<='1';clk_f<=notclk_f;elseclk_cnt2<=clk_cnt2+1;clk_s2<='0';clk_f<=clk_f;endif;endif;endif;endprocess;clk<=clk_s2;clk_flash<=clk_s1andclk_s2andclk_f;end;計(jì)數(shù)器程序libraryieee;useieee.std_logic_1164.all;useieee.std_logic_unsigned.all;useieee.std_logic_arith.all;entityjsqisport(clk,reset,recount,hold:instd_logic;din1,din2:instd_logic_vector(7downto0);dout1,dout2,dout3,dout4:outstd_logic_vector(3downto0);next_state:outstd_logic;flash:outstd_logic);end;architectureartofjsqissignalnext_sa,last_f:std_logic;signalt1,cnt2:std_logic_vector(7downto0);beginprocess(clk,reset,recount,hold)beginifreset='1'thent1<="00000000";t2<="00000000";elsifclk'eventandclk='1'thenifhold='1'thencnt1<=cnt1;cnt2<=cnt2;elsifrecount='1'thencnt1<=din1;cnt2<=din2;elset1<=cnt1-1;cnt2<=cnt2-1;endif;endif;endprocess;dout1<=cnt1(3downto0);dout2<=cnt1(7downto4);dout3<=cnt2(3downto0);dout4<=cnt2(7downto4);process(cnt1,cnt2)beginift1<="00000000"ort2<="00000000"thennext_sa<='1';elsenext_sa<='0';endif;ift1<="00000101"ort2<="00000101"thenlast_f<='1';elselast_f<='0';endif;endprocess;next_state<=next_sa;flash<=last_f;end;計(jì)數(shù)器控制器程序libraryieee;useieee.std_logic_1164.all;useieee.std_logic_unsigned.all;useieee.std_logic_arith.all;entityjsqkzqisport(clk:instd_logic;reset:instd_logic;recount:instd_logic;sign_s:instd_logic_vector(11downto0);load1:outstd_logic_vector(7downto0);load2:outstd_logic_vector(7downto0);flash_addr:outstd_logic_vector(1downto0));end;architectureartofjsqkzqisbeginprocess(clk)beginifreset='1'thenload1<="00000000";load2<="00000000";elsifclk'eventandclk='1'thenifrecount='1'thencasesign_siswhen"1"=>load1<=conv_std_logic_vector(50,8);load2<=conv_std_logic_vector(27,8);flash_addr<="00";when"1"=>load2<=conv_std_logic_vector(3,8);flash_addr<="00";when"0"=>load2<=conv_std_logic_vector(20,8);flash_addr<="01";when"1"=>load1<=conv_std_logic_vector(18,8);load2<=conv_std_logic_vector(35,8);flash_addr<="00";when"1"=>load1<=conv_std_logic_vector(3,8);flash_addr<="00";whenothers=>load1<=conv_std_logic_vector(14,8);flash_addr<="11";endcase;endif;endif;endprocess;end;交通燈控制器程序libraryieee;useieee.std_logic_1164.all;useieee.std_logic_unsigned.all;entityjtdkzisport(clk,reset,a_m,h_butt,hold:instd_logic;next_state:instd_logic;recount:outstd_logic;sign_state:inoutstd_logic_vector(11downto0));end;architectureoneofjtdkzissignalab:std_logic_vector(11downto0);typestate_typeis(a,b,c,d,e,f);signalstate:state_type;beginprocess(clk,reset,hold)beginifreset='1'thenstate<=a;sign_state<="1";recount<='1';elsifclk'eventandclk='1'thenifhold='1'thenab<=sign_state;sign_state<="1";elsifhold='0'thensign_state<=ab;elsecasestateiswhena=>ifa_m='1'thenifnext_state='1'thenrecount<='1';state<=b;sign_state<="1";elserecount<='0';state<=a;endif;elsifa_m='0'thenifh_butt='1'thenrecount<='1';state<=b;sign_state<="1";elserecount<='0';state<=a;endif;endif;whenb=>ifa_m='1'thenifnext_state='1'thenrecount<='1';state<=c;sign_state<="0";elserecount<='0';state<=b;endif;elsifa_m='0'thenifh_butt='1'thenrecount<='1';state<=c;sign_state<="0";elserecount<='0';state<=b;endif;endif;whenc=>ifa_m='1'thenifnext_state='1'thenrecount<='1';state<=d;sign_state<="1";elserecount<='0';state<=c;endif;elsifa_m='0'thenifh_butt='1'thenrecount<='1';state<=d;sign_state<="1";elserecount<='0';state<=c;endif;endif;whend=>ifa_m='1'thenifnext_state='1'thenrecount<='1';state<=e;sign_state<="1";elserecount<='0';state<=d;endif;elsifa_m='0'thenifh_butt='1'thenrecount<='1';state<=e;sign_state<="1";elserecount<='0';state<=d;endif;endif;whene=>ifa_m='1'thenifnext_state='1'thenrecount<='1';state<=f;sign_state<="1";elserecount<='0';state<=e;endif;elsifa_m='0'thenifh_butt='1'thenrecount<='1';state<=f;sign_state<="1";elserecount<='0';state<=e;endif;endif;whenf=>ifa_m='1'thenifnext_state='1'thenrecount<='1';state<=a;sign_state<="1";elserecount<='0';state<=f;endif;elsifa_m='0'thenifh_butt='1'thenrecount<='1';state<=a;sign_state<="1";elserecount<='0';state<=f;endif;endif;whenothers=> state<=a;endcase;endif;endif;endprocess;end;閃爍電路程序libraryieee;useieee.std_logic_1164.all;useieee.std_logic_unsigned.all;entityssmkisport(clk,reset,clk_flash,hold:instd_logic;flash:instd_logic;flash_addr:instd_logic_vector(1downto0);dins:instd_logic_vector(11downto0);dout:outstd_logic_vector(11downto0));end;architectureartofssmkissignalt:std_logic_vector(11downto0);signalt_flash:std_logic_vector(11downto0);beginprocess(clk_flash,clk,hold,flash_addr,reset)beginifreset='1'thencnt_flash<="0";elsifclk'eventandclk='1'thenifhold='1'thencnt_flash<=dins;elsifclk_flash='1'thenifflash_addr="01"andflash='1'thent<="0";cnt_flash<=dinsxort;elset_flash<=dins;endif;elsifflash_addr="11"andflash='1'thent<="1";cnt_flash<=dinsxort;elset_flash<=dins;endif;endif;endprocess;dout<=cnt_flash;end;消振電路程序libraryieee;useieee.std_lo
溫馨提示
- 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)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024版智能穿戴設(shè)備生產(chǎn)許可協(xié)議3篇
- 2024版商用辦公樓清潔服務(wù)標(biāo)準(zhǔn)協(xié)議書版
- 二零二五年度機(jī)床行業(yè)技術(shù)交流合作合同3篇
- 2024微信公眾號代運(yùn)營服務(wù)合同
- 二零二五年度互聯(lián)網(wǎng)+合股投資協(xié)議書3篇
- 2024年設(shè)施安裝協(xié)議
- 2025北京市裝修合同范本
- 二零二五年度班組勞務(wù)分包與職業(yè)健康安全合同規(guī)范3篇
- 二零二五年變壓器租賃及運(yùn)輸服務(wù)合同范本2篇
- 2025房屋出租標(biāo)準(zhǔn)租賃合同
- 新增值稅法學(xué)習(xí)課件
- 如何反饋與指導(dǎo)-培訓(xùn)課件
- 江蘇省高中名校2025屆高三下學(xué)期一模考試數(shù)學(xué)試題含解析
- 2024年上海市16區(qū)高考英語一模試卷聽力部分匯編(附14區(qū)聽力音頻)含答案與文本
- 江蘇省南通市2023-2024學(xué)年高二上學(xué)期期末考試物理試題(含答案)
- 2024年房屋租賃補(bǔ)充協(xié)議參考模板(四篇)
- 老年病護(hù)理學(xué)學(xué)習(xí)通超星期末考試答案章節(jié)答案2024年
- 《旅游職業(yè)禮儀》高職旅游專業(yè)全套教學(xué)課件
- 電梯維修安全培訓(xùn)課件
- 2025高考數(shù)學(xué)專項(xiàng)復(fù)習(xí):阿基米德三角形(解析版)
- 數(shù)據(jù)分析師歷年考試真題試題庫(含答案)
評論
0/150
提交評論