1/* 2 * Copyright (c) 2016, Dresden University of Technology (TU Dresden) 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions are 7 * met: 8 * --- 21 unchanged lines hidden (view full) --- 30 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 31 * 32 * Authors: Christian Menard 33 */ 34 35#include <systemc> 36#include <tlm> 37 |
38#include "cli_parser.hh" 39#include "report_handler.hh" |
40#include "sc_master_port.hh" 41#include "sim_control.hh" 42#include "stats.hh" 43#include "traffic_generator.hh" 44 |
45int 46sc_main(int argc, char** argv) 47{ |
48 CliParser parser; 49 parser.parse(argc, argv); 50 |
51 sc_core::sc_report_handler::set_handler(reportHandler); 52 |
53 Gem5SystemC::Gem5SimControl simControl("gem5", 54 parser.getConfigFile(), 55 parser.getSimulationEnd(), 56 parser.getDebugFlags()); 57 |
58 TrafficGenerator trafficGenerator("traffic_generator"); 59 |
60 tlm::tlm_target_socket<>* mem_port = 61 dynamic_cast<tlm::tlm_target_socket<>*>( 62 sc_core::sc_find_object("gem5.memory")); 63 64 if (mem_port) { 65 SC_REPORT_INFO("sc_main", "Port Found"); 66 trafficGenerator.socket.bind(*mem_port); 67 } else { 68 SC_REPORT_FATAL("sc_main", "Port Not Found"); 69 std::exit(EXIT_FAILURE); 70 } 71 |
72 SC_REPORT_INFO("sc_main", "Start of Simulation"); |
73 74 sc_core::sc_start(); // Run to end of simulation 75 76 SC_REPORT_INFO("sc_main", "End of Simulation"); 77 78 CxxConfig::statsDump(); 79 80 return EXIT_SUCCESS; 81} |