- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第五章组合逻辑电路进阶设计
;第五章组合逻辑电路进阶设计;ALU功能简介 ;功能选择
S2 S1 S0; Entity的定义 ;信号名称 ;library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.std_logic_arith.all;
use IEEE.std_logic_unsigned.all;
entity CH5_2_1 is
port
( A : in UNSIGNED (3 downto 0);
B : in UNSIGNED (3 downto 0);
Cin : in STD_LOGIC ;
S : in STD_LOGIC_VECTOR (2 downto 0) ;
BCDout : out STD_LOGIC_VECTOR (3 downto 0) ;
Cout : out STD_LOGIC
);
end CH5_2_1 ;;architecture ARCH of CH5_2_1 is
SIGNAL C,Y : STD_LOGIC_VECTOR (3 downto 0) ;
BEGIN
PROCESS( S)
BEGIN
--*****************ADDER***************
case S is
when 000 =
Y(0) = A(0) XOR B(0) XOR Cin ;
C(0) = (A(0) AND B(0)) OR (B(0) AND Cin) OR (A(0) AND Cin);
GEN1 : FOR I IN 1 TO 3 LOOP
Y(I) = A(I) XOR B(I) XOR C(I-1) ;
C(I) = (C(I-1) AND A(I)) OR (C(I-1) AND B(I)) OR (A(I) AND B(I));
END LOOP ;
BCDout = Y(3) Y(2) Y(1) Y(0) ;
Cout = C(3) ;;when 001 = --SUB ;
Y(0) = A(0) XOR B(0) XOR Cin ;
C(0) = (Cin AND NOT A(0)) OR (Cin AND B(0)) OR (NOT A(0) AND B(0));
GEN2: FOR I IN 1 TO 3 LOOP
Y(I) = A(I) XOR B(I) XOR C(I-1);
C(I) = (C(I-1) AND NOT A(I)) OR (C(I-1) AND B(I)) OR (NOT A(I) AND B(I));
END LOOP ;
BCDout = Y(3) Y(2) Y(1) Y(0) ;
Cout = C(3) ;;when 010 = --TRANSFER A+Cin
IF Cin=0 THEN
BCDout = A(3) A(2) A(1) A(0) ;
ELSE
BCDout = A + 1 ;
END IF ;;when 011 = --TRANSFER A-Cin ;
IF Cin=1 THEN
BCDout = A(3) A(2) A(1) A(0) ;
ELSE
BCDout = A - 1 ;
END IF ;
Cout = 0 ;
when others =
BCDout = 0000 ;
Cout = 0;
end case ;
END PROCESS;
end ARCH;;信号名称 ;architecture ARCH of CH5_3_1 is
signal Y: STD_LOGIC_VECTOR(3 downto 0) ;
BEGIN
PROCESS (A,B,S)
BEGIN
CASE S IS
when 100 =
Y(3) = A(3) and B(3) ;
Y(2) = A(2) and B(2) ;
Y(1) = A(1) and B(1) ;
Y(0) = A(0) and B(0) ;
BCDout = y(3)Y(2)Y(1)Y(0);
when 101 =
Y(3) = A(3) or B(3) ;
Y(2) = A(2
文档评论(0)