source: trunk/platforms/tsar_generic_leti/tsar_leti_cluster/caba/source/include/tsar_leti_cluster.h @ 628

Last change on this file since 628 was 628, checked in by alain, 10 years ago

Introducing the vci_iopic component in the tsar_generic_leti plat-form.
This platform has been tested wit three distributed applications
running on top of the giet_tsar:

  • soft_hello_giet
  • soft_transpose_giet
  • soft_sort_giet
File size: 10.2 KB
Line 
1//////////////////////////////////////////////////////////////////////////////
2// File: tsar_leti_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_LETI_CLUSTER_H
10#define SOCLIB_CABA_TSAR_LETI_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.h"
28#include "vci_multi_tty.h"
29#include "vci_block_device_tsar.h"
30#include "vci_mem_cache.h"
31#include "vci_cc_vcache_wrapper.h"
32
33namespace soclib { namespace caba {
34
35///////////////////////////////////////////////////////////////////////////
36template<size_t dspin_cmd_width,
37         size_t dspin_rsp_width,
38         typename vci_param_int,
39         typename vci_param_ext>  class TsarLetiCluster
40///////////////////////////////////////////////////////////////////////////
41    : public soclib::caba::BaseModule
42{
43    public:
44
45    // Used in destructor
46    size_t n_procs;
47
48    // Ports
49    sc_in<bool>                                     p_clk;
50    sc_in<bool>                                     p_resetn;
51
52    soclib::caba::DspinOutput<dspin_cmd_width>      *p_cmd_out;
53    soclib::caba::DspinInput<dspin_cmd_width>       *p_cmd_in;
54
55    soclib::caba::DspinOutput<dspin_rsp_width>      *p_rsp_out;
56    soclib::caba::DspinInput<dspin_rsp_width>       *p_rsp_in;
57
58    soclib::caba::DspinOutput<dspin_cmd_width>      *p_m2p_out;
59    soclib::caba::DspinInput<dspin_cmd_width>       *p_m2p_in;
60
61    soclib::caba::DspinOutput<dspin_rsp_width>      *p_p2m_out;
62    soclib::caba::DspinInput<dspin_rsp_width>       *p_p2m_in;
63
64    soclib::caba::DspinOutput<dspin_cmd_width>      *p_cla_out;
65    soclib::caba::DspinInput<dspin_cmd_width>       *p_cla_in;
66
67    // interrupt signals
68    sc_signal<bool>         signal_false;
69    sc_signal<bool>         signal_proc_irq[16];
70    sc_signal<bool>         signal_irq_mtty;
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[4];
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_fbuf;
98    VciSignals<vci_param_int>       signal_vci_tgt_mnic;
99    VciSignals<vci_param_int>       signal_vci_tgt_chbuf;
100    VciSignals<vci_param_int>       signal_vci_tgt_simh;
101
102    // Direct DSPIN signals to local crossbars
103    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_proc_i[4];
104    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_proc_i[4];
105    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_mdma_i;
106    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_mdma_i;
107    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_bdev_i;
108    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_bdev_i;
109    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_chbuf_i;
110    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_chbuf_i;
111
112    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_memc_t;
113    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_memc_t;
114    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_xicu_t;
115    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_xicu_t;
116    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_mdma_t;
117    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_mdma_t;
118    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_mtty_t;
119    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_mtty_t;
120    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_bdev_t;
121    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_bdev_t;
122    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_fbuf_t;
123    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_fbuf_t;
124    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_mnic_t;
125    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_mnic_t;
126    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_chbuf_t;
127    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_chbuf_t;
128    DspinSignals<dspin_cmd_width>     signal_dspin_cmd_simh_t;
129    DspinSignals<dspin_rsp_width>     signal_dspin_rsp_simh_t;
130
131    // Coherence DSPIN signals to local crossbar
132    DspinSignals<dspin_cmd_width>     signal_dspin_m2p_memc;
133    DspinSignals<dspin_cmd_width>     signal_dspin_clack_memc;
134    DspinSignals<dspin_rsp_width>     signal_dspin_p2m_memc;
135    DspinSignals<dspin_cmd_width>     signal_dspin_m2p_proc[4];
136    DspinSignals<dspin_cmd_width>     signal_dspin_clack_proc[4];
137    DspinSignals<dspin_rsp_width>     signal_dspin_p2m_proc[4];
138
139    // external RAM to MEMC VCI signal
140    VciSignals<vci_param_ext>         signal_vci_xram;
141
142    // Components
143
144    VciCcVCacheWrapper<vci_param_int,
145                       dspin_cmd_width,
146                       dspin_rsp_width,
147                       GdbServer<Mips32ElIss> >*  proc[4];
148
149    VciDspinInitiatorWrapper<vci_param_int,
150                             dspin_cmd_width,
151                             dspin_rsp_width>*    wi_proc[4];
152
153    VciMemCache<vci_param_int,
154                vci_param_ext,
155                dspin_rsp_width,
156                dspin_cmd_width>*                 memc;
157
158    VciDspinTargetWrapper<vci_param_int,
159                          dspin_cmd_width,
160                          dspin_rsp_width>*       wt_memc;
161
162    VciXicu<vci_param_int>*                       xicu;
163
164    VciDspinTargetWrapper<vci_param_int,
165                          dspin_cmd_width,
166                          dspin_rsp_width>*       wt_xicu;
167
168    VciSimpleRam<vci_param_ext>*                  xram;
169
170    VciMultiTty<vci_param_int>*                   mtty;
171
172    VciDspinTargetWrapper<vci_param_int,
173                          dspin_cmd_width,
174                          dspin_rsp_width>*       wt_mtty;
175
176    VciBlockDeviceTsar<vci_param_int>*            bdev;
177
178    VciDspinInitiatorWrapper<vci_param_int,
179                             dspin_cmd_width,
180                             dspin_rsp_width>*    wi_bdev;
181
182    VciDspinTargetWrapper<vci_param_int,
183                          dspin_cmd_width,
184                          dspin_rsp_width>*       wt_bdev;
185
186    DspinLocalCrossbar<dspin_cmd_width>*          xbar_cmd;
187    DspinLocalCrossbar<dspin_rsp_width>*          xbar_rsp;
188    DspinLocalCrossbar<dspin_cmd_width>*          xbar_m2p;
189    DspinLocalCrossbar<dspin_rsp_width>*          xbar_p2m;
190    DspinLocalCrossbar<dspin_cmd_width>*          xbar_cla;
191
192    DspinRouter<dspin_cmd_width>*                 router_cmd;
193    DspinRouter<dspin_rsp_width>*                 router_rsp;
194    DspinRouter<dspin_cmd_width>*                 router_m2p;
195    DspinRouter<dspin_rsp_width>*                 router_p2m;
196    DspinRouter<dspin_cmd_width>*                 router_cla;
197
198    TsarLetiCluster( sc_module_name                     insname,
199                     size_t                             nb_procs,      // processors
200                     size_t                             x,             // x coordinate
201                     size_t                             y,             // y coordinate
202                     size_t                             cluster,       // y + ymax*x
203                     const soclib::common::MappingTable &mtd,          // internal
204                     const soclib::common::MappingTable &mtx,          // external
205                     uint32_t                           reset_address, // boot address
206                     size_t                             x_width,       // x field bits
207                     size_t                             y_width,       // y field bits
208                     size_t                             l_width,       // l field bits
209                     size_t                             tgtid_memc,
210                     size_t                             tgtid_xicu,
211                     size_t                             tgtid_mtty,
212                     size_t                             tgtid_bdev,
213                     const char*                        disk_pathname,
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,  // external ram
221                     const Loader                       &loader,
222                     uint32_t                           frozen_cycles,
223                     uint32_t                           trace_start_cycle,
224                     bool                               trace_proc_ok,
225                     uint32_t                           trace_proc_id,
226                     bool                               trace_memc_ok,
227                     uint32_t                           trace_memc_id );
228
229    ~TsarLetiCluster();
230
231};
232}}
233
234#endif
Note: See TracBrowser for help on using the repository browser.