source: trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Prediction_unit/SelfTest/src/main.cpp @ 146

Last change on this file since 146 was 146, checked in by rosiere, 13 years ago

1) Integration of RegisterFile_Internal_Banked in RegisterFile?
2) Erase "read_write" interface in RegisterFile_Monolithic component
3) Add smith predictor parameters in Load_store_pointer_unit.
4) Fix not statistics flags

  • Property svn:keywords set to Id
File size: 7.8 KB
Line 
1/*
2 * $Id: main.cpp 146 2011-02-01 20:57:54Z rosiere $
3 *
4 * [ Description ]
5 *
6 */
7
8#include "Behavioural/Core/Multi_Front_end/Front_end/Prediction_unit/SelfTest/include/test.h"
9
10#define NB_PARAMS (12+3*8)
11
12void usage (int argc, char * argv[])
13{
14  err (_("<Usage> %s name_instance list_params.\n"),argv[0]);
15  err (_("list_params is :\n"));
16  err (_(" * nb_context                                (uint32_t     )\n"));
17  err (_(" * nb_decod_unit                             (uint32_t     )\n"));
18  err (_(" * size_address                              (uint32_t     )\n"));
19  err (_(" * nb_instruction             [nb_context]   (uint32_t     )\n"));
20  err (_(" * nb_inst_decod              [nb_decod_unit](uint32_t     )\n"));
21  err (_(" * nb_inst_branch_predict                    (uint32_t     )\n"));
22  err (_(" * nb_inst_branch_decod                      (uint32_t     )\n"));
23  err (_(" * nb_inst_branch_update                     (uint32_t     )\n"));
24  err (_(" * nb_inst_branch_complete                   (uint32_t     )\n"));
25  err (_(" * btb_size_queue                            (uint32_t     )\n"));
26  err (_(" * btb_associativity                         (uint32_t     )\n"));
27  err (_(" * btb_size_counter                          (uint32_t     )\n"));
28  err (_(" * btb_victim_scheme                         (Tvictim_t    )\n"));
29  err (_(" * dir_predictor_scheme                      (Tpredictor_t )\n"));
30  err (_(" * dir_have_bht               [3]            (bool         )\n"));
31  err (_(" * dir_bht_size_shifter       [3]            (uint32_t     )\n"));
32  err (_(" * dir_bht_nb_shifter         [3]            (uint32_t     )\n"));
33  err (_(" * dir_have_pht               [3]            (bool         )\n"));
34  err (_(" * dir_pht_size_counter       [3]            (uint32_t     )\n"));
35  err (_(" * dir_pht_nb_counter         [3]            (uint32_t     )\n"));
36  err (_(" * dir_pht_size_address_share [3]            (uint32_t     )\n"));
37  err (_(" * dir_pht_scheme             [3]            (Tpht_scheme_t)\n"));
38  err (_(" * ras_size_queue             [nb_context]   (uint32_t     )\n"));
39  err (_(" * upt_size_queue             [nb_context]   (uint32_t     )\n"));
40  err (_(" * ufpt_size_queue            [nb_context]   (uint32_t     )\n"));
41
42  exit (1);
43}
44
45#ifndef SYSTEMC
46int main    (int argc, char * argv[])
47#else
48int sc_main (int argc, char * argv[])
49#endif
50{
51  if (argc < static_cast<int>(2+NB_PARAMS))
52    usage (argc, argv);
53
54  uint32_t x = 1;
55
56  string name = argv[x++];
57  uint32_t     _nb_context                     = fromString<uint32_t>(argv[x++]);
58  uint32_t     _nb_decod_unit                  = fromString<uint32_t>(argv[x++]);
59  uint32_t     _size_address                   = fromString<uint32_t>(argv[x++]);
60
61  if (argc != static_cast<int>(2+NB_PARAMS+4*_nb_context+_nb_decod_unit))
62    usage (argc, argv);
63
64  uint32_t *   _nb_instruction                 = new uint32_t [_nb_context];
65  for (uint32_t i=0; i<_nb_context; i++)
66    _nb_instruction [i]                        = fromString<uint32_t    >(argv[x++]);
67  uint32_t *   _nb_inst_decod                  = new uint32_t [_nb_decod_unit];
68  for (uint32_t i=0; i<_nb_decod_unit; i++)
69    _nb_inst_decod [i]                         = fromString<uint32_t    >(argv[x++]);
70  uint32_t     _nb_inst_branch_predict         = fromString<uint32_t    >(argv[x++]);
71  uint32_t     _nb_inst_branch_decod           = fromString<uint32_t    >(argv[x++]);
72  uint32_t     _nb_inst_branch_update          = fromString<uint32_t    >(argv[x++]);
73  uint32_t     _nb_inst_branch_complete        = fromString<uint32_t    >(argv[x++]);
74  uint32_t     _btb_size_queue                 = fromString<uint32_t    >(argv[x++]);
75  uint32_t     _btb_associativity              = fromString<uint32_t    >(argv[x++]);
76  uint32_t     _btb_size_counter               = fromString<uint32_t    >(argv[x++]);
77  Tvictim_t    _btb_victim_scheme              = fromString<Tvictim_t   >(argv[x++]);
78  Tpredictor_t _dir_predictor_scheme           = fromString<Tpredictor_t>(argv[x++]);
79  bool         _dir_have_bht               [3];
80  for (uint32_t i=0; i<3; i++)
81    _dir_have_bht [i]                          = fromString<bool        >(argv[x++]);
82  uint32_t     _dir_bht_size_shifter       [3];
83  for (uint32_t i=0; i<3; i++)
84    _dir_bht_size_shifter [i]                  = fromString<uint32_t    >(argv[x++]);
85  uint32_t     _dir_bht_nb_shifter         [3];
86  for (uint32_t i=0; i<3; i++)
87    _dir_bht_nb_shifter [i]                    = fromString<uint32_t    >(argv[x++]);
88  bool         _dir_have_pht               [3];
89  for (uint32_t i=0; i<3; i++)
90    _dir_have_pht [i]                          = fromString<bool        >(argv[x++]);
91  uint32_t     _dir_pht_size_counter       [3];
92  for (uint32_t i=0; i<3; i++)
93    _dir_pht_size_counter [i]                  = fromString<uint32_t    >(argv[x++]);
94  uint32_t     _dir_pht_nb_counter         [3];
95  for (uint32_t i=0; i<3; i++)
96    _dir_pht_nb_counter [i]                    = fromString<uint32_t    >(argv[x++]);
97  uint32_t     _dir_pht_size_address_share [3];
98  for (uint32_t i=0; i<3; i++)
99    _dir_pht_size_address_share [i]            = fromString<uint32_t    >(argv[x++]);
100  Tpht_scheme_t _dir_pht_scheme             [3];
101  for (uint32_t i=0; i<3; i++)
102    _dir_pht_scheme [i]                        = fromString<Tpht_scheme_t>(argv[x++]);
103  uint32_t *   _ras_size_queue                 = new uint32_t    [_nb_context];
104  for (uint32_t i=0; i<_nb_context; i++)
105    _ras_size_queue [i]                        = fromString<uint32_t    >(argv[x++]);
106  uint32_t *   _upt_size_queue                 = new uint32_t    [_nb_context];
107  for (uint32_t i=0; i<_nb_context; i++)
108    _upt_size_queue [i]                        = fromString<uint32_t    >(argv[x++]);
109  uint32_t *   _ufpt_size_queue                = new uint32_t    [_nb_context];
110  for (uint32_t i=0; i<_nb_context; i++)
111    _ufpt_size_queue [i]                       = fromString<uint32_t    >(argv[x++]);
112
113  uint32_t     _nb_thread                           = _nb_context;
114  uint32_t *   _translate_num_context_to_num_thread = new uint32_t    [_nb_context];
115  for (uint32_t i=0; i<_nb_context; i++)
116    _translate_num_context_to_num_thread [i] = i;
117
118  int _return = EXIT_SUCCESS;
119  try 
120    {
121      morpheo::behavioural::core::multi_front_end::front_end::prediction_unit::Parameters * param = new morpheo::behavioural::core::multi_front_end::front_end::prediction_unit::Parameters
122        (_nb_context                ,
123         _nb_decod_unit             ,
124         _size_address              ,
125         _nb_instruction            ,
126         _nb_inst_decod             ,
127         _nb_inst_branch_predict    ,
128         _nb_inst_branch_decod      ,
129         _nb_inst_branch_update     ,
130         _nb_inst_branch_complete   ,
131         _btb_size_queue            ,
132         _btb_associativity         ,
133         _btb_size_counter          ,
134         _btb_victim_scheme         ,
135         _dir_predictor_scheme      ,
136         _dir_have_bht              ,
137         _dir_bht_size_shifter      ,
138         _dir_bht_nb_shifter        ,
139         _dir_have_pht              ,
140         _dir_pht_size_counter      ,
141         _dir_pht_nb_counter        ,
142         _dir_pht_size_address_share,
143         _dir_pht_scheme            ,
144         _ras_size_queue            ,
145         _upt_size_queue            ,
146         _ufpt_size_queue           ,
147         _nb_thread                          ,
148         _translate_num_context_to_num_thread,
149         true // is_toplevel
150         );
151     
152      msg(_("%s"),param->print(1).c_str());
153     
154      test (name,param);
155    }
156  catch (morpheo::ErrorMorpheo & error)
157    {
158      msg (_("<%s> :\n%s"),name.c_str(), error.what ());
159      _return = EXIT_FAILURE;
160    }
161  catch (...)
162    {
163      err (_("<%s> : This test must generate a error.\n"),name.c_str());
164      _return = EXIT_FAILURE;
165    }
166
167  delete [] _nb_instruction            ;
168  delete [] _nb_inst_decod             ;
169  delete [] _ras_size_queue            ;
170  delete [] _upt_size_queue            ;
171  delete [] _ufpt_size_queue           ;
172  delete [] _translate_num_context_to_num_thread;
173
174  return (_return);
175}
Note: See TracBrowser for help on using the repository browser.