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

Last change on this file since 885 was 885, checked in by devigne, 9 years ago

platform: tsar_generic_xbar
Replace virtual_dspin_router by dspin_router.

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