source: branches/fault_tolerance/platform/tsar_generic_iob/tsar_iob_cluster/caba/source/include/tsar_iob_cluster.h @ 717

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

fault_tolerance/tsar_generic_iob:

  • introducing the vci_iopic component on the IOX interconnect.


  • the input hardware interrupts on cluster(0,0) from the external peripherals have been removed because they are connected to the vci_iopic component.


  • Replacing "ad-hoc" dspin_tsar router by standard dspin_router on the RAM interconnect. To do so, in IO clusters (clusters with IOB) two crossbars are implemented:

+ One for commands which interconnects MEMC and IOB to the

local interface of RAM CMD dspin_router.

+ One for responses which interconnects local interface of RAM

RSP dspin_router to MEMC and IOB.

  • Considering case of mono cluster platform: Only one IOB must be instantiated.
  • Modifying IOX memory segments used by IOX network for routing:


+ bugfix: all segments of IOX interconnect must have

global id = 0.

+ Adding XICU segments with special attribute. This

attribute is used by IOB to determine if a command coming
from external DMA peripheral should be routed
through INT or RAM networks.

+ Using bit 32 of physical address to determine if an

external DMA command should be routed through IOB0
or IOB1.


File size: 10.2 KB
Line 
1//////////////////////////////////////////////////////////////////////////////
2// File: tsar_iob_cluster.h
3// Author: Alain Greiner
4// Copyright: UPMC/LIP6
5// Date : april 2013
6// This program is released under the GNU public license
7//////////////////////////////////////////////////////////////////////////////
8
9#ifndef SOCLIB_CABA_TSAR_IOB_CLUSTER_H
10#define SOCLIB_CABA_TSAR_IOB_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 "vci_local_crossbar.h"
26#include "dspin_local_crossbar.h"
27#include "vci_dspin_initiator_wrapper.h"
28#include "vci_dspin_target_wrapper.h"
29#include "dspin_router.h"
30#include "virtual_dspin_router.h"
31#include "vci_multi_dma.h"
32#include "vci_mem_cache.h"
33#include "vci_cc_vcache_wrapper.h"
34#include "vci_io_bridge.h"
35#include "vci_multi_tty.h"
36#include "hard_config.h"
37
38///////////////////////////////////////////////////////////////////////
39//     Number of channels for debug TTY (may be 0)
40///////////////////////////////////////////////////////////////////////
41#define NB_DEBUG_TTY_CHANNELS 1
42
43///////////////////////////////////////////////////////////////////////
44//     TGT_ID and INI_ID port indexing for INT local interconnect
45///////////////////////////////////////////////////////////////////////
46
47#define INT_MEMC_TGT_ID 0
48#define INT_XICU_TGT_ID 1
49#define INT_BROM_TGT_ID 2
50#define INT_MDMA_TGT_ID 3
51#define INT_MTTY_TGT_ID 4
52#define INT_IOBX_TGT_ID (4 + (NB_DEBUG_TTY_CHANNELS ? 1 : 0))
53
54#define INT_PROC_INI_ID 0 // from 0 to 7
55#define INT_MDMA_INI_ID NB_PROCS
56#define INT_IOBX_INI_ID (NB_PROCS + 1)
57
58///////////////////////////////////////////////////////////////////////
59//     TGT_ID and INI_ID port indexing for RAM local interconnect
60///////////////////////////////////////////////////////////////////////
61
62#define RAM_XRAM_TGT_ID 0
63
64#define RAM_MEMC_INI_ID 0
65#define RAM_IOBX_INI_ID 1
66
67namespace soclib { namespace caba {
68
69///////////////////////////////////////////////////////////////////////////
70template<typename vci_param_int,
71         typename vci_param_ext,
72         size_t   dspin_int_cmd_width,
73         size_t   dspin_int_rsp_width,
74         size_t   dspin_ram_cmd_width,
75         size_t   dspin_ram_rsp_width>
76class TsarIobCluster
77///////////////////////////////////////////////////////////////////////////
78    : public soclib::caba::BaseModule
79{
80
81   public:
82
83      // Ports
84      sc_in<bool>   p_clk;
85      sc_in<bool>   p_resetn;
86
87      // Thes two ports are used to connect IOB to IOX nework in top cell
88      soclib::caba::VciInitiator<vci_param_ext>* p_vci_iob_iox_ini;
89      soclib::caba::VciTarget<vci_param_ext>*    p_vci_iob_iox_tgt;
90
91      // These arrays of ports are used to connect the INT & RAM networks in
92      // top cell
93      soclib::caba::DspinOutput<dspin_int_cmd_width>** p_dspin_int_cmd_out;
94      soclib::caba::DspinInput<dspin_int_cmd_width>**  p_dspin_int_cmd_in;
95      soclib::caba::DspinOutput<dspin_int_rsp_width>** p_dspin_int_rsp_out;
96      soclib::caba::DspinInput<dspin_int_rsp_width>**  p_dspin_int_rsp_in;
97
98      soclib::caba::DspinOutput<dspin_ram_cmd_width>* p_dspin_ram_cmd_out;
99      soclib::caba::DspinInput<dspin_ram_cmd_width>*  p_dspin_ram_cmd_in;
100      soclib::caba::DspinOutput<dspin_ram_rsp_width>* p_dspin_ram_rsp_out;
101      soclib::caba::DspinInput<dspin_ram_rsp_width>*  p_dspin_ram_rsp_in;
102
103      // interrupt signals
104      sc_signal<bool> signal_false;
105      sc_signal<bool> signal_proc_it[NB_PROCS*IRQ_PER_PROCESSOR];
106      sc_signal<bool> signal_irq_mdma[NB_DMA_CHANNELS];
107      sc_signal<bool> signal_irq_mtty[NB_DEBUG_TTY_CHANNELS];
108      sc_signal<bool> signal_irq_memc;
109
110      // INT network DSPIN signals between DSPIN routers and DSPIN
111      // local_crossbars
112      DspinSignals<dspin_int_cmd_width> signal_int_dspin_cmd_l2g_d;
113      DspinSignals<dspin_int_cmd_width> signal_int_dspin_cmd_g2l_d;
114      DspinSignals<dspin_int_rsp_width> signal_int_dspin_rsp_l2g_d;
115      DspinSignals<dspin_int_rsp_width> signal_int_dspin_rsp_g2l_d;
116      DspinSignals<dspin_int_cmd_width> signal_int_dspin_m2p_l2g_c;
117      DspinSignals<dspin_int_cmd_width> signal_int_dspin_m2p_g2l_c;
118      DspinSignals<dspin_int_cmd_width> signal_int_dspin_clack_l2g_c;
119      DspinSignals<dspin_int_cmd_width> signal_int_dspin_clack_g2l_c;
120      DspinSignals<dspin_int_rsp_width> signal_int_dspin_p2m_l2g_c;
121      DspinSignals<dspin_int_rsp_width> signal_int_dspin_p2m_g2l_c;
122
123      // INT network VCI signals between VCI components and VCI local crossbar
124      VciSignals<vci_param_int> signal_int_vci_ini_proc[NB_PROCS];
125      VciSignals<vci_param_int> signal_int_vci_ini_mdma;
126      VciSignals<vci_param_int> signal_int_vci_ini_iobx;
127
128      VciSignals<vci_param_int> signal_int_vci_tgt_memc;
129      VciSignals<vci_param_int> signal_int_vci_tgt_xicu;
130      VciSignals<vci_param_int> signal_int_vci_tgt_brom;
131      VciSignals<vci_param_int> signal_int_vci_tgt_mtty;
132      VciSignals<vci_param_int> signal_int_vci_tgt_mdma;
133      VciSignals<vci_param_int> signal_int_vci_tgt_iobx;
134
135      VciSignals<vci_param_int> signal_int_vci_l2g;
136      VciSignals<vci_param_int> signal_int_vci_g2l;
137
138      // Coherence DSPIN signals between DSPIN local crossbars and CC
139      // components
140      DspinSignals<dspin_int_cmd_width> signal_int_dspin_m2p_memc;
141      DspinSignals<dspin_int_cmd_width> signal_int_dspin_clack_memc;
142      DspinSignals<dspin_int_rsp_width> signal_int_dspin_p2m_memc;
143      DspinSignals<dspin_int_cmd_width> signal_int_dspin_m2p_proc[NB_PROCS];
144      DspinSignals<dspin_int_cmd_width> signal_int_dspin_clack_proc[NB_PROCS];
145      DspinSignals<dspin_int_rsp_width> signal_int_dspin_p2m_proc[NB_PROCS];
146
147      // RAM network VCI signals between VCI components and VCI/DSPIN wrappers
148      VciSignals<vci_param_ext> signal_ram_vci_ini_memc;
149      VciSignals<vci_param_ext> signal_ram_vci_ini_iobx;
150      VciSignals<vci_param_ext> signal_ram_vci_tgt_xram;
151
152      // RAM network DSPIN signals between VCI/DSPIN wrappers and routers
153      DspinSignals<dspin_ram_cmd_width> signal_ram_dspin_cmd_xram_t;
154      DspinSignals<dspin_ram_rsp_width> signal_ram_dspin_rsp_xram_t;
155
156      DspinSignals<dspin_ram_cmd_width> signal_ram_dspin_cmd_memc_i;
157      DspinSignals<dspin_ram_rsp_width> signal_ram_dspin_rsp_memc_i;
158
159      DspinSignals<dspin_ram_cmd_width> signal_ram_dspin_cmd_iob_i;
160      DspinSignals<dspin_ram_rsp_width> signal_ram_dspin_rsp_iob_i;
161
162      DspinSignals<dspin_ram_cmd_width> signal_ram_dspin_cmd_xbar;
163      DspinSignals<dspin_ram_rsp_width> signal_ram_dspin_rsp_xbar;
164
165      DspinSignals<dspin_ram_cmd_width> signal_ram_dspin_cmd_false;
166      DspinSignals<dspin_ram_rsp_width> signal_ram_dspin_rsp_false;
167
168
169      //////////////////////////////////////
170      // Hardwate Components (pointers)
171      //////////////////////////////////////
172      typedef VciCcVCacheWrapper<vci_param_int, dspin_int_cmd_width,
173              dspin_int_rsp_width, GdbServer<Mips32ElIss> >
174              VciCcVCacheWrapperType;
175
176      typedef VciMemCache<vci_param_int, vci_param_ext, dspin_int_rsp_width,
177              dspin_int_cmd_width> VciMemCacheType;
178
179      typedef VciDspinInitiatorWrapper<vci_param_int, dspin_int_cmd_width,
180              dspin_int_rsp_width> VciIntDspinInitiatorWrapperType;
181
182      typedef VciDspinTargetWrapper<vci_param_int, dspin_int_cmd_width,
183              dspin_int_rsp_width> VciIntDspinTargetWrapperType;
184
185      typedef VciDspinInitiatorWrapper<vci_param_ext, dspin_ram_cmd_width,
186              dspin_ram_rsp_width> VciExtDspinInitiatorWrapperType;
187
188      typedef VciDspinTargetWrapper<vci_param_ext, dspin_ram_cmd_width,
189              dspin_ram_rsp_width> VciExtDspinTargetWrapperType;
190
191      VciCcVCacheWrapperType*          proc[8];
192
193      VciMemCacheType*                 memc;
194      VciExtDspinInitiatorWrapperType* memc_ram_wi;
195
196      VciXicu<vci_param_int>*          xicu;
197
198      VciMultiDma<vci_param_int>*      mdma;
199
200      VciSimpleRom<vci_param_int>*     brom;
201
202      VciMultiTty<vci_param_int>*      mtty;
203
204      VciLocalCrossbar<vci_param_int>*  int_xbar_d;
205      VciIntDspinInitiatorWrapperType*  int_wi_gate_d;
206      VciIntDspinTargetWrapperType*     int_wt_gate_d;
207     
208      DspinLocalCrossbar<dspin_int_cmd_width>* int_xbar_m2p_c;
209      DspinLocalCrossbar<dspin_int_rsp_width>* int_xbar_p2m_c;
210      DspinLocalCrossbar<dspin_int_cmd_width>* int_xbar_clack_c;
211
212      VirtualDspinRouter<dspin_int_cmd_width>* int_router_cmd;
213      VirtualDspinRouter<dspin_int_rsp_width>* int_router_rsp;
214
215      VciSimpleRam<vci_param_ext>*  xram;
216      VciExtDspinTargetWrapperType* xram_ram_wt;
217
218      DspinRouter<dspin_ram_cmd_width>* ram_router_cmd;
219      DspinRouter<dspin_ram_rsp_width>* ram_router_rsp;
220
221      DspinLocalCrossbar<dspin_ram_cmd_width>* ram_xbar_cmd;
222      DspinLocalCrossbar<dspin_ram_rsp_width>* ram_xbar_rsp;
223
224      // IO Network Components (not instanciated in all clusters)
225
226      VciIoBridge<vci_param_int, vci_param_ext>* iob;
227      VciExtDspinInitiatorWrapperType*           iob_ram_wi;
228
229      size_t m_procs;
230
231      struct ClusterParams {
232         sc_module_name insname;
233
234         size_t x_id;
235         size_t y_id;
236
237         const soclib::common::MappingTable &mt_int;
238         const soclib::common::MappingTable &mt_ext;
239         const soclib::common::MappingTable &mt_iox;
240
241         const bool is_io;
242         const soclib::common::IntTab iox_iob_tgtid;
243         const soclib::common::IntTab iox_iob_srcid;
244
245         size_t memc_ways;
246         size_t memc_sets;
247         size_t l1_i_ways;
248         size_t l1_i_sets;
249         size_t l1_d_ways;
250         size_t l1_d_sets;
251         size_t xram_latency;
252
253         const Loader& loader;
254
255         bool distboot;
256
257         uint32_t frozen_cycles;
258         uint32_t debug_start_cycle;
259         bool     memc_debug_ok;
260         bool     proc_debug_ok;
261         bool     iob_debug_ok;
262      };
263
264      // utility functions
265      static uint32_t clusterId(size_t x_id, size_t y_id) {
266         return ((x_id << Y_WIDTH) | y_id); 
267      };
268
269
270      SC_HAS_PROCESS(TsarIobCluster);
271
272      void init();
273
274      // cluster constructor
275      TsarIobCluster(struct ClusterParams& params);
276      ~TsarIobCluster();
277};
278
279}}
280
281#endif
282
283// vim: filetype=cpp:expandtab:shiftwidth=3:tabstop=3:softtabstop=3
Note: See TracBrowser for help on using the repository browser.