source: trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_OOO_Engine/OOO_Engine/Rename_unit/Rename_select/SelfTest/src/test.cpp @ 78

Last change on this file since 78 was 78, checked in by rosiere, 16 years ago

Add :

  • Execute_loop (must be test systemC)
  • Prediction
    • Direction : predifined scheme
    • Branch Target Buffer
  • iFetch_unit
    • ifetch_queue
    • pc management
  • Decod_unit
    • coming soon : support for custom operation
  • Rename_unit
    • RAT
    • Free_list
    • Dependence RAW check
    • Load store unit pointer
  • New Environnement (hierarchy_memory will remove in a next version)


Modif :

  • Manage Custom Operation
  • All component in execute_loop to use the new statistics management

Not Finish :

  • Return Address Stack
  • Environnement
File size: 22.1 KB
Line 
1/*
2 * $Id$
3 *
4 * [ Description ]
5 *
6 * Test
7 */
8
9#include "Behavioural/Core/Multi_OOO_Engine/OOO_Engine/Rename_unit/Rename_select/SelfTest/include/test.h"
10#include "Common/include/Test.h"
11#include "Common/include/BitManipulation.h"
12#include "Behavioural/include/Allocation.h"
13
14#define NB_ITERATION  256
15#define CYCLE_MAX     (128*NB_ITERATION)
16
17#define LABEL(str...)                                                   \
18  {                                                                     \
19    msg (_("{%d} "),static_cast<uint32_t>(sc_simulation_time()));       \
20    msg (str);                                                          \
21    msg (_("\n"));                                                      \
22  } while(0)
23
24#define SC_START(cycle_offset)                                                       \
25  do                                                                                 \
26    {                                                                                \
27      /*cout << "SC_START (begin)" << endl;*/                                        \
28                                                                                     \
29      uint32_t cycle_current = static_cast<uint32_t>(sc_simulation_time());          \
30      if (cycle_offset != 0)                                                         \
31        {                                                                            \
32          cout << "##########[ cycle "<< cycle_current+cycle_offset << " ]" << endl; \
33        }                                                                            \
34                                                                                     \
35      if (cycle_current > CYCLE_MAX)                                                 \
36        {                                                                            \
37          TEST_KO("Maximal cycles Reached");                                         \
38        }                                                                            \
39                                                                                     \
40      sc_start(cycle_offset);                                                        \
41                                                                                     \
42      /*cout << "SC_START (end  )" << endl;*/                                        \
43    } while(0)
44
45void test (string name,
46           morpheo::behavioural::core::multi_ooo_engine::ooo_engine::rename_unit::rename_select::Parameters * _param)
47{
48  msg(_("<%s> : Simulation SystemC.\n"),name.c_str());
49
50#ifdef STATISTICS
51  morpheo::behavioural::Parameters_Statistics * _parameters_statistics = new morpheo::behavioural::Parameters_Statistics (5,50);
52#endif
53
54  Rename_select * _Rename_select = new Rename_select (name.c_str(),
55#ifdef STATISTICS
56                                             _parameters_statistics,
57#endif
58                                             _param);
59 
60#ifdef SYSTEMC
61  /*********************************************************************
62   * Déclarations des signaux
63   *********************************************************************/
64  string rename;
65
66  sc_clock              *  in_CLOCK  = new sc_clock ("clock", 1.0, 0.5);         
67  sc_signal<Tcontrol_t> *  in_NRESET = new sc_signal<Tcontrol_t> ("NRESET");
68
69  ALLOC2_SC_SIGNAL( in_RENAME_IN_VAL           ," in_RENAME_IN_VAL           ",Tcontrol_t        ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
70  ALLOC2_SC_SIGNAL(out_RENAME_IN_ACK           ,"out_RENAME_IN_ACK           ",Tcontrol_t        ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
71  ALLOC2_SC_SIGNAL( in_RENAME_IN_FRONT_END_ID  ," in_RENAME_IN_FRONT_END_ID  ",Tcontext_t        ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
72  ALLOC2_SC_SIGNAL( in_RENAME_IN_CONTEXT_ID    ," in_RENAME_IN_CONTEXT_ID    ",Tcontext_t        ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
73  ALLOC2_SC_SIGNAL( in_RENAME_IN_DEPTH         ," in_RENAME_IN_DEPTH         ",Tdepth_t          ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
74  ALLOC2_SC_SIGNAL( in_RENAME_IN_TYPE          ," in_RENAME_IN_TYPE          ",Ttype_t           ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
75  ALLOC2_SC_SIGNAL( in_RENAME_IN_OPERATION     ," in_RENAME_IN_OPERATION     ",Toperation_t      ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
76  ALLOC2_SC_SIGNAL( in_RENAME_IN_ADDRESS       ," in_RENAME_IN_ADDRESS       ",Tgeneral_data_t   ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
77  ALLOC2_SC_SIGNAL( in_RENAME_IN_HAS_IMMEDIAT  ," in_RENAME_IN_HAS_IMMEDIAT  ",Tcontrol_t        ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
78  ALLOC2_SC_SIGNAL( in_RENAME_IN_IMMEDIAT      ," in_RENAME_IN_IMMEDIAT      ",Tgeneral_data_t   ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
79  ALLOC2_SC_SIGNAL( in_RENAME_IN_READ_RA       ," in_RENAME_IN_READ_RA       ",Tcontrol_t        ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
80  ALLOC2_SC_SIGNAL( in_RENAME_IN_NUM_REG_RA    ," in_RENAME_IN_NUM_REG_RA    ",Tgeneral_address_t,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
81  ALLOC2_SC_SIGNAL( in_RENAME_IN_READ_RB       ," in_RENAME_IN_READ_RB       ",Tcontrol_t        ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
82  ALLOC2_SC_SIGNAL( in_RENAME_IN_NUM_REG_RB    ," in_RENAME_IN_NUM_REG_RB    ",Tgeneral_address_t,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
83  ALLOC2_SC_SIGNAL( in_RENAME_IN_READ_RC       ," in_RENAME_IN_READ_RC       ",Tcontrol_t        ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
84  ALLOC2_SC_SIGNAL( in_RENAME_IN_NUM_REG_RC    ," in_RENAME_IN_NUM_REG_RC    ",Tspecial_address_t,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
85  ALLOC2_SC_SIGNAL( in_RENAME_IN_WRITE_RD      ," in_RENAME_IN_WRITE_RD      ",Tcontrol_t        ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
86  ALLOC2_SC_SIGNAL( in_RENAME_IN_NUM_REG_RD    ," in_RENAME_IN_NUM_REG_RD    ",Tgeneral_address_t,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
87  ALLOC2_SC_SIGNAL( in_RENAME_IN_WRITE_RE      ," in_RENAME_IN_WRITE_RE      ",Tcontrol_t        ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
88  ALLOC2_SC_SIGNAL( in_RENAME_IN_NUM_REG_RE    ," in_RENAME_IN_NUM_REG_RE    ",Tspecial_address_t,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
89  ALLOC2_SC_SIGNAL( in_RENAME_IN_EXCEPTION_USE ," in_RENAME_IN_EXCEPTION_USE ",Texception_t      ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
90
91  ALLOC1_SC_SIGNAL(out_RENAME_OUT_VAL          ,"out_RENAME_OUT_VAL          ",Tcontrol_t        ,_param->_nb_inst_rename);
92  ALLOC1_SC_SIGNAL( in_RENAME_OUT_ACK          ," in_RENAME_OUT_ACK          ",Tcontrol_t        ,_param->_nb_inst_rename);
93  ALLOC1_SC_SIGNAL(out_RENAME_OUT_FRONT_END_ID ,"out_RENAME_OUT_FRONT_END_ID ",Tcontext_t        ,_param->_nb_inst_rename);
94  ALLOC1_SC_SIGNAL(out_RENAME_OUT_CONTEXT_ID   ,"out_RENAME_OUT_CONTEXT_ID   ",Tcontext_t        ,_param->_nb_inst_rename);
95  ALLOC1_SC_SIGNAL(out_RENAME_OUT_DEPTH        ,"out_RENAME_OUT_DEPTH        ",Tdepth_t          ,_param->_nb_inst_rename);
96  ALLOC1_SC_SIGNAL(out_RENAME_OUT_TYPE         ,"out_RENAME_OUT_TYPE         ",Ttype_t           ,_param->_nb_inst_rename);
97  ALLOC1_SC_SIGNAL(out_RENAME_OUT_OPERATION    ,"out_RENAME_OUT_OPERATION    ",Toperation_t      ,_param->_nb_inst_rename);
98  ALLOC1_SC_SIGNAL(out_RENAME_OUT_ADDRESS      ,"out_RENAME_OUT_ADDRESS      ",Tgeneral_data_t   ,_param->_nb_inst_rename);
99  ALLOC1_SC_SIGNAL(out_RENAME_OUT_HAS_IMMEDIAT ,"out_RENAME_OUT_HAS_IMMEDIAT ",Tcontrol_t        ,_param->_nb_inst_rename);
100  ALLOC1_SC_SIGNAL(out_RENAME_OUT_IMMEDIAT     ,"out_RENAME_OUT_IMMEDIAT     ",Tgeneral_data_t   ,_param->_nb_inst_rename);
101  ALLOC1_SC_SIGNAL(out_RENAME_OUT_READ_RA      ,"out_RENAME_OUT_READ_RA      ",Tcontrol_t        ,_param->_nb_inst_rename);
102  ALLOC1_SC_SIGNAL(out_RENAME_OUT_NUM_REG_RA   ,"out_RENAME_OUT_NUM_REG_RA   ",Tgeneral_address_t,_param->_nb_inst_rename);
103  ALLOC1_SC_SIGNAL(out_RENAME_OUT_READ_RB      ,"out_RENAME_OUT_READ_RB      ",Tcontrol_t        ,_param->_nb_inst_rename);
104  ALLOC1_SC_SIGNAL(out_RENAME_OUT_NUM_REG_RB   ,"out_RENAME_OUT_NUM_REG_RB   ",Tgeneral_address_t,_param->_nb_inst_rename);
105  ALLOC1_SC_SIGNAL(out_RENAME_OUT_READ_RC      ,"out_RENAME_OUT_READ_RC      ",Tcontrol_t        ,_param->_nb_inst_rename);
106  ALLOC1_SC_SIGNAL(out_RENAME_OUT_NUM_REG_RC   ,"out_RENAME_OUT_NUM_REG_RC   ",Tspecial_address_t,_param->_nb_inst_rename);
107  ALLOC1_SC_SIGNAL(out_RENAME_OUT_WRITE_RD     ,"out_RENAME_OUT_WRITE_RD     ",Tcontrol_t        ,_param->_nb_inst_rename);
108  ALLOC1_SC_SIGNAL(out_RENAME_OUT_NUM_REG_RD   ,"out_RENAME_OUT_NUM_REG_RD   ",Tgeneral_address_t,_param->_nb_inst_rename);
109  ALLOC1_SC_SIGNAL(out_RENAME_OUT_WRITE_RE     ,"out_RENAME_OUT_WRITE_RE     ",Tcontrol_t        ,_param->_nb_inst_rename);
110  ALLOC1_SC_SIGNAL(out_RENAME_OUT_NUM_REG_RE   ,"out_RENAME_OUT_NUM_REG_RE   ",Tspecial_address_t,_param->_nb_inst_rename);
111  ALLOC1_SC_SIGNAL(out_RENAME_OUT_EXCEPTION_USE,"out_RENAME_OUT_EXCEPTION_USE",Texception_t      ,_param->_nb_inst_rename);
112 
113  /********************************************************
114   * Instanciation
115   ********************************************************/
116 
117  msg(_("<%s> : Instanciation of _Rename_select.\n"),name.c_str());
118
119  (*(_Rename_select->in_CLOCK))        (*(in_CLOCK));
120  (*(_Rename_select->in_NRESET))       (*(in_NRESET));
121
122  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_VAL           ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
123  INSTANCE2_SC_SIGNAL(_Rename_select,out_RENAME_IN_ACK           ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
124  if (_param->_have_port_front_end_id)
125  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_FRONT_END_ID  ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
126  if (_param->_have_port_context_id)
127  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_CONTEXT_ID    ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
128  if (_param->_have_port_depth)
129  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_DEPTH         ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
130  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_TYPE          ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
131  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_OPERATION     ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
132  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_ADDRESS       ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
133  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_HAS_IMMEDIAT  ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
134  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_IMMEDIAT      ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
135  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_READ_RA       ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
136  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_NUM_REG_RA    ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
137  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_READ_RB       ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
138  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_NUM_REG_RB    ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
139  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_READ_RC       ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
140  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_NUM_REG_RC    ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
141  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_WRITE_RD      ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
142  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_NUM_REG_RD    ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
143  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_WRITE_RE      ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
144  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_NUM_REG_RE    ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
145  INSTANCE2_SC_SIGNAL(_Rename_select, in_RENAME_IN_EXCEPTION_USE ,_param->_nb_front_end, _param->_nb_inst_decod[alloc_signal_it1]);
146
147  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_VAL          ,_param->_nb_inst_rename);
148  INSTANCE1_SC_SIGNAL(_Rename_select, in_RENAME_OUT_ACK          ,_param->_nb_inst_rename);
149  if (_param->_have_port_front_end_id)
150  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_FRONT_END_ID ,_param->_nb_inst_rename);
151  if (_param->_have_port_context_id)
152  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_CONTEXT_ID   ,_param->_nb_inst_rename);
153  if (_param->_have_port_depth)
154  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_DEPTH        ,_param->_nb_inst_rename);
155  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_TYPE         ,_param->_nb_inst_rename);
156  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_OPERATION    ,_param->_nb_inst_rename);
157  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_ADDRESS      ,_param->_nb_inst_rename);
158  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_HAS_IMMEDIAT ,_param->_nb_inst_rename);
159  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_IMMEDIAT     ,_param->_nb_inst_rename);
160  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_READ_RA      ,_param->_nb_inst_rename);
161  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_NUM_REG_RA   ,_param->_nb_inst_rename);
162  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_READ_RB      ,_param->_nb_inst_rename);
163  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_NUM_REG_RB   ,_param->_nb_inst_rename);
164  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_READ_RC      ,_param->_nb_inst_rename);
165  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_NUM_REG_RC   ,_param->_nb_inst_rename);
166  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_WRITE_RD     ,_param->_nb_inst_rename);
167  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_NUM_REG_RD   ,_param->_nb_inst_rename);
168  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_WRITE_RE     ,_param->_nb_inst_rename);
169  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_NUM_REG_RE   ,_param->_nb_inst_rename);
170  INSTANCE1_SC_SIGNAL(_Rename_select,out_RENAME_OUT_EXCEPTION_USE,_param->_nb_inst_rename);
171
172  msg(_("<%s> : Start Simulation ............\n"),name.c_str());
173   
174  Time * _time = new Time();
175
176  /********************************************************
177   * Simulation - Begin
178   ********************************************************/
179
180  // Initialisation
181
182  const uint32_t seed = 0;
183//const uint32_t seed = static_cast<uint32_t>(time(NULL));
184
185  srand(seed);
186
187  const  int32_t percent_transaction_rename_in  = 75;
188  const  int32_t percent_transaction_rename_out = 75;
189
190  uint32_t nb_rename_in = 0;
191  for (uint32_t i=0; i<_param->_nb_front_end; i++)
192    nb_rename_in += _param->_nb_inst_decod[i];
193
194  SC_START(0);
195  LABEL("Initialisation");
196
197  LABEL("Reset");
198  in_NRESET->write(0);
199  SC_START(5);
200  in_NRESET->write(1); 
201
202  LABEL("Loop of Test");
203
204  for (uint32_t iteration=0; iteration<NB_ITERATION; iteration ++)
205    {
206      LABEL("Iteration %d",iteration);
207
208      uint32_t address=0;
209      for (uint32_t i=0; i<_param->_nb_front_end; i++)
210        for (uint32_t j=0; j<_param->_nb_inst_decod[i]; j++)
211          {
212            in_RENAME_IN_VAL          [i][j]->write((rand()%100)<percent_transaction_rename_in);
213            in_RENAME_IN_FRONT_END_ID [i][j]->write(range<Tcontext_t        >(rand(),_param->_size_front_end_id          ));
214            in_RENAME_IN_CONTEXT_ID   [i][j]->write(range<Tcontext_t        >(rand(),log2(_param->_nb_context[i])        ));
215            in_RENAME_IN_DEPTH        [i][j]->write(range<Tdepth_t          >(rand(),_param->_size_depth                 ));
216            in_RENAME_IN_TYPE         [i][j]->write(range<Ttype_t           >(rand(),_param->_size_type                  ));
217            in_RENAME_IN_OPERATION    [i][j]->write(range<Toperation_t      >(rand(),_param->_size_operation             ));
218            in_RENAME_IN_ADDRESS      [i][j]->write(address++                                                             );
219            in_RENAME_IN_HAS_IMMEDIAT [i][j]->write(range<Tcontrol_t        >(rand(),1                                   ));
220            in_RENAME_IN_IMMEDIAT     [i][j]->write(range<Tgeneral_data_t   >(rand(),_param->_size_general_data          ));
221            in_RENAME_IN_READ_RA      [i][j]->write(range<Tcontrol_t        >(rand(),1                                   ));
222            in_RENAME_IN_NUM_REG_RA   [i][j]->write(range<Tgeneral_address_t>(rand(),_param->_size_general_register_logic));
223            in_RENAME_IN_READ_RB      [i][j]->write(range<Tcontrol_t        >(rand(),1                                   ));
224            in_RENAME_IN_NUM_REG_RB   [i][j]->write(range<Tgeneral_address_t>(rand(),_param->_size_general_register_logic));
225            in_RENAME_IN_READ_RC      [i][j]->write(range<Tcontrol_t        >(rand(),1                                   ));
226            in_RENAME_IN_NUM_REG_RC   [i][j]->write(range<Tspecial_address_t>(rand(),_param->_size_special_register_logic));
227            in_RENAME_IN_WRITE_RD     [i][j]->write(range<Tcontrol_t        >(rand(),1                                   ));
228            in_RENAME_IN_NUM_REG_RD   [i][j]->write(range<Tgeneral_address_t>(rand(),_param->_size_general_register_logic));
229            in_RENAME_IN_WRITE_RE     [i][j]->write(range<Tcontrol_t        >(rand(),1                                   ));
230            in_RENAME_IN_NUM_REG_RE   [i][j]->write(range<Tspecial_address_t>(rand(),_param->_size_special_register_logic));
231            in_RENAME_IN_EXCEPTION_USE[i][j]->write(range<Texception_t      >(rand(),_param->_size_exception             ));
232          }
233
234      for (uint32_t i=0; i<_param->_nb_inst_rename; i++)
235        in_RENAME_OUT_ACK [i]->write((rand()%100)<percent_transaction_rename_out);
236
237      SC_START(0);
238
239      uint32_t nb_transaction_rename_in  = 0;
240      uint32_t nb_transaction_rename_out = 0;
241
242      bool rename_in_use [nb_rename_in];
243      address = 0;
244
245      for (uint32_t i=0; i<_param->_nb_front_end; i++)
246        for (uint32_t j=0; j<_param->_nb_inst_decod[i]; j++)
247          {
248            rename_in_use[address++] = false;
249
250            if (in_RENAME_IN_VAL [i][j]->read() and out_RENAME_IN_ACK [i][j]->read())
251              {
252                nb_transaction_rename_in ++;
253              }
254          }
255     
256      for (uint32_t i=0; i<_param->_nb_inst_rename; i++)
257        {
258          if (out_RENAME_OUT_VAL [i]->read() and in_RENAME_OUT_ACK [i]->read())
259            {
260              nb_transaction_rename_out ++;
261
262              // Test
263              address = out_RENAME_OUT_ADDRESS [i]->read();
264
265              TEST(bool, address<nb_rename_in, true);
266              TEST(bool, rename_in_use[address], false);
267              rename_in_use[address] = true;
268
269              bool find = false;
270
271              for (uint32_t x=0; x<_param->_nb_front_end; x++)
272                for (uint32_t y=0; y<_param->_nb_inst_decod[x]; y++)
273                  if (in_RENAME_IN_ADDRESS [x][y]->read() == address)
274                    {
275                      find = true;
276                     
277                      if (_param->_have_port_front_end_id)
278                      TEST(Tcontext_t        ,out_RENAME_OUT_FRONT_END_ID [i]->read(),in_RENAME_IN_FRONT_END_ID [x][y]->read());
279                      if (_param->_have_port_context_id)
280                      TEST(Tcontext_t        ,out_RENAME_OUT_CONTEXT_ID   [i]->read(),in_RENAME_IN_CONTEXT_ID   [x][y]->read());
281                      if (_param->_have_port_depth)
282                      TEST(Tdepth_t          ,out_RENAME_OUT_DEPTH        [i]->read(),in_RENAME_IN_DEPTH        [x][y]->read());
283                      TEST(Ttype_t           ,out_RENAME_OUT_TYPE         [i]->read(),in_RENAME_IN_TYPE         [x][y]->read());
284                      TEST(Toperation_t      ,out_RENAME_OUT_OPERATION    [i]->read(),in_RENAME_IN_OPERATION    [x][y]->read());
285                      TEST(Tcontrol_t        ,out_RENAME_OUT_HAS_IMMEDIAT [i]->read(),in_RENAME_IN_HAS_IMMEDIAT [x][y]->read());
286                      TEST(Tgeneral_data_t   ,out_RENAME_OUT_IMMEDIAT     [i]->read(),in_RENAME_IN_IMMEDIAT     [x][y]->read());
287                      TEST(Tcontrol_t        ,out_RENAME_OUT_READ_RA      [i]->read(),in_RENAME_IN_READ_RA      [x][y]->read());
288                      TEST(Tgeneral_address_t,out_RENAME_OUT_NUM_REG_RA   [i]->read(),in_RENAME_IN_NUM_REG_RA   [x][y]->read());
289                      TEST(Tcontrol_t        ,out_RENAME_OUT_READ_RB      [i]->read(),in_RENAME_IN_READ_RB      [x][y]->read());
290                      TEST(Tgeneral_address_t,out_RENAME_OUT_NUM_REG_RB   [i]->read(),in_RENAME_IN_NUM_REG_RB   [x][y]->read());
291                      TEST(Tcontrol_t        ,out_RENAME_OUT_READ_RC      [i]->read(),in_RENAME_IN_READ_RC      [x][y]->read());
292                      TEST(Tspecial_address_t,out_RENAME_OUT_NUM_REG_RC   [i]->read(),in_RENAME_IN_NUM_REG_RC   [x][y]->read());
293                      TEST(Tcontrol_t        ,out_RENAME_OUT_WRITE_RD     [i]->read(),in_RENAME_IN_WRITE_RD     [x][y]->read());
294                      TEST(Tgeneral_address_t,out_RENAME_OUT_NUM_REG_RD   [i]->read(),in_RENAME_IN_NUM_REG_RD   [x][y]->read());
295                      TEST(Tcontrol_t        ,out_RENAME_OUT_WRITE_RE     [i]->read(),in_RENAME_IN_WRITE_RE     [x][y]->read());
296                      TEST(Tspecial_address_t,out_RENAME_OUT_NUM_REG_RE   [i]->read(),in_RENAME_IN_NUM_REG_RE   [x][y]->read());
297                      TEST(Texception_t      ,out_RENAME_OUT_EXCEPTION_USE[i]->read(),in_RENAME_IN_EXCEPTION_USE[x][y]->read());
298
299                  }
300
301              TEST(bool, find, true);
302            }
303        }
304
305      TEST(uint32_t, nb_transaction_rename_in, nb_transaction_rename_out);
306
307      SC_START(1);
308    }
309
310  /********************************************************
311   * Simulation - End
312   ********************************************************/
313
314  TEST_OK ("End of Simulation");
315  delete _time;
316
317  msg(_("<%s> : ............ Stop Simulation\n"),name.c_str());
318
319  delete in_CLOCK;
320  delete in_NRESET;
321
322  delete []  in_RENAME_IN_VAL           ;
323  delete [] out_RENAME_IN_ACK           ;
324  delete []  in_RENAME_IN_FRONT_END_ID  ;
325  delete []  in_RENAME_IN_CONTEXT_ID    ;
326  delete []  in_RENAME_IN_DEPTH         ;
327  delete []  in_RENAME_IN_TYPE          ;
328  delete []  in_RENAME_IN_OPERATION     ;
329  delete []  in_RENAME_IN_ADDRESS       ;
330  delete []  in_RENAME_IN_HAS_IMMEDIAT  ;
331  delete []  in_RENAME_IN_IMMEDIAT      ;
332  delete []  in_RENAME_IN_READ_RA       ;
333  delete []  in_RENAME_IN_NUM_REG_RA    ;
334  delete []  in_RENAME_IN_READ_RB       ;
335  delete []  in_RENAME_IN_NUM_REG_RB    ;
336  delete []  in_RENAME_IN_READ_RC       ;
337  delete []  in_RENAME_IN_NUM_REG_RC    ;
338  delete []  in_RENAME_IN_WRITE_RD      ;
339  delete []  in_RENAME_IN_NUM_REG_RD    ;
340  delete []  in_RENAME_IN_WRITE_RE      ;
341  delete []  in_RENAME_IN_NUM_REG_RE    ;
342  delete []  in_RENAME_IN_EXCEPTION_USE ;
343 
344  delete [] out_RENAME_OUT_VAL          ;
345  delete []  in_RENAME_OUT_ACK          ;
346  delete [] out_RENAME_OUT_FRONT_END_ID ;
347  delete [] out_RENAME_OUT_CONTEXT_ID   ;
348  delete [] out_RENAME_OUT_DEPTH        ;
349  delete [] out_RENAME_OUT_TYPE         ;
350  delete [] out_RENAME_OUT_OPERATION    ;
351  delete [] out_RENAME_OUT_ADDRESS      ;
352  delete [] out_RENAME_OUT_HAS_IMMEDIAT ;
353  delete [] out_RENAME_OUT_IMMEDIAT     ;
354  delete [] out_RENAME_OUT_READ_RA      ;
355  delete [] out_RENAME_OUT_NUM_REG_RA   ;
356  delete [] out_RENAME_OUT_READ_RB      ;
357  delete [] out_RENAME_OUT_NUM_REG_RB   ;
358  delete [] out_RENAME_OUT_READ_RC      ;
359  delete [] out_RENAME_OUT_NUM_REG_RC   ;
360  delete [] out_RENAME_OUT_WRITE_RD     ;
361  delete [] out_RENAME_OUT_NUM_REG_RD   ;
362  delete [] out_RENAME_OUT_WRITE_RE     ;
363  delete [] out_RENAME_OUT_NUM_REG_RE   ;
364  delete [] out_RENAME_OUT_EXCEPTION_USE;
365#endif
366
367  delete _Rename_select;
368#ifdef STATISTICS
369  delete _parameters_statistics;
370#endif
371}
Note: See TracBrowser for help on using the repository browser.