counter4.vhd

来自「多个Verilog和vhdl程序例子」· VHDL 代码 · 共 42 行

VHD
42
字号
-- 4 bit down-counter with load

library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;

entity counter is
port (data_in : in std_logic_vector (3 downto 0);
         clk, load, down : in std_logic;
         max_val : in std_logic_vector (3 downto 0);
         count : out std_logic_vector (3 downto 0);
         zero : out std_logic);
end counter;

architecture behave of counter is
    signal cnt : std_logic_vector (3 downto 0);
begin
    process
    begin
        wait until rising_edge(clk);
        if (load = '1') then
             cnt <= data_in;
        elsif (down = '1') then
            if (cnt = "0000") then
                cnt <= max_val;
            else
                cnt <= cnt - "0001";
            end if;
        else
             cnt <= cnt;
        end if;
        if (cnt = "0000") then
             zero <= '1';
        else
            zero <= '0';
        end if;
    end process;

    count <= cnt;

end behave;

⌨️ 快捷键说明

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