欢迎来到天天文库
浏览记录
ID:56384529
大小:1.26 MB
页数:123页
时间:2020-06-14
《用VHDL语言设计基本逻辑电路.ppt》由会员上传分享,免费在线阅读,更多相关内容在PPT专区-天天文库。
1、在前面的学习中,我们对VHDL语言的语句、语法及利用VHDL语言设计逻辑电路的基本方法作了详细介绍。为了深入理解使用VHDL语言设计逻辑电路的具体步骤和方法,本章以常用的基本逻辑电路设计为例,再次对其进行系统和详细的介绍,以使大家初步掌握用VHDL语言描述基本逻辑电路的方法。3.1SummaryofbasicstatementsinVHDLcodes1、SequentialAssignmentStatements1)IF、CASE、LOOP、NULLstatementsonlyusinginprocess,proce
2、dureandfunction.2)IF、CASE用于条件选择;LOOP用于循环控制偏重计算;NULL是一条空语句,一般用于CASE语句中。2、ConcurrentAssignmentStatements1)PROCESS语句注意敏感信号表,一般将进程中的输入信号或变量都写入敏感信号表中,如无敏感信号,则使用WAIT语句。2)BLOCK语句改善并行语句及其结构的可读性。3)并行信号赋值语句:(1)简单信号赋值语句(2)WHEN……ELSE语句(ELSE后面无符号)(3)选择信号赋值语句的用法ARCHITECTUREa
3、r_7OFfzh_2ISBEGINWITHqSELECTy<=aWHEN″00″,--选择值用“,”结束bWHEN″01″,cWHEN″10″,dWHENOTHERS;ENDar_7;4)元件例化语句:主要用于在VHDL中的层次设计。5)生成语句:作用就是复制FOR循环变量IN取值范围GENERATE3.SubprogramVHDL中的子程序包括函数(FUNCTION)和过程(PROCEDURE)等两类。函数的作用就是输入若干个参数,通过函数运算求值,最后直接返回一个值。过程的调用是一条语句,调用时通过其接口返回0个
4、或多个值。4.LibraryandPackage3.2VHDLforCombinationalCircuitsHavinglearnedanumberofusefulcircuitsthatcanbeusedasbuildingblocksinlargercircuitsinbeforecourses,suchaslogicgates,multiplexers,decodersandencoders,wewillnowconsiderhowsuchcircuitscanbedescribedinVHDL.3.2.1L
5、ogicGates简单门电路包括2输入“与非”门、集电极开路的2输入“与非”门、2输入“或非”门、反相器、集电极开路的反相器、3输入“与非”门、2输入“或”门和2输入“异或”门等,它们是构成所有逻辑电路的基本电路。Two-inputXORGatef.e.3.2.2Encoder,DecoderandMultiplexer编、译码器和选择器是组合电路中较简单的3种通用电路。它们可以由简单的门电路组合连接而成,但采用这种方式,只给出电路,让读者来判断该电路的功能,那么要读通该电路需要花较多的时间。如果采用VHDL语言,从
6、行为、功能来描述,不仅逻辑设计变得非常容易,而且阅读也会很方便。例1:一位共阴七段数码管译码器LIBRARYieee;USEieee.std_logic_1164.ALL;entitybcd7ISPORT(d3,d2,d1,d0:INstd_logic;a,b,c,d,e,f,g:OUTstd_logic);END;ARCHITECTUREarc_bcd7OFbcd7ISSIGNALdin:std_logic_vector(3DOWNTO0);SIGNALdout:std_logic_vector(6DOWNTO0)
7、;BEGINdin<=d3&d2&d1&d0;--&为并置运算符PROCESS(din)BEGINCASEdinIS--abcdefg,输出的7段码WHEN“0000”=>dout<=“1111110”;--显示0WHEN"0001"=>dout<="0110000";--显示1WHEN"0010"=>dout<="1101101";--显示2WHEN"0011"=>dout<="1111001";--显示3WHEN"0100"=>dout<="0110011";--显示4WHEN"0101"=>dout<="101
8、1011";--显示5WHEN"0110"=>dout<="1011111";--显示6WHEN"1000"=>dout<="1111111";--显示8WHEN"1001"=>dout<="1111011";--显示9WHEN"0111"=>dout<="1110000";--显示7...ENDCASE;ENDPROCESS;a<=dout(
此文档下载收益归作者所有