source: branches/v5/platforms/tsar_generic_xbar/tsar_xbar_cluster/caba/source/include/tsar_xbar_cluster.h @ 448

Last change on this file since 448 was 448, checked in by cfuguet, 11 years ago

Modification in branches/v5/platforms/tsar_generic_xbar:

  • Adding a DSPIN router to the platform to allow the inter-cluster communication for the CLACK commands.

With this modification, the tsar_generic_xbar platform can be used
for multi-cluster simulations

File size: 11.5 KB
Line 
1//////////////////////////////////////////////////////////////////////////////
2// File: tsar_xbar_cluster.h
3// Author: Alain Greiner
4// Copyright: UPMC/LIP6
5// Date : march 2013
6// This program is released under the GNU public license
7//////////////////////////////////////////////////////////////////////////////
8
9#ifndef SOCLIB_CABA_TSAR_XBAR_CLUSTER_H
10#define SOCLIB_CABA_TSAR_XBAR_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_simple_rom.h"
24#include "vci_xicu.h"
25#include "dspin_local_crossbar.h"
26#include "vci_dspin_initiator_wrapper.h"
27#include "vci_dspin_target_wrapper.h"
28#include "virtual_dspin_router.h"
29#include "dspin_router.h"
30#include "vci_multi_tty.h"
31#include "vci_multi_nic.h"
32#include "vci_block_device_tsar.h"
33#include "vci_framebuffer.h"
34#include "vci_multi_dma.h"
35#include "vci_mem_cache.h"
36#include "vci_cc_vcache_wrapper.h"
37
38namespace soclib { namespace caba {
39
40///////////////////////////////////////////////////////////////////////////
41template<size_t dspin_cmd_width,
42         size_t dspin_rsp_width,
43         typename vci_param_int,
44         typename vci_param_ext>  class TsarXbarCluster
45///////////////////////////////////////////////////////////////////////////
46    : public soclib::caba::BaseModule
47{
48    public:
49
50    // Ports
51    sc_in<bool>                                     p_clk;
52    sc_in<bool>                                     p_resetn;
53    soclib::caba::DspinOutput<dspin_cmd_width>      **p_cmd_out;
54    soclib::caba::DspinInput<dspin_cmd_width>       **p_cmd_in;
55    soclib::caba::DspinOutput<dspin_rsp_width>      **p_rsp_out;
56    soclib::caba::DspinInput<dspin_rsp_width>       **p_rsp_in;
57    soclib::caba::DspinOutput<dspin_cmd_width>      *p_clack_out;
58    soclib::caba::DspinInput<dspin_cmd_width>       *p_clack_in;
59
60    // interrupt signals
61    sc_signal<bool>         signal_false;
62    sc_signal<bool>         signal_proc_it[8];
63    sc_signal<bool>         signal_irq_mdma[8];
64    sc_signal<bool>         signal_irq_mtty[23];
65    sc_signal<bool>         signal_irq_mnic_rx[8];  // unused
66    sc_signal<bool>         signal_irq_mnic_tx[8];  // unused
67    sc_signal<bool>         signal_irq_bdev;
68
69    // DSPIN signals between DSPIN routers and local_crossbars
70    DspinSignals<dspin_cmd_width>   signal_dspin_cmd_l2g_d;
71    DspinSignals<dspin_cmd_width>   signal_dspin_cmd_g2l_d;
72    DspinSignals<dspin_cmd_width>   signal_dspin_m2p_l2g_c;
73    DspinSignals<dspin_cmd_width>   signal_dspin_m2p_g2l_c;
74    DspinSignals<dspin_cmd_width>   signal_dspin_clack_l2g_c;
75    DspinSignals<dspin_cmd_width>   signal_dspin_clack_g2l_c;
76    DspinSignals<dspin_rsp_width>   signal_dspin_rsp_l2g_d;
77    DspinSignals<dspin_rsp_width>   signal_dspin_rsp_g2l_d;
78    DspinSignals<dspin_rsp_width>   signal_dspin_p2m_l2g_c;
79    DspinSignals<dspin_rsp_width>   signal_dspin_p2m_g2l_c;
80
81    // Direct VCI signals to VCI/DSPIN wrappers
82    VciSignals<vci_param_int>       signal_vci_ini_proc[8];
83    VciSignals<vci_param_int>       signal_vci_ini_mdma;
84    VciSignals<vci_param_int>       signal_vci_ini_bdev;
85
86    VciSignals<vci_param_int>       signal_vci_tgt_memc;
87    VciSignals<vci_param_int>       signal_vci_tgt_xicu;
88    VciSignals<vci_param_int>       signal_vci_tgt_mdma;
89    VciSignals<vci_param_int>       signal_vci_tgt_mtty;
90    VciSignals<vci_param_int>       signal_vci_tgt_bdev;
91    VciSignals<vci_param_int>       signal_vci_tgt_brom;
92    VciSignals<vci_param_int>       signal_vci_tgt_fbuf;
93    VciSignals<vci_param_int>       signal_vci_tgt_mnic;
94
95    // Direct DSPIN signals to local crossbars
96    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_proc_i[8];
97    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_proc_i[8];
98    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_mdma_i;
99    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_mdma_i;
100    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_bdev_i;
101    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_bdev_i;
102
103    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_memc_t;
104    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_memc_t;
105    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_xicu_t;
106    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_xicu_t;
107    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_mdma_t;
108    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_mdma_t;
109    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_mtty_t;
110    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_mtty_t;
111    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_bdev_t;
112    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_bdev_t;
113    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_brom_t;
114    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_brom_t;
115    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_fbuf_t;
116    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_fbuf_t;
117    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_mnic_t;
118    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_mnic_t;
119
120    // Coherence DSPIN signals to local crossbar
121    DspinSignals<dspin_cmd_width>     signal_dspin_m2p_memc;
122    DspinSignals<dspin_cmd_width>     signal_dspin_clack_memc;
123    DspinSignals<dspin_rsp_width>     signal_dspin_p2m_memc;
124    DspinSignals<dspin_cmd_width>     signal_dspin_m2p_proc[8];
125    DspinSignals<dspin_cmd_width>     signal_dspin_clack_proc[8];
126    DspinSignals<dspin_rsp_width>     signal_dspin_p2m_proc[8];
127
128    // external RAM to MEMC VCI signal
129    VciSignals<vci_param_ext>         signal_vci_xram;
130
131    // Components
132
133    VciCcVCacheWrapper<vci_param_int,
134                       dspin_cmd_width,
135                       dspin_rsp_width,
136                       GdbServer<Mips32ElIss> >*  proc[8];
137
138    VciDspinInitiatorWrapper<vci_param_int,
139                             dspin_cmd_width,
140                             dspin_rsp_width>*    wi_proc[8];
141
142    VciMemCache<vci_param_int,
143                vci_param_ext,
144                dspin_rsp_width,
145                dspin_cmd_width>*                 memc;
146
147    VciDspinTargetWrapper<vci_param_int,
148                          dspin_cmd_width,
149                          dspin_rsp_width>*       wt_memc;
150
151    VciXicu<vci_param_int>*                       xicu;
152
153    VciDspinTargetWrapper<vci_param_int,
154                          dspin_cmd_width,
155                          dspin_rsp_width>*       wt_xicu;
156
157    VciMultiDma<vci_param_int>*                   mdma;
158
159    VciDspinInitiatorWrapper<vci_param_int,
160                             dspin_cmd_width,
161                             dspin_rsp_width>*    wi_mdma;
162
163    VciDspinTargetWrapper<vci_param_int,
164                          dspin_cmd_width,
165                          dspin_rsp_width>*       wt_mdma;
166
167    VciSimpleRam<vci_param_ext>*                  xram;
168
169    VciSimpleRom<vci_param_int>*                  brom;
170
171    VciDspinTargetWrapper<vci_param_int,
172                          dspin_cmd_width,
173                          dspin_rsp_width>*       wt_brom;
174
175    VciMultiTty<vci_param_int>*                   mtty;
176
177    VciDspinTargetWrapper<vci_param_int,
178                          dspin_cmd_width,
179                          dspin_rsp_width>*       wt_mtty;
180
181    VciFrameBuffer<vci_param_int>*                fbuf;
182
183    VciDspinTargetWrapper<vci_param_int,
184                          dspin_cmd_width,
185                          dspin_rsp_width>*       wt_fbuf;
186
187    VciMultiNic<vci_param_int>*                   mnic;
188
189    VciDspinTargetWrapper<vci_param_int,
190                          dspin_cmd_width,
191                          dspin_rsp_width>*       wt_mnic;
192
193    VciBlockDeviceTsar<vci_param_int>*            bdev;
194
195    VciDspinInitiatorWrapper<vci_param_int,
196                             dspin_cmd_width,
197                             dspin_rsp_width>*    wi_bdev;
198
199    VciDspinTargetWrapper<vci_param_int,
200                          dspin_cmd_width,
201                          dspin_rsp_width>*       wt_bdev;
202
203    DspinLocalCrossbar<dspin_cmd_width>*          xbar_cmd_d;
204    DspinLocalCrossbar<dspin_rsp_width>*          xbar_rsp_d;
205    DspinLocalCrossbar<dspin_cmd_width>*          xbar_m2p_c;
206    DspinLocalCrossbar<dspin_rsp_width>*          xbar_p2m_c;
207    DspinLocalCrossbar<dspin_cmd_width>*          xbar_clack_c;
208
209    VirtualDspinRouter<dspin_cmd_width>*          router_cmd;
210    VirtualDspinRouter<dspin_rsp_width>*          router_rsp;
211    DspinRouter<dspin_cmd_width>*                 router_clack;
212
213    TsarXbarCluster( sc_module_name                     insname,
214                     size_t                             nb_procs,      // processors
215                     size_t                             nb_ttys,       // TTY terminals
216                     size_t                             nb_dmas,       //  DMA channels
217                     size_t                             x,             // x coordinate
218                     size_t                             y,             // y coordinate
219                     size_t                             cluster,       // y + ymax*x
220                     const soclib::common::MappingTable &mtd,          // internal
221                     const soclib::common::MappingTable &mtx,          // external
222                     size_t                             x_width,       // x field bits
223                     size_t                             y_width,       // y field bits
224                     size_t                             l_width,       // l field bits
225                     size_t                             tgtid_memc,
226                     size_t                             tgtid_xicu,
227                     size_t                             tgtid_mdma,
228                     size_t                             tgtid_fbuf,
229                     size_t                             tgtid_mtty,
230                     size_t                             tgtid_brom,
231                     size_t                             tgtid_mnic,
232                     size_t                             tgtid_bdev,
233                     size_t                             memc_ways,
234                     size_t                             memc_sets,
235                     size_t                             l1_i_ways,
236                     size_t                             l1_i_sets,
237                     size_t                             l1_d_ways,
238                     size_t                             l1_d_sets,
239                     size_t                             xram_latency,  // external ram
240                     bool                               io,            // I/O cluster
241                     size_t                             xfb,           // fbf pixels
242                     size_t                             yfb,           // fbf lines
243                     char*                              disk_name,     // virtual disk
244                     size_t                             block_size,    // block size
245                     size_t                             nic_channels,  // number channels
246                     char*                              nic_rx_name,   // filename rx
247                     char*                              nic_tx_name,   // filename tx
248                     uint32_t                           nic_timeout,   // cycles
249                     const Loader                       &loader,
250                     uint32_t                           frozen_cycles,
251                     uint32_t                           start_debug_cycle,
252                     bool                               memc_debug_ok,
253                     bool                               proc_debug_ok);
254
255};
256}}
257
258#endif
Note: See TracBrowser for help on using the repository browser.