source: trunk/IPs/systemC/processor/Morpheo/Behavioural/Generic/RegisterFile/RegisterFile_Multi_Banked/RegisterFile_Multi_Banked_Glue/src/RegisterFile_Multi_Banked_Glue_vhdl_testbench_transition.cpp @ 44

Last change on this file since 44 was 44, checked in by rosiere, 17 years ago

Modification des classes d'encapsulation des interfaces.
Stable sur tous les composants actuels

File size: 3.6 KB
Line 
1#ifdef VHDL_TESTBENCH
2/*
3 * $Id$
4 *
5 * [ Description ]
6 *
7 */
8
9#include "Behavioural/Generic/RegisterFile/RegisterFile_Multi_Banked/RegisterFile_Multi_Banked_Glue/include/RegisterFile_Multi_Banked_Glue.h"
10
11namespace morpheo                    {
12namespace behavioural {
13namespace generic {
14namespace registerfile{
15namespace registerfile_multi_banked {
16namespace registerfile_multi_banked_glue {
17
18
19  void RegisterFile_Multi_Banked_Glue::vhdl_testbench_transition ()
20  {
21    log_printf(FUNC,RegisterFile_Multi_Banked_Glue,"vhdl_testbench_transition","Begin");
22
23    // Evaluation before read the ouput signal
24//     sc_start(0);
25
26    // In order with file RegisterFile_Multi_Banked_Glue_vhdl_testbench_port.cpp
27    // Warning : if a output depend of a subcomponent, take directly the port of subcomponent
28    // (because we have no control on the ordonnancer's policy)
29
30    //_vhdl_testbench->add_input (PORT_READ( in_NRESET));
31   
32   for (uint32_t i=0; i<_param._nb_port_read; i++)
33     {
34       _vhdl_testbench->add_input (PORT_READ( in_READ_IN_VAL       [i]));
35       _vhdl_testbench->add_output(PORT_READ(out_READ_IN_ACK       [i]));
36       _vhdl_testbench->add_input (PORT_READ( in_READ_IN_ADDRESS   [i]));
37       _vhdl_testbench->add_input (PORT_READ(out_READ_IN_DATA      [i]));
38     }
39
40   for (uint32_t i=0; i<_param._nb_bank; i++)
41     for (uint32_t j=0; j<_param._nb_port_read_by_bank; j++)
42       for (uint32_t k=0; k<_param._nb_port_select_by_bank_read_port [j]; k++)
43         {
44           _vhdl_testbench->add_output(PORT_READ(out_READ_SELECT_VAL [i][j][k]));
45           _vhdl_testbench->add_input (PORT_READ( in_READ_SELECT_ACK [i][j][k]));
46         }
47   
48    for (uint32_t i=0; i<_param._nb_bank; i++)
49      for (uint32_t j=0; j<_param._nb_port_read_by_bank; j++)
50        {
51          _vhdl_testbench->add_output(PORT_READ(out_READ_OUT_VAL      [i][j]));
52          _vhdl_testbench->add_input (PORT_READ( in_READ_OUT_ACK      [i][j]));
53          _vhdl_testbench->add_output(PORT_READ(out_READ_OUT_ADDRESS  [i][j]));
54          _vhdl_testbench->add_input (PORT_READ( in_READ_OUT_DATA     [i][j]));
55        }
56
57   for (uint32_t i=0; i<_param._nb_port_write; i++)
58     {
59       _vhdl_testbench->add_input (PORT_READ( in_WRITE_IN_VAL      [i]));
60       _vhdl_testbench->add_output(PORT_READ(out_WRITE_IN_ACK      [i]));
61       _vhdl_testbench->add_input (PORT_READ( in_WRITE_IN_ADDRESS  [i]));
62       _vhdl_testbench->add_input (PORT_READ( in_WRITE_IN_DATA     [i]));
63     }
64   
65   for (uint32_t i=0; i<_param._nb_bank; i++)
66     for (uint32_t j=0; j<_param._nb_port_write_by_bank; j++)
67       for (uint32_t k=0; k<_param._nb_port_select_by_bank_write_port [j]; k++)
68         {
69           _vhdl_testbench->add_output(PORT_READ(out_WRITE_SELECT_VAL [i][j][k]));
70           _vhdl_testbench->add_input (PORT_READ( in_WRITE_SELECT_ACK [i][j][k]));
71         }
72   
73    for (uint32_t i=0; i<_param._nb_bank; i++)
74      for (uint32_t j=0; j<_param._nb_port_write_by_bank; j++)
75        {
76          _vhdl_testbench->add_output(PORT_READ(out_WRITE_OUT_VAL     [i][j]));
77          _vhdl_testbench->add_input (PORT_READ( in_WRITE_OUT_ACK     [i][j]));
78          _vhdl_testbench->add_output(PORT_READ(out_WRITE_OUT_ADDRESS [i][j]));
79          _vhdl_testbench->add_output(PORT_READ(out_WRITE_OUT_DATA    [i][j]));
80        }
81   
82
83    // add_test :
84    //  - True  : the cycle must be compare with the output of systemC
85    //  - False : no test
86    _vhdl_testbench->add_test(true);
87
88    _vhdl_testbench->new_cycle (); // always at the end
89
90    log_printf(FUNC,RegisterFile_Multi_Banked_Glue,"vhdl_testbench_transition","End");
91  };
92
93}; // end namespace registerfile_multi_banked_glue
94}; // end namespace registerfile_multi_banked
95}; // end namespace registerfile
96}; // end namespace generic
97
98}; // end namespace behavioural
99}; // end namespace morpheo             
100#endif
Note: See TracBrowser for help on using the repository browser.