使用变量的状态机.txt

来自「VHDL实例」· 文本 代码 · 共 58 行

TXT
58
字号
-- State Machine using Variable
-- dowload from: www.fpga.com.cn & www.pld.com.cn

library ieee;
use ieee.std_logic_1164.all;

ENTITY fsm2 IS

    PORT(clock,x : IN BIT; z : OUT BIT);
END fsm2;
-------------------------------------------------
ARCHITECTURE using_wait OF fsm2 IS

TYPE state_type IS (s0,s1,s2,s3);

BEGIN
   PROCESS

      VARIABLE state : state_type := s0;

   BEGIN

      WAIT UNTIL (clock'EVENT AND clock = '1');
         CASE state IS
            WHEN s0 => IF x = '0' THEN 
                           state := s0;
                           z <= '0';
                       ELSE
                           state := s2;
                           z <= '1';
                       END IF;
            WHEN s2 => IF x = '0' THEN 
                           state := s2;
                           z <= '1';
                       ELSE
                           state := s3;
                           z <= '0';
                       END IF;
            WHEN s3 => IF x = '0' THEN 
                           state := s3;
                           z <= '0';
                       ELSE
                           state := s1;
                           z <= '1';
                       END IF;
            WHEN s1 => IF x = '0' THEN 
                           state := s0;
                           z <= '0';
                       ELSE
                           state := s2;
                           z <= '0';
                       END IF;
            
         END CASE;
   END PROCESS;
END using_wait;

⌨️ 快捷键说明

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