7 use ieee.std_logic_1164.all ;
12 PCI_CLOCK :in std_logic;
13 PCI_RSTn :in std_logic;
14 IO_READ :in std_logic;
15 IO_WRITE :in std_logic;
16 CONF_READ :in std_logic;
17 CONF_WRITE :in std_logic;
18 FIFO_READ :in std_logic;
19 READ :out std_logic;--> MUX_SEL(1) , OE_PCI_AD
20 PERR_CHECK :out std_logic;
21 DEVSELn :out std_logic;
22 OE_PCI_PAR :out std_logic;
23 OE_PCI_PERR :out std_logic;
25 PCI_TRDYn :out std_logic; -- s/t/s
26 PCI_STOPn :out std_logic; -- s/t/s
27 PCI_DEVSELn :out std_logic; -- s/t/s
28 FIFO_RDn :out std_logic
32 architecture CONT_FSM_DESIGN of CONT_FSM is
36 --**********************************************************
37 --*** CONTROL FSM CODIERUNG ***
38 --**********************************************************
43 -- ||---------- FIFO_READn
44 -- |||--------- OE_PCI_PERR
45 -- ||||-------- PERR_CHECK
48 -- |||||||----- DEVSELn
49 -- ||||||||---- OE_PCI_PAR
50 -- |||||||||--- OE_CONTROL
51 -- ||||||||||-- READ / MUX_SEL(1) / OE_PCI_AD
53 constant ST_IDLE :std_logic_vector (9 downto 0) := "0100111000" ;-- 138
55 constant ST_READ_1 :std_logic_vector (9 downto 0) := "0100110011" ;-- 133
56 constant ST_READ_2 :std_logic_vector (9 downto 0) := "0100000111" ;-- 107
57 constant ST_READ_3 :std_logic_vector (9 downto 0) := "0100111111" ;-- 13F
59 constant ST_RD_FIFO_1 :std_logic_vector (9 downto 0) := "0000110011" ;-- 033
60 constant ST_RD_FIFO_2 :std_logic_vector (9 downto 0) := "1000110011" ;-- 233
63 constant ST_WRITE_1 :std_logic_vector (9 downto 0) := "0111110010" ;-- 1F2
64 constant ST_WRITE_2 :std_logic_vector (9 downto 0) := "0110000010" ;-- 182
65 constant ST_WRITE_3 :std_logic_vector (9 downto 0) := "0110111010" ;-- 1BA
67 signal CONTROL_STATE :std_logic_vector (9 downto 0);
70 --signal DEVSELn :std_logic;
71 signal STOPn :std_logic;
72 --signal TRDYn :std_logic;
74 --************************************************************
75 --*** FSM SPEICHER-AUTOMAT ***
76 --************************************************************
78 attribute syn_state_machine : boolean;
79 attribute syn_state_machine of CONTROL_STATE : signal is false;
83 --**********************************************************
85 --**********************************************************
87 process (PCI_CLOCK, PCI_RSTn)
89 if PCI_RSTn = '0' then CONTROL_STATE <= ST_IDLE;
91 elsif (PCI_CLOCK'event and PCI_CLOCK = '1') then
97 CONTROL_STATE <= ST_READ_1;
99 elsif CONF_READ = '1' then
100 CONTROL_STATE <= ST_READ_1;
102 elsif IO_WRITE = '1' then
103 CONTROL_STATE <= ST_WRITE_1;
105 elsif CONF_WRITE = '1' then
106 CONTROL_STATE <= ST_WRITE_1;
108 else CONTROL_STATE <= ST_IDLE;
111 -- when ST_READ_1 => CONTROL_STATE <= ST_READ_2;
113 if FIFO_READ = '1' then
114 CONTROL_STATE <= ST_RD_FIFO_1;
115 else CONTROL_STATE <= ST_READ_2;
119 when ST_READ_2 => CONTROL_STATE <= ST_READ_3;
120 when ST_READ_3 => CONTROL_STATE <= ST_IDLE;
122 when ST_RD_FIFO_1=> CONTROL_STATE <= ST_RD_FIFO_2;
123 when ST_RD_FIFO_2=> CONTROL_STATE <= ST_READ_2;
127 when ST_WRITE_1 => CONTROL_STATE <= ST_WRITE_2;
128 when ST_WRITE_2 => CONTROL_STATE <= ST_WRITE_3;
129 when ST_WRITE_3 => CONTROL_STATE <= ST_IDLE;
132 when others => CONTROL_STATE <= ST_IDLE;
134 end case; -- COMM_STATE
136 end process; -- PROCESS
139 READ <= CONTROL_STATE(0);
140 --OE_CONTROL <= CONTROL_STATE(1);
141 OE_PCI_PAR <= CONTROL_STATE(2);
142 DEVSELn <= CONTROL_STATE(3);
143 STOPn <= CONTROL_STATE(4);
144 TRDYn <= CONTROL_STATE(5);
145 PERR_CHECK <= CONTROL_STATE(6);
146 OE_PCI_PERR <= CONTROL_STATE(7);
148 FIFO_RDn <= CONTROL_STATE(8);
151 PCI_DEVSELn <= CONTROL_STATE(3) when CONTROL_STATE(1) = '1' else 'Z';
152 PCI_STOPn <= STOPn when CONTROL_STATE(1) = '1' else 'Z';
153 PCI_TRDYn <= CONTROL_STATE(5) when CONTROL_STATE(1) = '1' else 'Z';
155 end architecture CONT_FSM_DESIGN ;