OpenCores
URL https://opencores.org/ocsvn/gamepads/gamepads/trunk

Subversion Repositories gamepads

[/] [gamepads/] [trunk/] [snespad/] [bench/] [vhdl/] [tb.vhd] - Blame information for rev 42

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 3 arniml
-------------------------------------------------------------------------------
2
--
3
-- Testbench for the
4
-- SNESpad controller core
5
--
6 41 arniml
-- $Id: tb.vhd 41 2009-04-01 19:58:04Z arniml $
7 3 arniml
--
8
-- Copyright (c) 2004, Arnim Laeuger (arniml@opencores.org)
9
--
10
-- All rights reserved
11
--
12
-- Redistribution and use in source and synthezised forms, with or without
13
-- modification, are permitted provided that the following conditions are met:
14
--
15
-- Redistributions of source code must retain the above copyright notice,
16
-- this list of conditions and the following disclaimer.
17
--
18
-- Redistributions in synthesized form must reproduce the above copyright
19
-- notice, this list of conditions and the following disclaimer in the
20
-- documentation and/or other materials provided with the distribution.
21
--
22
-- Neither the name of the author nor the names of other contributors may
23
-- be used to endorse or promote products derived from this software without
24
-- specific prior written permission.
25
--
26
-- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
27
-- AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
28
-- THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
29
-- PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE
30
-- LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
31
-- CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
32
-- SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
33
-- INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
34
-- CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
35
-- ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
36
-- POSSIBILITY OF SUCH DAMAGE.
37
--
38
-- Please report bugs to the author, but before you do so, please
39
-- make sure that this is not a derivative work and that
40
-- you have the latest version of this file.
41
--
42
-- The latest version of this file can be found at:
43
--      http://www.opencores.org/cvsweb.shtml/gamepads/
44
--
45
-- The project homepage is located at:
46
--      http://www.opencores.org/projects.cgi/web/gamepads/overview
47
--
48
-------------------------------------------------------------------------------
49
 
50
library ieee;
51
use ieee.std_logic_1164.all;
52
 
53
entity tb is
54
 
55
end tb;
56
 
57
 
58
use work.snespad_pack.all;
59 5 arniml
use work.snespad_comp.snespad;
60 3 arniml
 
61
architecture behav of tb is
62
 
63
  constant period_c       : time    := 100 ns;
64
  constant num_pads_c     : natural := 2;
65
  constant reset_level_c  : natural := 0;
66
  constant button_level_c : natural := 0;
67
 
68
 
69
  signal clk_s   : std_logic;
70
  signal reset_s : std_logic;
71
 
72
  signal pad_clk_s   : std_logic;
73
  signal pad_latch_s : std_logic;
74
  signal pad_data_s  : std_logic_vector(num_pads_c-1 downto 0);
75
 
76
  type buttons_t is array (11 downto 0) of std_logic_vector(num_pads_c-1 downto 0);
77
  signal buttons_s : buttons_t;
78
 
79
  signal buttons0_s,
80
         buttons1_s  : std_logic_vector(11 downto 0);
81
 
82
 
83
begin
84
 
85
  dut : snespad
86
    generic map (
87
      num_pads_g       => 2,
88
      reset_level_g    => reset_level_c,
89
      button_level_g   => button_level_c,
90
      clocks_per_6us_g => 60
91
    )
92
    port map (
93
      clk_i            => clk_s,
94
      reset_i          => reset_s,
95
      pad_clk_o        => pad_clk_s,
96
      pad_latch_o      => pad_latch_s,
97
      pad_data_i       => pad_data_s,
98
      but_a_o          => buttons_s(but_pos_a_c),
99
      but_b_o          => buttons_s(but_pos_b_c),
100
      but_x_o          => buttons_s(but_pos_x_c),
101
      but_y_o          => buttons_s(but_pos_y_c),
102
      but_start_o      => buttons_s(but_pos_start_c),
103
      but_sel_o        => buttons_s(but_pos_sel_c),
104
      but_tl_o         => buttons_s(but_pos_tl_c),
105
      but_tr_o         => buttons_s(but_pos_tr_c),
106
      but_up_o         => buttons_s(but_pos_up_c),
107
      but_down_o       => buttons_s(but_pos_down_c),
108
      but_left_o       => buttons_s(but_pos_left_c),
109
      but_right_o      => buttons_s(but_pos_right_c)
110
    );
