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

📄 mux8.vhd

📁 电子钟的源码
💻 VHD
字号:
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
use ieee.std_logic_arith.all;

entity mux8 is

port(
	a,b,c,d,e,f:in std_logic_vector(3 downto 0);
	clk:in std_logic;
	sel:out std_logic_vector(7 downto 0);
	q:out std_logic_vector(3 downto 0) );
end mux8;

architecture behave of mux8 is

signal other:std_logic_vector(3 downto 0);

begin
	other <= "1010";

	process(a,b,c,d,e,f,clk)
	variable state: integer range 0 to 7;
	begin
		if(clk'event and clk='1') then
			if(state=7) then
				state:=0;
			else
				state:=state+1;
			end if;
		end if;
		case state is
			when 0 => 
				q<=f;
				sel<="00000001";
			when 1 => 
				q<=e;
				sel<="00000010";
			when 2 => 
				q<=other;
				sel<="00000100";
			when 3 => 
				q<=d;
				sel<="00001000";
			when 4 => 
				q<=c;
				sel<="00010000";
			when 5 => 
				q<=other;
				sel<="00100000";
			when 6 => 
				q<=b;
				sel<="01000000";
			when 7 => 
				q<=a;
				sel<="10000000";	
			when others => 
				q<="0000";
				sel<="000000";
		end case;
	end process;

end behave;

⌨️ 快捷键说明

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