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

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

add two component :

  • Write Queue (in Moore version)
  • Execute Queue

add macro to help the interface allocation : Allocation.h

File size: 10.0 KB
Line 
1#ifndef morpheo_behavioural_core_multi_execute_loop_execute_loop_multi_write_unit_write_unit_write_queue_Write_queue_h
2#define morpheo_behavioural_core_multi_execute_loop_execute_loop_multi_write_unit_write_unit_write_queue_Write_queue_h
3
4/*
5 * $Id$
6 *
7 * [ Description ]
8 *
9 */
10
11#ifdef SYSTEMC
12#include "systemc.h"
13#endif
14
15#include <iostream>
16#include <list>
17#include "Common/include/ToString.h"
18#include "Common/include/Debug.h"
19#include "Behavioural/include/Types.h"
20
21#include "Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Write_unit/Write_unit/Write_queue/include/Parameters.h"
22#ifdef STATISTICS
23#include "Behavioural/include/Stat.h"
24#endif
25#include "Behavioural/include/Component.h"
26#ifdef VHDL
27#include "Behavioural/include/Vhdl.h"
28#endif
29#include "Behavioural/include/Usage.h"
30
31namespace morpheo {
32namespace behavioural {
33namespace core {
34namespace multi_execute_loop {
35namespace execute_loop {
36namespace multi_write_unit {
37namespace write_unit {
38namespace write_queue {
39
40  class write_queue_entry_t
41  {
42  public  : Tcontext_t         _context_id   ;
43  public  : Tcontext_t         _front_end_id ;
44  public  : Tcontext_t         _ooo_engine_id;
45  public  : Tpacket_t          _packet_id    ;
46//public  : Toperation_t       _operation    ;
47//public  : Ttype_t            _type         ;
48  public  : Tcontrol_t         _write_rd     ;
49  public  : Tgeneral_address_t _num_reg_rd   ;
50  public  : Tgeneral_data_t    _data_rd      ;
51  public  : Tcontrol_t         _write_re     ;
52  public  : Tspecial_address_t _num_reg_re   ;
53  public  : Tspecial_data_t    _data_re      ;
54  public  : Texception_t       _exception    ;
55  public  : Tcontrol_t         _no_sequence  ;
56  public  : Tgeneral_data_t    _address      ;
57   
58  public  : write_queue_entry_t (Tcontext_t         context_id   ,
59                                 Tcontext_t         front_end_id ,
60                                 Tcontext_t         ooo_engine_id,
61                                 Tpacket_t          packet_id    ,
62                               //Toperation_t       operation    ,
63                               //Ttype_t            type         ,
64                                 Tcontrol_t         write_rd     ,
65                                 Tgeneral_address_t num_reg_rd   ,
66                                 Tgeneral_data_t    data_rd      ,
67                                 Tcontrol_t         write_re     ,
68                                 Tspecial_address_t num_reg_re   ,
69                                 Tspecial_data_t    data_re      ,
70                                 Texception_t       exception    ,
71                                 Tcontrol_t         no_sequence  ,
72                                 Tgeneral_data_t    address      )
73    {
74      _context_id    = context_id   ;
75      _front_end_id  = front_end_id ;
76      _ooo_engine_id = ooo_engine_id;
77      _packet_id     = packet_id    ;
78    //_operation     = operation    ;
79    //_type          = type         ;
80      _write_rd      = write_rd     ;
81      _num_reg_rd    = num_reg_rd   ;
82      _data_rd       = data_rd      ;
83      _write_re      = write_re     ;
84      _num_reg_re    = num_reg_re   ;
85      _data_re       = data_re      ;
86      _exception     = exception    ;
87      _no_sequence   = no_sequence  ;
88      _address       = address      ;
89    };
90  };
91
92
93  class Write_queue
94#if SYSTEMC
95    : public sc_module
96#endif
97  {
98    // -----[ fields ]----------------------------------------------------
99    // Parameters
100  protected : const std::string  _name;
101  protected : const Parameters * _param;
102  private   : const Tusage_t     _usage;
103
104#ifdef STATISTICS
105  private   : Stat                           * _stat;
106
107  private   : counter_t                      * _stat_use_queue;
108  private   : counter_t                      * _stat_average_use_queue;
109  private   : counter_t                      * _stat_percent_use_queue;
110
111#endif
112
113  public    : Component                      * _component;
114  private   : Interfaces                     * _interfaces;
115
116#ifdef SYSTEMC
117    // ~~~~~[ Interface ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
118    // Interface
119  public    : SC_CLOCK                      *  in_CLOCK        ;
120  public    : SC_IN (Tcontrol_t)            *  in_NRESET       ;
121
122    // -----[ Interface "Write_queue_in" ]--------------------------------   
123  public    : SC_IN (Tcontrol_t        )    *  in_WRITE_QUEUE_IN_VAL          ;
124  public    : SC_OUT(Tcontrol_t        )    * out_WRITE_QUEUE_IN_ACK          ;
125  public    : SC_IN (Tcontext_t        )    *  in_WRITE_QUEUE_IN_CONTEXT_ID   ;
126  public    : SC_IN (Tcontext_t        )    *  in_WRITE_QUEUE_IN_FRONT_END_ID ;
127  public    : SC_IN (Tcontext_t        )    *  in_WRITE_QUEUE_IN_OOO_ENGINE_ID;
128  public    : SC_IN (Tpacket_t         )    *  in_WRITE_QUEUE_IN_PACKET_ID    ;
129//public    : SC_IN (Toperation_t      )    *  in_WRITE_QUEUE_IN_OPERATION    ;
130//public    : SC_IN (Ttype_t           )    *  in_WRITE_QUEUE_IN_TYPE         ;
131  public    : SC_IN (Tcontrol_t        )    *  in_WRITE_QUEUE_IN_WRITE_RD     ;
132  public    : SC_IN (Tgeneral_address_t)    *  in_WRITE_QUEUE_IN_NUM_REG_RD   ;
133  public    : SC_IN (Tgeneral_data_t   )    *  in_WRITE_QUEUE_IN_DATA_RD      ;
134  public    : SC_IN (Tcontrol_t        )    *  in_WRITE_QUEUE_IN_WRITE_RE     ;
135  public    : SC_IN (Tspecial_address_t)    *  in_WRITE_QUEUE_IN_NUM_REG_RE   ;
136  public    : SC_IN (Tspecial_data_t   )    *  in_WRITE_QUEUE_IN_DATA_RE      ;
137  public    : SC_IN (Texception_t      )    *  in_WRITE_QUEUE_IN_EXCEPTION    ;
138  public    : SC_IN (Tcontrol_t        )    *  in_WRITE_QUEUE_IN_NO_SEQUENCE  ;
139  public    : SC_IN (Tgeneral_data_t   )    *  in_WRITE_QUEUE_IN_ADDRESS      ;
140
141    // -----[ Interface "Write_queue_out" ]-------------------------------   
142  public    : SC_OUT(Tcontrol_t        )    * out_WRITE_QUEUE_OUT_VAL          ;
143  public    : SC_IN (Tcontrol_t        )    *  in_WRITE_QUEUE_OUT_ACK          ;
144  public    : SC_OUT(Tcontext_t        )    * out_WRITE_QUEUE_OUT_CONTEXT_ID   ;
145  public    : SC_OUT(Tcontext_t        )    * out_WRITE_QUEUE_OUT_FRONT_END_ID ;
146  public    : SC_OUT(Tcontext_t        )    * out_WRITE_QUEUE_OUT_OOO_ENGINE_ID;
147  public    : SC_OUT(Tpacket_t         )    * out_WRITE_QUEUE_OUT_PACKET_ID    ;
148//public    : SC_OUT(Toperation_t      )    * out_WRITE_QUEUE_OUT_OPERATION    ;
149//public    : SC_OUT(Ttype_t           )    * out_WRITE_QUEUE_OUT_TYPE         ;
150  public    : SC_OUT(Tspecial_data_t   )    * out_WRITE_QUEUE_OUT_FLAGS        ;
151  public    : SC_OUT(Texception_t      )    * out_WRITE_QUEUE_OUT_EXCEPTION    ;
152  public    : SC_OUT(Tcontrol_t        )    * out_WRITE_QUEUE_OUT_NO_SEQUENCE  ;
153  public    : SC_OUT(Tgeneral_data_t   )    * out_WRITE_QUEUE_OUT_ADDRESS      ;
154
155    // -----[ Interface "gpr_write" ]-------------------------------------
156  public    : SC_OUT(Tcontrol_t        )   ** out_GPR_WRITE_VAL               ;
157  public    : SC_IN (Tcontrol_t        )   **  in_GPR_WRITE_ACK               ;
158  public    : SC_OUT(Tcontext_t        )   ** out_GPR_WRITE_OOO_ENGINE_ID     ;
159  public    : SC_OUT(Tgeneral_address_t)   ** out_GPR_WRITE_NUM_REG           ;
160  public    : SC_OUT(Tgeneral_data_t   )   ** out_GPR_WRITE_DATA              ;
161   
162    // -----[ Interface "spr_write" ]-------------------------------------
163  public    : SC_OUT(Tcontrol_t        )   ** out_SPR_WRITE_VAL               ;
164  public    : SC_IN (Tcontrol_t        )   **  in_SPR_WRITE_ACK               ;
165  public    : SC_OUT(Tcontext_t        )   ** out_SPR_WRITE_OOO_ENGINE_ID     ;
166  public    : SC_OUT(Tspecial_address_t)   ** out_SPR_WRITE_NUM_REG           ;
167  public    : SC_OUT(Tspecial_data_t   )   ** out_SPR_WRITE_DATA              ;
168
169    // -----[ Interface "bypass_write" ]----------------------------------
170  public    : SC_OUT(Tcontext_t        )   ** out_BYPASS_WRITE_OOO_ENGINE_ID ;
171  public    : SC_OUT(Tcontrol_t        )   ** out_BYPASS_WRITE_GPR_VAL       ;
172  public    : SC_OUT(Tgeneral_address_t)   ** out_BYPASS_WRITE_GPR_NUM_REG   ; // RD
173  public    : SC_OUT(Tgeneral_data_t   )   ** out_BYPASS_WRITE_GPR_DATA      ;
174  public    : SC_OUT(Tcontrol_t        )   ** out_BYPASS_WRITE_SPR_VAL       ;
175  public    : SC_OUT(Tspecial_address_t)   ** out_BYPASS_WRITE_SPR_NUM_REG   ; // RE
176  public    : SC_OUT(Tspecial_data_t   )   ** out_BYPASS_WRITE_SPR_DATA      ;
177
178    // ~~~~~[ Component ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~   
179
180    // ~~~~~[ Register ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~   
181  protected : list<write_queue_entry_t *> * _queue;
182
183    // ~~~~~[ Internal ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
184    Tcontrol_t     internal_WRITE_QUEUE_IN_ACK;
185    Tcontrol_t     internal_WRITE_QUEUE_OUT_VAL;
186    Tcontrol_t     internal_GPR_WRITE_VAL;
187    Tcontrol_t     internal_SPR_WRITE_VAL;
188#endif
189
190    // -----[ Methods ]---------------------------------------------------
191
192#ifdef SYSTEMC
193    SC_HAS_PROCESS (Write_queue);
194#endif
195  public  :          Write_queue             
196  (
197#ifdef SYSTEMC
198   sc_module_name                                name,
199#else                                         
200   std::string                                   name,
201#endif                                         
202#ifdef STATISTICS
203   morpheo::behavioural::Parameters_Statistics * param_statistics,
204#endif
205   Parameters                                  * param,
206   morpheo::behavioural::Tusage_t                usage=USE_ALL
207   );
208  public  :          ~Write_queue             (void);
209                                               
210  private : void     allocation                (void);
211  private : void     deallocation              (void);
212                                               
213#ifdef SYSTEMC                                 
214  public  : void     transition                (void);
215  public  : void     genMoore                  (void);
216#endif                                         
217#ifdef STATISTICS
218  public  : void        statistics_declaration    (morpheo::behavioural::Parameters_Statistics * param_statistics);
219  public  : std::string statistics_print          (uint32_t depth);
220#endif
221                                               
222#if VHDL                                       
223  public  : void     vhdl                      (void);
224  private : void     vhdl_declaration          (Vhdl * & vhdl);
225  private : void     vhdl_body                 (Vhdl * & vhdl);
226#endif                                         
227                                               
228#if defined(STATISTICS) or defined(VHDL_TESTBENCH)
229  private : void     end_cycle                 (void);
230#endif
231  };
232
233}; // end namespace write_queue
234}; // end namespace write_unit
235}; // end namespace multi_write_unit
236}; // end namespace execute_loop
237}; // end namespace multi_execute_loop
238}; // end namespace core
239
240}; // end namespace behavioural
241}; // end namespace morpheo             
242
243#endif
Note: See TracBrowser for help on using the repository browser.