source: trunk/platforms/tsar_generic_3d/tsar_xbar_cluster/caba/source/include/tsar_xbar_cluster.h @ 1040

Last change on this file since 1040 was 1040, checked in by bouyer, 8 years ago

Add a platform using the new dspin 3d router.
Only giet-vm is suported at this time.
The software is not aware of the 3d layout; the software's y
dimention is subdivided in hardware y and z.

File size: 10.4 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#include <stdint.h>
19
20#include "vci_multi_nic.h"
21#include "gdbserver.h"
22#include "mapping_table.h"
23#include "mips32.h"
24#include "vci_simple_ram.h"
25#include "vci_simple_rom.h"
26#include "vci_xicu.h"
27#include "dspin_local_crossbar.h"
28#include "vci_local_crossbar.h"
29#include "vci_dspin_initiator_wrapper.h"
30#include "vci_dspin_target_wrapper.h"
31#include "dspin_router_3d.h"
32#include "vci_multi_tty.h"
33#include "vci_chbuf_dma.h"
34#include "vci_block_device_tsar.h"
35#include "vci_framebuffer.h"
36#include "vci_multi_dma.h"
37#include "vci_mem_cache.h"
38#include "vci_cc_vcache_wrapper.h"
39#include "vci_simhelper.h"
40
41namespace soclib { namespace caba {
42
43///////////////////////////////////////////////////////////////////////////
44template<size_t dspin_cmd_width,
45         size_t dspin_rsp_width,
46         typename vci_param_int,
47         typename vci_param_ext>  class TsarXbarCluster
48///////////////////////////////////////////////////////////////////////////
49    : public soclib::caba::BaseModule
50{
51    public:
52
53    // Used in destructor
54    size_t n_procs;
55
56    // Ports
57    sc_in<bool>                                     p_clk;
58    sc_in<bool>                                     p_resetn;
59
60    soclib::caba::DspinOutput<dspin_cmd_width>      *p_cmd_out;
61    soclib::caba::DspinInput<dspin_cmd_width>       *p_cmd_in;
62
63    soclib::caba::DspinOutput<dspin_rsp_width>      *p_rsp_out;
64    soclib::caba::DspinInput<dspin_rsp_width>       *p_rsp_in;
65
66    soclib::caba::DspinOutput<dspin_cmd_width>      *p_m2p_out;
67    soclib::caba::DspinInput<dspin_cmd_width>       *p_m2p_in;
68
69    soclib::caba::DspinOutput<dspin_rsp_width>      *p_p2m_out;
70    soclib::caba::DspinInput<dspin_rsp_width>       *p_p2m_in;
71
72    soclib::caba::DspinOutput<dspin_cmd_width>      *p_cla_out;
73    soclib::caba::DspinInput<dspin_cmd_width>       *p_cla_in;
74
75    // interrupt signals
76    sc_signal<bool>         signal_false;
77    sc_signal<bool>         signal_proc_it[8 * 6]; // 6 = Number of IRQs in the MIPS
78    sc_signal<bool>         signal_irq_mdma[8];
79    sc_signal<bool>         signal_irq_mtty[23];
80    sc_signal<bool>         signal_irq_mnic_rx[8];  // unused
81    sc_signal<bool>         signal_irq_mnic_tx[8];  // unused
82    sc_signal<bool>         signal_irq_chbuf[8];  // unused
83    sc_signal<bool>         signal_irq_memc;
84    sc_signal<bool>         signal_irq_bdev;
85
86    // DSPIN signals between DSPIN routers and local_crossbars
87    DspinSignals<dspin_cmd_width>   signal_dspin_cmd_l2g_d;
88    DspinSignals<dspin_cmd_width>   signal_dspin_cmd_g2l_d;
89    DspinSignals<dspin_cmd_width>   signal_dspin_m2p_l2g_c;
90    DspinSignals<dspin_cmd_width>   signal_dspin_m2p_g2l_c;
91    DspinSignals<dspin_cmd_width>   signal_dspin_clack_l2g_c;
92    DspinSignals<dspin_cmd_width>   signal_dspin_clack_g2l_c;
93    DspinSignals<dspin_rsp_width>   signal_dspin_rsp_l2g_d;
94    DspinSignals<dspin_rsp_width>   signal_dspin_rsp_g2l_d;
95    DspinSignals<dspin_rsp_width>   signal_dspin_p2m_l2g_c;
96    DspinSignals<dspin_rsp_width>   signal_dspin_p2m_g2l_c;
97
98    // Direct VCI signals to VCI/DSPIN wrappers
99    VciSignals<vci_param_int>       signal_vci_g2l_d;
100    VciSignals<vci_param_int>       signal_vci_l2g_d;
101
102    VciSignals<vci_param_int>       signal_vci_ini_proc[8];
103    VciSignals<vci_param_int>       signal_vci_ini_mdma;
104    VciSignals<vci_param_int>       signal_vci_ini_bdev;
105    VciSignals<vci_param_int>       signal_vci_ini_chbuf;
106
107    VciSignals<vci_param_int>       signal_vci_tgt_memc;
108    VciSignals<vci_param_int>       signal_vci_tgt_xicu;
109    VciSignals<vci_param_int>       signal_vci_tgt_mdma;
110    VciSignals<vci_param_int>       signal_vci_tgt_mtty;
111    VciSignals<vci_param_int>       signal_vci_tgt_bdev;
112    VciSignals<vci_param_int>       signal_vci_tgt_brom;
113    VciSignals<vci_param_int>       signal_vci_tgt_fbuf;
114    VciSignals<vci_param_int>       signal_vci_tgt_mnic;
115    VciSignals<vci_param_int>       signal_vci_tgt_chbuf;
116    VciSignals<vci_param_int>       signal_vci_tgt_simh;
117
118
119    // Coherence DSPIN signals to local crossbar
120    DspinSignals<dspin_cmd_width>     signal_dspin_m2p_memc;
121    DspinSignals<dspin_cmd_width>     signal_dspin_clack_memc;
122    DspinSignals<dspin_rsp_width>     signal_dspin_p2m_memc;
123    DspinSignals<dspin_cmd_width>     signal_dspin_m2p_proc[8];
124    DspinSignals<dspin_cmd_width>     signal_dspin_clack_proc[8];
125    DspinSignals<dspin_rsp_width>     signal_dspin_p2m_proc[8];
126
127    // external RAM to MEMC VCI signal
128    VciSignals<vci_param_ext>         signal_vci_xram;
129
130    // Components
131
132    VciCcVCacheWrapper<vci_param_int,
133                       dspin_cmd_width,
134                       dspin_rsp_width,
135                       GdbServer<Mips32ElIss> >*  proc[8];
136
137
138    VciMemCache<vci_param_int,
139                vci_param_ext,
140                dspin_rsp_width,
141                dspin_cmd_width>*                 memc;
142
143    VciXicu<vci_param_int>*                       xicu;
144
145    VciMultiDma<vci_param_int>*                   mdma;
146
147    VciSimpleRam<vci_param_ext>*                  xram;
148
149    VciSimpleRom<vci_param_int>*                  brom;
150
151    VciMultiTty<vci_param_int>*                   mtty;
152
153    VciSimhelper<vci_param_int>*                  simhelper;
154
155    VciFrameBuffer<vci_param_int>*                fbuf;
156
157    VciMultiNic<vci_param_int>*                   mnic;
158
159    VciChbufDma<vci_param_int>*                   chbuf;
160
161    VciBlockDeviceTsar<vci_param_int>*            bdev;
162
163    VciLocalCrossbar<vci_param_int>*              xbar_d;
164    VciDspinInitiatorWrapper<vci_param_int,
165                             dspin_cmd_width,
166                             dspin_rsp_width>*    wi_xbar_d;
167    VciDspinTargetWrapper<vci_param_int,
168                          dspin_cmd_width,
169                          dspin_rsp_width>*       wt_xbar_d;
170
171    DspinLocalCrossbar<dspin_cmd_width>*          xbar_m2p_c;
172    DspinLocalCrossbar<dspin_rsp_width>*          xbar_p2m_c;
173    DspinLocalCrossbar<dspin_cmd_width>*          xbar_clack_c;
174
175    DspinRouter3d<dspin_cmd_width>*                 router_cmd;
176    DspinRouter3d<dspin_rsp_width>*                 router_rsp;
177    DspinRouter3d<dspin_cmd_width>*                 router_m2p;
178    DspinRouter3d<dspin_rsp_width>*                 router_p2m;
179    DspinRouter3d<dspin_cmd_width>*                 router_cla;
180
181    TsarXbarCluster( sc_module_name                     insname,
182                     size_t                             nb_procs,      // processors
183                     size_t                             nb_ttys,       // TTY terminals
184                     size_t                             nb_dmas,       //  DMA channels
185                     size_t                             x,             // x coordinate
186                     size_t                             y,             // y coordinate
187                     size_t                             z,             // z coordinate
188                     size_t                             cluster,       // z + zmax * y + ymax*x
189                     size_t                             elevator_x,
190                     size_t                             elevator_y,
191                     const soclib::common::MappingTable &mtd,          // internal
192                     const soclib::common::MappingTable &mtx,          // external
193                     size_t                             x_width,       // x field bits
194                     size_t                             y_width,       // y field bits
195                     size_t                             z_width,       // z field bits
196                     size_t                             l_width,       // l field bits
197                     size_t                             p_width,
198                     size_t                             tgtid_memc,
199                     size_t                             tgtid_xicu,
200                     size_t                             tgtid_mdma,
201                     size_t                             tgtid_fbuf,
202                     size_t                             tgtid_mtty,
203                     size_t                             tgtid_brom,
204                     size_t                             tgtid_mnic,
205                     size_t                             tgtid_chbuf,
206                     size_t                             tgtid_bdev,
207                     size_t                             tgtid_simh,
208                     size_t                             memc_ways,
209                     size_t                             memc_sets,
210                     size_t                             l1_i_ways,
211                     size_t                             l1_i_sets,
212                     size_t                             l1_d_ways,
213                     size_t                             l1_d_sets,
214                     size_t                             irq_per_processor,
215                     size_t                             xram_latency,  // external ram
216                     bool                               io,            // I/O cluster
217                     size_t                             xfb,           // fbf pixels
218                     size_t                             yfb,           // fbf lines
219                     char*                              disk_name,     // virtual disk
220                     size_t                             block_size,    // block size
221                     size_t                             nic_channels,  // number channels
222                     char*                              nic_rx_name,   // filename rx
223                     char*                              nic_tx_name,   // filename tx
224                     uint32_t                           nic_timeout,   // cycles
225                     size_t                             chbufdma_channels,  // number channels
226                     const Loader                       &loader,
227                     uint32_t                           frozen_cycles,
228                     uint32_t                           start_debug_cycle,
229                     bool                               memc_debug_ok,
230                     bool                               proc_debug_ok);
231
232    ~TsarXbarCluster();
233    void trace(sc_trace_file * tf, const std::string & name);
234
235};
236}}
237
238#endif
Note: See TracBrowser for help on using the repository browser.