source: trunk/IPs/systemC/processor/Morpheo/Behavioural/Generic/Victim/src/Victim_allocation.cpp @ 142

Last change on this file since 142 was 142, checked in by rosiere, 14 years ago

1) Full parallel compilation
2) Add statistics in ROB : list instruction affinity

  • Property svn:keywords set to Id
File size: 4.9 KB
Line 
1/*
2 * $Id: Victim_allocation.cpp 142 2010-08-04 20:09:03Z rosiere $
3 *
4 * [ Description ]
5 *
6 */
7
8#include "Behavioural/Generic/Victim/include/Victim.h"
9#include "Behavioural/include/Allocation.h"
10
11namespace morpheo                    {
12namespace behavioural {
13namespace generic {
14namespace victim {
15
16
17
18#undef  FUNCTION
19#define FUNCTION "Victim::allocation"
20  void Victim::allocation (
21#ifdef STATISTICS
22                               morpheo::behavioural::Parameters_Statistics * param_statistics
23#else
24                               void
25#endif
26                               )
27  {
28    log_printf(FUNC,Victim,FUNCTION,"Begin");
29
30#ifdef SYSTEMCASS_SPECIFIC
31    // ~~~~~[ Interface : "" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
32    {
33      __ALLOC0_SIGNAL    (in_CLOCK ,"in_CLOCK" ,SC_CLOCK          );
34      __ALLOC0_SIGNAL    (in_NRESET,"in_NRESET",SC_IN(Tcontrol_t));
35    }
36
37    // ~~~~~[ Interface : "Access" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
38    {
39      __ALLOC1_INTERFACE_BEGIN("ACCESS",_param->_nb_access);
40
41      __ALLOC1_SIGNAL_IN ( in_ACCESS_VAL    ,"VAL"    ,Tcontrol_t);
42      __ALLOC1_SIGNAL_OUT(out_ACCESS_ACK    ,"ACK"    ,Tcontrol_t);
43      if (_param->_have_port_address)
44      __ALLOC1_SIGNAL_IN ( in_ACCESS_ADDRESS,"ADDRESS",Taddress_t);
45      __ALLOC1_SIGNAL_IN ( in_ACCESS_HIT    ,"HIT"    ,Tcontrol_t);
46      __ALLOC1_SIGNAL_IN ( in_ACCESS_ENTITY ,"ENTITY" ,Tentity_t );
47      __ALLOC1_SIGNAL_OUT(out_ACCESS_VICTIM ,"VICTIM" ,Tentity_t );
48
49      __ALLOC1_INTERFACE_END(_param->_nb_access);
50    }
51#endif
52
53    // ~~~~~[ Component ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
54    std::string name;
55
56    switch (_param->_victim_scheme)
57      {
58//       case VICTIM_RANDOM      :
59//       case VICTIM_ROUND_ROBIN :
60//       case VICTIM_NLU         :
61      case VICTIM_PSEUDO_LRU  :
62        {
63          log_printf(INFO,Victim,FUNCTION,_("Create   : %s"),_name.c_str());
64
65          _component_victim_pseudo_lru = new morpheo::behavioural::generic::victim::victim_pseudo_lru::Victim_Pseudo_LRU
66            (_name.c_str()
67#ifdef STATISTICS
68             ,param_statistics
69#endif
70             ,_param->_param_victim_pseudo_lru
71             ,_usage);
72          break;
73        }
74//       case VICTIM_LRU         :
75//       case VICTIM_FIFO        :
76      default : break;
77      }
78   
79    // ~~~~~[ Instanciation ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~   
80
81    log_printf(INFO,Victim,FUNCTION,_("Instance : %s"),_name.c_str());
82
83    switch (_param->_victim_scheme)
84      {
85
86//       case VICTIM_RANDOM      :
87//       case VICTIM_ROUND_ROBIN :
88//       case VICTIM_NLU         :
89      case VICTIM_PSEUDO_LRU  :
90        {
91#ifdef SYSTEMCASS_SPECIFIC
92          {
93            (*(_component_victim_pseudo_lru-> in_CLOCK )) (*( in_CLOCK));
94            (*(_component_victim_pseudo_lru-> in_NRESET)) (*( in_NRESET));
95          }
96         
97          for (uint32_t i=0; i<_param->_nb_access; i++)
98            {
99              (*(_component_victim_pseudo_lru-> in_ACCESS_VAL     [i])) (*( in_ACCESS_VAL     [i]));
100              (*(_component_victim_pseudo_lru->out_ACCESS_ACK     [i])) (*(out_ACCESS_ACK     [i]));
101              if (_param->_have_port_address)
102              (*(_component_victim_pseudo_lru-> in_ACCESS_ADDRESS [i])) (*( in_ACCESS_ADDRESS [i]));
103              (*(_component_victim_pseudo_lru-> in_ACCESS_HIT     [i])) (*( in_ACCESS_HIT     [i]));
104              (*(_component_victim_pseudo_lru-> in_ACCESS_ENTITY  [i])) (*( in_ACCESS_ENTITY  [i]));
105              (*(_component_victim_pseudo_lru->out_ACCESS_VICTIM  [i])) (*(out_ACCESS_VICTIM  [i]));
106            }
107#else
108           in_CLOCK          = _component_victim_pseudo_lru-> in_CLOCK         ;
109           in_NRESET         = _component_victim_pseudo_lru-> in_NRESET        ;
110           in_ACCESS_VAL     = _component_victim_pseudo_lru-> in_ACCESS_VAL    ;
111          out_ACCESS_ACK     = _component_victim_pseudo_lru->out_ACCESS_ACK    ;
112           in_ACCESS_ADDRESS = _component_victim_pseudo_lru-> in_ACCESS_ADDRESS;
113           in_ACCESS_HIT     = _component_victim_pseudo_lru-> in_ACCESS_HIT    ;
114           in_ACCESS_ENTITY  = _component_victim_pseudo_lru-> in_ACCESS_ENTITY ;
115          out_ACCESS_VICTIM  = _component_victim_pseudo_lru->out_ACCESS_VICTIM ;
116#endif
117          break;
118        }
119//       case VICTIM_LRU         :
120//       case VICTIM_FIFO        :
121      default : break;
122      }
123
124   
125    // ~~~~~[ Others ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
126    switch (_param->_victim_scheme)
127      {
128//    case VICTIM_RANDOM      : _component = _component_victim_random     ->_component; break;
129//    case VICTIM_ROUND_ROBIN : _component = _component_victim_round_robin->_component; break;
130//    case VICTIM_NLU         : _component = _component_victim_nlu        ->_component; break;
131      case VICTIM_PSEUDO_LRU  : _component = _component_victim_pseudo_lru ->_component; break;
132//    case VICTIM_LRU         : _component = _component_victim_lru        ->_component; break;
133//    case VICTIM_FIFO        : _component = _component_victim_fifo       ->_component; break;
134      default : break;
135      }
136
137    log_printf(FUNC,Victim,FUNCTION,"End");
138  };
139
140}; // end namespace victim
141}; // end namespace generic
142
143}; // end namespace behavioural
144}; // end namespace morpheo             
Note: See TracBrowser for help on using the repository browser.