-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtb_avm_master3.vhd
185 lines (158 loc) · 6.46 KB
/
tb_avm_master3.vhd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
library ieee;
use ieee.std_logic_1164.all;
use ieee.numeric_std.all;
entity tb_avm_master3 is
end entity tb_avm_master3;
architecture simulation of tb_avm_master3 is
constant C_DATA_SIZE : integer := 32;
constant C_ADDRESS_SIZE : integer := 5;
signal clk : std_logic := '1';
signal rst : std_logic := '1';
signal running : std_logic := '1';
signal avm_start : std_logic;
signal avm_wait : std_logic;
signal avm_write : std_logic;
signal avm_read : std_logic;
signal avm_address : std_logic_vector(C_ADDRESS_SIZE - 1 downto 0);
signal avm_writedata : std_logic_vector(C_DATA_SIZE - 1 downto 0);
signal avm_byteenable : std_logic_vector(C_DATA_SIZE / 8 - 1 downto 0);
signal avm_burstcount : std_logic_vector(7 downto 0);
signal avm_readdata : std_logic_vector(C_DATA_SIZE - 1 downto 0);
signal avm_readdatavalid : std_logic;
signal avm_waitrequest : std_logic;
signal pipe_avm_write : std_logic;
signal pipe_avm_read : std_logic;
signal pipe_avm_address : std_logic_vector(C_ADDRESS_SIZE - 1 downto 0);
signal pipe_avm_writedata : std_logic_vector(C_DATA_SIZE - 1 downto 0);
signal pipe_avm_byteenable : std_logic_vector(C_DATA_SIZE / 8 - 1 downto 0);
signal pipe_avm_burstcount : std_logic_vector(7 downto 0);
signal pipe_avm_readdata : std_logic_vector(C_DATA_SIZE - 1 downto 0);
signal pipe_avm_readdatavalid : std_logic;
signal pipe_avm_waitrequest : std_logic;
constant C_CLK_PERIOD : time := 10 ns;
begin
---------------------------------------------------------
-- Controller clock and reset
---------------------------------------------------------
clk <= running and not clk after C_CLK_PERIOD / 2;
rst <= '1', '0' after 10 * C_CLK_PERIOD;
avm_start_proc : process
begin
avm_start <= '0';
wait until rst = '0';
avm_start <= '1';
wait until clk = '1';
avm_start <= '0';
wait until clk = '1';
wait until avm_wait = '0';
wait until clk = '1';
wait until clk = '1';
wait until clk = '1';
avm_start <= '1';
wait until clk = '1';
avm_start <= '0';
wait until clk = '1';
wait until avm_wait = '0';
wait until clk = '1';
wait until clk = '1';
wait until clk = '1';
running <= '0';
wait;
end process avm_start_proc;
---------------------------------------------------------
-- Instantiate Master
---------------------------------------------------------
avm_master3_inst : entity work.avm_master3
generic map (
G_INIT_FIRST => true,
G_ADDRESS_SIZE => C_ADDRESS_SIZE,
G_DATA_SIZE => C_DATA_SIZE
)
port map (
clk_i => clk,
rst_i => rst,
start_i => avm_start,
wait_o => avm_wait,
m_avm_waitrequest_i => avm_waitrequest,
m_avm_write_o => avm_write,
m_avm_read_o => avm_read,
m_avm_address_o => avm_address,
m_avm_writedata_o => avm_writedata,
m_avm_byteenable_o => avm_byteenable,
m_avm_burstcount_o => avm_burstcount,
m_avm_readdata_i => avm_readdata,
m_avm_readdatavalid_i => avm_readdatavalid
); -- avm_master3_inst
avm_verifier_inst : entity work.avm_verifier
generic map (
G_INIT_ZEROS => false,
G_ADDRESS_SIZE => C_ADDRESS_SIZE,
G_DATA_SIZE => C_DATA_SIZE
)
port map (
clk_i => clk,
rst_i => rst,
avm_waitrequest_i => avm_waitrequest,
avm_write_i => avm_write,
avm_read_i => avm_read,
avm_address_i => avm_address,
avm_writedata_i => avm_writedata,
avm_byteenable_i => avm_byteenable,
avm_burstcount_i => avm_burstcount,
avm_readdata_i => avm_readdata,
avm_readdatavalid_i => avm_readdatavalid
); -- avm_verifier_inst
---------------------------------------------------------
-- Add pipeline to store multiple outstanding requests
---------------------------------------------------------
avm_pipe_inst : entity work.avm_pipe
generic map (
G_ADDRESS_SIZE => C_ADDRESS_SIZE,
G_DATA_SIZE => C_DATA_SIZE
)
port map (
clk_i => clk,
rst_i => rst,
s_avm_write_i => avm_write,
s_avm_read_i => avm_read,
s_avm_address_i => avm_address,
s_avm_writedata_i => avm_writedata,
s_avm_byteenable_i => avm_byteenable,
s_avm_burstcount_i => avm_burstcount,
s_avm_readdata_o => avm_readdata,
s_avm_readdatavalid_o => avm_readdatavalid,
s_avm_waitrequest_o => avm_waitrequest,
m_avm_write_o => pipe_avm_write,
m_avm_read_o => pipe_avm_read,
m_avm_address_o => pipe_avm_address,
m_avm_writedata_o => pipe_avm_writedata,
m_avm_byteenable_o => pipe_avm_byteenable,
m_avm_burstcount_o => pipe_avm_burstcount,
m_avm_readdata_i => pipe_avm_readdata,
m_avm_readdatavalid_i => pipe_avm_readdatavalid,
m_avm_waitrequest_i => pipe_avm_waitrequest
); -- avm_pipe_inst
---------------------------------------------------------
-- Instantiate Avalon Memory Slave
---------------------------------------------------------
avm_memory_pause_inst : entity work.avm_memory_pause
generic map (
G_REQ_PAUSE => 3,
G_RESP_PAUSE => 4,
G_ADDRESS_SIZE => C_ADDRESS_SIZE,
G_DATA_SIZE => C_DATA_SIZE
)
port map (
clk_i => clk,
rst_i => rst,
avm_write_i => pipe_avm_write,
avm_read_i => pipe_avm_read,
avm_address_i => pipe_avm_address,
avm_writedata_i => pipe_avm_writedata,
avm_byteenable_i => pipe_avm_byteenable,
avm_burstcount_i => pipe_avm_burstcount,
avm_readdata_o => pipe_avm_readdata,
avm_readdatavalid_o => pipe_avm_readdatavalid,
avm_waitrequest_o => pipe_avm_waitrequest
); -- avm_memory_pause_inst
end architecture simulation;