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

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

1) Stat List : scan all queue to find free register
2) Write_queue : test "genMealy" add bypass [0]
3) Functionnal_unit : add const parameters to add or not the pipeline_in
4) Load Store Unit : if load make an exception, free nb_check
5) Debug, change test to add model

  • Property svn:keywords set to Id
File size: 6.6 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 118 2009-05-20 22:01:32Z 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  typedef enum
29    {
30      BYPASS_WRITE_FROM_ALU,
31      BYPASS_WRITE_FROM_QUEUE
32    } Tbypass_write_scheme_t;
33
34  class write_queue_entry_t
35  {
36  public  : Tcontext_t         _context_id   ;
37  public  : Tcontext_t         _front_end_id ;
38  public  : Tcontext_t         _ooo_engine_id;
39  public  : Tpacket_t          _packet_id    ;
40//public  : Toperation_t       _operation    ;
41//public  : Ttype_t            _type         ;
42  public  : Tcontrol_t         _write_rd     ;
43  public  : Tgeneral_address_t _num_reg_rd   ;
44  public  : Tgeneral_data_t    _data_rd      ;
45  public  : Tcontrol_t         _write_re     ;
46  public  : Tspecial_address_t _num_reg_re   ;
47  public  : Tspecial_data_t    _data_re      ;
48  public  : Texception_t       _exception    ;
49  public  : Tcontrol_t         _no_sequence  ;
50  public  : Tgeneral_data_t    _address      ;
51   
52  public  : write_queue_entry_t (Tcontext_t         context_id   ,
53                                 Tcontext_t         front_end_id ,
54                                 Tcontext_t         ooo_engine_id,
55                                 Tpacket_t          packet_id    ,
56//                               Toperation_t       operation    ,
57//                               Ttype_t            type         ,
58                                 Tcontrol_t         write_rd     ,
59                                 Tgeneral_address_t num_reg_rd   ,
60                                 Tgeneral_data_t    data_rd      ,
61                                 Tcontrol_t         write_re     ,
62                                 Tspecial_address_t num_reg_re   ,
63                                 Tspecial_data_t    data_re      ,
64                                 Texception_t       exception    ,
65                                 Tcontrol_t         no_sequence  ,
66                                 Tgeneral_data_t    address      )
67    {
68      _context_id    = context_id   ;
69      _front_end_id  = front_end_id ;
70      _ooo_engine_id = ooo_engine_id;
71      _packet_id     = packet_id    ;
72    //_operation     = operation    ;
73    //_type          = type         ;
74      _write_rd      = write_rd     ;
75      _num_reg_rd    = num_reg_rd   ;
76      _data_rd       = data_rd      ;
77      _write_re      = write_re     ;
78      _num_reg_re    = num_reg_re   ;
79      _data_re       = data_re      ;
80      _exception     = exception    ;
81      _no_sequence   = no_sequence  ;
82      _address       = address      ;
83    };
84  };
85
86}; // end namespace write_queue
87}; // end namespace write_unit
88}; // end namespace multi_write_unit
89}; // end namespace execute_loop
90}; // end namespace multi_execute_loop
91}; // end namespace core
92}; // end namespace behavioural
93
94  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)
95  {
96    switch (x)
97      {
98      case morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::WRITE_QUEUE_SCHEME_MOORE : return "moore"; break;
99      case morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::WRITE_QUEUE_SCHEME_MEALY : return "mealy"; break;
100      default : return ""; break;
101      }
102  };
103
104  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)
105  {
106    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
107         (x.compare("moore") == 0))
108      return morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::WRITE_QUEUE_SCHEME_MOORE;
109    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
110         (x.compare("mealy") == 0))
111      return morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::WRITE_QUEUE_SCHEME_MEALY;
112   
113    throw (ErrorMorpheo ("<fromString> : Unknow string : \""+x+"\""));
114  };
115
116  template<> inline std::string toString<morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::Tbypass_write_scheme_t>(const morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::Tbypass_write_scheme_t& x)
117  {
118    switch (x)
119      {
120      case morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::BYPASS_WRITE_FROM_ALU   : return "alu"  ; break;
121      case morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::BYPASS_WRITE_FROM_QUEUE : return "queue"; break;
122      default : return ""; break;
123      }
124  };
125
126  template<> inline morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::Tbypass_write_scheme_t fromString<morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::Tbypass_write_scheme_t>(const std::string& x)
127  {
128    if ( (x.compare(toString(static_cast<uint32_t>(morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::BYPASS_WRITE_FROM_ALU))) == 0) or
129         (x.compare("alu") == 0))
130      return morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::BYPASS_WRITE_FROM_ALU;
131    if ( (x.compare(toString(static_cast<uint32_t>(morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::BYPASS_WRITE_FROM_QUEUE))) == 0) or
132         (x.compare("queue") == 0))
133      return morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_write_unit::write_unit::write_queue::BYPASS_WRITE_FROM_QUEUE;
134   
135    throw (ErrorMorpheo ("<fromString> : Unknow string : \""+x+"\""));
136  };
137
138}; // end namespace morpheo             
139
140#endif
Note: See TracBrowser for help on using the repository browser.