source: trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Network/Execution_unit_to_Write_unit/SelfTest/src/main.cpp @ 88

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

Almost complete design
with Test and test platform

  • Property svn:keywords set to Id
File size: 5.2 KB
Line 
1/*
2 * $Id: main.cpp 88 2008-12-10 18:31:39Z rosiere $
3 *
4 * [ Description ]
5 *
6 */
7
8#include "Behavioural/Core/Multi_Execute_loop/Execute_loop/Network/Execution_unit_to_Write_unit/SelfTest/include/test.h"
9
10#define NB_PARAMS 11
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_execute_unit                                                      (uint32_t)\n"));
17  err (_("  * nb_execute_unit_port [nb_execute_unit]                               (uint32_t)\n"));
18  err (_("  * nb_write_unit                                                        (uint32_t)\n"));
19  err (_("  * nb_context                                                           (uint32_t)\n"));
20  err (_("  * nb_front_end                                                         (uint32_t)\n"));
21  err (_("  * nb_ooo_engine                                                        (uint32_t)\n"));
22  err (_("  * nb_packet                                                            (uint32_t)\n"));
23  err (_("  * size_general_data                                                    (uint32_t)\n"));
24  err (_("  * size_special_data                                                    (uint32_t)\n"));
25  err (_("  * nb_general_register                                                  (uint32_t)\n"));
26  err (_("  * nb_special_register                                                  (uint32_t)\n"));
27  err (_("  * priority                                                             (uint32_t)\n"));
28  err (_("  * table_routing [nb_execute_unit][nb_execute_unit_port][nb_write_unit] (bool    )\n"));
29  err (_("  * table_thread  [nb_write_unit][nb_thread]                             (bool    )\n"));
30
31  exit (1);
32}
33
34#ifndef SYSTEMC
35int main    (int argc, char * argv[])
36#else
37int sc_main (int argc, char * argv[])
38#endif
39{
40  if (argc < 2+NB_PARAMS)
41    usage (argc, argv);
42
43  uint32_t       x = 1;
44
45  const string   name      =      argv[x++];
46  uint32_t    _nb_execute_unit      = fromString<uint32_t>(argv[x++]);
47
48  if (static_cast<uint32_t>(argc) <= 2+NB_PARAMS+_nb_execute_unit)
49    usage (argc, argv);
50
51  uint32_t    _sum_execute_unit_port = 0;
52  uint32_t *  _nb_execute_unit_port = new uint32_t [_nb_execute_unit];
53  for (uint32_t i=0; i<_nb_execute_unit; i++)
54    {
55      _nb_execute_unit_port [i] = fromString<uint32_t>(argv[x++]);
56      _sum_execute_unit_port += _nb_execute_unit_port [i];
57    }
58
59  uint32_t    _nb_write_unit        = fromString<uint32_t>(argv[x++]);
60  uint32_t    _nb_context           = fromString<uint32_t>(argv[x++]);
61  uint32_t    _nb_front_end         = fromString<uint32_t>(argv[x++]);
62  uint32_t    _nb_ooo_engine        = fromString<uint32_t>(argv[x++]);
63  uint32_t    _nb_packet            = fromString<uint32_t>(argv[x++]);
64  uint32_t    _size_general_data    = fromString<uint32_t>(argv[x++]);
65  uint32_t    _size_special_data    = fromString<uint32_t>(argv[x++]);
66  uint32_t    _nb_general_register  = fromString<uint32_t>(argv[x++]);
67  uint32_t    _nb_special_register  = fromString<uint32_t>(argv[x++]);
68  Tpriority_t _priority             = fromString<Tpriority_t>(argv[x++]);
69
70  uint32_t    _nb_thread            = get_nb_thread(_nb_context, _nb_front_end, _nb_ooo_engine);
71
72  if (static_cast<uint32_t>(argc) != 2+NB_PARAMS+_nb_execute_unit+(_nb_write_unit*_sum_execute_unit_port)+(_nb_write_unit*_nb_thread))
73    usage (argc, argv);
74 
75  bool *** _table_routing;
76  bool  ** _table_thread ;
77 
78  _table_routing = new bool ** [_nb_execute_unit];
79  for (uint32_t i=0; i<_nb_execute_unit; i++)
80    {
81      _table_routing [i] = new bool * [_nb_execute_unit_port [i]];
82      for (uint32_t j=0; j<_nb_execute_unit_port [i]; j++)
83        {
84          _table_routing [i][j] = new bool [_nb_write_unit];
85          for (uint32_t k=0; k<_nb_write_unit; k++)
86            _table_routing [i][j][k] = fromString<bool>(argv[x++]);
87        }
88    }
89
90  _table_thread = new bool * [_nb_write_unit];
91  for (uint32_t i=0; i<_nb_write_unit; i++)
92    {
93      _table_thread [i] = new bool [_nb_thread];
94
95      for (uint32_t j=0; j<_nb_thread; j++)
96        _table_thread [i][j] = fromString<bool>(argv[x++]);
97    }
98
99  int _return = EXIT_SUCCESS;
100  try 
101    {
102      morpheo::behavioural::core::multi_execute_loop::execute_loop::network::execution_unit_to_write_unit::Parameters * param = new morpheo::behavioural::core::multi_execute_loop::execute_loop::network::execution_unit_to_write_unit::Parameters
103        (_nb_execute_unit      ,
104         _nb_execute_unit_port ,
105         _nb_write_unit        ,
106         _nb_context           ,
107         _nb_front_end         ,
108         _nb_ooo_engine        ,
109         _nb_packet            ,
110         _size_general_data    ,
111         _size_special_data    ,
112         _nb_general_register  ,
113         _nb_special_register  ,
114         _priority             ,
115         _table_routing        ,
116         _table_thread         ,
117         true //is_toplevel
118         );
119     
120      msg(_("%s"),param->print(0).c_str());
121     
122      test (name,param);
123    }
124  catch (morpheo::ErrorMorpheo & error)
125    {
126      msg (_("<%s> :\n%s"),name.c_str(), error.what ());
127      _return = EXIT_FAILURE;
128    }
129 
130  try 
131    {
132      if (_return == EXIT_SUCCESS)
133        TEST_OK("Execution_unit_to_Write_unit : no error");
134      else
135        TEST_KO("Execution_unit_to_Write_unit : a lot of error");
136    }
137  catch (morpheo::ErrorMorpheo & error)
138    {
139//       msg (_("<%s> :\n%s"),name.c_str(), error.what ());
140      _return = EXIT_FAILURE;
141    }
142
143  return (EXIT_SUCCESS);
144}
145
Note: See TracBrowser for help on using the repository browser.