source: trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Write_unit/Write_unit/Write_queue/include/Types.h @ 115

Last change on this file since 115 was 115, checked in by rosiere, 15 years ago

1) Write queue with mealy
2) Network : fix bug
3) leak memory

  • Property svn:keywords set to Id
File size: 4.7 KB
Line 
1#ifndef morpheo_behavioural_core_multi_execute_loop_execute_loop_multi_write_unit_write_unit_write_queue_Types_h
2#define morpheo_behavioural_core_multi_execute_loop_execute_loop_multi_write_unit_write_unit_write_queue_Types_h
3
4/*
5 * $Id: Types.h 115 2009-04-20 21:29:17Z rosiere $
6 *
7 * [ Description ]
8 *
9 */
10
11#include "Behavioural/include/Types.h"
12
13namespace morpheo {
14namespace behavioural {
15namespace core {
16namespace multi_execute_loop {
17namespace execute_loop {
18namespace multi_write_unit {
19namespace write_unit {
20namespace write_queue {
21
22  typedef enum 
23    {
24       WRITE_QUEUE_SCHEME_MOORE // Write register and pop is not in same cycle
25      ,WRITE_QUEUE_SCHEME_MEALY // Write register and pop can be in same cycle
26    } Twrite_queue_scheme_t;
27
28  class write_queue_entry_t
29  {
30  public  : Tcontext_t         _context_id   ;
31  public  : Tcontext_t         _front_end_id ;
32  public  : Tcontext_t         _ooo_engine_id;
33  public  : Tpacket_t          _packet_id    ;
34//public  : Toperation_t       _operation    ;
35//public  : Ttype_t            _type         ;
36  public  : Tcontrol_t         _write_rd     ;
37  public  : Tgeneral_address_t _num_reg_rd   ;
38  public  : Tgeneral_data_t    _data_rd      ;
39  public  : Tcontrol_t         _write_re     ;
40  public  : Tspecial_address_t _num_reg_re   ;
41  public  : Tspecial_data_t    _data_re      ;
42  public  : Texception_t       _exception    ;
43  public  : Tcontrol_t         _no_sequence  ;
44  public  : Tgeneral_data_t    _address      ;
45   
46  public  : write_queue_entry_t (Tcontext_t         context_id   ,
47                                 Tcontext_t         front_end_id ,
48                                 Tcontext_t         ooo_engine_id,
49                                 Tpacket_t          packet_id    ,
50//                               Toperation_t       operation    ,
51//                               Ttype_t            type         ,
52                                 Tcontrol_t         write_rd     ,
53                                 Tgeneral_address_t num_reg_rd   ,
54                                 Tgeneral_data_t    data_rd      ,
55                                 Tcontrol_t         write_re     ,
56                                 Tspecial_address_t num_reg_re   ,
57                                 Tspecial_data_t    data_re      ,
58                                 Texception_t       exception    ,
59                                 Tcontrol_t         no_sequence  ,
60                                 Tgeneral_data_t    address      )
61    {
62      _context_id    = context_id   ;
63      _front_end_id  = front_end_id ;
64      _ooo_engine_id = ooo_engine_id;
65      _packet_id     = packet_id    ;
66    //_operation     = operation    ;
67    //_type          = type         ;
68      _write_rd      = write_rd     ;
69      _num_reg_rd    = num_reg_rd   ;
70      _data_rd       = data_rd      ;
71      _write_re      = write_re     ;
72      _num_reg_re    = num_reg_re   ;
73      _data_re       = data_re      ;
74      _exception     = exception    ;
75      _no_sequence   = no_sequence  ;
76      _address       = address      ;
77    };
78  };
79
80}; // end namespace write_queue
81}; // end namespace write_unit
82}; // end namespace multi_write_unit
83}; // end namespace execute_loop
84}; // end namespace multi_execute_loop
85}; // end namespace core
86}; // end namespace behavioural
87
88  template<> inline std::string toString<morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::Twrite_queue_scheme_t>(const morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::Twrite_queue_scheme_t& x)
89  {
90    switch (x)
91      {
92      case morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::WRITE_QUEUE_SCHEME_MOORE : return "moore"; break;
93      case morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::WRITE_QUEUE_SCHEME_MEALY : return "mealy"; break;
94      default : return ""; break;
95      }
96  };
97
98  template<> inline morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::Twrite_queue_scheme_t fromString<morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::Twrite_queue_scheme_t>(const std::string& x)
99  {
100    if ( (x.compare(toString(static_cast<uint32_t>(morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::WRITE_QUEUE_SCHEME_MOORE))) == 0) or
101         (x.compare("moore") == 0))
102      return morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::WRITE_QUEUE_SCHEME_MOORE;
103    if ( (x.compare(toString(static_cast<uint32_t>(morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::WRITE_QUEUE_SCHEME_MEALY))) == 0) or
104         (x.compare("mealy") == 0))
105      return morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::WRITE_QUEUE_SCHEME_MEALY;
106   
107    throw (ErrorMorpheo ("<fromString> : Unknow string : \""+x+"\""));
108  };
109
110}; // end namespace morpheo             
111
112#endif
Note: See TracBrowser for help on using the repository browser.