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

Last change on this file since 693 was 693, checked in by cfuguet, 10 years ago

tsar_generic_iob:

  • Replacing tsar_iob_cluster dspin_local_crossbar by vci_local_crossbar (Direct Network)
  • Display real simulation clock frequency in top.cpp
File size: 10.3 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 "vci_local_crossbar.h"
25#include "dspin_local_crossbar.h"
26#include "vci_dspin_initiator_wrapper.h"
27#include "vci_dspin_target_wrapper.h"
28#include "dspin_router_tsar.h"
29#include "virtual_dspin_router.h"
30#include "vci_multi_dma.h"
31#include "vci_mem_cache.h"
32#include "vci_cc_vcache_wrapper.h"
33#include "vci_io_bridge.h"
34
35namespace soclib { namespace caba   {
36
37///////////////////////////////////////////////////////////////////////////
38template<typename vci_param_int, 
39         typename vci_param_ext,
40         size_t   dspin_int_cmd_width, 
41         size_t   dspin_int_rsp_width,
42         size_t   dspin_ram_cmd_width,
43         size_t   dspin_ram_rsp_width>
44class TsarIobCluster
45///////////////////////////////////////////////////////////////////////////
46    : public soclib::caba::BaseModule
47{
48
49  public:
50
51    // Ports
52    sc_in<bool>                                        p_clk;
53    sc_in<bool>                                        p_resetn;
54
55    // Thes two ports are used to connect IOB to IOX nework in top cell
56    soclib::caba::VciInitiator<vci_param_ext>*         p_vci_iob_iox_ini;
57    soclib::caba::VciTarget<vci_param_ext>*            p_vci_iob_iox_tgt; 
58
59    // These ports are used to connect IOB to RAM network in top cell
60    soclib::caba::DspinOutput<dspin_ram_cmd_width>*    p_dspin_iob_cmd_out; 
61    soclib::caba::DspinInput<dspin_ram_rsp_width>*     p_dspin_iob_rsp_in; 
62
63    // These ports are used to connect hard IRQ from external peripherals to IOB0
64    sc_in<bool>*                                       p_irq[32];
65
66    // These arrays of ports are used to connect the INT & RAM networks in top cell
67    soclib::caba::DspinOutput<dspin_int_cmd_width>**   p_dspin_int_cmd_out;
68    soclib::caba::DspinInput<dspin_int_cmd_width>**    p_dspin_int_cmd_in;
69    soclib::caba::DspinOutput<dspin_int_rsp_width>**   p_dspin_int_rsp_out;
70    soclib::caba::DspinInput<dspin_int_rsp_width>**    p_dspin_int_rsp_in;
71
72    soclib::caba::DspinOutput<dspin_ram_cmd_width>*    p_dspin_ram_cmd_out;
73    soclib::caba::DspinInput<dspin_ram_cmd_width>*     p_dspin_ram_cmd_in;
74    soclib::caba::DspinOutput<dspin_ram_rsp_width>*    p_dspin_ram_rsp_out;
75    soclib::caba::DspinInput<dspin_ram_rsp_width>*     p_dspin_ram_rsp_in;
76
77    // interrupt signals
78    sc_signal<bool>                       signal_false;
79    sc_signal<bool>                       signal_proc_it[8];
80    sc_signal<bool>                       signal_irq_mdma[8];
81    sc_signal<bool>                       signal_irq_memc;
82   
83    // INT network DSPIN signals between DSPIN routers and DSPIN local_crossbars
84    DspinSignals<dspin_int_cmd_width>     signal_int_dspin_cmd_l2g_d; 
85    DspinSignals<dspin_int_cmd_width>     signal_int_dspin_cmd_g2l_d; 
86    DspinSignals<dspin_int_cmd_width>     signal_int_dspin_m2p_l2g_c;
87    DspinSignals<dspin_int_cmd_width>     signal_int_dspin_m2p_g2l_c; 
88    DspinSignals<dspin_int_cmd_width>     signal_int_dspin_clack_l2g_c;
89    DspinSignals<dspin_int_cmd_width>     signal_int_dspin_clack_g2l_c;
90    DspinSignals<dspin_int_rsp_width>     signal_int_dspin_rsp_l2g_d; 
91    DspinSignals<dspin_int_rsp_width>     signal_int_dspin_rsp_g2l_d; 
92    DspinSignals<dspin_int_rsp_width>     signal_int_dspin_p2m_l2g_c;
93    DspinSignals<dspin_int_rsp_width>     signal_int_dspin_p2m_g2l_c;
94
95    // INT network VCI signals between VCI components and VCI local crossbar
96    VciSignals<vci_param_int>             signal_int_vci_ini_proc[8]; 
97    VciSignals<vci_param_int>             signal_int_vci_ini_mdma; 
98    VciSignals<vci_param_int>             signal_int_vci_ini_iobx; 
99
100    VciSignals<vci_param_int>             signal_int_vci_tgt_memc;
101    VciSignals<vci_param_int>             signal_int_vci_tgt_xicu;
102    VciSignals<vci_param_int>             signal_int_vci_tgt_mdma;
103    VciSignals<vci_param_int>             signal_int_vci_tgt_iobx;
104
105    VciSignals<vci_param_int>             signal_int_vci_l2g;
106    VciSignals<vci_param_int>             signal_int_vci_g2l;
107
108    // Coherence DSPIN signals between DSPIN local crossbars and CC components
109    DspinSignals<dspin_int_cmd_width>     signal_int_dspin_m2p_memc;
110    DspinSignals<dspin_int_cmd_width>     signal_int_dspin_clack_memc;
111    DspinSignals<dspin_int_rsp_width>     signal_int_dspin_p2m_memc;
112    DspinSignals<dspin_int_cmd_width>     signal_int_dspin_m2p_proc[8];
113    DspinSignals<dspin_int_cmd_width>     signal_int_dspin_clack_proc[8];
114    DspinSignals<dspin_int_rsp_width>     signal_int_dspin_p2m_proc[8];
115
116    // RAM network VCI signals between VCI components and VCI/DSPIN wrappers
117    VciSignals<vci_param_ext>             signal_ram_vci_ini_memc;
118    VciSignals<vci_param_ext>             signal_ram_vci_ini_iobx;
119    VciSignals<vci_param_ext>             signal_ram_vci_tgt_xram;
120
121    // RAM network DSPIN signals between VCI/DSPIN wrappers and routers
122    DspinSignals<dspin_ram_cmd_width>     signal_ram_dspin_cmd_xram_t;
123    DspinSignals<dspin_ram_rsp_width>     signal_ram_dspin_rsp_xram_t;
124    DspinSignals<dspin_ram_cmd_width>     signal_ram_dspin_cmd_memc_i;
125    DspinSignals<dspin_ram_rsp_width>     signal_ram_dspin_rsp_memc_i;
126 
127    //////////////////////////////////////
128    // Hardwate Components (pointers)
129    //////////////////////////////////////
130    VciCcVCacheWrapper<vci_param_int, 
131                       dspin_int_cmd_width,
132                       dspin_int_rsp_width,
133                       GdbServer<Mips32ElIss> >*      proc[8];
134
135    VciMemCache<vci_param_int,
136                vci_param_ext, 
137                dspin_int_rsp_width, 
138                dspin_int_cmd_width>*                 memc;
139
140    VciDspinInitiatorWrapper<vci_param_ext,
141                             dspin_ram_cmd_width,
142                             dspin_ram_rsp_width>*    memc_ram_wi;
143
144    VciXicu<vci_param_int>*                           xicu;
145
146    VciMultiDma<vci_param_int>*                       mdma;
147
148    VciLocalCrossbar<vci_param_int>*                  int_xbar_d;
149   
150    VciDspinInitiatorWrapper<vci_param_int,
151                             dspin_int_cmd_width,
152                             dspin_int_rsp_width>*    int_wi_gate_d;
153
154    VciDspinTargetWrapper<vci_param_int,
155                          dspin_int_cmd_width,
156                          dspin_int_rsp_width>*       int_wt_gate_d;
157
158    DspinLocalCrossbar<dspin_int_cmd_width>*          int_xbar_m2p_c;
159    DspinLocalCrossbar<dspin_int_rsp_width>*          int_xbar_p2m_c;
160    DspinLocalCrossbar<dspin_int_cmd_width>*          int_xbar_clack_c;
161
162    VirtualDspinRouter<dspin_int_cmd_width>*          int_router_cmd;
163    VirtualDspinRouter<dspin_int_rsp_width>*          int_router_rsp;
164
165    VciSimpleRam<vci_param_ext>*                      xram;
166
167    VciDspinTargetWrapper<vci_param_ext,
168                          dspin_ram_cmd_width,
169                          dspin_ram_rsp_width>*       xram_ram_wt;
170   
171    DspinRouterTsar<dspin_ram_cmd_width>*             ram_router_cmd;
172    DspinRouterTsar<dspin_ram_rsp_width>*             ram_router_rsp;
173
174    // IO Network Components (not instanciated in all clusters)
175
176    VciIoBridge<vci_param_int,
177                vci_param_ext>*                       iob;
178
179    VciDspinInitiatorWrapper<vci_param_ext,
180                             dspin_ram_cmd_width,
181                             dspin_ram_rsp_width>*    iob_ram_wi;
182   
183    // cluster constructor
184    TsarIobCluster( sc_module_name                     insname,
185                    size_t                             nb_procs,   
186                    size_t                             nb_dmas, 
187                    size_t                             x,             // x coordinate
188                    size_t                             y,             // y coordinate
189                    size_t                             xmax,
190                    size_t                             ymax,
191
192                    const soclib::common::MappingTable &mt_int,
193                    const soclib::common::MappingTable &mt_ext,
194                    const soclib::common::MappingTable &mt_iox,
195
196                    size_t                             x_width,       // x field  bits
197                    size_t                             y_width,       // y field  bits
198                    size_t                             l_width,       // l field  bits
199
200                    size_t                             int_memc_tgtid,
201                    size_t                             int_xicu_tgtid,
202                    size_t                             int_mdma_tgtid,
203                    size_t                             int_iobx_tgtid,
204
205                    size_t                             int_proc_srcid,
206                    size_t                             int_mdma_srcid,
207                    size_t                             int_iobx_srcid,
208
209                    size_t                             ext_xram_tgtid,
210
211                    size_t                             ext_memc_srcid,
212                    size_t                             ext_iobx_srcid,
213
214                    size_t                             memc_ways,
215                    size_t                             memc_sets,
216                    size_t                             l1_i_ways,
217                    size_t                             l1_i_sets, 
218                    size_t                             l1_d_ways,
219                    size_t                             l1_d_sets,   
220                    size_t                             xram_latency, 
221
222                    const Loader                       &loader,       // loader for XRAM
223
224                    uint32_t                           frozen_cycles, 
225                    uint32_t                           start_debug_cycle,
226                    bool                               memc_debug_ok, 
227                    bool                               proc_debug_ok, 
228                    bool                               iob0_debug_ok ); 
229
230};
231
232}}
233
234#endif
Note: See TracBrowser for help on using the repository browser.