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

Subversion Repositories mblite

[/] [mblite/] [trunk/] [designs/] [core_decoder_wb/] [testbench.vhd] - Blame information for rev 9

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

Line No. Rev Author Line
1 2 takar
----------------------------------------------------------------------------------------------
2
--
3
--      Input file         : config_Pkg.vhd
4
--      Design name        : config_Pkg
5
--      Author             : Tamar Kranenburg
6
--      Company            : Delft University of Technology
7
--                         : Faculty EEMCS, Department ME&CE
8
--                         : Systems and Circuits group
9
--
10
--      Description        : Testbench instantiates data and instruction memories, core, 
11
--                           core address decoder, wishbone adapter and wishbone stdio
12
--
13
----------------------------------------------------------------------------------------------
14
 
15 8 takar
library ieee;
16
use ieee.std_logic_1164.all;
17
use ieee.std_logic_unsigned.all;
18 2 takar
 
19 8 takar
library mblite;
20
use mblite.config_Pkg.all;
21
use mblite.core_Pkg.all;
22
use mblite.std_Pkg.all;
23 2 takar
 
24 8 takar
entity testbench is
25
end testbench;
26 2 takar
 
27 8 takar
architecture arch of testbench is
28 2 takar
 
29 8 takar
    component wb_stdio is port
30 2 takar
    (
31 8 takar
        wb_o : out wb_slv_out_type;
32
        wb_i : in wb_slv_in_type
33 2 takar
    );
34 8 takar
    end component;
35 2 takar
 
36 8 takar
    signal dmem_o : dmem_out_type;
37
    signal dmem_i : dmem_in_type;
38
    signal imem_o : imem_out_type;
39
    signal imem_i : imem_in_type;
40
    signal s_dmem_o : dmem_out_array_type(CFG_NUM_SLAVES - 1 downto 0);
41
    signal s_dmem_i : dmem_in_array_type(CFG_NUM_SLAVES - 1 downto 0);
42 2 takar
 
43 8 takar
    signal m_wb_i : wb_mst_in_type;
44
    signal m_wb_o : wb_mst_out_type;
45
    signal s_wb_i : wb_slv_in_type;
46
    signal s_wb_o : wb_slv_out_type;
47 2 takar
 
48 8 takar
    signal sys_clk_i : std_logic := '0';
49
    signal sys_int_i : std_logic;
50
    signal sys_rst_i : std_logic;
51 2 takar
 
52 8 takar
    constant rom_size : integer := 16;
53
    constant ram_size : integer := 16;
54 2 takar
 
55 8 takar
    signal sel_o : std_logic_vector(3 downto 0);
56
    signal ena_o : std_logic;
57 2 takar
 
58 8 takar
begin
59 2 takar
 
60 8 takar
    sys_clk_i <= not sys_clk_i after 10000 ps;
61
    sys_rst_i <= '1' after 0 ps, '0' after  150000 ps;
62
    sys_int_i <= '1' after 500000000 ps, '0' after 500040000 ps;
63 2 takar
 
64
    -- Warning: an infinite loop like while(1) {} triggers this timeout too!
65
    -- disable this feature when a premature finish occur.
66 8 takar
    timeout: process(sys_clk_i)
67
    begin
68
        if NOW = 10 ms then
69
            report "TIMEOUT" severity FAILURE;
70
        end if;
71 2 takar
        -- BREAK ON EXIT (0xB8000000)
72 8 takar
        if compare(imem_i.dat_i, "10111000000000000000000000000000") = '1' then
73 2 takar
            -- Make sure the simulator finishes when an error is encountered.
74
            -- For modelsim: see menu Simulate -> Runtime options -> Assertions
75 8 takar
            report "FINISHED" severity FAILURE;
76
        end if;
77
    end process;
78 2 takar
 
79
    s_wb_i.clk_i <= sys_clk_i;
80
    s_wb_i.rst_i <= sys_rst_i;
81
    s_wb_i.adr_i <= m_wb_o.adr_o;
82
    s_wb_i.dat_i <= m_wb_o.dat_o;
83
    s_wb_i.we_i  <= m_wb_o.we_o;
84
    s_wb_i.stb_i <= m_wb_o.stb_o;
85
    s_wb_i.sel_i <= m_wb_o.sel_o;
86
    s_wb_i.cyc_i <= m_wb_o.cyc_o;
87
 
88
    m_wb_i.clk_i <= sys_clk_i;
89
    m_wb_i.rst_i <= sys_rst_i;
90
    m_wb_i.dat_i <= s_wb_o.dat_o;
91
    m_wb_i.ack_i <= s_wb_o.ack_o;
92
    m_wb_i.int_i <= s_wb_o.int_o;
93
 
94 8 takar
    stdio : wb_stdio port map
95 2 takar
    (
96
        wb_i  => s_wb_i,
97
        wb_o  => s_wb_o
98
    );
99
 
100 8 takar
    wb_adapter : core_wb_adapter port map
101 2 takar
    (
102
        dmem_i => s_dmem_i(1),
103
        wb_o   => m_wb_o,
104
        dmem_o => s_dmem_o(1),
105
        wb_i   => m_wb_i
106
    );
107
 
108
    s_dmem_i(0).ena_i <= '1';
109 8 takar
    sel_o <= s_dmem_o(0).sel_o when s_dmem_o(0).we_o = '1' else (others => '0');
110
    ena_o <= not sys_rst_i and s_dmem_o(0).ena_o;
111 2 takar
 
112 8 takar
    dmem : sram_4en generic map
113 2 takar
    (
114
        WIDTH => CFG_DMEM_WIDTH,
115 8 takar
        SIZE  => ram_size - 2
116 2 takar
    )
117 8 takar
    port map
118 2 takar
    (
119
        dat_o => s_dmem_i(0).dat_i,
120
        dat_i => s_dmem_o(0).dat_o,
121 8 takar
        adr_i => s_dmem_o(0).adr_o(ram_size - 1 downto 2),
122 2 takar
        wre_i => sel_o,
123
        ena_i => ena_o,
124
        clk_i => sys_clk_i
125
    );
126
 
127 8 takar
    decoder : core_address_decoder generic map
128 2 takar
    (
129
        G_NUM_SLAVES => CFG_NUM_SLAVES
130
    )
131 8 takar
    port map
132 2 takar
    (
133
        m_dmem_i => dmem_i,
134
        s_dmem_o => s_dmem_o,
135
        m_dmem_o => dmem_o,
136
        s_dmem_i => s_dmem_i,
137
        clk_i    => sys_clk_i
138
    );
139
 
140 8 takar
    imem : sram generic map
141 2 takar
    (
142
        WIDTH => CFG_IMEM_WIDTH,
143 8 takar
        SIZE  => rom_size - 2
144 2 takar
    )
145 8 takar
    port map
146 2 takar
    (
147
        dat_o => imem_i.dat_i,
148
        dat_i => "00000000000000000000000000000000",
149 8 takar
        adr_i => imem_o.adr_o(rom_size - 1 downto 2),
150 2 takar
        wre_i => '0',
151
        ena_i => imem_o.ena_o,
152
        clk_i => sys_clk_i
153
    );
154
 
155 8 takar
    core0 : core port map
156 2 takar
    (
157
        imem_o => imem_o,
158
        dmem_o => dmem_o,
159
        imem_i => imem_i,
160
        dmem_i => dmem_i,
161
        int_i  => sys_int_i,
162
        rst_i  => sys_rst_i,
163
        clk_i  => sys_clk_i
164
    );
165
 
166 8 takar
end arch;

powered by: WebSVN 2.1.0

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