⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ch5_2_1.vhd

📁 《VHDL与数字电路设计》配套光盘,可以实际调用
💻 VHD
字号:
library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.std_logic_arith.all;
use IEEE.std_logic_unsigned.all;

--*********************************************************
-- 4 BITS ALU : check 4-BIT ARITH OPERATOR
--*********************************************************
--
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 ;
   			Cout <= '0' ;
	
		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;
--*********************************************************

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -