source: trunk/platforms/tsar_generic_xbar/tsar_xbar_cluster/caba/source/include/tsar_xbar_cluster.h @ 624

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

Modification in tsar_generic_xbar platform:

  • Using the constant IRQ_PER_PROCESSOR on the hard_config.h file to specify more than one irq from the XICU to each processor.
File size: 12.9 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 "vci_multi_tty.h"
30#include "vci_multi_nic.h"
31#include "vci_chbuf_dma.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#include "vci_simhelper.h"
38#include "../../../../giet_vm/hard_config.h"
39
40namespace soclib { namespace caba {
41
42///////////////////////////////////////////////////////////////////////////
43template<size_t dspin_cmd_width,
44         size_t dspin_rsp_width,
45         typename vci_param_int,
46         typename vci_param_ext>  class TsarXbarCluster
47///////////////////////////////////////////////////////////////////////////
48    : public soclib::caba::BaseModule
49{
50    public:
51
52    // Used in destructor
53    size_t n_procs;
54
55    // Ports
56    sc_in<bool>                                     p_clk;
57    sc_in<bool>                                     p_resetn;
58    soclib::caba::DspinOutput<dspin_cmd_width>      **p_cmd_out;
59    soclib::caba::DspinInput<dspin_cmd_width>       **p_cmd_in;
60    soclib::caba::DspinOutput<dspin_rsp_width>      **p_rsp_out;
61    soclib::caba::DspinInput<dspin_rsp_width>       **p_rsp_in;
62
63    // interrupt signals
64    sc_signal<bool>         signal_false;
65    sc_signal<bool>         signal_proc_it[8*IRQ_PER_PROCESSOR];
66    sc_signal<bool>         signal_irq_mdma[8];
67    sc_signal<bool>         signal_irq_mtty[23];
68    sc_signal<bool>         signal_irq_mnic_rx[8];  // unused
69    sc_signal<bool>         signal_irq_mnic_tx[8];  // unused
70    sc_signal<bool>         signal_irq_chbuf[8];  // unused
71    sc_signal<bool>         signal_irq_memc;
72    sc_signal<bool>         signal_irq_bdev;
73
74    // DSPIN signals between DSPIN routers and local_crossbars
75    DspinSignals<dspin_cmd_width>   signal_dspin_cmd_l2g_d;
76    DspinSignals<dspin_cmd_width>   signal_dspin_cmd_g2l_d;
77    DspinSignals<dspin_cmd_width>   signal_dspin_m2p_l2g_c;
78    DspinSignals<dspin_cmd_width>   signal_dspin_m2p_g2l_c;
79    DspinSignals<dspin_cmd_width>   signal_dspin_clack_l2g_c;
80    DspinSignals<dspin_cmd_width>   signal_dspin_clack_g2l_c;
81    DspinSignals<dspin_rsp_width>   signal_dspin_rsp_l2g_d;
82    DspinSignals<dspin_rsp_width>   signal_dspin_rsp_g2l_d;
83    DspinSignals<dspin_rsp_width>   signal_dspin_p2m_l2g_c;
84    DspinSignals<dspin_rsp_width>   signal_dspin_p2m_g2l_c;
85
86    // Direct VCI signals to VCI/DSPIN wrappers
87    VciSignals<vci_param_int>       signal_vci_ini_proc[8];
88    VciSignals<vci_param_int>       signal_vci_ini_mdma;
89    VciSignals<vci_param_int>       signal_vci_ini_bdev;
90    VciSignals<vci_param_int>       signal_vci_ini_chbuf;
91
92    VciSignals<vci_param_int>       signal_vci_tgt_memc;
93    VciSignals<vci_param_int>       signal_vci_tgt_xicu;
94    VciSignals<vci_param_int>       signal_vci_tgt_mdma;
95    VciSignals<vci_param_int>       signal_vci_tgt_mtty;
96    VciSignals<vci_param_int>       signal_vci_tgt_bdev;
97    VciSignals<vci_param_int>       signal_vci_tgt_brom;
98    VciSignals<vci_param_int>       signal_vci_tgt_fbuf;
99    VciSignals<vci_param_int>       signal_vci_tgt_mnic;
100    VciSignals<vci_param_int>       signal_vci_tgt_chbuf;
101    VciSignals<vci_param_int>       signal_vci_tgt_simh;
102
103    // Direct DSPIN signals to local crossbars
104    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_proc_i[8];
105    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_proc_i[8];
106    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_mdma_i;
107    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_mdma_i;
108    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_bdev_i;
109    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_bdev_i;
110    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_chbuf_i;
111    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_chbuf_i;
112
113    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_memc_t;
114    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_memc_t;
115    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_xicu_t;
116    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_xicu_t;
117    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_mdma_t;
118    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_mdma_t;
119    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_mtty_t;
120    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_mtty_t;
121    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_bdev_t;
122    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_bdev_t;
123    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_brom_t;
124    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_brom_t;
125    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_fbuf_t;
126    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_fbuf_t;
127    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_mnic_t;
128    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_mnic_t;
129    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_chbuf_t;
130    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_chbuf_t;
131    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_simh_t;
132    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_simh_t;
133
134    // Coherence DSPIN signals to local crossbar
135    DspinSignals<dspin_cmd_width>     signal_dspin_m2p_memc;
136    DspinSignals<dspin_cmd_width>     signal_dspin_clack_memc;
137    DspinSignals<dspin_rsp_width>     signal_dspin_p2m_memc;
138    DspinSignals<dspin_cmd_width>     signal_dspin_m2p_proc[8];
139    DspinSignals<dspin_cmd_width>     signal_dspin_clack_proc[8];
140    DspinSignals<dspin_rsp_width>     signal_dspin_p2m_proc[8];
141
142    // external RAM to MEMC VCI signal
143    VciSignals<vci_param_ext>         signal_vci_xram;
144
145    // Components
146
147    VciCcVCacheWrapper<vci_param_int,
148                       dspin_cmd_width,
149                       dspin_rsp_width,
150                       GdbServer<Mips32ElIss> >*  proc[8];
151
152    VciDspinInitiatorWrapper<vci_param_int,
153                             dspin_cmd_width,
154                             dspin_rsp_width>*    wi_proc[8];
155
156    VciMemCache<vci_param_int,
157                vci_param_ext,
158                dspin_rsp_width,
159                dspin_cmd_width>*                 memc;
160
161    VciDspinTargetWrapper<vci_param_int,
162                          dspin_cmd_width,
163                          dspin_rsp_width>*       wt_memc;
164
165    VciXicu<vci_param_int>*                       xicu;
166
167    VciDspinTargetWrapper<vci_param_int,
168                          dspin_cmd_width,
169                          dspin_rsp_width>*       wt_xicu;
170
171    VciMultiDma<vci_param_int>*                   mdma;
172
173    VciDspinInitiatorWrapper<vci_param_int,
174                             dspin_cmd_width,
175                             dspin_rsp_width>*    wi_mdma;
176
177    VciDspinTargetWrapper<vci_param_int,
178                          dspin_cmd_width,
179                          dspin_rsp_width>*       wt_mdma;
180
181    VciSimpleRam<vci_param_ext>*                  xram;
182
183    VciSimpleRom<vci_param_int>*                  brom;
184
185    VciDspinTargetWrapper<vci_param_int,
186                          dspin_cmd_width,
187                          dspin_rsp_width>*       wt_brom;
188
189    VciMultiTty<vci_param_int>*                   mtty;
190
191    VciDspinTargetWrapper<vci_param_int,
192                          dspin_cmd_width,
193                          dspin_rsp_width>*       wt_mtty;
194
195    VciSimhelper<vci_param_int>*                  simhelper;
196
197    VciDspinTargetWrapper<vci_param_int,
198                          dspin_cmd_width,
199                          dspin_rsp_width>*       wt_simhelper;
200
201
202    VciFrameBuffer<vci_param_int>*                fbuf;
203
204    VciDspinTargetWrapper<vci_param_int,
205                          dspin_cmd_width,
206                          dspin_rsp_width>*       wt_fbuf;
207
208    VciMultiNic<vci_param_int>*                   mnic;
209
210    VciDspinTargetWrapper<vci_param_int,
211                          dspin_cmd_width,
212                          dspin_rsp_width>*       wt_mnic;
213
214    VciChbufDma<vci_param_int>*                   chbuf;
215
216    VciDspinTargetWrapper<vci_param_int,
217                          dspin_cmd_width,
218                          dspin_rsp_width>*       wt_chbuf;
219
220    VciDspinInitiatorWrapper<vci_param_int,
221                          dspin_cmd_width,
222                          dspin_rsp_width>*       wi_chbuf;
223
224    VciBlockDeviceTsar<vci_param_int>*            bdev;
225
226    VciDspinInitiatorWrapper<vci_param_int,
227                             dspin_cmd_width,
228                             dspin_rsp_width>*    wi_bdev;
229
230    VciDspinTargetWrapper<vci_param_int,
231                          dspin_cmd_width,
232                          dspin_rsp_width>*       wt_bdev;
233
234    DspinLocalCrossbar<dspin_cmd_width>*          xbar_cmd_d;
235    DspinLocalCrossbar<dspin_rsp_width>*          xbar_rsp_d;
236    DspinLocalCrossbar<dspin_cmd_width>*          xbar_m2p_c;
237    DspinLocalCrossbar<dspin_rsp_width>*          xbar_p2m_c;
238    DspinLocalCrossbar<dspin_cmd_width>*          xbar_clack_c;
239
240    VirtualDspinRouter<dspin_cmd_width>*          router_cmd;
241    VirtualDspinRouter<dspin_rsp_width>*          router_rsp;
242
243    TsarXbarCluster( sc_module_name                     insname,
244                     size_t                             nb_procs,      // processors
245                     size_t                             nb_ttys,       // TTY terminals
246                     size_t                             nb_dmas,       //  DMA channels
247                     size_t                             x,             // x coordinate
248                     size_t                             y,             // y coordinate
249                     size_t                             cluster,       // y + ymax*x
250                     const soclib::common::MappingTable &mtd,          // internal
251                     const soclib::common::MappingTable &mtx,          // external
252                     size_t                             x_width,       // x field bits
253                     size_t                             y_width,       // y field bits
254                     size_t                             l_width,       // l field bits
255                     size_t                             tgtid_memc,
256                     size_t                             tgtid_xicu,
257                     size_t                             tgtid_mdma,
258                     size_t                             tgtid_fbuf,
259                     size_t                             tgtid_mtty,
260                     size_t                             tgtid_brom,
261                     size_t                             tgtid_mnic,
262                     size_t                             tgtid_chbuf,
263                     size_t                             tgtid_bdev,
264                     size_t                             tgtid_simh,
265                     size_t                             memc_ways,
266                     size_t                             memc_sets,
267                     size_t                             l1_i_ways,
268                     size_t                             l1_i_sets,
269                     size_t                             l1_d_ways,
270                     size_t                             l1_d_sets,
271                     size_t                             xram_latency,  // external ram
272                     bool                               io,            // I/O cluster
273                     size_t                             xfb,           // fbf pixels
274                     size_t                             yfb,           // fbf lines
275                     char*                              disk_name,     // virtual disk
276                     size_t                             block_size,    // block size
277                     size_t                             nic_channels,  // number channels
278                     char*                              nic_rx_name,   // filename rx
279                     char*                              nic_tx_name,   // filename tx
280                     uint32_t                           nic_timeout,   // cycles
281                     size_t                             chbufdma_channels,  // number channels
282                     const Loader                       &loader,
283                     uint32_t                           frozen_cycles,
284                     uint32_t                           start_debug_cycle,
285                     bool                               memc_debug_ok,
286                     bool                               proc_debug_ok);
287
288    ~TsarXbarCluster();
289
290};
291}}
292
293#endif
Note: See TracBrowser for help on using the repository browser.