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

Last change on this file since 396 was 396, checked in by alain, 11 years ago

Major evolution of platform "tsar_generic_xbar"
to support 40 bits physical addresse, and 64 bits data
between mem_cache and external RAM.

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