版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
實(shí)訓(xùn)十七基本單元電路的VHDL設(shè)計(jì)
本章提要:本章介紹了數(shù)字系統(tǒng)設(shè)計(jì)中經(jīng)常用到的計(jì)數(shù)器,分頻器,選擇器,譯碼器,編碼器,寄存器,
存儲(chǔ)器,輸入電路,顯示電路等基本單元電路的VHDL程序設(shè)計(jì)。
學(xué)習(xí)要求:在教師講授這些基本單元電路的設(shè)計(jì)思想的基礎(chǔ)上,通過上機(jī)調(diào)試熟練掌握這些基本單元電路
的設(shè)計(jì)。
關(guān)鍵詞:計(jì)數(shù)器(Counter),分頻器(Divder),選擇器(Multiplexer),譯碼器(Decoder),編碼器
(Encoder),寄存器(Register),存儲(chǔ)器(Memory),輸入電路(InputCircuit),顯示電路(Display
Circuit)
6.1計(jì)數(shù)器的設(shè)計(jì)
6.1.1同步計(jì)數(shù)器的設(shè)計(jì)
6.1.2異步計(jì)數(shù)器的設(shè)計(jì)
6.2分頻器的設(shè)計(jì)
6.3選擇器的設(shè)計(jì)
6.4譯碼器的設(shè)計(jì)
6.5編碼器的設(shè)計(jì)
6.5.1一般編碼器的設(shè)計(jì)
6.5.2優(yōu)先級(jí)編碼器的設(shè)計(jì)
6.6寄存器的設(shè)計(jì)
6.6.1數(shù)碼寄存器的設(shè)計(jì)
6.6.2移位寄存器的設(shè)計(jì)
6.6.3并行加載移位寄存器的設(shè)計(jì)
6.7存儲(chǔ)器的設(shè)計(jì)
6.7.1只讀存儲(chǔ)器ROM的設(shè)計(jì)
6.7.2讀寫存儲(chǔ)器SRAM的設(shè)計(jì)
6.8輸入電路的設(shè)計(jì)
6.8.1鍵盤掃描電路的設(shè)計(jì)
6.8.2鍵盤接口電路的設(shè)計(jì)
6.9顯示電路的設(shè)計(jì)
6.9.1數(shù)碼管靜態(tài)顯示電路的設(shè)計(jì)
6.9.2數(shù)碼管動(dòng)態(tài)顯示電路的設(shè)計(jì)
6.9.2液晶顯示控制電路的設(shè)計(jì)
6.1計(jì)數(shù)器的設(shè)計(jì)
計(jì)數(shù)器是在數(shù)字系統(tǒng)中使用最多的時(shí)序電路,它不僅能用于對(duì)時(shí)鐘脈沖計(jì)數(shù),還可以用于分頻,定時(shí),產(chǎn)
生節(jié)拍脈沖和脈沖序列以及進(jìn)行數(shù)字運(yùn)算等。計(jì)數(shù)器是一個(gè)典型的時(shí)序電路,分析計(jì)數(shù)器就能更好地了解
時(shí)序電路的特性。計(jì)數(shù)器分同步計(jì)數(shù)器和異步計(jì)數(shù)器兩種。
6.1.1同步計(jì)數(shù)器的設(shè)計(jì)
所謂同步計(jì)數(shù)器,就是在時(shí)鐘脈沖(計(jì)數(shù)脈沖)的控制下,構(gòu)成計(jì)數(shù)器的各觸發(fā)器狀態(tài)同時(shí)發(fā)生變化的那
一類計(jì)數(shù)器。
1)六十進(jìn)制計(jì)數(shù)器
眾所周知,用一個(gè)4位二進(jìn)制計(jì)數(shù)器可構(gòu)成1位十進(jìn)制計(jì)數(shù)器,而2位十進(jìn)制計(jì)數(shù)器連接起來可以構(gòu)成一
個(gè)六十進(jìn)制的計(jì)數(shù)器。六十進(jìn)制計(jì)數(shù)器常用于時(shí)鐘計(jì)數(shù)。一個(gè)六十進(jìn)制計(jì)數(shù)器的外部端口示意圖如圖6.1
所示。在該六十進(jìn)制計(jì)數(shù)器的電路中,BCDLWR和BCD10WR與DATAIN配合,以實(shí)現(xiàn)對(duì)六十進(jìn)制計(jì)數(shù)器的個(gè)
位和十位值的預(yù)置操作。應(yīng)注意,在對(duì)個(gè)位和十位進(jìn)行預(yù)置操作時(shí),DATAIN輸入端是公用的,因而個(gè)位和
十位的預(yù)置操作必定要串行進(jìn)行。利用VHDL語言描述六十進(jìn)制計(jì)數(shù)器的程序如例6.1所示。
圖6.1六十進(jìn)制計(jì)數(shù)器外部端口示意圖
【例6.1]用VHDL設(shè)計(jì)一個(gè)六十進(jìn)制計(jì)數(shù)器(方法1)。
—BCD60C0UNT.VHD
LIBRARYIEEE;
USEIEEE.STD_L0GIC_1164.ALL;
USEIEEE.STD_LOGIC_UNSIGNED.ALL;
ENTITYBCD60C0UNTIS
PORT(CLK,BCD1WR,BCD10WR,CIN:STD_LOGIC;
CO:OUTSTD_LOGIC;
DATAIN:INSTD_LOGIC_VECTOR(3DOWNTO0);
BCD1:OUTSTD_LOGIC_VECTOR(3DOWNTO0);
BCDIO:OUTSTD_LOGIC_VECTOR(2DOWNTO0));
ENDBCD60C0UNT;
ARCHITECTURERTLOFBCD60C0UNTIS
SIGNALBCD1N:STD_LOGIC_VECTOR(3DOWNTO0);
SIGNALBCD10N:STD_LOGIC_VECTOR(2DOWNTO0);
BEGIN
BCD1<=BCD1N;
BCDI0<=BCD10N;
PROCESS(CLK,BCD1WR)--個(gè)位數(shù)處理進(jìn)程
BEGIN
IF(BCD1WR=T')THEN
BCD1N<=DATAIN;
ELSIF(CLK,EVENTANDCLK='1')THEN
IF(CIN=f)THEN
IF(BCD1N=9)THEN
BCD1NU0000";
ELSE
BCD1N<=BCD1N+1;
ENDIF;
ENDIF;
ENDIF;
ENDPROCESS:
PROCESS(CLK,BCD1OWR)--十位數(shù)處理進(jìn)程
BEGIN
IF(BCD1OWR='1')THEN
BCD1ON<=DATAIN(2DOWNTO0);
ELSIF(CLK'EVENTANDCLK=T')THEN
IF(CIN=fANDBCD1N=9)THEN
IF(BCD10N=5)THEN
BCD1ON<=Z/OOO";
ELSE
BCD1ON<=BCD1ON+1;
ENDIF;
ENDIF;
ENDIF;
ENDPROCESS:
PROCESS(BCD1ON,BCD1N,CIN)--進(jìn)位位處理進(jìn)程
BEGIN
IF(CIN=TANDBCD1N=9ANDBCD10N=5)THEN
CO<=r;
ELSE
CO<=O';
ENDIF;
ENDPROCESS:
ENDRTL;
【例6.2】用VHDL設(shè)計(jì)一個(gè)六十進(jìn)制計(jì)數(shù)器(方法2)。
—C0UNTER60.vhd
LIBRARYIEEE;
USEIEEE.STD_LOGIC_1164.ALL;
USEIEEE.STD_LOGIC_ARITH.ALL;
USEIEEE.STD_LOGIC_UNSIGNED.ALL;
ENTITYC0UNTER60IS
PORT(CP:INSTD_LOGIC;一時(shí)鐘脈沖
BIN:OUTSTD_LOGIC_VECTOR(5DOWNTO0);一二進(jìn)制
S:INSTD_LOGIC;一輸出啟動(dòng)信號(hào)
CLR:INSTD_LOGIC;一清除信號(hào)
EC:INSTD_LOGIC:一使能計(jì)數(shù)信號(hào)
CY60:OUTSTD_LOGIC);一計(jì)數(shù)60進(jìn)位信號(hào)
ENDC0UNTER60;
ARCHITECTURERTLOFC0UNTER60IS
SIGNALQ:STD_LOGIC_VECTOR(5DOWNTO0);
SIGNALRST,DLY:STD_LOGIC;
BEGIN
PROCESS(CP,RST)—計(jì)數(shù)60
BEGIN
IFRST=T'THEN
Q<="000000”;一復(fù)位計(jì)數(shù)器
ELSIFCP*EVENTANDCP二T'THEN
DLY<=Q(5);
IFEC=T'THEN
Q<=Q+l;~計(jì)數(shù)值加1
ENDIF;
ENDIF;
ENDPROCESS;
CY60<=NOTQ(5)ANDDLY;—進(jìn)位信號(hào)微分
RST〈二T'WHENQ=60ORCLR=T'ELSE—復(fù)位信號(hào)設(shè)定
'O';
BIN<=QWHENS='1'ELSE"計(jì)數(shù)輸出
“000000〃;
ENDRTL;
2)可逆計(jì)數(shù)器
在時(shí)序應(yīng)用電路中,計(jì)數(shù)器的應(yīng)用十分普遍,如加法計(jì)數(shù)器,減法計(jì)數(shù)器,可逆計(jì)數(shù)器等。所謂可逆計(jì)數(shù)
器,就是根據(jù)計(jì)數(shù)控制信號(hào)的不同,在時(shí)鐘脈沖作用下,計(jì)數(shù)器可以進(jìn)行加1或者減1操作的一種計(jì)數(shù)器。
可逆計(jì)數(shù)器有一個(gè)特殊的控制端,這就是UPDN端。當(dāng)UPDN='1'時(shí),計(jì)數(shù)器進(jìn)行加1操作,當(dāng)UPDN='0'
時(shí),計(jì)數(shù)器就進(jìn)行減1操作。表6.1是一個(gè)3位可逆計(jì)數(shù)器的真值表,它的VHDL語言描述如例6.3所示。
表6.1可逆計(jì)數(shù)器真值表
輸入端輸出端
DIRCPQ2QIQ0
XX000
1計(jì)數(shù)器加1操作
0計(jì)數(shù)器減1操作
【例6.3]用VHDL設(shè)計(jì)一個(gè)3位二進(jìn)制的可逆計(jì)數(shù)器。
—C0UNT3.vhd
LIBRARYIEEE;
USEIEEE.STDLOGIC1164.ALL;
USEIEEE.STD_LOGIC_ARITH.ALL;
USEIEEE.STD_LOGIC_UNSIGNED.ALL;
ENTITYC0UNT3IS
PORT(CP,DIR:INSTD_LOGIC;
Q:OUTSTD_L0GIC_VECT0R(2DOWNTO0));
END;
ARCHITECTURERTLOFCOUNT3IS
SIGNALQN:STD_L0GIC_VECT0R(2DOWNTO0);
BEGIN
PROCESS(CP)
BEGIN
IFCP'EVENTANDCP:'TTHEN
IFDIR='O'THEN
QN<=QN+1;
ELSE
QN<=QN-1;
ENDIF;
ENDIF;
ENDPROCESS;
Q<=QN;
ENDRTL;
編寫可逆計(jì)數(shù)器VHDL程序時(shí),在語法上,就是把加法和減法計(jì)數(shù)器合并,使用一個(gè)控制信號(hào)決定計(jì)數(shù)器作
加法或減法的動(dòng)作。在本例中,利用“控制信號(hào)DIR”可以讓計(jì)數(shù)器的計(jì)數(shù)動(dòng)作加1或減1。
6.1.2異步計(jì)數(shù)器的設(shè)計(jì)
異步計(jì)數(shù)器又稱行波計(jì)數(shù)器,它將低/高位計(jì)數(shù)器的輸出做為高/低位計(jì)數(shù)器的時(shí)鐘信號(hào),這一級(jí)一級(jí)串行
連接起來就構(gòu)成了一個(gè)異步計(jì)數(shù)器。異步計(jì)數(shù)器與同步計(jì)數(shù)器不同之處就在于時(shí)鐘脈沖的提供方式,但是,
由于異步計(jì)數(shù)器采用行波計(jì)數(shù),從而使計(jì)數(shù)延遲增加,在要求延遲小的領(lǐng)域受到了很大限制。盡管如此,
由于它的電路簡(jiǎn)單,仍有廣泛的應(yīng)用。
圖6.2是用VHDL語言描述的一個(gè)由8個(gè)觸發(fā)器構(gòu)成的異步計(jì)數(shù)器.它的程序如例6.4所示,采用元件例化
方式生成。與上述同步計(jì)數(shù)器不同之處主要表現(xiàn)在對(duì)各級(jí)時(shí)鐘脈沖的描述上,這一點(diǎn)請(qǐng)讀者在閱讀程序時(shí)
多加注意。
圖6.28位異步計(jì)數(shù)器原理圖
【例6.4]用VHDL設(shè)計(jì)一個(gè)由8個(gè)觸發(fā)器構(gòu)成的8位二進(jìn)制異步計(jì)數(shù)器。
-RPLCONT.VHD
LIBRARYIEEE;
USEIEEE.STD_L0GIC_1164.ALL;
ENTITYDFFRIS
PORT(CLK,CLR,D:INSTD_LOGIC;
Q,QB:OUTSTD_LOGIC);
ENDENTITYDFFR;
ARCHITECTUREART1OFDFFRIS
SIGNALQ_IN:STD_LOGIC;
BEGIN
QB<=NOTQ_IN;
Q<=Q_IN;
PROCESS(CLK,CLR)IS
BEGIN
IF(CLR='1')THEN
Q_IN<=,0*;
ELSIF(CLK,EVENTANDCLK二T')THEN
Q_IN<=D;
ENDIF;
ENDPROCESS;
ENDARCHITECTUREART1;
LIBRARYIEEE;
USEIEEE.STD_L0GIC_1164.ALL;
ENTITYRPLCONTIS
PORT(CLK,CLR:INSTD_LOGIC;
COUNT:OUTSTD_LOGIC_VECTOR(7DOWNTO0));
ENDENTITYRPLCONT;
ARCHITECTUREART2OFRPLCONTIS
SIGNALCOUNT_IN_BAR:STD_LOGIC_VECTOR(8DOWNTO0);
COMPONENTDFFRIS
PORT(CLK,CLR,D:INSTD_LOGIC;
Q,QB:OUTSTD_LOGIC);
ENDCOMPONENT;
BEGIN
COUNT_IN_BAR(O)<=CLK;
GEN1:FORIIN0TO7GENERATE
U:DFFRPORTMAP(CLK=>COUNT_IN_BAR(I),CLR=>CLR,
D二)COUNT」N_BAR(1+1),Q=>COUNT(I),QB=>COUNT_IN_BAR(1+1));
ENDGENERATE;
ENDARCHITECTUREART2;
6.2分頻器的設(shè)計(jì)
一般來說,可以把加法計(jì)數(shù)器看成一種分頻電路,而且是除2的N的次方的分頻電路。
但是也常常會(huì)有除M(M不是2的N次方)的分頻電路需求.
下面就介紹一個(gè)除6的加法分頻電路。先建立一個(gè)計(jì)數(shù)器,而這個(gè)計(jì)數(shù)器的大小必須是3位(計(jì)數(shù)默認(rèn)范圍
是0?2R-1:7),不過將把這樣的計(jì)數(shù)值為6的瞬間,立即復(fù)位改變?yōu)?,其丫皿1程序如例6.5所示
【例6.5】用VHDL設(shè)計(jì)一個(gè)除6的加法分頻電路。
—C0UNT6.vhd
LIBRARYIEEE;
USEIEEE.STD_L0GIC_1164.ALL;
USEIEEE.STD_LOGIC_ARITILALL;
USEIEEE.STDLOGICUNSIGNED.ALL;
ENTITYC0UNT6is
PORT(CP:INSTD_LOGIC;
Result:OUTSTD_LOGIC);
ENDC0UNT6;
ARCHITECTUREaOFC0UNT6IS
SIGNALRST:STD_LOGIC;
SIGNALQN:STD_LOGIC_VECTOR(2DOWNTO0);
BEGIN
PROCESS(CP,RST)—***COUNTER
BEGIN
IFRST='1'THEN
QN<="000〃;一ResetCounter
ELSIFCP*eventANDCP='1'THEN
QN<=QN+1;—COUNTER+1
ENDIF;
ENDPROCESS;
RST<=T'WHENQN=6ELSE—RESETCOUNTER
'O';
Result<=QN(2);-ResultOutput
ENDa;
以后遇到需要分頻是N的同步計(jì)數(shù)器,需將上述QN=6改成QN=N,而且計(jì)數(shù)器Xbits數(shù)需調(diào)整為符合條件
2X〉二N才可以。
6.3選擇器的設(shè)計(jì)
多路選擇器可以從多組數(shù)據(jù)來源中選取一組送入目的地。它的應(yīng)用范圍相當(dāng)廣泛,從組合邏輯的執(zhí)行,到
數(shù)據(jù)路徑的選擇,經(jīng)常可以看到它的蹤影。另外在像時(shí)鐘,計(jì)數(shù)定時(shí)器等的輸出顯示電路中都可以看到利
用多路選擇器制作掃描電路來分別驅(qū)動(dòng)輸出裝置(通常為七段數(shù)碼顯示管,點(diǎn)矩陣或液晶面板),以降低功率
的消耗。有時(shí)也希望把兩組沒有必要同時(shí)觀察的數(shù)據(jù),共享一組顯示電路,以降低成本。
多路選擇器的結(jié)構(gòu)是2N個(gè)輸入線,會(huì)有N個(gè)地址選擇線及一個(gè)輸出線配合?,F(xiàn)以一個(gè)四選一的多路選擇器
為例,其四選一電路的真值表如表6.2所示,其外部端口示意圖如圖6.3所示。
表6.2四選一電路真值表
選擇輸入數(shù)據(jù)輸入數(shù)據(jù)輸出
baInput(0)Input(1)Input(2)Input(3)y
000XXX0
001XXX1
01X0XX0
01X1XX1
10XX0X0
10XX1X1
11XXX00
11XXX11
圖6.3四選一電路外部端口示意圖
描述四選一多路選擇器的方法有多種,例如在一個(gè)進(jìn)程中使用if-then-else語句;在一個(gè)進(jìn)程中使用case
語句;使用wilhselect構(gòu)造或使用結(jié)構(gòu)VHDL?,F(xiàn)用ifThen-else語句對(duì)它進(jìn)行描述,就可以得到如例
6.6所示的程序。
【例6.6】設(shè)計(jì)一個(gè)四選一的多路選擇器的VHDL程序(使用if-lhen-else語句)。
—MUX4.VHD
LIBRARYIEEE;
USEIEEE.STD_L0GIC_1164.ALL;
ENTITYMUX4IS
PORT(DATAO,DATA1,DATA2,DATA3:INSTD_LOGIC_VECTOR(3DOWNTO0);
A,B:INSTD_LOGIC;
Y:OUTSTD_L0GIC_VECT0R(3DOWNTO0));
ENDENTITYMUX4;
ARCHITECTUREARTOFMUX4IS
SIGNALSEL:STD_LOGIC_VECTOR(1DOWNTO0);
BEGIN
SELCB&A;
PROCESS(SEL)
BEGIN
IF(SEL=〃OO〃)THEN
Y<=DATAO;
ELSIF6EL="01")THEN
Y<=DATA1;
ELSIF(SEL="10")THEN
Y<=DATA2;
ELSE
Y<=DATA3;
ENDIF;
ENDPROCESS;
ARCHITECTUREART;
例6.6中的四選一選擇器是用IF語句描述的,程序中的ELSE項(xiàng)作為余下的條件,將選擇INPUT(3)從Y
端輸出,這種描述比較安全。當(dāng)然,不用ELSE項(xiàng)也可以,這時(shí)必須列出SEL的所有可能出現(xiàn)的情況,加以
一一確認(rèn)。在進(jìn)程中使用CASE語句會(huì)更清晰易讀。例6.7是用CASE語句描述的四選一選擇器。
【例6.7】設(shè)計(jì)一個(gè)四選一的多路選擇器的VHDL程序(使用case語句)。
—MUX4.VHD
LIBRARYIEEE;
USEIEEE.STD_LOGIC」164.ALL;
ENTITYMUX4IS
PORT(DATAO,DATA1,DATA2,DATA3:INSTD_LOGIC_VECTOR(3DOWNTO0);
A,B:INSTD_LOGIC;
Y:OUTSTD_L0GIC_VECT0R(3DOWNTO0));
ENDENTITYMUX4;
ARCHITECTUREARTOFMUX4IS
SIGNALSEL:STD_LOGIC_VECTOR(1DOWNTO0);
BEGIN
SELCB&A;
PROCESS(SEL)
BEGIN
CASESELIS
WHEN〃00"=>Y〈=DATA0;
WHEN,,0r=>Y<=DATAl;
WHEN,,10,=>Y<=DATA2;
WHEN,/ir=>Y<=DATA3;
WHENOTHERS=>Y<=NULL;
ENDCASE;
ENDPROCESS;
ENDARCHITECTUREART;
【例6.8】設(shè)計(jì)一個(gè)四選一的多路選擇器的VHDL程序(使用WHEN-ELSE并行條件賦值語句)。
—MUX4.VHD
LIBRARYIEEE;
USEIEEE.STD_LOGIC_1164.ALL;
ENTITYMUX4IS
PORT(DATAO,DATA1,DATA2,DATA3:INSTD_LOGIC_VECTOR(3DOWNTO0);
A,B:INSTD_LOGIC;
Y:OUTSTD_L0GIC_VECT0R(3DOWNTO0));
ENDENTITYMUX4;
ARCHITECTUREARTOFMUX4IS
SIGNALSEL:STDLOGICVECTOR(1DOWNTO0);
BEGIN
SELCB&A;
Y<=DATAOWHENSEL=〃00〃ELSE
DATA1WHENSEL=〃01〃ELSE
DATA2WHENSEL="10"ELSE
DATA3WHENSEL=ELSE
'O';
ENDARCHITECTUREART;
6.4譯碼器的設(shè)計(jì)
譯碼器是把輸入的數(shù)碼解出其對(duì)應(yīng)的數(shù)碼,如果有N個(gè)二進(jìn)制選擇線,則最多可以譯碼轉(zhuǎn)換成2N個(gè)數(shù)據(jù)。
譯碼器也經(jīng)常被應(yīng)用在地址總線或用作電路的控制線。像只讀存儲(chǔ)器(ROM)中便利用譯碼器來進(jìn)行地址選
址的工作。
3-8譯碼器是最常用的種小規(guī)模集成電路。3-8譯碼器外部端口示意圖如圖6.9所示,它有3個(gè)二進(jìn)制輸入
端a,b,c和8個(gè)譯碼輸出端yO~y7。對(duì)輸入a,b,c的值進(jìn)行譯碼,就可以確定輸出端yO~y7的哪一個(gè)輸出
端變?yōu)橛行Вǖ碗娖剑?,從而達(dá)到譯碼的目的。另外為方便譯碼器的控制或便于將來擴(kuò)充用,在設(shè)計(jì)時(shí)常
常會(huì)增加一個(gè)EN使能輸入腳。3-8譯碼器的真值表如表6.3所示。有了真值表,就可以直接用查表法來設(shè)
計(jì)。
在VHDL中,“WITH…SELECT,“CASE…WHEN”及“WHEN…ELSE”這類指令都是執(zhí)行查表或?qū)?yīng)動(dòng)作的
能手。
圖6.43-8譯碼器外部端口示意圖
表6.33-8譯碼器的真值表
使能二進(jìn)制輸入端譯碼輸出端
encbayOyly2y3y4y5y6y7
0xxx1111111
100001111111
100110111111
101011011111
101111101111
10011110111
110111111011
111011111101
11111111110
【例6.9]用VHDL設(shè)計(jì)一個(gè)3-8譯碼器(用“CASE…'”語句)。
—DEC0DER38.VHD
LIBRARYIEEE;
USEIEEE.STD_L0GIC_1164.ALL;
ENTITYDEC0DER38IS
PORT(A,B,C,EN:INSTD_LOGIC;
Y:OUTSTDLOGICVECTOR(7DOWNTO0));
ENDDEC0DER38;
ARCHITECTURERTLOFDECODER38IS
SIGNALINDATA:STD_L0GIC_VECT0R(2DOWNTO0);
BEGIN
INDATA〈=C&B&A;
PROCESS(INDATA,EN)
BEGIN
IF(EN=T)THEN
CASEINDATAIS
WHEN"000〃
WHEN"001〃
WHEN"010〃=>Y<=〃11111011”;
WHEN〃011〃=>Y<="111101ir;
WHEN"100〃=>Y<=/z111011irz;
WHEN"101〃=>Y<=〃11011111”;
WHEN〃110"=>Y<=z,101111ir;
WHEN〃111〃
WHENOTHERS=>Y<=NULL;
ENDCASE;
ELSE
¥<=/zllllllir;
ENDIF;
ENDPROCESS;
ENDRTL;
【例6.10]用VHDL設(shè)計(jì)一個(gè)3-8譯碼器(用“WITH…SELECT”語句)。
LIBRARYIEEE;
USEIEEE.STD_LOGIC」164.All;
ENTITYDECODER38IS
PORT(A,B,C,EN:INSTD_LOGIC;
Y:OUTSTD_L0GIC_VECT0R(7DOWNTO0));
ENDDEC0DER38;
ARCHITECTURERTLOFDEC0DER38IS
SIGNALINDATA:STD_L0GIC_VECT0R(3DOWNTO0);
BEGIN
INDATA<=EN&C&B&A;一將EN,A,B,C合并成序列的一種寫法
WITHINDATASELECT
¥<="11111110"WHEN〃1000〃,
"minorWHEN"1001”,
"liiiioirWHEN"1010”,
"llllOlll"WHEN"1011”,
T1101111"WHEN"1100”,
"11011111"WHEN"1101”,
"10111111"WHEN"1110”,
01111111〃WHEN
“11111111〃WHENOTHERS;
ENDRTL;
在本節(jié)中用到的兩種描述語句,“WITH…SELECT'是并行同時(shí)性語句,“CASE…WHEN”是與其功能相同的
順序性語句,讀者在使用時(shí)一定要確定需要的是順序性語句還是并行性語句,否則程序在編譯時(shí)會(huì)發(fā)生錯(cuò)
誤。
6.5編碼器的設(shè)計(jì)
編碼器是將2飛個(gè)分離的信息代碼以N個(gè)二進(jìn)制碼來表示。它的功能和譯碼器正好相反。編碼器常常運(yùn)用
于影音壓縮或通信方面,以達(dá)到精簡(jiǎn)傳輸量的目的??梢詫⒕幋a器看成壓縮電路,譯碼起看成解壓縮電路。
傳送數(shù)據(jù)前先用編碼器壓縮數(shù)據(jù)后在傳送出去,在接收端則由譯碼器將數(shù)據(jù)解壓縮,還原其原來的數(shù)據(jù)。
這樣,在傳送過程中,就可以以N個(gè)數(shù)碼來代替2飛個(gè)數(shù)碼的數(shù)據(jù)量,來提升傳輸效率。
6.5.1一般編碼器的設(shè)計(jì)
如果沒有特別說明,各編碼輸入端無優(yōu)先
區(qū)別。圖6.5是8-3編碼器的外部端口圖,
有了外部端口圖,就能夠做ENTITY的定義,
再根據(jù)編碼器的真值表如表6.4所示.,再使用
查表法就可以輕松描述結(jié)構(gòu)體了。
圖6.58-3編碼器外部端口圖
表6.48-3編碼器的真值表
輸入二進(jìn)制編碼輸出
A7A6A5A4A3A2AlAOY2Y1Y0
11111110111
1111110110
11111011101
11110111100
11101111011
1101111100
10111111001
0111111000
【例6.11】用VHDL設(shè)計(jì)一個(gè)8-3編碼器。
—CH_8_3.VHD
LIBRARYIEEE;
USEIEEE.STD_LOGIC_1164.ALL;
ENTITYCH_8_3IS
PORT(A:INSTD_L0GIC_VECT0R(7DOWNTO0);
Y:OUTSTD_L0GIC_VECT0R(2DOWNTO0));
ENDCH_8_3;
ARCHITECTURERTLOFCH_8_3IS
BEGIN
WITHASELECT
Y〈二”000〃WHEN”11111110”,
“001〃WHEN"minor,
”010〃WHEN"iimoir,
“011〃WHEN“11110111”,
〃100〃WHEN"11101111",
,ziorWHEN"iioimr;
“110〃WHEN"loiimr,
WHEN"omiiir,
〃000”WHENOTHERS;
ENDRTL;
6.5.2優(yōu)先級(jí)編碼器的設(shè)計(jì)
優(yōu)先級(jí)編碼器長(zhǎng)用于中斷的優(yōu)先級(jí)控制,例如,74LS148是一個(gè)8輸入,3位二進(jìn)制碼輸出的優(yōu)先級(jí)編碼器。
當(dāng)其某一個(gè)輸入有效時(shí),就可以輸出一個(gè)對(duì)應(yīng)的3位二進(jìn)制編碼。另外,當(dāng)同時(shí)有幾個(gè)輸入有效時(shí),將輸
優(yōu)先級(jí)最高的那個(gè)輸入所對(duì)應(yīng)的二進(jìn)制編碼。
該優(yōu)先級(jí)編碼器的真值表如表6.5所示。表中的“X”項(xiàng)表示任意項(xiàng),它可以是“0”,也可以是“1”。
INPUT(0)的優(yōu)先級(jí)最高,INPUT(7)的優(yōu)先級(jí)最低。
表6.5優(yōu)先級(jí)編碼器真值表
輸入二進(jìn)制編碼輸出
Input(7)Input(6)Input(5)Input(4)Input(3)Input(2)Input(1)Input(0)Y2Y1Y0
XXXXXXX0111
XXXXXX01110
XXXXX011101
XXXX0111100
XXX01111011
01111100
X0111111001
X111111000
【例6.12]用VHDL設(shè)計(jì)一個(gè)8-3優(yōu)先級(jí)編碼器。
—CH8_3.VHD
LIBRARYIEEE;
USEIEEE.STD_LOGIC_1164.ALL;
ENTITYCH8_3IS
PORT(INPUT:INSTD_L0GIC_VECT0R(7DOWNTO0);
Y:OUTSTD_L0GIC_VECT0R(2DOWNTO0));
ENDCH8_3;
ARCHITECTURERTLOFCH8.3IS
BEGIN
PROCESS(INPUT)
BEGIN
IF(INPUT(0)='O')THEN
Y<=,znr;
ELSIF(INPUT(1)='O'THEN
Y<=〃110”;
ELSIF(INPUT(2)=0*THEN
YU101〃;
ELSIF(INPUT(3)='O'THEN
YU'IOO";
ELSIF(INPUT(4)='O'THEN
Y<=/Zoir;
ELSIF(INPUT(5)=,0,THEN
Y<=〃010〃;
ELSIF(INPUT(6)=0,THEN
y<=z/oor;
ELSIF
YU'OOO";
ENDIF;
ENDPROCESS;
ENDRTL;
6.6寄存器的設(shè)計(jì)
寄存(鎖存)器是一種重要的數(shù)字電路部件,常用來暫時(shí)存放指令、參與運(yùn)算的數(shù)據(jù)或運(yùn)算結(jié)果等。它是數(shù)
字測(cè)量和數(shù)字控制中常用的部件,是計(jì)算機(jī)的主要部件之一。寄存器的主要組成部分是具有記憶功能的雙
穩(wěn)態(tài)觸發(fā)器。一個(gè)觸發(fā)器可以儲(chǔ)存一位二進(jìn)制代碼,要儲(chǔ)存N位二進(jìn)制代碼,就在有N個(gè)觸發(fā)器。寄存器
從功能上說,通??煞譃閿?shù)碼寄存器和移位寄存器兩種。
6.6.1數(shù)碼寄存器的設(shè)計(jì)
數(shù)碼寄存器用于寄存一組二進(jìn)制代碼,廣泛用于各類數(shù)字系統(tǒng)。下面給出一個(gè)8位寄存器的VHDL描述。
【例6.13】用VHDL設(shè)計(jì)一個(gè)8位的數(shù)碼寄存器。
—REG.VHD
LIBRARYIEEE;
USEIEEE.STD_L0GIC_1164.ALL;
ENTITYREGIS
PORT(D:INSTD_LOGIC_VECTOR(7TO0);
CLK:INSTD_LOGIC;
Q:OUTSTD_L0GIC_VECT0R(7TO0));
ENDENTITYREG;
ARCHITECTUREARTOFREGIS
BEGIN
PROCESS(CLK)IS
BEGIN
IF(CLK*EVENTANDCLK=T')THEN
Q<=D;
ENDIF;
ENDPROCESS;
ENDARCHITECTUREART;
6.6.2移位寄存器的設(shè)計(jì)
移位寄存器除了具有存儲(chǔ)代碼的功能以外,還具有移位功能。所謂移位功能,是指寄存器里存儲(chǔ)的代碼能
在移位脈沖的作用下依次左移或右移。因此,移位寄存器不但可以用來寄存代碼,還可用來實(shí)現(xiàn)數(shù)據(jù)的串
并轉(zhuǎn)換、數(shù)值的運(yùn)算以及數(shù)據(jù)處理等。下面給出一個(gè)8位的移位寄存器,其具有左移一位或右移一位、并
行輸入和同步復(fù)位的功能。
【例6.14】用VHDL設(shè)計(jì)一個(gè)8位的移位寄存器,其具有左移一位或右移一位、并行輸入和同步復(fù)位的功
能.
—SHIFT_REG.VHD
LIBRARYIEEE;
USEIEEE.STD_L0GIC_1164.ALL;
ENTITYSHIFT_REGIS
PORT(DATA:INSTD_LOGIC_VECTOR(7DOWNTO0);
CLK:INSTD_LOGIC;
SHIFT_LEFT,SHIFT_RIGHT:INSTD_LOGIC;
RESET:INSTD_LOGIC;
MODE:INSTD_LOGIC_VECTOR(1DOWNTO0);
QOUT:BUFFERSTD_L0GIC_VECT0R(7DOWNTO0));
ENDENTITYSHIFT_REG;
ARCHITECTUREARTOFSHIFT_REGIS
BEGIN
PROCESSIS
BEGIN
WAITUNTIL(RISING_EDGE(CLK));
IF(RESET='1')THEN
Q0UT<="00000000\
ELSE一同步復(fù)位功能的實(shí)現(xiàn)
CASEMODEIS
WHEN//O1Z'=>QOUT<=SHIFT_RIGHT&QOIIT(7DOWTO1);一右移一位
WHEN"10"=〉Q0UT〈=Q0UT(6DOWNTOO)&SHIFT_LEFT;一左移一位
WHEN<,ir=>QOUT<=DATA;一并行輸入
WHENOTHERS=>NULL;
ENDCASE;
ENDIF;
ENDPROCESS;
ENDARCHITECTUREART;
6.6.3并行加載移位寄存器的設(shè)計(jì)
在TTL手冊(cè)中的74LS166是一個(gè)帶清零端的8位并行加載的移位寄存器,其引腳圖及邏輯圖如圖6.6所示。
圖6.674LS166的引腳圖及邏輯圖
圖中各引腳名稱和功能如下:
A,B,C,D,E,F,G,II:8位并行數(shù)據(jù)輸入端;
SER:串行數(shù)據(jù)輸入端;
QH:串行數(shù)據(jù)輸出端;
CLK:時(shí)鐘信號(hào)輸入端;
CLKINH:時(shí)鐘信號(hào)禁止(FE)端:
SH/LD:移位加載控制(SL)端;
CLR:清零端。
當(dāng)清零輸入端CLR為‘0'時(shí),8個(gè)觸發(fā)器的輸出均為'0',從而使輸出Q為‘0'。CLKINH是時(shí)鐘禁止端,
當(dāng)它為‘1'時(shí)將禁止時(shí)鐘,即不管時(shí)鐘信號(hào)如何變化,移位寄存器的狀態(tài)不發(fā)生改變。另外,時(shí)鐘信號(hào)只
在上升沿時(shí)才有效,且CLKINH為‘0'。當(dāng)控制端SH/LD='1'時(shí)是移位狀態(tài),在時(shí)鐘脈沖上升沿的控制
下右移,當(dāng)SH/LD='0'時(shí)是加載狀態(tài),在時(shí)鐘脈沖上升沿的作用下,數(shù)據(jù)輸入端A?H的信號(hào)就是裝載
到移位寄存器的QA?QH。根據(jù)上述描述,就可以用VHDL語言編寫出描述74166功能的程序。
【例6.15】用VHDL設(shè)計(jì)的帶清零端的8位并行加載的移位寄存器74LS166.
一SREG8PARLWCLR.VHD
LIBRARYIEEE;
USEIEEE.STD_LOGIC_1164.ALL;
ENTITYSREG8PARLWCLRIS
PORT(CLR,SL,FE,CLK,SER:INSTD_LOGIC;
A,B,C,D,E,F,G,H:INSTD_LOGIC;
Q:OUTSTD_LOGIC);
ENDSREG8PARLWCLR;
ARCHITECTUREBEHAVOFSREG8PARLWCLRIS
SIGNALTMPREG8:STD_LOGIC_VECTOR(7DOWNTO0);
BEGIN
PROCESS(CLK,SL,FE,CLR)
IF(CLR='O')THEN
TMPREG8<="00000000”:
Q<=TMPREG8(7);
ELSIF(CLK'EVENT)AND(CLK='1')AND(FE='O')THEN
IF(SL='O')THEN
TMPREG8(0)<=A;
TMPREG8(1)<=B;
TMPREG8(2)<=C;
TMPREG8(3)<=D;
TMPREG8(4)<=E;
TMPREG8(5)<=F;
TMPREG8(6)<=G;
TMPREG8(7)<=H;
Q<=TMPREG8(7);
ELSIF(SL=)THEN
FORIINTMPREG8,HIGHDOWNTOTMPREG8'LOW+1LOOP
TMPREG8(I)<=TMPREG8(I-1);
ENDLOOP;
TMPREG8(TMPREG8'LOW)<=SE;
Q<=TMPREG8(7);
ENDIF;
ENDIF;
ENDPROCESS;
ENDBEHAV;
6.7存儲(chǔ)器的設(shè)計(jì)
半導(dǎo)體存儲(chǔ)器的種類很多,從功能上可以分為只讀存儲(chǔ)器(READONLYMEMORY,簡(jiǎn)稱ROM)和隨機(jī)存儲(chǔ)器
(RANDOMACCESSMEMORY,簡(jiǎn)稱RAM)兩大類。
6.7.1只讀存儲(chǔ)器ROM的設(shè)計(jì)
只讀存儲(chǔ)器在正常工作時(shí)從中讀取數(shù)據(jù),不能快速地修改或重新寫入數(shù),適用于存儲(chǔ)固定數(shù)據(jù)的場(chǎng)合。下
面是一個(gè)容量為256X4的ROM存儲(chǔ)的例子,該ROM有8位地址線ADR(0)-ADR(7),4位數(shù)據(jù)輸出線DOUT(0)?
D0UT(3)及使能EN,如圖6.7所示。
圖6.7ROM
【例6.16】用VHDL設(shè)計(jì)一個(gè)一個(gè)容量為256X4的ROM存儲(chǔ)的例子,該ROM有8位地址線ADR(O)-ADR(7),
4位數(shù)據(jù)輸出線DOUT(0)?DOUT(3)及使能EN。
—ROM.VHD
LIBRARYIEEE;
USEIEEE.STD_LOGIC_1164.ALL:
USEIEEE.STDJOGICJJNSIGNED.ALL;
USESTD.TEXTIO.ALL;
ENTITYROMIS
PORT(EN:INSTD_LOGIC;
ADR:INSTD_L0GIC_VECT0R(7DOWNTO0);
DOUT:OUTSTD_L0GIC_VECT0R(3DOTOTO0));
ENDENTITYROM;
ARCHITECTUREARTOFROMIS
SUBTYPEWORDISSTD_L0GICJ,ECT0R(3DOWNTO0);
TYPEMEMORYISARRAY(0TO255)OFWORD;
SIGNALADRIN:INTEGERRANGE0TO255:
VARIABLEROM:MEMORY;
VARIABLESTARTUP:BOOLEAN:=TRUE;
VARIABLEL:LINE;
VARIABLEJ:INTEGER;
FILEROMIN:TEXTISIN“ROMIN”:
BEGIN
PROCESS(EN,ADR)IS
BEGIN
IFSTART_UPTHEN-初始化開始
FORJINROM'RANGELOOP
READLINE(ROMIN,1);
READ(1,ROM(J));
ENDLOOP;
STARTUP::FALSE:一初始化結(jié)束
ENDIF;
ADR」N<=CONV」NTEGER(ADR);一將向量轉(zhuǎn)化成整數(shù)
IF(EN=T)THEN
DOUT<=ROM(ADR_IN);
ELSE
DOUT<="ZZZZ”;
ENDIF;
ENDPROCESS;
ENDARCHITECTUREART;
6.7.2讀寫存儲(chǔ)器SRAM的設(shè)計(jì)
RAM和ROM的主要區(qū)別在于RAM描述上有讀和寫兩種操作,而且在讀寫上對(duì)時(shí)間有較嚴(yán)格的要求。下面我
們給出一個(gè)8X8位的雙口SRAM的VHDL描述實(shí)例,如圖6.8所示。
圖6.8雙口SRAM
【例6.17]用VHDL設(shè)計(jì)一個(gè)8X8位的雙口SRAM。
—DPRAM.VHD
LIBRARYIEEE;
USEIEEE.STD_LOGIC_1164.ALL;
USEIEEE.STD_LOGIC_ARITH.ALL;
USEIEEE.STD_LOGIC_UNSIGNED.ALL;
ENTITYDPRAMIS
GENERIC(WIDTH:INTEGER:=8;
DEPTH:INTEGER:=8;
ADDER:INTEGER:=3);
PORT(DATAIN:INSTD_LOGIC_VECTOR(WIDTH-1DOWNTO0);
DATAOUT:OUTSTD_LOGIC_VECTOR(WIDTH-1DOWNTO0);
CLOCK:INSTD_LOGIC;
WE,RE:INSTD_LOGIC;
WADD:INSTD_LOGIC_VECTOR(ADDER-1DOWNTO0);
RADD:INSTDLOGICVECTOR(ADDER-1DOWNTO0));
ENDENTITYDPRAM;
ARCHITECTUREARTOFDPRAMIS
TYPEMEMISARRAY(DEPTH-1TO0)OF
STD_LOGIC_VECTOR(WIDTH-1DOWNTO0);
SIGNALRAMTMP:MEM:
BEGIN
一寫進(jìn)程
PROCESS(CLOCK)IS
BEGIN
IF(CLOCK'EVENTANDCLOCK=T)THEN
IF(WE=DTHEN
RAMTMP(CONV_INTEGER(WADD))<=DATAIN;
ENDIF;
ENDIF;
ENDPROCESS;
一讀進(jìn)程
PROCESS(CLOCK)IS
BEGIN
IF(CLOCK'EVENTANDCLOCK?1')THEN
IF(RE="I')THEN
DATAOUT<=RAMTMP(CONV_INTEGER(RADD));
ENDIF;
ENDIF;
ENDPROCESS;
ENDARCHITECTUREART;
6.8輸入電路的設(shè)計(jì)
6.8.1鍵盤掃描電路的設(shè)計(jì)
計(jì)算機(jī)控制系統(tǒng)中,數(shù)據(jù)和控制信號(hào)的輸入主要使用鍵盤。下面給出一個(gè)鍵盤掃描電路VHDL描述。
【例6.18]用VHDL設(shè)計(jì)一個(gè)鍵盤掃描電路。
—KSCAN.VHD
LIBRARYIEEE;
USEIEEE.STD_LOGIC_1164.ALL;
USEIEEE.STD_LOGIC_UNSIGNED.ALL;
USEIEEE.STD_LOGIC_ARITH.ALL:
ENTITYKSCANIS
PORT(CLK:INSTD_LOGIC;
KIN1,KIN2:INSTD_LOGIC;
LEDA,LEDB,LEDC:OUTSTD_LOGIC;
LEDD:OUTSTD_LOGIC_VECTOR(7DOWNTO0));
ENDKSCAN;
ARCHITECTUREHAVOFKSCANIS
SIGNALSEG:STD_LOGIC_VECTOR(7DOWNTO0);
SIGNALSEL:STD_L0GIC_VECT0R(2DOWNTO0);
SIGNALKNUM:STDLOGICVECTOR(3DOWNTO0):
SIGNALCOUNT:STD_L0GIC_VECT0R(4DOWNTO0);
SIGNALCOUNTO:STD_LOGIC;
BEGIN
LEDD<=SEG;
PROCESS(CLK)
BEGIN
IFCLK'EVENTANDCLK='1'THEN
COUNT<=COUNT+1;
ENDIF;
ENDPROCESS;
COUNTO<=COUNT(0):
PROCESS(COUNTO,COUNT,KIN1,KIN2)
BEGIN
IFCOUNT。'EVENTANDCOUNTO:PTHEN
IF(KIN2='O')ANDCOUNT(1)='O'THEN
KNUM<=T&COUNT(4DOWNTO2);
ELSIF(KIN1='O')ANDCOUNT(1)='O'THEN
KNUM<='O'&COUNT(4DOWNTO2);
ENDIF;
ENDIF;
ENDPROCESS;
SEL<=COUNT(4DOWNTO2):
PROCESS(KNUM)
BEGIN
CASEKNUMIS
WHEN“0000”=>SEG<="00111111”
WHEN“0001”=>SEG<="00000110”
WHEN“0010”=>SEG<="01011011”
WHEN“0011”=>SEG<="01001111”
WHEN“0100”=>SEG<="01100110”
WHEN“0101”=>SEG<="01101101”
WHEN“0110”=>SEG<="01111101”
WHEN“0111”=>SEG<="00000111”
WHEN“1000”=>SEG<="01111111”
WHEN“1001”=>SEG<="01101111”
WHEN“1010”=>SEG<="01110111”
WHEN“1011”=>SEG<="01111100"
WHEN“1100”=>SEG<="00111001”
WHEN=>SEG<="01011110”
WHEN“1110”=>SEG<="01111001”
WHEN“1111”=>SEG<="01110001”
WHENOTHERS=>SEG<="OOOOOOOO”;
ENDCASE;
ENDPROCESS;
LEDA〈二SEL(O);
LEDB<=SEL(1);
LEDC<=SEL(2);
ENDHAV;
6.8.2鍵盤接口電路的設(shè)計(jì)
PS/2鍵盤接口通常使用專用芯片實(shí)現(xiàn)。由于PS/2鍵盤或鼠標(biāo)串行輸出信號(hào)速度較高,普通單片機(jī)無法
接收,現(xiàn)利用VHDL在目標(biāo)器件FPGA/CPLD上實(shí)現(xiàn)一個(gè)鍵碼接收部分。PS/2接口的鍵盤每按下一個(gè)鍵,
該鍵的掃描碼即以十六進(jìn)制形式顯示在數(shù)碼管上。以下為接收PS/2鍵盤信號(hào)的VHDL邏輯描述。
【例6.20]用VI1DL設(shè)計(jì)一個(gè)接收PS/2鍵盤信號(hào)的接口電路。
—KB2PCL.VHD
LIBRARYIEEE;
USEIEEE.STD_LOG1C_1164.ALL;
ENTITYKB2PCLIS
PORT(SYSCLK:INSTD_LOGIC;RESET:INSTD_LOGIC;
KBCLK:INSTD_LOGIC;KBDATA:INSTD_LOGIC;
PDATA:OUTSTD_LOGIC_VECTOR(7DOWNTO0);
PARITY:OUTSTD_LOGIC;DTOE:BUFFERSTD_LOGIC);
ENDKB2PC1;
ARCHITECTUREONEOFKB2PC1IS
SIGNALCOSTATE:STD_LOGIC,VECTOR(1DOWNTO0);
SIGNALSPDATA:STD_LOGIC_VECTOR(8DOWNTO0);
SIGNALSTART,SWT002,RECVEN:STDLOGIC;
SIGNALCNT8:INTEGERRANGE0TO15;
BEGIN
SLRL:PROCESS(RESET,KBCLK,KBDATA,STAFF,COSTATE)
BEGIN
IFRESET='1'THEN
START<='O';
ELSIFKBCLK,EVENTANDKBCLK='O'THEN
IFCOSTATE="00"ANDKBDATA='O'THEN
STAFF<=T';
ENDIF;
ENDIF;
ENDPROCESS;
STR2:PROCESS(RESET,KBCLK,KBDATA,STAFF,COSTATE)
BEGIN
IFRESET=THEN
SWT002<='O';
ELSIFKBCLK'EVENTANDKBCLK=THEN
IFCOSTATE="00"ANDSTART='1'ANDKBDATA='O'THEN
SWT002O’1’;
ENDIF;
ENDIF;
ENDPROCESS;
CHSTATE:PROCESS(RESET,SYSCLK,COSTATE,SWTOO2)
BEGIN
IFRESET=T'THEN
COSTATE<=“00”;
ELSIFSYSCLK,EVENTANDSYSCLK:THEN
IFSWT002='1'THEN
COSTATE<="01”;
ELSIFCNT8=9THEN
COSTATE<=“10”;
ENDIF;
ENDIF;
ENDPROCESS;
RECV:PROCESS(RESET,KBCLK,KBDATA,COSTATE)
BEGIN
IFRESET='THEN
CNT8<=0:SPDATA<="000000000”;
ELSIFKBCLK,EVENTANDKBCLK='O'THEN
IFCOSTATE="01”THEN
IFCNT8/=9THEN
SPDATA(7DOWNTO0)<=SPDATA(8D0WT01);
SPDATA(8)<=KBDATA:
CNT8<=CNT8+1:
ENDIF;
ENDIF;
ENDIF;
ENDPROCESS;
RECVEND:PROCESS(RESET,KBCLK,RECVEN,COSTATE)
BEGIN
IFRESET二T'THEN
DTOE<='O';
ELSIFKBCLK,EVENTANDKBCLK='1'THEN
IFCNT8=9ANDCOSTATE="01”THEN
DTOE<=4";ENDIF;
ENDIF;
ENDPROCESS;
PARITY<=SPDATA(8);PDATA<=SPDATA(7DOWNTO0);
ENDONE;
6.9顯示電路的設(shè)計(jì)
常用的顯示器件有發(fā)光二極管,數(shù)碼管,液晶顯示器等,其中最常用的為數(shù)碼管。數(shù)碼管顯示數(shù)據(jù)的方式
有靜態(tài)顯示和動(dòng)態(tài)顯示之分。所謂靜態(tài)顯示,就是將被顯示的數(shù)據(jù)的BCD碼,通過各自的4-7/8顯示譯碼
器譯碼后,分別接到顯示譯碼器的顯示驅(qū)動(dòng)段a-g(p),而公共端COM則根據(jù)數(shù)碼管的類型(共陰/共陽)
分別接GND/VCC。動(dòng)態(tài)顯示,就是將被顯示的數(shù)據(jù)的BCD碼,按照一定的變化頻率,在不同的時(shí)刻周期性
地分別送到一個(gè)數(shù)據(jù)總線上,再通過一個(gè)公共的4-7/8顯示譯碼器譯碼后,接到多個(gè)顯示譯碼器的公共顯
示驅(qū)動(dòng)段a-g(p)上,同時(shí),在不同的時(shí)刻周期性地選通對(duì)應(yīng)的數(shù)碼管的公共端COM。
6.9.1數(shù)碼管靜態(tài)顯示電路的設(shè)計(jì)
七段數(shù)碼顯示器由7根顯示碼管組成,對(duì)每一根碼管,用一位二進(jìn)制表示。若該數(shù)碼管的為共陰數(shù)碼管,
則該位為1時(shí),表示此碼管發(fā)光,如為0,表示此碼管不發(fā)光,對(duì)7根碼管編號(hào)。共陽數(shù)碼管則正好相反。
下面用一個(gè)7位二進(jìn)制數(shù)表示一個(gè)七段顯示器的編碼,其VHDL程序段描述如下:
CASECNT4BIS
WHEN0=>DOUT<="0111111”;
WHEN1=>DOUT<="0000110”;
WHEN2=>DOUT<="1011011”;
WHEN3=>DOUT<="1001111”;
WHEN4=>DOUT<="1100110”;
WHEN5=>DOUT<="1101101”;
WHEN6=>DOUT<="1111101”;
WHEN7=>DOUT<="0000111”;
WHEN8=>DOUT<="1111111”;
WHEN9=>DOUT<="1101111”;
WHENOTHERS=>DOUT<="0000000”
ENDCASE;
下面給出一個(gè)4位二進(jìn)制加法計(jì)數(shù)器靜態(tài)顯示的VHDL程序。
【例6.21]用VIIDL設(shè)計(jì)一個(gè)4位二進(jìn)制加法計(jì)數(shù)器,并將計(jì)數(shù)結(jié)果用7段LED顯示數(shù)碼管進(jìn)行靜態(tài)顯示。
—CNTDISPLAY.VHD
LIBRARYIEEE;
USEIEEE.STDLOGIC1164.ALL;
USEIEEE.STD_LOGIC_UNSIGNED.ALL;
ENTITYCNTDISPLAYIS
PORT(CLK:INSTD_LOGIC;
DOUT:OUTSTD_LOGIC_VECTOR(6DOWNTO0));
ENDDECLED;
ARCHITECTUREBEHAVOFCNTDISPLAYIS
SIGNALCNT4B:STD_LOGIC_VECTOR(3DOWNTO0);
BEGIN
PROCESS(CLK)
BEGIN
IFCLK'EVENTANDCLK='1'THEN
CNT4B<=CNT4B+1;
ENDIF;
ENDPROCESS;
PROCESS(CNT4B)
BEGIN
CASECNT4BIS
WHEN“0000”=>DOUT<=“0111111”
WHEN“0001”=>DOUT“0000110”
WHEN“0010”=>DOUT“1011011”
WHEN“0011”=>DOUT<=“1001111”
WHEN“0100”=>DOUT<=“1100110”
〈二
WHEN“0101”二>DOUT“1101101”
WHEN“0110”=>DOUT<=“1111101”
WHEN“0111”=>DOUT<=“0000111”
WHEN
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年牛津上海版高一物理下冊(cè)階段測(cè)試試卷含答案
- 2025年人教版(2024)選擇性必修1物理下冊(cè)階段測(cè)試試卷含答案
- 2025年人教A版九年級(jí)物理下冊(cè)階段測(cè)試試卷
- 2025年人教A版九年級(jí)地理上冊(cè)階段測(cè)試試卷
- 2025年新科版八年級(jí)生物上冊(cè)階段測(cè)試試卷
- 廣西梧州市言和涉電糾紛調(diào)解中心招考1名工作人員高頻重點(diǎn)提升(共500題)附帶答案詳解
- 2025年北師大版一年級(jí)語文下冊(cè)階段測(cè)試試卷
- 2025年北師大版高二數(shù)學(xué)下冊(cè)月考試卷含答案
- 2025年新科版選修4地理上冊(cè)階段測(cè)試試卷
- 2025年湘教新版選修1歷史上冊(cè)月考試卷
- GB/T 6052-2011工業(yè)液體二氧化碳
- GB/T 36964-2018軟件工程軟件開發(fā)成本度量規(guī)范
- 瓦楞紙箱工藝流程
- 小學(xué)數(shù)學(xué)專題講座:小學(xué)數(shù)學(xué)計(jì)算能力的培養(yǎng)課件
- PPT預(yù)制小箱梁施工技術(shù)
- 河北省滄州市各縣區(qū)鄉(xiāng)鎮(zhèn)行政村村莊村名居民村民委員會(huì)明細(xì)
- 精品電力工程質(zhì)量目標(biāo)、質(zhì)量保證體系及技術(shù)組織措施
- 高考物理知識(shí)歸納總結(jié)之六(磁場(chǎng)、電磁感應(yīng)和交流電)
- 檳榔黃化病的診斷及防控
- 眼外傷-PPT課件
- 重點(diǎn)高中自主招生數(shù)學(xué)試題含答案
評(píng)論
0/150
提交評(píng)論