updates scc
This commit is contained in:
		| @@ -7,6 +7,7 @@ | ||||
| #include <unordered_map> | ||||
|  | ||||
| using namespace sc_core; | ||||
| using tlm_gp_shared_ptr_vec = std::vector<tlm::scc::tlm_gp_shared_ptr>; | ||||
|  | ||||
| factory::add<testbench> tb; | ||||
|  | ||||
| @@ -83,11 +84,12 @@ template <typename STATE> unsigned run_scenario(STATE& state) { | ||||
|             tlm::scc::tlm_gp_shared_ptr trans = | ||||
|                 prepare_trans<testbench::bus_cfg>(StartAddr, 4, state.BurstLengthByte, state.BurstSizeBytes, 1); | ||||
|             trans->set_command(tlm::TLM_READ_COMMAND); | ||||
|             SCCDEBUG(__FUNCTION__) << "run1, iteration " << i << " TX: " << *trans; | ||||
|             SCCDEBUG("run1") << "iteration " << i << " TX: " << *trans; | ||||
|             dut.intor_pe.transport(*trans, false); | ||||
|             state.read_tx[axi::get_axi_id(*trans)].first.emplace_back(trans); | ||||
|             StartAddr += state.BurstSizeBytes; | ||||
|         } | ||||
|         SCCDEBUG("run1") << "finished " << state.NumberOfIterations << " iterations"; | ||||
|     }); | ||||
|     auto run2 = sc_spawn([&dut, &state]() { | ||||
|         unsigned int StartAddr{0x2000}; | ||||
| @@ -96,11 +98,12 @@ template <typename STATE> unsigned run_scenario(STATE& state) { | ||||
|                 prepare_trans<testbench::bus_cfg>(StartAddr, 4, state.BurstLengthByte, state.BurstSizeBytes, 2); | ||||
|             trans->set_command(tlm::TLM_WRITE_COMMAND); | ||||
|             randomize(*trans); | ||||
|             SCCDEBUG(__FUNCTION__) << "run2, iteration " << i << " TX: " << *trans; | ||||
|             SCCDEBUG("run2") << "iteration " << i << " TX: " << *trans; | ||||
|             dut.intor_pe.transport(*trans, false); | ||||
|             state.write_tx[axi::get_axi_id(*trans)].first.emplace_back(trans); | ||||
|             StartAddr += state.BurstSizeBytes; | ||||
|         } | ||||
|         SCCDEBUG("run2") << "finished " << state.NumberOfIterations << " iterations"; | ||||
|     }); | ||||
|     auto run3 = sc_spawn([&dut, &state]() { | ||||
|         unsigned int StartAddr{0x1000}; | ||||
| @@ -108,11 +111,12 @@ template <typename STATE> unsigned run_scenario(STATE& state) { | ||||
|             tlm::scc::tlm_gp_shared_ptr trans = | ||||
|                 prepare_trans<testbench::bus_cfg>(StartAddr, 4, state.BurstLengthByte, state.BurstSizeBytes, 3); | ||||
|             trans->set_command(tlm::TLM_READ_COMMAND); | ||||
|             SCCDEBUG(__FUNCTION__) << "run3, iteration " << i << " TX: " << *trans; | ||||
|             SCCDEBUG("run3") << "iteration " << i << " TX: " << *trans; | ||||
|             dut.intor_pe.transport(*trans, false); | ||||
|             state.read_tx[axi::get_axi_id(*trans)].first.emplace_back(trans); | ||||
|             StartAddr += state.BurstSizeBytes; | ||||
|         } | ||||
|         SCCDEBUG("run3") << "finished " << state.NumberOfIterations << " iterations"; | ||||
|     }); | ||||
|     auto run4 = sc_spawn([&dut, &state]() { | ||||
|         unsigned int StartAddr{0x3000}; | ||||
| @@ -121,11 +125,12 @@ template <typename STATE> unsigned run_scenario(STATE& state) { | ||||
|                 prepare_trans<testbench::bus_cfg>(StartAddr, 4, state.BurstLengthByte, state.BurstSizeBytes, 4); | ||||
|             trans->set_command(tlm::TLM_WRITE_COMMAND); | ||||
|             randomize(*trans); | ||||
|             SCCDEBUG(__FUNCTION__) << "run4, iteration " << i << " TX: " << *trans; | ||||
|             SCCDEBUG("run4") << "iteration " << i << " TX: " << *trans; | ||||
|             dut.intor_pe.transport(*trans, false); | ||||
|             state.write_tx[axi::get_axi_id(*trans)].first.emplace_back(trans); | ||||
|             StartAddr += state.BurstSizeBytes; | ||||
|         } | ||||
|         SCCDEBUG("run4") << "finished " << state.NumberOfIterations << " iterations"; | ||||
|     }); | ||||
|  | ||||
|     unsigned cycles{0}; | ||||
| @@ -142,9 +147,8 @@ void axi4_burst_alignment(bool pipelined_wrreq, bool write_bp) { | ||||
|         unsigned int BurstLengthByte{16}; | ||||
|         unsigned int BurstSizeBytes{8}; | ||||
|         unsigned int NumberOfIterations{8}; | ||||
|         std::unordered_map<unsigned, std::pair<std::vector<tlm::scc::tlm_gp_shared_ptr>, std::vector<tlm::scc::tlm_gp_shared_ptr>>> read_tx; | ||||
|         std::unordered_map<unsigned, std::pair<std::vector<tlm::scc::tlm_gp_shared_ptr>, std::vector<tlm::scc::tlm_gp_shared_ptr>>> | ||||
|             write_tx; | ||||
|         std::unordered_map<unsigned, std::pair<tlm_gp_shared_ptr_vec, tlm_gp_shared_ptr_vec>> read_tx; | ||||
|         std::unordered_map<unsigned, std::pair<tlm_gp_shared_ptr_vec, tlm_gp_shared_ptr_vec>> write_tx; | ||||
|         unsigned resp_cnt{0}; | ||||
|     } state; | ||||
|  | ||||
| @@ -184,9 +188,8 @@ void axi4_narrow_burst(bool pipelined_wrreq, bool write_bp) { | ||||
|         unsigned int BurstLengthByte{16}; | ||||
|         unsigned int BurstSizeBytes{4}; | ||||
|         unsigned int NumberOfIterations{8}; | ||||
|         std::unordered_map<unsigned, std::pair<std::vector<tlm::scc::tlm_gp_shared_ptr>, std::vector<tlm::scc::tlm_gp_shared_ptr>>> read_tx; | ||||
|         std::unordered_map<unsigned, std::pair<std::vector<tlm::scc::tlm_gp_shared_ptr>, std::vector<tlm::scc::tlm_gp_shared_ptr>>> | ||||
|             write_tx; | ||||
|         std::unordered_map<unsigned, std::pair<tlm_gp_shared_ptr_vec, tlm_gp_shared_ptr_vec>> read_tx; | ||||
|         std::unordered_map<unsigned, std::pair<tlm_gp_shared_ptr_vec, tlm_gp_shared_ptr_vec>> write_tx; | ||||
|         unsigned resp_cnt{0}; | ||||
|     } state; | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user