source: trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Prediction_unit/Direction/include/Parameters.h @ 45

Last change on this file since 45 was 45, checked in by rosiere, 17 years ago
  • Documentation : specification d'un cache de donnée non bloquant
  • Modification de l'aborescence
File size: 4.8 KB
Line 
1#ifndef morpheo_behavioural_stage_1_ifetch_predictor_meta_predictor_Parameters_h
2#define morpheo_behavioural_stage_1_ifetch_predictor_meta_predictor_Parameters_h
3
4/*
5 * $Id$
6 *
7 * [ Description ]
8 *
9 */
10
11#include "Common/include/Debug.h"
12#include "Behavioural/include/Parameters.h"
13#include "Behavioural/Stage_1_Ifetch/Predictor/Meta_Predictor/Two_Level_Branch_Predictor/include/Parameters.h"
14#include "Behavioural/Stage_1_Ifetch/Predictor/Meta_Predictor/Meta_Predictor_Glue/include/Parameters.h"
15#include <math.h>
16
17namespace morpheo {
18namespace behavioural {
19namespace stage_1_ifetch {
20namespace predictor {
21namespace meta_predictor {
22
23  class Parameters : public morpheo::behavioural::Parameters
24  {
25    //-----[ fields ]------------------------------------------------------------
26  public : const bool     _have_meta_predictor               ;
27
28  public : const bool     _predictor_0_have_bht              ;
29  public : const uint32_t _predictor_0_bht_size_shifter      ;
30  public : const uint32_t _predictor_0_bht_nb_shifter        ;
31  public : const bool     _predictor_0_have_pht              ;
32  public : const uint32_t _predictor_0_pht_size_counter      ;
33  public : const uint32_t _predictor_0_pht_nb_counter        ;
34  public : const uint32_t _predictor_0_pht_size_address_share;
35
36  public : const bool     _predictor_1_have_bht              ;
37  public : const uint32_t _predictor_1_bht_size_shifter      ;
38  public : const uint32_t _predictor_1_bht_nb_shifter        ;
39  public : const bool     _predictor_1_have_pht              ;
40  public : const uint32_t _predictor_1_pht_size_counter      ;
41  public : const uint32_t _predictor_1_pht_nb_counter        ;
42  public : const uint32_t _predictor_1_pht_size_address_share;
43
44  public : const bool     _predictor_2_have_bht              ;
45  public : const uint32_t _predictor_2_bht_size_shifter      ;
46  public : const uint32_t _predictor_2_bht_nb_shifter        ;
47  public : const bool     _predictor_2_have_pht              ;
48  public : const uint32_t _predictor_2_pht_size_counter      ;
49  public : const uint32_t _predictor_2_pht_nb_counter        ;
50  public : const uint32_t _predictor_2_pht_size_address_share;
51
52  public : const uint32_t _size_address                      ;
53  public : const uint32_t _nb_prediction                     ;
54  public : const uint32_t _nb_branch_complete                ;
55
56  public : const uint32_t _size_history                      ;
57
58  public :       morpheo::behavioural::stage_1_ifetch::predictor::meta_predictor::two_level_branch_predictor::Parameters * _param_two_level_branch_predictor_0;
59  public :       morpheo::behavioural::stage_1_ifetch::predictor::meta_predictor::two_level_branch_predictor::Parameters * _param_two_level_branch_predictor_1;
60  public :       morpheo::behavioural::stage_1_ifetch::predictor::meta_predictor::two_level_branch_predictor::Parameters * _param_two_level_branch_predictor_2;
61  public :       morpheo::behavioural::stage_1_ifetch::predictor::meta_predictor::meta_predictor_glue::Parameters        * _param_meta_predictor_glue;
62
63    //-----[ methods ]-----------------------------------------------------------
64  public : Parameters  (bool     have_meta_predictor               ,
65                       
66                        bool     predictor_0_have_bht              ,
67                        uint32_t predictor_0_bht_size_shifter      ,
68                        uint32_t predictor_0_bht_nb_shifter        ,
69                        bool     predictor_0_have_pht              ,
70                        uint32_t predictor_0_pht_size_counter      ,
71                        uint32_t predictor_0_pht_nb_counter        ,
72                        uint32_t predictor_0_pht_size_address_share,
73                       
74                        bool     predictor_1_have_bht              ,
75                        uint32_t predictor_1_bht_size_shifter      ,
76                        uint32_t predictor_1_bht_nb_shifter        ,
77                        bool     predictor_1_have_pht              ,
78                        uint32_t predictor_1_pht_size_counter      ,
79                        uint32_t predictor_1_pht_nb_counter        ,
80                        uint32_t predictor_1_pht_size_address_share,
81                       
82                        bool     predictor_2_have_bht              ,
83                        uint32_t predictor_2_bht_size_shifter      ,
84                        uint32_t predictor_2_bht_nb_shifter        ,
85                        bool     predictor_2_have_pht              ,
86                        uint32_t predictor_2_pht_size_counter      ,
87                        uint32_t predictor_2_pht_nb_counter        ,
88                        uint32_t predictor_2_pht_size_address_share,
89                       
90                        uint32_t size_address                      ,
91                        uint32_t nb_prediction                     ,
92                        uint32_t nb_branch_complete                );
93  public : Parameters  (Parameters & param) ;
94  public : ~Parameters () ;
95   
96  public : string msg_error (void);
97
98  public :        string   print      (uint32_t depth);
99  public : friend ostream& operator<< (ostream& output_stream,
100                                       morpheo::behavioural::stage_1_ifetch::predictor::meta_predictor::Parameters & x);
101  };
102
103}; // end namespace meta_predictor
104}; // end namespace predictor
105}; // end namespace stage_1_ifetch
106}; // end namespace behavioural
107}; // end namespace morpheo             
108
109#endif
Note: See TracBrowser for help on using the repository browser.