source: trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_OOO_Engine/OOO_Engine/Commit_unit/include/Types.h @ 111

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

1) Decod_queue : multi implementation (one_fifo, multi_fifo)
2) Issue_queue : multi implementation (in_order, out_of_order)
3) Direction : Add Meta predictor
4) Context_State : re add Branch_complete, More priority to Load miss (is not speculative)
5) Return_Address_Stack : update reg_PREDICT pointer on decod miss prediction
6) UPT : Fix bug in multi event
7) Prediction_glue : in read_stack case, insert in UPT pc_next
8) Rename select : when rob have an event (need flush), read_r{a,b,c} and write_r{d,e} is set at 0

  • Property svn:keywords set to Id
File size: 7.9 KB
Line 
1#ifndef morpheo_behavioural_core_multi_ooo_engine_ooo_engine_commit_unit_Types_h
2#define morpheo_behavioural_core_multi_ooo_engine_ooo_engine_commit_unit_Types_h
3
4/*
5 * $Id: Types.h 111 2009-02-27 18:37:40Z rosiere $
6 *
7 * [ Description ]
8 *
9 */
10
11#include "Behavioural/include/Types.h"
12
13namespace morpheo {
14namespace behavioural {
15namespace core {
16namespace multi_ooo_engine {
17namespace ooo_engine {
18namespace commit_unit {
19
20  typedef enum
21    {
22      RETIRE_IN_ORDER       ,
23      RETIRE_OOO_RENAME_UNIT,
24      RETIRE_OOO_CONTEXT
25    } retire_ooo_t;
26
27  typedef enum
28    {
29      ROB_EMPTY                      , //
30      ROB_BRANCH_WAIT_END            , //
31      ROB_BRANCH_COMPLETE            , //
32      ROB_STORE_WAIT_HEAD_OK         , //
33//    ROB_STORE_WAIT_HEAD_KO         , //
34      ROB_STORE_HEAD_OK              , //
35      ROB_STORE_HEAD_KO              , //
36      ROB_OTHER_WAIT_END             , //
37      ROB_MISS_WAIT_END              , //
38      ROB_END_OK_SPECULATIVE         , //
39      ROB_END_OK                     , //
40      ROB_END_KO_SPECULATIVE         , //
41      ROB_END_KO                     , //
42      ROB_END_BRANCH_MISS_SPECULATIVE, //
43      ROB_END_BRANCH_MISS            , //
44      ROB_END_LOAD_MISS_SPECULATIVE  , //
45      ROB_END_LOAD_MISS_UPDATE       , //
46      ROB_END_LOAD_MISS              , //
47      ROB_END_MISS                   , //
48      ROB_END_EXCEPTION_WAIT_HEAD    , //
49      ROB_END_EXCEPTION_UPDATE       , //
50      ROB_END_EXCEPTION                //
51    } rob_state_t;
52
53  class entry_t
54  {
55  public  : rob_state_t        state                   ;
56  public  : uint32_t           ptr                     ;
57  public  : Tcontext_t         front_end_id            ;
58  public  : Tcontext_t         context_id              ;
59  public  : uint32_t           rename_unit_id          ;
60  public  : Tdepth_t           depth                   ;
61  public  : Ttype_t            type                    ;
62  public  : Toperation_t       operation               ;
63  public  : Tcontrol_t         is_delay_slot           ;
64//public  : Tgeneral_data_t    address                 ;
65  public  : Tcontrol_t         use_store_queue         ;
66  public  : Tcontrol_t         use_load_queue          ;
67  public  : Tlsq_ptr_t         store_queue_ptr_write   ;
68  public  : Tlsq_ptr_t         load_queue_ptr_write    ;
69  public  : Tcontrol_t         read_ra                 ;
70  public  : Tgeneral_address_t num_reg_ra_log          ;
71  public  : Tgeneral_address_t num_reg_ra_phy          ;
72  public  : Tcontrol_t         read_rb                 ;
73  public  : Tgeneral_address_t num_reg_rb_log          ;
74  public  : Tgeneral_address_t num_reg_rb_phy          ;
75  public  : Tcontrol_t         read_rc                 ;
76  public  : Tspecial_address_t num_reg_rc_log          ;
77  public  : Tspecial_address_t num_reg_rc_phy          ;
78  public  : Tcontrol_t         write_rd                ;
79  public  : Tgeneral_address_t num_reg_rd_log          ;
80  public  : Tgeneral_address_t num_reg_rd_phy_old      ;
81  public  : Tgeneral_address_t num_reg_rd_phy_new      ;
82  public  : Tcontrol_t         write_re                ;
83  public  : Tspecial_address_t num_reg_re_log          ;
84  public  : Tspecial_address_t num_reg_re_phy_old      ;
85  public  : Tspecial_address_t num_reg_re_phy_new      ;
86
87  public  : Texception_t       exception               ;
88  public  : Texception_t       exception_use           ;
89
90  public  : Tspecial_data_t    flags                   ;
91  public  : Tcontrol_t         no_sequence             ;
92  public  : Tcontrol_t         speculative             ;
93//public  : Tgeneral_data_t    data_commit             ; // branch's destination
94#ifdef DEBUG
95  public  : Taddress_t         address                 ;
96#endif
97  public  : Taddress_t         address_next            ;
98#ifdef DEBUG
99  public  : double             cycle_rob_in            ;
100  public  : double             cycle_commit            ;
101#endif   
102
103  };
104
105}; // end namespace commit_unit
106}; // end namespace ooo_engine
107}; // end namespace multi_ooo_engine
108}; // end namespace core
109}; // end namespace behavioural
110
111 template<> inline std::string toString<morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::rob_state_t>(const morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::rob_state_t& x)
112  {
113    switch (x)
114      {
115      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_EMPTY                      : return "ROB_EMPTY"                       ; break;
116      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_BRANCH_WAIT_END            : return "ROB_BRANCH_WAIT_END"             ; break;
117      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_BRANCH_COMPLETE            : return "ROB_BRANCH_COMPLETE"             ; break;
118      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_STORE_WAIT_HEAD_OK         : return "ROB_STORE_WAIT_HEAD_OK"          ; break;
119//    case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_STORE_WAIT_HEAD_KO         : return "ROB_STORE_WAIT_HEAD_KO"          ; break;
120      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_STORE_HEAD_OK              : return "ROB_STORE_HEAD_OK"               ; break;
121      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_STORE_HEAD_KO              : return "ROB_STORE_HEAD_KO"               ; break;
122      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_OTHER_WAIT_END             : return "ROB_OTHER_WAIT_END"              ; break;
123      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_MISS_WAIT_END              : return "ROB_MISS_WAIT_END"               ; break;
124      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_END_OK_SPECULATIVE         : return "ROB_END_OK_SPECULATIVE"          ; break;
125      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_END_OK                     : return "ROB_END_OK"                      ; break;
126      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_END_KO_SPECULATIVE         : return "ROB_END_KO_SPECULATIVE"          ; break;
127      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_END_KO                     : return "ROB_END_KO"                      ; break;
128      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_END_BRANCH_MISS_SPECULATIVE: return "ROB_END_BRANCH_MISS_SPECULATIVE" ; break;
129      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_END_BRANCH_MISS            : return "ROB_END_BRANCH_MISS"             ; break;
130      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_END_LOAD_MISS_SPECULATIVE  : return "ROB_END_LOAD_MISS_SPECULATIVE"   ; break;
131      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_END_LOAD_MISS_UPDATE       : return "ROB_END_LOAD_MISS_UPDATE"        ; break;
132      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_END_LOAD_MISS              : return "ROB_END_LOAD_MISS"               ; break;
133      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_END_MISS                   : return "ROB_END_MISS"                    ; break;
134      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_END_EXCEPTION_WAIT_HEAD    : return "ROB_END_EXCEPTION_WAIT_HEAD"     ; break;
135      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_END_EXCEPTION_UPDATE       : return "ROB_END_EXCEPTION_UPDATE"        ; break;
136      case morpheo::behavioural::core::multi_ooo_engine::ooo_engine::commit_unit::ROB_END_EXCEPTION              : return "ROB_END_EXCEPTION"               ; break;
137
138      default    : return ""      ; break;
139      }
140  };
141
142}; // end namespace morpheo             
143
144#endif
Note: See TracBrowser for help on using the repository browser.