source: trunk/platforms/caba-ring-ccxcachev1_memcachev3-mipsel/top.cpp @ 342

Last change on this file since 342 was 137, checked in by simerabe, 14 years ago

replacing old ring versions with new one

  • Property svn:eol-style set to native
  • Property svn:executable set to *
  • Property svn:keywords set to "Author Date Id Rev URL Revision"
  • Property svn:mime-type set to text/plain
File size: 11.9 KB
Line 
1
2#include <systemc>
3#include <sys/time.h>
4#include <iostream>
5#include <cstdlib>
6#include <cstdarg>
7
8#include "mapping_table.h"
9#include "mips32.h"
10#include "iss2_simhelper.h"
11#include "vci_simple_ram.h"
12#include "vci_multi_tty.h"
13#include "vci_simple_ring_fast.h"
14#include "vci_mem_cache_v3.h"
15#include "vci_cc_xcache_wrapper_v1.h"
16#include "vci_logger.h"
17
18#ifdef USE_GDB_SERVER
19#include "iss/gdbserver.h"
20#endif
21
22//#define  VCI_LOGGER
23#include "segmentation.h"
24
25int _main(int argc, char *argv[])
26{
27        using namespace sc_core;
28        // Avoid repeating these everywhere
29        using soclib::common::IntTab;
30        using soclib::common::Segment;
31
32        // Define VCI parameters
33        typedef soclib::caba::VciParams<4,8,32,2,1,1,8,4,4,1> vci_param;
34        typedef soclib::common::Iss2Simhelper<soclib::common::Mips32ElIss> proc_iss;
35        // Mapping table
36
37        soclib::common::MappingTable maptabp(32, IntTab(8), IntTab(8), 0x00300000);
38
39        maptabp.add(Segment("reset", RESET_BASE, RESET_SIZE, IntTab(2), true));
40        maptabp.add(Segment("excep", EXCEP_BASE, EXCEP_SIZE, IntTab(2), true));
41        maptabp.add(Segment("text" , TEXT_BASE , TEXT_SIZE , IntTab(2), true));
42        maptabp.add(Segment("tty"  , TTY_BASE  , TTY_SIZE  , IntTab(1), false));
43        maptabp.add(Segment("mc_m" , MC_M_BASE , MC_M_SIZE , IntTab(2), true ));
44 
45        std::cout << maptabp << std::endl;
46
47        soclib::common::MappingTable maptabc(32, IntTab(8), IntTab(8), 0x00300000);
48        maptabc.add(Segment("c_proc0" , C_PROC0_BASE , C_PROC0_SIZE , IntTab(0), false, true, IntTab(0)));
49        maptabc.add(Segment("c_proc1" , C_PROC1_BASE , C_PROC1_SIZE , IntTab(1), false, true, IntTab(1)));
50        maptabc.add(Segment("c_proc2" , C_PROC2_BASE , C_PROC2_SIZE , IntTab(2), false, true, IntTab(2)));
51        maptabc.add(Segment("c_proc3" , C_PROC3_BASE , C_PROC3_SIZE , IntTab(3), false, true, IntTab(3)));
52        maptabc.add(Segment("mc_m"  , MC_M_BASE , MC_M_SIZE  , IntTab(4), false, false));
53        maptabc.add(Segment("reset", RESET_BASE, RESET_SIZE, IntTab(4), false, false));
54        maptabc.add(Segment("excep", EXCEP_BASE, EXCEP_SIZE, IntTab(4), false, false));
55        maptabc.add(Segment("text" , TEXT_BASE , TEXT_SIZE , IntTab(4), false, false));
56
57        std::cout << maptabc << std::endl;
58       
59        soclib::common::MappingTable maptabx(32, IntTab(8), IntTab(8), 0x00300000);
60        maptabx.add(Segment("xram" , MC_M_BASE , MC_M_SIZE , IntTab(0), false));
61        maptabx.add(Segment("reset", RESET_BASE, RESET_SIZE, IntTab(0), false));
62        maptabx.add(Segment("excep", EXCEP_BASE, EXCEP_SIZE, IntTab(0), false));
63        maptabx.add(Segment("text" , TEXT_BASE , TEXT_SIZE , IntTab(0), false));
64       
65        std::cout << maptabx << std::endl;
66
67        // Signals
68        sc_clock        signal_clk("clk");
69        sc_signal<bool> signal_resetn("resetn");
70   
71        sc_signal<bool> signal_proc0_it0("proc0_it0");
72        sc_signal<bool> signal_proc0_it1("proc0_it1");
73        sc_signal<bool> signal_proc0_it2("proc0_it2");
74        sc_signal<bool> signal_proc0_it3("proc0_it3");
75        sc_signal<bool> signal_proc0_it4("proc0_it4");
76        sc_signal<bool> signal_proc0_it5("proc0_it5");
77
78        sc_signal<bool> signal_proc1_it0("proc1_it0");
79        sc_signal<bool> signal_proc1_it1("proc1_it1");
80        sc_signal<bool> signal_proc1_it2("proc1_it2");
81        sc_signal<bool> signal_proc1_it3("proc1_it3");
82        sc_signal<bool> signal_proc1_it4("proc1_it4");
83        sc_signal<bool> signal_proc1_it5("proc1_it5");
84
85        sc_signal<bool> signal_proc2_it0("proc2_it0");
86        sc_signal<bool> signal_proc2_it1("proc2_it1");
87        sc_signal<bool> signal_proc2_it2("proc2_it2");
88        sc_signal<bool> signal_proc2_it3("proc2_it3");
89        sc_signal<bool> signal_proc2_it4("proc2_it4");
90        sc_signal<bool> signal_proc2_it5("proc2_it5");
91
92        sc_signal<bool> signal_proc3_it0("proc3_it0");
93        sc_signal<bool> signal_proc3_it1("proc3_it1");
94        sc_signal<bool> signal_proc3_it2("proc3_it2");
95        sc_signal<bool> signal_proc3_it3("proc3_it3");
96        sc_signal<bool> signal_proc3_it4("proc3_it4");
97        sc_signal<bool> signal_proc3_it5("proc3_it5");
98
99        soclib::caba::VciSignals<vci_param> signal_vci_ini_rw_proc0("vci_ini_rw_proc0");
100        soclib::caba::VciSignals<vci_param> signal_vci_ini_c_proc0("vci_ini_c_proc0");
101
102        soclib::caba::VciSignals<vci_param> signal_vci_tgt_proc0("vci_tgt_proc0");
103
104        soclib::caba::VciSignals<vci_param> signal_vci_ini_rw_proc1("vci_ini_rw_proc1");
105        soclib::caba::VciSignals<vci_param> signal_vci_ini_c_proc1("vci_ini_c_proc1");
106
107        soclib::caba::VciSignals<vci_param> signal_vci_tgt_proc1("vci_tgt_proc1");
108
109        soclib::caba::VciSignals<vci_param> signal_vci_ini_rw_proc2("vci_ini_rw_proc2");
110        soclib::caba::VciSignals<vci_param> signal_vci_ini_c_proc2("vci_ini_c_proc2");
111
112        soclib::caba::VciSignals<vci_param> signal_vci_tgt_proc2("vci_tgt_proc2");
113
114        soclib::caba::VciSignals<vci_param> signal_vci_ini_rw_proc3("vci_ini_rw_proc3");
115        soclib::caba::VciSignals<vci_param> signal_vci_ini_c_proc3("vci_ini_c_proc3");
116
117        soclib::caba::VciSignals<vci_param> signal_vci_tgt_proc3("vci_tgt_proc3");
118
119        soclib::caba::VciSignals<vci_param> signal_vci_tgt_tty("vci_tgt_tty");
120
121        soclib::caba::VciSignals<vci_param> signal_vci_tgt_rom("vci_tgt_rom");
122
123        soclib::caba::VciSignals<vci_param> signal_vci_tgt_xram("vci_tgt_xram");
124
125        soclib::caba::VciSignals<vci_param> signal_vci_ixr_memc("vci_ixr_memc");
126        soclib::caba::VciSignals<vci_param> signal_vci_ini_memc("vci_ini_memc");
127        soclib::caba::VciSignals<vci_param> signal_vci_tgt_memc("vci_tgt_memc");
128        soclib::caba::VciSignals<vci_param> signal_vci_tgt_cleanup_memc("vci_tgt_cleanup_memc");
129
130        sc_signal<bool> signal_tty_irq0("signal_tty_irq0");
131        sc_signal<bool> signal_tty_irq1("signal_tty_irq1");
132        sc_signal<bool> signal_tty_irq2("signal_tty_irq2");
133        sc_signal<bool> signal_tty_irq3("signal_tty_irq3");
134
135        soclib::common::Loader loader("soft/bin.soft");
136
137        //                                  init_rw   init_c   tgt
138/*      soclib::caba::VciCcXCacheWrapperV1<vci_param, proc_iss >
139        proc0("proc0", 0, maptabp, maptabc, IntTab(0),IntTab(0),IntTab(0),4,64,16,4,64,16);
140
141        soclib::caba::VciCcXCacheWrapperV1<vci_param, proc_iss >
142        proc1("proc1", 1, maptabp, maptabc, IntTab(1),IntTab(1),IntTab(1),4,64,16,4,64,16);
143
144        soclib::caba::VciCcXCacheWrapperV1<vci_param, proc_iss >
145        proc2("proc2", 2, maptabp, maptabc, IntTab(2),IntTab(2),IntTab(2),4,64,16,4,64,16);
146
147        soclib::caba::VciCcXCacheWrapperV1<vci_param, proc_iss >
148        proc3("proc3", 3, maptabp, maptabc, IntTab(3),IntTab(3),IntTab(3),4,64,16,4,64,16);
149*/
150
151        soclib::caba::VciCcXCacheWrapperV1<vci_param, proc_iss >
152        proc0("proc0", 0, maptabp, maptabc, IntTab(0),IntTab(0),IntTab(0),1,8,16,1,8,16);
153
154        soclib::caba::VciCcXCacheWrapperV1<vci_param, proc_iss >
155        proc1("proc1", 1, maptabp, maptabc, IntTab(1),IntTab(1),IntTab(1),1,8,16,1,8,16);
156
157        soclib::caba::VciCcXCacheWrapperV1<vci_param, proc_iss >
158        proc2("proc2", 2, maptabp, maptabc, IntTab(2),IntTab(2),IntTab(2),1,8,16,1,8,16);
159
160        soclib::caba::VciCcXCacheWrapperV1<vci_param, proc_iss >
161        proc3("proc3", 3, maptabp, maptabc, IntTab(3),IntTab(3),IntTab(3),1,8,16,1,8,16);
162
163
164        soclib::caba::VciSimpleRam<vci_param>
165        rom("rom", IntTab(0), maptabp, loader);
166
167        soclib::caba::VciSimpleRam<vci_param>
168        xram("xram", IntTab(0), maptabx, loader);
169
170        //                                  x_init    c_init    p_tgt     c_tgt
171        soclib::caba::VciMemCacheV3<vci_param>
172        //memc("memc",maptabp,maptabc,maptabx,IntTab(0),IntTab(4),IntTab(2), IntTab(4),16,256,16);
173        //memc("memc",maptabp,maptabc,maptabx,IntTab(0),IntTab(4),IntTab(2), IntTab(4),4,16,16);
174        memc("memc",maptabp,maptabc,maptabx,IntTab(0),IntTab(4),IntTab(2), IntTab(4),4,4,16);
175       
176        soclib::caba::VciMultiTty<vci_param>
177        tty("tty",IntTab(1),maptabp,"tty0","tty1","tty2","tty3",NULL);
178
179#ifdef VCI_LOGGER
180  soclib::caba::VciLogger<vci_param> vci_logger0("vci_logger0",maptabp);
181#endif
182
183        soclib::caba::VciSimpleRingFast<vci_param, 40, 33>
184        ringp("ringp",maptabp, IntTab(), 2, 4, 3);
185
186        soclib::caba::VciSimpleRingFast<vci_param, 40, 33>
187        ringc("ringc",maptabc, IntTab(), 2, 5, 5);
188
189        soclib::caba::VciSimpleRingFast<vci_param, 40, 33>
190        ringx("ringx",maptabx, IntTab(), 2, 1, 1);
191
192        // Net-List
193 
194        proc0.p_clk(signal_clk); 
195        proc0.p_resetn(signal_resetn); 
196        proc0.p_irq[0](signal_proc0_it0);
197        proc0.p_irq[1](signal_proc0_it1);
198        proc0.p_irq[2](signal_proc0_it2);
199        proc0.p_irq[3](signal_proc0_it3);
200        proc0.p_irq[4](signal_proc0_it4);
201        proc0.p_irq[5](signal_proc0_it5);
202        proc0.p_vci_ini_rw(signal_vci_ini_rw_proc0);
203        proc0.p_vci_ini_c(signal_vci_ini_c_proc0);
204        proc0.p_vci_tgt(signal_vci_tgt_proc0);
205
206        proc1.p_clk(signal_clk); 
207        proc1.p_resetn(signal_resetn); 
208        proc1.p_irq[0](signal_proc1_it0);
209        proc1.p_irq[1](signal_proc1_it1);
210        proc1.p_irq[2](signal_proc1_it2);
211        proc1.p_irq[3](signal_proc1_it3);
212        proc1.p_irq[4](signal_proc1_it4);
213        proc1.p_irq[5](signal_proc1_it5);
214        proc1.p_vci_ini_rw(signal_vci_ini_rw_proc1);
215        proc1.p_vci_ini_c(signal_vci_ini_c_proc1);
216        proc1.p_vci_tgt(signal_vci_tgt_proc1);
217
218        proc2.p_clk(signal_clk); 
219        proc2.p_resetn(signal_resetn); 
220        proc2.p_irq[0](signal_proc2_it0);
221        proc2.p_irq[1](signal_proc2_it1);
222        proc2.p_irq[2](signal_proc2_it2);
223        proc2.p_irq[3](signal_proc2_it3);
224        proc2.p_irq[4](signal_proc2_it4);
225        proc2.p_irq[5](signal_proc2_it5);
226        proc2.p_vci_ini_rw(signal_vci_ini_rw_proc2);
227        proc2.p_vci_ini_c(signal_vci_ini_c_proc2);
228        proc2.p_vci_tgt(signal_vci_tgt_proc2);
229
230        proc3.p_clk(signal_clk); 
231        proc3.p_resetn(signal_resetn); 
232        proc3.p_irq[0](signal_proc3_it0);
233        proc3.p_irq[1](signal_proc3_it1);
234        proc3.p_irq[2](signal_proc3_it2);
235        proc3.p_irq[3](signal_proc3_it3);
236        proc3.p_irq[4](signal_proc3_it4);
237        proc3.p_irq[5](signal_proc3_it5);
238        proc3.p_vci_ini_rw(signal_vci_ini_rw_proc3);
239        proc3.p_vci_ini_c(signal_vci_ini_c_proc3);
240        proc3.p_vci_tgt(signal_vci_tgt_proc3);
241
242        rom.p_clk(signal_clk);
243        rom.p_resetn(signal_resetn);
244        rom.p_vci(signal_vci_tgt_rom);
245
246#ifdef VCI_LOGGER
247  vci_logger0.p_clk(signal_clk);
248  vci_logger0.p_resetn(signal_resetn);
249  vci_logger0.p_vci(signal_vci_ini_rw_proc2);
250#endif
251
252        tty.p_clk(signal_clk);
253        tty.p_resetn(signal_resetn);
254        tty.p_vci(signal_vci_tgt_tty);
255        tty.p_irq[0](signal_tty_irq0);
256        tty.p_irq[1](signal_tty_irq1);
257        tty.p_irq[2](signal_tty_irq2);
258        tty.p_irq[3](signal_tty_irq3);
259
260        memc.p_clk(signal_clk);
261        memc.p_resetn(signal_resetn);
262        memc.p_vci_tgt(signal_vci_tgt_memc);
263        memc.p_vci_tgt_cleanup(signal_vci_tgt_cleanup_memc);
264        memc.p_vci_ini(signal_vci_ini_memc);
265        memc.p_vci_ixr(signal_vci_ixr_memc);
266
267        xram.p_clk(signal_clk);
268  xram.p_resetn(signal_resetn);
269        xram.p_vci(signal_vci_tgt_xram);
270       
271        ringp.p_clk(signal_clk);
272        ringp.p_resetn(signal_resetn);
273
274        ringc.p_clk(signal_clk);
275        ringc.p_resetn(signal_resetn);
276
277        ringx.p_clk(signal_clk);
278        ringx.p_resetn(signal_resetn);
279
280        ringp.p_to_initiator[0](signal_vci_ini_rw_proc0);
281        ringp.p_to_initiator[1](signal_vci_ini_rw_proc1);
282        ringp.p_to_initiator[2](signal_vci_ini_rw_proc2);
283        ringp.p_to_initiator[3](signal_vci_ini_rw_proc3);
284
285        ringc.p_to_initiator[4](signal_vci_ini_memc);
286        ringc.p_to_initiator[0](signal_vci_ini_c_proc0);
287        ringc.p_to_initiator[1](signal_vci_ini_c_proc1);
288        ringc.p_to_initiator[2](signal_vci_ini_c_proc2);
289        ringc.p_to_initiator[3](signal_vci_ini_c_proc3);
290
291        ringx.p_to_initiator[0](signal_vci_ixr_memc);
292
293        ringp.p_to_target[0](signal_vci_tgt_rom);
294        ringp.p_to_target[1](signal_vci_tgt_tty);
295        ringp.p_to_target[2](signal_vci_tgt_memc);
296
297        ringc.p_to_target[0](signal_vci_tgt_proc0);
298        ringc.p_to_target[1](signal_vci_tgt_proc1);
299        ringc.p_to_target[2](signal_vci_tgt_proc2);
300        ringc.p_to_target[3](signal_vci_tgt_proc3);
301        ringc.p_to_target[4](signal_vci_tgt_cleanup_memc);
302
303        ringx.p_to_target[0](signal_vci_tgt_xram);
304
305        int ncycles;
306
307        if (argc == 2) {
308                ncycles = std::atoi(argv[1]);
309        } else {
310                std::cerr
311                        << std::endl
312                        << "The number of simulation cycles must "
313                           "be defined in the command line"
314                        << std::endl;
315                exit(1);
316        }
317
318        sc_start(sc_core::sc_time(0, SC_NS));
319        signal_resetn = false;
320
321        sc_start(sc_core::sc_time(1, SC_NS));
322        signal_resetn = true;
323
324
325        for (int i = 0; i < ncycles ; i+=1) {
326                sc_start(sc_core::sc_time(1, SC_NS));
327        }
328
329        std::cout << "Hit ENTER to end simulation" << std::endl;
330        char buf[1];
331
332        std::cin.getline(buf,1);
333
334        return EXIT_SUCCESS;
335}
336
337int sc_main (int argc, char *argv[])
338{
339        try {
340                return _main(argc, argv);
341        } catch (std::exception &e) {
342                std::cout << e.what() << std::endl;
343        } catch (...) {
344                std::cout << "Unknown exception occured" << std::endl;
345                throw;
346        }
347        return 1;
348}
Note: See TracBrowser for help on using the repository browser.