111
 
112
  buttons: process (buttons_s)
113
  begin
114
    for i in 0 to 11 loop
115
      buttons0_s(i) <= buttons_s(i)(0);
116
      buttons1_s(i) <= buttons_s(i)(1);
117
    end loop;
118
  end process buttons;
119
 
120
  -----------------------------------------------------------------------------
121
  -- DUT Stimuli
122
  -----------------------------------------------------------------------------
123
  stimuli: process
124
 
125
    procedure dispatch(pad : in natural;
126
                       packet : in std_logic_vector(11 downto 0)) is
127
    begin
128
 
129
      wait until pad_latch_s = '0';
130
      for i in 11 downto 0 loop
131
        wait until pad_clk_s = '0';
132
        pad_data_s(pad) <= packet(i);
133
        wait until pad_clk_s = '1';
134
      end loop;
135
 
136
      wait for period_c;
137
 
138
      assert pad_latch_s = '1'
139
        report "Latch not deasserted!"
140
        severity error;
141
 
142
      wait for period_c;
143
      for i in 11 downto 0 loop
144
        assert button_active_f(buttons_s(i)(pad), button_level_c) = packet(i)
145
          report "Mismatch for received vs. sent buttons!"
146
          severity error;
147
      end loop;
148
 
149
    end dispatch;
150
 
151
  begin
152
    pad_data_s <= (others => '1');
153
 
154
    wait until reset_s = '1';
155
    wait for period_c * 4;
156
 
157
    for pad in 0 to 1 loop
158
      dispatch(pad, packet => "000000000000");
159
      dispatch(pad, packet => "111111111111");
160
      dispatch(pad, packet => "010101010101");
161
      dispatch(pad, packet => "101010101010");
162
      dispatch(pad, packet => "100000000000");
163
      dispatch(pad, packet => "010000000000");
164
      dispatch(pad, packet => "001000000000");
165
      dispatch(pad, packet => "000100000000");
166
      dispatch(pad, packet => "000010000000");
167
      dispatch(pad, packet => "000001000000");
168
      dispatch(pad, packet => "000000100000");
169
      dispatch(pad, packet => "000000010000");
170
      dispatch(pad, packet => "000000001000");
171
      dispatch(pad, packet => "000000000100");
172
      dispatch(pad, packet => "000000000010");
173
      dispatch(pad, packet => "000000000001");
174
    end loop;
175
 
176
 
177
    wait for period_c * 4;
178
    assert false
179
      report "End of simulation reached."
180
      severity failure;
181
 
182
  end process stimuli;
183
 
184
 
185
  -----------------------------------------------------------------------------
186
  -- Clock Generator
187
  -----------------------------------------------------------------------------
188
  clk: process
189
  begin
190
    clk_s <= '0';
191
    wait for period_c / 2;
192
    clk_s <= '1';
193
    wait for period_c / 2;
194
  end process clk;
195
 
196
 
197
  -----------------------------------------------------------------------------
198
  -- Reset Generator
199
  -----------------------------------------------------------------------------
200
  reset: process
201
  begin
202
    if reset_level_c = 0 then
203
      reset_s <= '0';
204
    else
205
      reset_s <= '1';
206
    end if;
207
 
208
    wait for period_c * 4 + 10 ns;
209
 
210
    reset_s <= not reset_s;
211
 
212
    wait;
213
  end process reset;
214
 
215
end behav;

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.