source: trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Prediction_unit/Branch_Target_Buffer/Branch_Target_Buffer_Glue/src/Branch_Target_Buffer_Glue_genMealy_predict.cpp @ 108

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

1) decod_queue : add reg_LAST_SLOT.
2) Commit : insert on event -> to pop decod_queue. Head test : add information (speculative or not)
3) Context State / UPT : Branch miss and Load miss in same cycle.
4) Free List : Bank is on LSB not MSB.
5) Platforms : move data

  • Property svn:keywords set to Id
File size: 4.4 KB
Line 
1#ifdef SYSTEMC
2/*
3 * $Id: Branch_Target_Buffer_Glue_genMealy_predict.cpp 108 2009-02-12 11:55:06Z rosiere $
4 *
5 * [ Description ]
6 *
7 */
8
9#include "Behavioural/Core/Multi_Front_end/Front_end/Prediction_unit/Branch_Target_Buffer/Branch_Target_Buffer_Glue/include/Branch_Target_Buffer_Glue.h"
10
11namespace morpheo {
12namespace behavioural {
13namespace core {
14namespace multi_front_end {
15namespace front_end {
16namespace prediction_unit {
17namespace branch_target_buffer {
18namespace branch_target_buffer_glue {
19
20#undef  FUNCTION
21#define FUNCTION "Branch_Target_Buffer_Glue::genMealy_predict"
22  void Branch_Target_Buffer_Glue::genMealy_predict (void)
23  {
24    log_begin(Branch_Target_Buffer_Glue,FUNCTION);
25    log_function(Branch_Target_Buffer_Glue,FUNCTION,_name.c_str());
26
27    for (uint32_t i=0; i<_param->_nb_inst_predict; i++)
28      {
29        log_printf(TRACE,Branch_Target_Buffer_Glue,FUNCTION,"  * PREDICT [%d]",i);
30
31        Tcontrol_t val          = PORT_READ(in_PREDICT_VAL          [i]);
32        Tcontrol_t register_ack = PORT_READ(in_PREDICT_REGISTER_ACK [i]);
33        Tcontrol_t sort_val     = (_param->_have_port_victim)?PORT_READ(in_PREDICT_SORT_VAL   [i]):true;
34        Tcontrol_t victim_ack   = (_param->_have_port_victim)?PORT_READ(in_PREDICT_VICTIM_ACK [i]):true;
35
36        log_printf(TRACE,Branch_Target_Buffer_Glue,FUNCTION,"    * val          : %d",val         );
37        log_printf(TRACE,Branch_Target_Buffer_Glue,FUNCTION,"    * register_ack : %d",register_ack);
38        log_printf(TRACE,Branch_Target_Buffer_Glue,FUNCTION,"    * sort_val     : %d",sort_val    );
39        log_printf(TRACE,Branch_Target_Buffer_Glue,FUNCTION,"    * victim_ack   : %d",victim_ack  );
40       
41        Tptr_t          index       = (_param->_have_port_victim)?PORT_READ(in_PREDICT_SORT_INDEX [i]):0;
42        Tcontrol_t      hit         = // (_param->_have_port_victim)?sort_val:
43                                      PORT_READ(in_PREDICT_REGISTER_HIT [i][index]);
44        Tgeneral_data_t address_src = PORT_READ(in_PREDICT_REGISTER_ADDRESS_SRC [i][index]);
45
46        log_printf(TRACE,Branch_Target_Buffer_Glue,FUNCTION,"    * index        : %d"  ,index      );
47        log_printf(TRACE,Branch_Target_Buffer_Glue,FUNCTION,"    * hit          : %d"  ,hit        );
48        log_printf(TRACE,Branch_Target_Buffer_Glue,FUNCTION,"    * address_src  : %.8x",address_src);
49
50        // Multiplexor
51        PORT_WRITE(out_PREDICT_HIT          [i],hit);
52        PORT_WRITE(out_PREDICT_ADDRESS_SRC  [i],address_src);
53        PORT_WRITE(out_PREDICT_ADDRESS_DEST [i],PORT_READ(in_PREDICT_REGISTER_ADDRESS_DEST  [i][index]));
54        PORT_WRITE(out_PREDICT_CONDITION    [i],PORT_READ(in_PREDICT_REGISTER_CONDITION     [i][index]));
55        PORT_WRITE(out_PREDICT_LAST_TAKE    [i],PORT_READ(in_PREDICT_REGISTER_LAST_TAKE     [i][index]));
56        PORT_WRITE(out_PREDICT_IS_ACCURATE  [i],PORT_READ(in_PREDICT_REGISTER_IS_ACCURATE   [i][index]));
57
58        PORT_WRITE(out_PREDICT_ACK            [i], (
59//                                                  val          and
60                                                    register_ack and
61//                                                  sort_val     and
62                                                    victim_ack
63                                                    ));
64        PORT_WRITE(out_PREDICT_REGISTER_VAL   [i], (
65                                                    val          and
66//                                                  register_ack and
67//                                                  sort_val     and
68                                                    victim_ack
69                                                    ));
70
71        if (_param->_have_port_victim)
72          {
73        PORT_WRITE(out_PREDICT_VICTIM_VAL     [i], (
74                                                    val          and
75                                                    register_ack // and
76//                                                  sort_val     and
77//                                                  victim_ack
78                                                    ));
79        PORT_WRITE(out_PREDICT_VICTIM_HIT     [i], hit);
80        if (not _param->_is_full_associative)
81        PORT_WRITE(out_PREDICT_VICTIM_ADDRESS [i], (address_src >> _param->_shift_bank)&_param->_mask_bank);
82        PORT_WRITE(out_PREDICT_VICTIM_INDEX   [i], index);
83          }
84      }
85
86    log_end(Branch_Target_Buffer_Glue,FUNCTION);
87  };
88
89}; // end namespace branch_target_buffer_glue
90}; // end namespace branch_target_buffer
91}; // end namespace prediction_unit
92}; // end namespace front_end
93}; // end namespace multi_front_end
94}; // end namespace core
95}; // end namespace behavioural
96}; // end namespace morpheo             
97#endif
Note: See TracBrowser for help on using the repository browser.