source: trunk/modules/vci_local_ring_network_2/caba/source/src/vci_local_ring_network_2.cpp @ 33

Last change on this file since 33 was 33, checked in by simerabe, 14 years ago

fixing bug : case of non initiator or non target

  • Property svn:executable set to *
File size: 9.0 KB
Line 
1/* -*- c++ -*-
2 * SOCLIB_LGPL_HEADER_BEGIN
3 *
4 * This file is part of SoCLib, GNU LGPLv2.1.
5 *
6 * SoCLib is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU Lesser General Public License as published
8 * by the Free Software Foundation; version 2.1 of the License.
9 *
10 * SoCLib is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13 * Lesser General Public License for more details.
14 *
15 * You should have received a copy of the GNU Lesser General Public
16 * License along with SoCLib; if not, write to the Free Software
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
18 * 02110-1301 USA
19 *
20 * SOCLIB_LGPL_HEADER_END
21 *
22 * Authors  : Abdelmalek SI MERABET
23 * Date     : March 2010
24 * Copyright: UPMC - LIP6
25 */
26
27#include <iostream> 
28#include <string>
29#include <stdarg.h>
30#include "alloc_elems.h"
31#include "../include/vci_local_ring_network_2.h"
32
33namespace soclib { namespace caba {
34
35using soclib::common::alloc_elems;
36using soclib::common::dealloc_elems;
37
38#define tmpl(x) template<typename vci_param, int ring_cmd_data_size, int ring_rsp_data_size > x VciLocalRingNetwork2<vci_param, ring_cmd_data_size, ring_rsp_data_size >
39
40////////////////////////////////
41//      constructor
42//
43////////////////////////////////
44tmpl(/**/)::VciLocalRingNetwork2( sc_module_name insname,
45                         const soclib::common::MappingTable &mt,
46                         const soclib::common::IntTab &ringid,
47                         const int &wrapper_fifo_depth,
48                         const int &half_gateway_fifo_depth,
49                         int nb_attached_initiator,
50                         int nb_attached_target)                                             
51                         : soclib::caba::BaseModule(insname), 
52                           m_ns(nb_attached_initiator+nb_attached_target+2), 
53                           m_nai(nb_attached_initiator), 
54                           m_nat(nb_attached_target)
55 {
56       
57
58       
59        p_to_initiator =  soclib::common::alloc_elems<soclib::caba::VciTarget<vci_param> >("p_to_initiator", m_nai);
60        p_to_target = soclib::common::alloc_elems<soclib::caba::VciInitiator<vci_param> >("p_to_target", m_nat);
61
62        m_ring_initiator = new ring_initiator_t*[m_nai];
63        m_ring_target    = new ring_target_t*[m_nat]; 
64        m_ring_signal    = new ring_signal_t[m_ns];
65
66
67        std::ostringstream o;
68        o << name() << "_hg_init";
69        bool alloc_hg_init = (m_nai == 0);
70        m_half_gateway_initiator = new half_gateway_initiator_t(o.str().c_str(), alloc_hg_init, half_gateway_fifo_depth, mt, ringid, false);
71
72        std::ostringstream p;
73        p << name() << "_hg_target";
74        bool alloc_hg_target = (m_nat == 0);
75        m_half_gateway_target    = new half_gateway_target_t(p.str().c_str(), alloc_hg_target, half_gateway_fifo_depth, mt, ringid, false);
76
77        for(size_t i=0; i<m_nai; ++i) {
78                bool alloc_init = (i==0);
79                std::ostringstream o;
80                o << name() << "_init_" << i;
81                m_ring_initiator[i] = new ring_initiator_t(o.str().c_str(), alloc_init, wrapper_fifo_depth, mt, ringid, i);
82        }
83
84        for(size_t i=0; i<m_nat; ++i) {
85                bool alloc_target = (i==0);
86                std::ostringstream o;
87                o << name() << "_target_" << i;
88                m_ring_target[i]  = new ring_target_t(o.str().c_str(), alloc_target, wrapper_fifo_depth, mt, ringid, i);
89        }
90
91        SC_METHOD(transition);
92        dont_initialize();
93        sensitive << p_clk.pos();
94
95        SC_METHOD(genMoore);
96        dont_initialize();
97        sensitive << p_clk.neg();
98 }
99//--------------------------//
100tmpl(void)::transition()    //
101//--------------------------//
102{
103
104
105        if ( ! p_resetn.read() ) {
106                for(size_t i=0;i<m_nai;i++) 
107                        m_ring_initiator[i]->reset();
108                for(size_t t=0;t<m_nat;t++)
109                        m_ring_target[t]->reset();
110
111                m_half_gateway_initiator->reset();
112                m_half_gateway_target->reset();
113                return;
114        }
115
116// update ring signals Three iterations
117// this is intended in order to break the loop due to dependency existing between ring signals
118// this rule is based based on relaxation principle
119
120//- 1st
121       for(size_t i=0;i<m_nai;i++) {
122                size_t h = 0;
123                if(i == 0) h = m_ns-1;
124                else h = i-1;
125                m_ring_initiator[i]->update_ring_signals(m_ring_signal[h], m_ring_signal[i]);
126        }
127
128if(m_nai > 0) {
129        for(size_t i=0;i<m_nat;i++){
130                m_ring_target[i]->update_ring_signals(m_ring_signal[m_nai+i-1], m_ring_signal[m_nai+i] );
131        }
132 }
133else {
134
135        for(size_t i=0;i<m_nat;i++){
136                size_t h = 0;
137                if(i == 0) h = m_ns-1;
138                else h = i-1;
139                m_ring_target[i]->update_ring_signals(m_ring_signal[h], m_ring_signal[i] );
140        }
141}
142
143        m_half_gateway_initiator->update_ring_signals(m_ring_signal[m_nai+m_nat-1], m_ring_signal[m_nai+m_nat] );
144
145        m_half_gateway_target->update_ring_signals(m_ring_signal[m_ns-2], m_ring_signal[m_ns-1] );
146
147//- 2nd
148       for(size_t i=0;i<m_nai;i++) {
149                size_t h = 0;
150                if(i == 0) h = m_ns-1;
151                else h = i-1;
152                m_ring_initiator[i]->update_ring_signals(m_ring_signal[h], m_ring_signal[i]);
153        }
154
155if(m_nai > 0) {
156        for(size_t i=0;i<m_nat;i++){
157                m_ring_target[i]->update_ring_signals(m_ring_signal[m_nai+i-1], m_ring_signal[m_nai+i] );
158        }
159 }
160else {
161
162        for(size_t i=0;i<m_nat;i++){
163                size_t h = 0;
164                if(i == 0) h = m_ns-1;
165                else h = i-1;
166                m_ring_target[i]->update_ring_signals(m_ring_signal[h], m_ring_signal[i] );
167        }
168}
169
170
171        m_half_gateway_initiator->update_ring_signals(m_ring_signal[m_nai+m_nat-1], m_ring_signal[m_nai+m_nat] );
172
173        m_half_gateway_target->update_ring_signals(m_ring_signal[m_ns-2], m_ring_signal[m_ns-1] );
174
175
176//- 3rd
177       for(size_t i=0;i<m_nai;i++) {
178                size_t h = 0;
179                if(i == 0) h = m_ns-1;
180                else h = i-1;
181                m_ring_initiator[i]->update_ring_signals(m_ring_signal[h], m_ring_signal[i]);
182        }
183
184if(m_nai > 0) {
185        for(size_t i=0;i<m_nat;i++){
186                m_ring_target[i]->update_ring_signals(m_ring_signal[m_nai+i-1], m_ring_signal[m_nai+i] );
187        }
188 }
189else {
190
191        for(size_t i=0;i<m_nat;i++){
192                size_t h = 0;
193                if(i == 0) h = m_ns-1;
194                else h = i-1;
195                m_ring_target[i]->update_ring_signals(m_ring_signal[h], m_ring_signal[i] );
196        }
197}
198
199
200        m_half_gateway_initiator->update_ring_signals(m_ring_signal[m_nai+m_nat-1], m_ring_signal[m_nai+m_nat] );
201
202        m_half_gateway_target->update_ring_signals(m_ring_signal[m_ns-2], m_ring_signal[m_ns-1] );
203
204//-----------------------------------------------//
205// transition                                    //
206//----------------------------------------------//
207
208        for(size_t i=0;i<m_nai;i++) {
209                size_t h = 0;
210                if(i == 0) h = m_ns-1;
211                else h = i-1;
212                m_ring_initiator[i]->transition(p_to_initiator[i], m_ring_signal[h]);
213        }
214
215if(m_nai > 0) {
216        for(size_t t=0;t<m_nat;t++) {
217                m_ring_target[t]->transition(p_to_target[t], m_ring_signal[m_nai+t-1]);
218        }
219}
220else {
221
222        for(size_t t=0;t<m_nat;t++) {
223                size_t h = 0;
224                if(t == 0) h = m_ns-1;
225                else h = t-1;
226
227                m_ring_target[t]->transition(p_to_target[t], m_ring_signal[h]);
228        }
229}
230        m_half_gateway_initiator->transition(p_gate_initiator, m_ring_signal[m_nai+m_nat-1]);
231        m_half_gateway_target->transition(p_gate_target, m_ring_signal[m_nai+m_nat]);
232
233
234/*-------- print
235        for(size_t t=0;t<m_nat;t++) {
236                print_signal(m_nai+t-1);
237                print_vci_target(t);
238        }
239
240        for(size_t i=0;i<m_nai;i++) {
241                size_t h = 0;
242                if(i == 0) h = m_ns-1;
243                else h = i-1;
244                print_signal(h);
245                print_vci_init(i);
246        }
247*/
248}
249
250tmpl(void)::genMoore()
251{
252
253        for(size_t i=0;i<m_nai;i++) 
254                m_ring_initiator[i]->genMoore(p_to_initiator[i]);
255        for(size_t t=0;t<m_nat;t++)
256                m_ring_target[t]->genMoore(p_to_target[t]);   
257
258        m_half_gateway_initiator->genMoore(p_gate_initiator);
259   
260        m_half_gateway_target->genMoore(p_gate_target);
261}   
262//---------------- destructor
263tmpl(/**/)::~VciLocalRingNetwork2()
264    {
265
266        delete m_half_gateway_initiator;
267        delete m_half_gateway_target;
268
269        for(size_t x = 0; x < m_nai; x++)
270                delete m_ring_initiator[x];
271       
272        for(size_t x = 0; x < m_nat; x++)
273                delete m_ring_target[x];
274
275//for(size_t x = 0; x < m_ns; x++)
276//      delete m_ring_signal[x];
277
278        delete [] m_ring_initiator;
279        delete [] m_ring_target;
280        delete [] m_ring_signal;
281       
282        dealloc_elems(p_to_initiator,m_nai);
283        dealloc_elems(p_to_target, m_nat);;       
284    }
285}} // end namespace
Note: See TracBrowser for help on using the repository browser.