VHDL code position: p186_ex7_7_ADC0809
Note: 1: The code is about state coding of FSM
2: Compare it with example 7_8, 7_9
-------------------------------------------------------------------------------
LIBARY IEEE;
USE IEEE.STD_LOGIC_1164.ALL;
-- USE IEEE.STD_LOGIC_UNSIGNED.ALL;
ENTITY ADC0809 IS
PORT ( D : IN STD_LOGIC_VECTOR(7 DOWNTO 0);
CLK, EOC : IN STD_LOGIC;
ALE, START,
OE, ADDA, : OUT STD_LOGIC;
c_state : OUT STD_LOGIC_VECTOR(4 DOWNTO 0);
Q : OUT STD_LOGIC_VECTOR(7 DOWNTO 0)
);
END ENTITY ADC0809;
ARCHITECTURE BEHAV OF ADC0809 IS
TYPE states IS ( st0, st1, st2, st3, st4 );
SIGNAL current_state, next_state : STD_LOGIC_VECTOR ( 4 DOWNTO 0 );
CONSTANT st0 : STD_LOGIC_VECTOR ( 4 DOWNTO 0 ) := "00000";
CONSTANT st1 : STD_LOGIC_VECTOR ( 4 DOWNTO 0 ) := "11000";
CONSTANT st2 : STD_LOGIC_VECTOR ( 4 DOWNTO 0 ) := "00001";
CONSTANT st3 : STD_LOGIC_VECTOR ( 4 DOWNTO 0 ) := "00100";
CONSTANT st4 : STD_LOGIC_VECTOR ( 4 DOWNTO 0 ) := "00110";
SIGNAL REGL : STD_LOGIC_VECTOR(7 DOWNTO 0);
SIGNAL LOCK : STD_LOGIC;
BEGIN
ADDA <= '1'; -- ADC0809 channel select:
-- 0-channel 0; 1-channel 1
Q <= REGL;
START <= current_state (4 );
ALE <= current_state (3 );
OE <= current_state (2 );
LOCK <= current_state (1 );
c_state <= current_state ;
COM:
PROCESS ( current_state, EOC )
BEGIN
CASE current_state IS
WHEN st0 => -- ADC 0809 initial
next_state <= st1;
WHEN st1 => -- ADC 0809 start sampling
next_state <= st2;
WHEN st2 => -- ADC 0809 state test and wait
IF EOC = '1' THEN
next_state <= st3;
ELSE
next_state <= st2;
END IF;
WHEN st3 => -- ADC 0809 data output
next_state <= st4;
WHEN st4 =>
next_state <= st0;
WHEN OTHERS =>
next_state <=st0;
END CASE;
END PROCESS COM;
REG:
PROCESS ( CLK )
BEGIN
IF CLK'EVENT AND CLK = '1' THEN
current_state <= next_state;
END IF;
END PROCESS REG;
LATCH1:
PROCESS ( LOCK ) -- latch data in the rising edge of LOCK
BEGIN
IF LOCK'EVENT AND LOCK = '1' THEN
REGL <= D;
END IF;
END PROCESS LATCH1;
END ARCHITECTURE BEHAV;