source: trunk/platforms/caba-xxx-ccxcachemulti-mipsel/top.cpp @ 46

Last change on this file since 46 was 46, checked in by alain, 14 years ago
  • 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: 14.4 KB
RevLine 
[3]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_vgsb.h"
14#include "vci_vgmn.h"
15//#include "vci_simple_ring_network.h"
16#include "vci_mem_cache_v1.h"
17#include "vci_cc_xcache_wrapper_multi.h"
18#include "vci_logger.h"
19
20#ifdef USE_GDB_SERVER
21#include "iss/gdbserver.h"
22#endif
23
24#include "segmentation.h"
25
26int _main(int argc, char *argv[])
27{
28        using namespace sc_core;
29        // Avoid repeating these everywhere
30        using soclib::common::IntTab;
31        using soclib::common::Segment;
32
33        // Define VCI parameters
34        typedef soclib::caba::VciParams<4,8,32,1,1,1,8,6,6,1> vci_param;
35        typedef soclib::common::Iss2Simhelper<soclib::common::Mips32ElIss> proc_iss;
36        // Mapping table
37
38        soclib::common::MappingTable maptabp(32, IntTab(8), IntTab(8), 0x00300000);
39
40        maptabp.add(Segment("reset", RESET_BASE, RESET_SIZE, IntTab(2), true));
41        maptabp.add(Segment("excep", EXCEP_BASE, EXCEP_SIZE, IntTab(2), true));
42        maptabp.add(Segment("text" , TEXT_BASE , TEXT_SIZE , IntTab(2), true));
43        maptabp.add(Segment("tty"  , TTY_BASE  , TTY_SIZE  , IntTab(1), false));
44        maptabp.add(Segment("mc_r" , MC_R_BASE , MC_R_SIZE , IntTab(2), false, true, IntTab(0)));
45        maptabp.add(Segment("mc_m" , MC_M_BASE , MC_M_SIZE , IntTab(2), true ));
[46]46        maptabp.add(Segment("ptba" , PTD_ADDR  , TAB_SIZE  , IntTab(2), true));
[3]47 
48        std::cout << maptabp << std::endl;
49
50        soclib::common::MappingTable maptabc(32, IntTab(8), IntTab(8), 0x00300000);
51        maptabc.add(Segment("c_proc0" , C_PROC0_BASE , C_PROC0_SIZE , IntTab(0), false, true, IntTab(0)));
52        maptabc.add(Segment("c_proc1" , C_PROC1_BASE , C_PROC1_SIZE , IntTab(1), false, true, IntTab(1)));
53        maptabc.add(Segment("c_proc2" , C_PROC2_BASE , C_PROC2_SIZE , IntTab(2), false, true, IntTab(2)));
54        maptabc.add(Segment("c_proc3" , C_PROC3_BASE , C_PROC3_SIZE , IntTab(3), false, true, IntTab(3)));
55        maptabc.add(Segment("mc_r"    , MC_R_BASE , MC_R_SIZE , IntTab(4), false, false));
56        maptabc.add(Segment("mc_m"  , MC_M_BASE , MC_M_SIZE  , IntTab(4), false, false));
57        maptabc.add(Segment("reset", RESET_BASE, RESET_SIZE, IntTab(4), false, false));
58        maptabc.add(Segment("excep", EXCEP_BASE, EXCEP_SIZE, IntTab(4), false, false));
59        maptabc.add(Segment("text" , TEXT_BASE , TEXT_SIZE , IntTab(4), false, false));
60        maptabc.add(Segment("ptba" , PTD_ADDR  , TAB_SIZE  , IntTab(4), false, false));
61
62        std::cout << maptabc << std::endl;
63       
64        soclib::common::MappingTable maptabx(32, IntTab(8), IntTab(8), 0x00300000);
65        maptabx.add(Segment("xram" , MC_M_BASE , MC_M_SIZE , IntTab(0), false));
66        maptabx.add(Segment("reset", RESET_BASE, RESET_SIZE, IntTab(0), false));
67        maptabx.add(Segment("excep", EXCEP_BASE, EXCEP_SIZE, IntTab(0), false));
68        maptabx.add(Segment("text" , TEXT_BASE , TEXT_SIZE , IntTab(0), false));
69        maptabx.add(Segment("ptba" , PTD_ADDR  , TAB_SIZE  , IntTab(0), false));
70       
71        std::cout << maptabx << std::endl;
72
73        // Signals
74        sc_clock        signal_clk("clk");
75        sc_signal<bool> signal_resetn("resetn");
76   
77        sc_signal<bool> signal_proc0_it0("proc0_it0");
78        sc_signal<bool> signal_proc0_it1("proc0_it1");
79        sc_signal<bool> signal_proc0_it2("proc0_it2");
80        sc_signal<bool> signal_proc0_it3("proc0_it3");
81        sc_signal<bool> signal_proc0_it4("proc0_it4");
82        sc_signal<bool> signal_proc0_it5("proc0_it5");
83
84        sc_signal<bool> signal_proc1_it0("proc1_it0");
85        sc_signal<bool> signal_proc1_it1("proc1_it1");
86        sc_signal<bool> signal_proc1_it2("proc1_it2");
87        sc_signal<bool> signal_proc1_it3("proc1_it3");
88        sc_signal<bool> signal_proc1_it4("proc1_it4");
89        sc_signal<bool> signal_proc1_it5("proc1_it5");
90
91        sc_signal<bool> signal_proc2_it0("proc2_it0");
92        sc_signal<bool> signal_proc2_it1("proc2_it1");
93        sc_signal<bool> signal_proc2_it2("proc2_it2");
94        sc_signal<bool> signal_proc2_it3("proc2_it3");
95        sc_signal<bool> signal_proc2_it4("proc2_it4");
96        sc_signal<bool> signal_proc2_it5("proc2_it5");
97
98        sc_signal<bool> signal_proc3_it0("proc3_it0");
99        sc_signal<bool> signal_proc3_it1("proc3_it1");
100        sc_signal<bool> signal_proc3_it2("proc3_it2");
101        sc_signal<bool> signal_proc3_it3("proc3_it3");
102        sc_signal<bool> signal_proc3_it4("proc3_it4");
103        sc_signal<bool> signal_proc3_it5("proc3_it5");
104
105        soclib::caba::VciSignals<vci_param> signal_vci_ini_d_proc0("vci_ini_d_proc0");
106        soclib::caba::VciSignals<vci_param> signal_vci_ini_c_proc0("vci_ini_c_proc0");
[46]107        soclib::caba::VciSignals<vci_param> signal_vci_tgt_c_proc0("vci_tgt_proc0");
[3]108
109        soclib::caba::VciSignals<vci_param> signal_vci_ini_d_proc1("vci_ini_d_proc1");
110        soclib::caba::VciSignals<vci_param> signal_vci_ini_c_proc1("vci_ini_c_proc1");
[46]111        soclib::caba::VciSignals<vci_param> signal_vci_tgt_c_proc1("vci_tgt_proc1");
[3]112
113        soclib::caba::VciSignals<vci_param> signal_vci_ini_d_proc2("vci_ini_d_proc2");
114        soclib::caba::VciSignals<vci_param> signal_vci_ini_c_proc2("vci_ini_c_proc2");
[46]115        soclib::caba::VciSignals<vci_param> signal_vci_tgt_c_proc2("vci_tgt_proc2");
[3]116
117        soclib::caba::VciSignals<vci_param> signal_vci_ini_d_proc3("vci_ini_d_proc3");
118        soclib::caba::VciSignals<vci_param> signal_vci_ini_c_proc3("vci_ini_c_proc3");
[46]119        soclib::caba::VciSignals<vci_param> signal_vci_tgt_c_proc3("vci_tgt_proc3");
[3]120
121        soclib::caba::VciSignals<vci_param> signal_vci_tgt_tty("vci_tgt_tty");
122
123        soclib::caba::VciSignals<vci_param> signal_vci_tgt_rom("vci_tgt_rom");
124
125        soclib::caba::VciSignals<vci_param> signal_vci_tgt_xram("vci_tgt_xram");
126
127        soclib::caba::VciSignals<vci_param> signal_vci_ixr_memc("vci_ixr_memc");
128        soclib::caba::VciSignals<vci_param> signal_vci_ini_memc("vci_ini_memc");
[46]129        soclib::caba::VciSignals<vci_param> signal_vci_tgt_d_memc("vci_tgt_memc");
130        soclib::caba::VciSignals<vci_param> signal_vci_tgt_c_memc("vci_tgt_cleanup_memc");
[3]131
132        sc_signal<bool> signal_tty_irq0("signal_tty_irq0");
133        sc_signal<bool> signal_tty_irq1("signal_tty_irq1");
134        sc_signal<bool> signal_tty_irq2("signal_tty_irq2");
135        sc_signal<bool> signal_tty_irq3("signal_tty_irq3");
136
137        sc_signal<bool> signal_stuck0("signal_stuck0");
138
139        soclib::common::Loader loader("soft/bin.soft");
140
141        // Components
142        soclib::caba::VciCcXCacheWrapperMulti<vci_param, proc_iss >
[46]143        proc0("proc0", 0, maptabp, maptabc, IntTab(0),IntTab(0),IntTab(0),1,8,16,1,8,16,4,8,16);
[3]144
145        soclib::caba::VciCcXCacheWrapperMulti<vci_param, proc_iss >
[46]146        proc1("proc1", 1, maptabp, maptabc, IntTab(1),IntTab(1),IntTab(1),1,8,16,1,8,16,4,8,16);
[3]147
148        soclib::caba::VciCcXCacheWrapperMulti<vci_param, proc_iss >
[46]149        proc2("proc2", 2, maptabp, maptabc, IntTab(2),IntTab(2),IntTab(2),1,8,16,1,8,16,4,8,16);
[3]150
151        soclib::caba::VciCcXCacheWrapperMulti<vci_param, proc_iss >
[46]152        proc3("proc3", 3, maptabp, maptabc, IntTab(3),IntTab(3),IntTab(3),1,8,16,1,8,16,4,8,16);
[3]153
154        soclib::caba::VciSimpleRam<vci_param>
155        rom("rom", IntTab(0), maptabp, loader);
156
157        soclib::caba::VciSimpleRam<vci_param>
158        xram("xram", IntTab(0), maptabx, loader);
159
160        soclib::caba::VciMemCacheV1<vci_param>
161        memc("memc",maptabp,maptabc,maptabx,IntTab(0),IntTab(4),IntTab(2), IntTab(4),4,16,16);
162       
163        soclib::caba::VciMultiTty<vci_param>
164        tty("tty",IntTab(1),maptabp,"tty0","tty1","tty2","tty3",NULL);
165
166//      soclib::caba::VciLogger<vci_param> vci_logger_proc0("vci_logger_proc0",maptabp);
167//      soclib::caba::VciLogger<vci_param> vci_logger_proc1("vci_logger_proc1",maptabp);
168//      soclib::caba::VciLogger<vci_param> vci_logger_proc2("vci_logger_proc2",maptabp);
169//      soclib::caba::VciLogger<vci_param> vci_logger_proc3("vci_logger_proc3",maptabp);
170//      soclib::caba::VciLogger<vci_param> vci_logger_memc("vci_logger_memc",maptabp);
171
172//      soclib::caba::VciSimpleRingNetwork<vci_param>
173//      ringd("ringd",maptabp, IntTab(), 2, 4, 3);
174//      soclib::caba::VciVgsb<vci_param>
175//      ringd("ringd",maptabp, 4, 3);
176        soclib::caba::VciVgmn<vci_param>
177        ringd("ringd",maptabp, 4, 3, 2, 2);
178
179//      soclib::caba::VciSimpleRingNetwork<vci_param>
180//      ringc("ringc",maptabc, IntTab(), 2, 5, 5);
181//      soclib::caba::VciVgsb<vci_param>
182//      ringc("ringc",maptabc, 5, 5);
183        soclib::caba::VciVgmn<vci_param>
184        ringc("ringc",maptabc, 5, 5, 2, 2);
185
186//      soclib::caba::VciSimpleRingNetwork<vci_param>
187//      ringx("ringx",maptabx, IntTab(), 2, 1, 1);
188//      soclib::caba::VciVgsb<vci_param>
189//      ringx("ringx",maptabx, 1, 1);
190        soclib::caba::VciVgmn<vci_param>
191        ringx("ringx",maptabx, 1, 1, 2, 2);
192
193        // Net-List
194 
195        proc0.p_clk(signal_clk); 
196        proc0.p_resetn(signal_resetn); 
197        proc0.p_irq[0](signal_proc0_it0);
198        proc0.p_irq[1](signal_proc0_it1);
199        proc0.p_irq[2](signal_proc0_it2);
200        proc0.p_irq[3](signal_proc0_it3);
201        proc0.p_irq[4](signal_proc0_it4);
202        proc0.p_irq[5](signal_proc0_it5);
203        proc0.p_vci_ini_d(signal_vci_ini_d_proc0);
204        proc0.p_vci_ini_c(signal_vci_ini_c_proc0);
[46]205        proc0.p_vci_tgt_c(signal_vci_tgt_c_proc0);
[3]206
207        proc1.p_clk(signal_clk); 
208        proc1.p_resetn(signal_resetn); 
209        proc1.p_irq[0](signal_proc1_it0);
210        proc1.p_irq[1](signal_proc1_it1);
211        proc1.p_irq[2](signal_proc1_it2);
212        proc1.p_irq[3](signal_proc1_it3);
213        proc1.p_irq[4](signal_proc1_it4);
214        proc1.p_irq[5](signal_proc1_it5);
215        proc1.p_vci_ini_d(signal_vci_ini_d_proc1);
216        proc1.p_vci_ini_c(signal_vci_ini_c_proc1);
[46]217        proc1.p_vci_tgt_c(signal_vci_tgt_c_proc1);
[3]218
219        proc2.p_clk(signal_clk); 
220        proc2.p_resetn(signal_resetn); 
221        proc2.p_irq[0](signal_proc2_it0);
222        proc2.p_irq[1](signal_proc2_it1);
223        proc2.p_irq[2](signal_proc2_it2);
224        proc2.p_irq[3](signal_proc2_it3);
225        proc2.p_irq[4](signal_proc2_it4);
226        proc2.p_irq[5](signal_proc2_it5);
227        proc2.p_vci_ini_d(signal_vci_ini_d_proc2);
228        proc2.p_vci_ini_c(signal_vci_ini_c_proc2);
[46]229        proc2.p_vci_tgt_c(signal_vci_tgt_c_proc2);
[3]230
231        proc3.p_clk(signal_clk); 
232        proc3.p_resetn(signal_resetn); 
233        proc3.p_irq[0](signal_proc3_it0);
234        proc3.p_irq[1](signal_proc3_it1);
235        proc3.p_irq[2](signal_proc3_it2);
236        proc3.p_irq[3](signal_proc3_it3);
237        proc3.p_irq[4](signal_proc3_it4);
238        proc3.p_irq[5](signal_proc3_it5);
239        proc3.p_vci_ini_d(signal_vci_ini_d_proc3);
240        proc3.p_vci_ini_c(signal_vci_ini_c_proc3);
[46]241        proc3.p_vci_tgt_c(signal_vci_tgt_c_proc3);
[3]242
243        rom.p_clk(signal_clk);
244        rom.p_resetn(signal_resetn);
245        rom.p_vci(signal_vci_tgt_rom);
246
247        tty.p_clk(signal_clk);
248        tty.p_resetn(signal_resetn);
249        tty.p_vci(signal_vci_tgt_tty);
250        tty.p_irq[0](signal_tty_irq0);
251        tty.p_irq[1](signal_tty_irq1);
252        tty.p_irq[2](signal_tty_irq2);
253        tty.p_irq[3](signal_tty_irq3);
254
255        memc.p_clk(signal_clk);
256        memc.p_resetn(signal_resetn);
[46]257        memc.p_vci_tgt(signal_vci_tgt_d_memc);
258        memc.p_vci_tgt_cleanup(signal_vci_tgt_c_memc);
[3]259        memc.p_vci_ini(signal_vci_ini_memc);
260        memc.p_vci_ixr(signal_vci_ixr_memc);
261
262        xram.p_clk(signal_clk);
263        xram.p_resetn(signal_resetn);
264        xram.p_vci(signal_vci_tgt_xram);
265       
266        ringd.p_clk(signal_clk);
267        ringd.p_resetn(signal_resetn);
268        ringd.p_to_initiator[0](signal_vci_ini_d_proc0);
269        ringd.p_to_initiator[1](signal_vci_ini_d_proc1);
270        ringd.p_to_initiator[2](signal_vci_ini_d_proc2);
271        ringd.p_to_initiator[3](signal_vci_ini_d_proc3);
272        ringd.p_to_target[0](signal_vci_tgt_rom);
273        ringd.p_to_target[1](signal_vci_tgt_tty);
[46]274        ringd.p_to_target[2](signal_vci_tgt_d_memc);
[3]275
276        ringc.p_clk(signal_clk);
277        ringc.p_resetn(signal_resetn);
278        ringc.p_to_initiator[0](signal_vci_ini_c_proc0);
279        ringc.p_to_initiator[1](signal_vci_ini_c_proc1);
280        ringc.p_to_initiator[2](signal_vci_ini_c_proc2);
281        ringc.p_to_initiator[3](signal_vci_ini_c_proc3);
282        ringc.p_to_initiator[4](signal_vci_ini_memc);
[46]283        ringc.p_to_target[0](signal_vci_tgt_c_proc0);
284        ringc.p_to_target[1](signal_vci_tgt_c_proc1);
285        ringc.p_to_target[2](signal_vci_tgt_c_proc2);
286        ringc.p_to_target[3](signal_vci_tgt_c_proc3);
287        ringc.p_to_target[4](signal_vci_tgt_c_memc);
[3]288
289        ringx.p_clk(signal_clk);
290        ringx.p_resetn(signal_resetn);
291        ringx.p_to_initiator[0](signal_vci_ixr_memc);
292        ringx.p_to_target[0](signal_vci_tgt_xram);
293
[46]294        int ncycles = 1000000000;
[3]295
296        if (argc == 2) {
297                ncycles = std::atoi(argv[1]);
298        }
299
300        sc_start(sc_core::sc_time(0, SC_NS));
301        signal_resetn = false;
302        signal_stuck0 = false;
303
304        sc_start(sc_core::sc_time(1, SC_NS));
305        signal_resetn = true;
306
307        for (int i = 0; i < ncycles ; i++)
308        {
309                if ( i%10000 == 0 )
310                {
[46]311                        proc0.printStatistics();
312                        proc1.printStatistics();
313                        proc2.printStatistics();
314                        proc3.printStatistics();
[3]315                        memc.print_stats();
316                }
[46]317/*
[3]318
[46]319                std::cout << "***************************************** cycle = " << std::dec << i
320                          << " *************************************************" << std::endl; 
321                proc0.printTrace(0);
322                proc1.printTrace(0);
323                proc2.printTrace(0);
324                proc3.printTrace(0);
325            std::cout << " proc0.cmdval  = " << signal_vci_ini_c_proc0.cmdval << std::endl;
326            std::cout << " proc0.cmdack  = " << signal_vci_ini_c_proc0.cmdack << std::endl;
327            std::cout << " proc0.address = " << signal_vci_ini_c_proc0.address << std::endl;
328            std::cout << " proc0.wdata   = " << signal_vci_ini_c_proc0.wdata << std::endl;
329            std::cout << " proc0.eop     = " << signal_vci_ini_c_proc0.eop << std::endl;
330            std::cout << " proc0.len     = " << signal_vci_ini_c_proc0.plen << std::endl;
331            std::cout << " proc0.rspval  = " << signal_vci_ini_c_proc0.rspval << std::endl;
332            std::cout << " proc0.rspack  = " << signal_vci_ini_c_proc0.rspack << std::endl;
333            std::cout << " proc0.reop    = " << signal_vci_ini_c_proc0.reop << std::endl;
334            std::cout << " proc0.rdata   = " << signal_vci_ini_c_proc0.rdata << std::endl;
335            std::cout << " proc0.rerror  = " << signal_vci_ini_c_proc0.rerror << std::endl;
336            std::cout << " memc.cmdval   = " << signal_vci_tgt_c_memc.cmdval << std::endl;
337            std::cout << " memc.cmdack   = " << signal_vci_tgt_c_memc.cmdack << std::endl;
338            std::cout << " memc.address  = " << signal_vci_tgt_c_memc.address << std::endl;
339            std::cout << " memc.wdata    = " << signal_vci_tgt_c_memc.wdata << std::endl;
340            std::cout << " memc.eop      = " << signal_vci_tgt_c_memc.eop << std::endl;
341            std::cout << " memc.len      = " << signal_vci_tgt_c_memc.plen << std::endl;
342            std::cout << " memc.rspval   = " << signal_vci_tgt_c_memc.rspval << std::endl;
343            std::cout << " memc.rspack   = " << signal_vci_tgt_c_memc.rspack << std::endl;
344            std::cout << " memc.reop     = " << signal_vci_tgt_c_memc.reop << std::endl;
345            std::cout << " memc.rdata    = " << signal_vci_tgt_c_memc.rdata << std::endl;
346            std::cout << " memc.rerror   = " << signal_vci_tgt_c_memc.rerror << std::endl;
347*/
[3]348
[46]349                sc_start(sc_core::sc_time(1, SC_NS));
350        }
[3]351
352        return EXIT_SUCCESS;
353}
354
355int sc_main (int argc, char *argv[])
356{
357        try {
358                return _main(argc, argv);
359        } catch (std::exception &e) {
360                std::cout << e.what() << std::endl;
361        } catch (...) {
362                std::cout << "Unknown exception occured" << std::endl;
363                throw;
364        }
365        return 1;
366}
Note: See TracBrowser for help on using the repository browser.