source: trunk/platforms/tsar_generic_iob/tsar_iob_cluster/caba/source/include/tsar_iob_cluster.h @ 584

Last change on this file since 584 was 550, checked in by alain, 11 years ago

Compliance with the mapping_table defined in release 2462.
Modifying the L2 to L3 network, to use the dspin_router_tsar component,
in order to simplify the architecture (no more local crossbar in RAM network.

File size: 11.8 KB
Line 
1//////////////////////////////////////////////////////////////////////////////
2// File: tsar_iob_cluster.h
3// Author: Alain Greiner
4// Copyright: UPMC/LIP6
5// Date : april 2013
6// This program is released under the GNU public license
7//////////////////////////////////////////////////////////////////////////////
8
9#ifndef SOCLIB_CABA_TSAR_IOB_CLUSTER_H
10#define SOCLIB_CABA_TSAR_IOB_CLUSTER_H
11
12#include <systemc>
13#include <sys/time.h>
14#include <iostream>
15#include <sstream>
16#include <cstdlib>
17#include <cstdarg>
18
19#include "gdbserver.h"
20#include "mapping_table.h"
21#include "mips32.h"
22#include "vci_simple_ram.h"
23#include "vci_xicu.h"
24#include "dspin_local_crossbar.h"
25#include "vci_dspin_initiator_wrapper.h"
26#include "vci_dspin_target_wrapper.h"
27#include "dspin_router_tsar.h"
28#include "virtual_dspin_router.h"
29#include "vci_multi_dma.h"
30#include "vci_mem_cache.h"
31#include "vci_cc_vcache_wrapper.h"
32#include "vci_io_bridge.h"
33
34namespace soclib { namespace caba       {
35
36///////////////////////////////////////////////////////////////////////////
37template<typename vci_param_int, 
38         typename vci_param_ext,
39         size_t   dspin_int_cmd_width, 
40         size_t   dspin_int_rsp_width,
41         size_t   dspin_ram_cmd_width,
42         size_t   dspin_ram_rsp_width>
43class TsarIobCluster
44///////////////////////////////////////////////////////////////////////////
45    : public soclib::caba::BaseModule
46{
47
48  public:
49
50        // Ports
51    sc_in<bool>                                            p_clk;
52    sc_in<bool>                                            p_resetn;
53
54    // Thes two ports are used to connect IOB to IOX nework in top cell
55    soclib::caba::VciInitiator<vci_param_ext>*         p_vci_iob_iox_ini;
56    soclib::caba::VciTarget<vci_param_ext>*            p_vci_iob_iox_tgt; 
57
58    // These ports are used to connect IOB to RAM network in top cell
59    soclib::caba::DspinOutput<dspin_ram_cmd_width>*    p_dspin_iob_cmd_out; 
60    soclib::caba::DspinInput<dspin_ram_rsp_width>*     p_dspin_iob_rsp_in; 
61
62    // These ports are used to connect hard IRQ from external peripherals to IOB0
63    sc_in<bool>*                                       p_irq[32];
64
65    // These arrays of ports are used to connect the INT & RAM networks in top cell
66        soclib::caba::DspinOutput<dspin_int_cmd_width>**   p_dspin_int_cmd_out;
67        soclib::caba::DspinInput<dspin_int_cmd_width>**    p_dspin_int_cmd_in;
68    soclib::caba::DspinOutput<dspin_int_rsp_width>**   p_dspin_int_rsp_out;
69    soclib::caba::DspinInput<dspin_int_rsp_width>**    p_dspin_int_rsp_in;
70
71        soclib::caba::DspinOutput<dspin_ram_cmd_width>*    p_dspin_ram_cmd_out;
72        soclib::caba::DspinInput<dspin_ram_cmd_width>*     p_dspin_ram_cmd_in;
73    soclib::caba::DspinOutput<dspin_ram_rsp_width>*    p_dspin_ram_rsp_out;
74    soclib::caba::DspinInput<dspin_ram_rsp_width>*     p_dspin_ram_rsp_in;
75
76    // interrupt signals
77        sc_signal<bool>                       signal_false;
78        sc_signal<bool>                               signal_proc_it[8];
79        sc_signal<bool>                               signal_irq_mdma[8];
80       
81        // INT network DSPIN signals between DSPIN routers and DSPIN local_crossbars
82        DspinSignals<dspin_int_cmd_width>     signal_int_dspin_cmd_l2g_d; 
83        DspinSignals<dspin_int_cmd_width>     signal_int_dspin_cmd_g2l_d; 
84        DspinSignals<dspin_int_cmd_width>     signal_int_dspin_m2p_l2g_c;
85        DspinSignals<dspin_int_cmd_width>     signal_int_dspin_m2p_g2l_c; 
86        DspinSignals<dspin_int_cmd_width>     signal_int_dspin_clack_l2g_c;
87        DspinSignals<dspin_int_cmd_width>     signal_int_dspin_clack_g2l_c;
88        DspinSignals<dspin_int_rsp_width>     signal_int_dspin_rsp_l2g_d; 
89        DspinSignals<dspin_int_rsp_width>     signal_int_dspin_rsp_g2l_d; 
90        DspinSignals<dspin_int_rsp_width>     signal_int_dspin_p2m_l2g_c;
91        DspinSignals<dspin_int_rsp_width>     signal_int_dspin_p2m_g2l_c;
92
93        // INT network VCI signals between VCI components and VCI/DSPIN wrappers
94        VciSignals<vci_param_int>                 signal_int_vci_ini_proc[8]; 
95        VciSignals<vci_param_int>                 signal_int_vci_ini_mdma; 
96        VciSignals<vci_param_int>                 signal_int_vci_ini_iobx; 
97
98        VciSignals<vci_param_int>                 signal_int_vci_tgt_memc;
99        VciSignals<vci_param_int>                 signal_int_vci_tgt_xicu;
100        VciSignals<vci_param_int>             signal_int_vci_tgt_mdma;
101        VciSignals<vci_param_int>             signal_int_vci_tgt_iobx;
102
103        // INT network DSPIN signals between DSPIN local crossbars and VCI/DSPIN wrappers
104        DspinSignals<dspin_int_cmd_width>     signal_int_dspin_cmd_proc_i[8];
105        DspinSignals<dspin_int_rsp_width>     signal_int_dspin_rsp_proc_i[8];
106        DspinSignals<dspin_int_cmd_width>     signal_int_dspin_cmd_mdma_i;
107        DspinSignals<dspin_int_rsp_width>     signal_int_dspin_rsp_mdma_i;
108        DspinSignals<dspin_int_cmd_width>     signal_int_dspin_cmd_iobx_i;
109        DspinSignals<dspin_int_rsp_width>     signal_int_dspin_rsp_iobx_i;
110
111        DspinSignals<dspin_int_cmd_width>     signal_int_dspin_cmd_memc_t;
112        DspinSignals<dspin_int_rsp_width>     signal_int_dspin_rsp_memc_t;
113        DspinSignals<dspin_int_cmd_width>     signal_int_dspin_cmd_xicu_t;
114        DspinSignals<dspin_int_rsp_width>     signal_int_dspin_rsp_xicu_t;
115        DspinSignals<dspin_int_cmd_width>     signal_int_dspin_cmd_mdma_t;
116        DspinSignals<dspin_int_rsp_width>     signal_int_dspin_rsp_mdma_t;
117        DspinSignals<dspin_int_cmd_width>     signal_int_dspin_cmd_iobx_t;
118        DspinSignals<dspin_int_rsp_width>     signal_int_dspin_rsp_iobx_t;
119
120        // Coherence DSPIN signals between DSPIN local crossbars and CC components
121        DspinSignals<dspin_int_cmd_width>     signal_int_dspin_m2p_memc;
122        DspinSignals<dspin_int_cmd_width>     signal_int_dspin_clack_memc;
123        DspinSignals<dspin_int_rsp_width>     signal_int_dspin_p2m_memc;
124        DspinSignals<dspin_int_cmd_width>     signal_int_dspin_m2p_proc[8];
125        DspinSignals<dspin_int_cmd_width>     signal_int_dspin_clack_proc[8];
126        DspinSignals<dspin_int_rsp_width>     signal_int_dspin_p2m_proc[8];
127
128        // RAM network VCI signals between VCI components and VCI/DSPIN wrappers
129        VciSignals<vci_param_ext>             signal_ram_vci_ini_memc;
130        VciSignals<vci_param_ext>             signal_ram_vci_ini_iobx;
131        VciSignals<vci_param_ext>             signal_ram_vci_tgt_xram;
132
133    // RAM network DSPIN signals between VCI/DSPIN wrappers and routers
134        DspinSignals<dspin_ram_cmd_width>     signal_ram_dspin_cmd_xram_t;
135        DspinSignals<dspin_ram_rsp_width>     signal_ram_dspin_rsp_xram_t;
136        DspinSignals<dspin_ram_cmd_width>     signal_ram_dspin_cmd_memc_i;
137        DspinSignals<dspin_ram_rsp_width>     signal_ram_dspin_rsp_memc_i;
138 
139    //////////////////////////////////////
140    // Hardwate Components (pointers)
141    //////////////////////////////////////
142    VciCcVCacheWrapper<vci_param_int, 
143                       dspin_int_cmd_width,
144                       dspin_int_rsp_width,
145                       GdbServer<Mips32ElIss> >*      proc[8];
146
147    VciDspinInitiatorWrapper<vci_param_int,
148                             dspin_int_cmd_width,
149                             dspin_int_rsp_width>*    proc_wi[8];
150
151    VciMemCache<vci_param_int,
152                vci_param_ext, 
153                dspin_int_rsp_width, 
154                dspin_int_cmd_width>*                 memc;
155
156    VciDspinTargetWrapper<vci_param_int,
157                          dspin_int_cmd_width,
158                          dspin_int_rsp_width>*       memc_int_wt;
159
160    VciDspinInitiatorWrapper<vci_param_ext,
161                             dspin_ram_cmd_width,
162                             dspin_ram_rsp_width>*    memc_ram_wi;
163
164    VciXicu<vci_param_int>*                           xicu;
165
166    VciDspinTargetWrapper<vci_param_int,
167                          dspin_int_cmd_width,
168                          dspin_int_rsp_width>*       xicu_int_wt;
169
170    VciMultiDma<vci_param_int>*                       mdma;
171
172    VciDspinInitiatorWrapper<vci_param_int,
173                             dspin_int_cmd_width,
174                             dspin_int_rsp_width>*    mdma_int_wi;
175
176    VciDspinTargetWrapper<vci_param_int,
177                          dspin_int_cmd_width,
178                          dspin_int_rsp_width>*       mdma_int_wt;
179
180    DspinLocalCrossbar<dspin_int_cmd_width>*          int_xbar_cmd_d;
181    DspinLocalCrossbar<dspin_int_rsp_width>*          int_xbar_rsp_d;
182    DspinLocalCrossbar<dspin_int_cmd_width>*          int_xbar_m2p_c;
183    DspinLocalCrossbar<dspin_int_rsp_width>*          int_xbar_p2m_c;
184    DspinLocalCrossbar<dspin_int_cmd_width>*          int_xbar_clack_c;
185
186    VirtualDspinRouter<dspin_int_cmd_width>*          int_router_cmd;
187    VirtualDspinRouter<dspin_int_rsp_width>*          int_router_rsp;
188
189    VciSimpleRam<vci_param_ext>*                      xram;
190
191    VciDspinTargetWrapper<vci_param_ext,
192                          dspin_ram_cmd_width,
193                          dspin_ram_rsp_width>*       xram_ram_wt;
194       
195    DspinRouterTsar<dspin_ram_cmd_width>*                 ram_router_cmd;
196    DspinRouterTsar<dspin_ram_rsp_width>*             ram_router_rsp;
197
198        // IO Network Components (not instanciated in all clusters)
199
200    VciIoBridge<vci_param_int,
201                vci_param_ext>*                       iob;
202
203    VciDspinInitiatorWrapper<vci_param_int,
204                             dspin_int_cmd_width,
205                             dspin_int_rsp_width>*    iob_int_wi;
206
207    VciDspinTargetWrapper<vci_param_int,
208                          dspin_int_cmd_width,
209                          dspin_int_rsp_width>*       iob_int_wt;
210
211    VciDspinInitiatorWrapper<vci_param_ext,
212                             dspin_ram_cmd_width,
213                             dspin_ram_rsp_width>*    iob_ram_wi;
214       
215    // cluster constructor
216        TsarIobCluster( sc_module_name                     insname,
217                    size_t                             nb_procs,   
218                    size_t                             nb_dmas, 
219                    size_t                             x,             // x coordinate
220                    size_t                             y,             // y coordinate
221                    size_t                             xmax,
222                    size_t                             ymax,
223
224                    const soclib::common::MappingTable &mt_int,
225                    const soclib::common::MappingTable &mt_ext,
226                    const soclib::common::MappingTable &mt_iox,
227
228                    size_t                                 x_width,       // x field  bits
229                    size_t                                 y_width,       // y field  bits
230                    size_t                                 l_width,       // l field  bits
231
232                    size_t                                 int_memc_tgtid,
233                    size_t                                 int_xicu_tgtid,
234                    size_t                                 int_mdma_tgtid,
235                    size_t                                 int_iobx_tgtid,
236
237                    size_t                             int_proc_srcid,
238                    size_t                             int_mdma_srcid,
239                    size_t                             int_iobx_srcid,
240
241                    size_t                             ext_xram_tgtid,
242
243                    size_t                             ext_memc_srcid,
244                    size_t                             ext_iobx_srcid,
245
246                    size_t                             memc_ways,
247                    size_t                             memc_sets,
248                    size_t                             l1_i_ways,
249                    size_t                             l1_i_sets, 
250                    size_t                             l1_d_ways,
251                    size_t                             l1_d_sets,       
252                    size_t                             xram_latency, 
253
254                    const Loader                       &loader,       // loader for XRAM
255
256                    uint32_t                           frozen_cycles, 
257                    uint32_t                           start_debug_cycle,
258                    bool                               memc_debug_ok, 
259                    bool                               proc_debug_ok, 
260                    bool                               iob0_debug_ok ); 
261
262};
263
264}}
265
266#endif
Note: See TracBrowser for help on using the repository browser.