34class axi_initiator_b :
35 public sc_core::sc_module,
41 using payload_type = axi::axi_protocol_types::tlm_payload_type;
42 using phase_type = axi::axi_protocol_types::tlm_phase_type;
44 sc_core::sc_in<bool> clk_i{
"clk_i"};
46 sc_core::sc_export<tlm::scc::pe::intor_fw_b> fw_i{
"fw_i"};
48 sc_core::sc_port<tlm::scc::pe::intor_bw_b, 1, sc_core::SC_ZERO_OR_MORE_BOUND> bw_o{
"bw_o"};
50 void b_snoop(payload_type& trans, sc_core::sc_time& t)
override;
52 tlm::tlm_sync_enum nb_transport_bw(payload_type& trans, phase_type& phase, sc_core::sc_time& t)
override;
54 void invalidate_direct_mem_ptr(sc_dt::uint64 start_range, sc_dt::uint64 end_range)
override;
56 size_t get_transferwith_in_bytes()
const {
return transfer_width_in_bytes; }
66 void transport(payload_type& trans,
bool blocking)
override;
73 void snoop_resp(payload_type& trans,
bool sync =
false)
override;
76 size_t transfer_width, flavor_e flavor);
78 virtual ~axi_initiator_b();
80 axi_initiator_b() =
delete;
82 axi_initiator_b(axi_initiator_b
const&) =
delete;
84 axi_initiator_b(axi_initiator_b&&) =
delete;
86 axi_initiator_b& operator=(axi_initiator_b
const&) =
delete;
88 axi_initiator_b& operator=(axi_initiator_b&&) =
delete;
93 cci::cci_param<bool> data_interleaving{
"data_interleaving",
false};
95 cci::cci_param<unsigned>
artv{
"artv", 1};
97 cci::cci_param<unsigned>
awtv{
"awtv", 1};
99 cci::cci_param<unsigned>
wbv{
"wbv", 1};
101 cci::cci_param<unsigned>
rbr{
"rbr", 0};
103 cci::cci_param<unsigned>
br{
"br", 0};
105 cci::cci_param<unsigned>
rla{
"rla", 1};
107 cci::cci_param<unsigned>
ba{
"ba", 1};
122 void add_protocol_cb(axi::fsm::protocol_time_point_e e, std::function<
void(payload_type&,
bool)> cb) {
123 assert(e < axi::fsm::CB_CNT);
129 unsigned calculate_beats(payload_type& p) {
130 sc_assert(p.get_data_length() > 0);
131 return p.get_data_length() < transfer_width_in_bytes ? 1 : p.get_data_length() / transfer_width_in_bytes;
136 const size_t transfer_width_in_bytes;
138 const flavor_e flavor;
140 sc_core::sc_port_b<axi::axi_fw_transport_if<axi_protocol_types>>& socket_fw;
143 payload_type* active_tx{
nullptr};
146 std::unordered_map<void*, tx_state*> tx_state_by_tx;
147 std::unordered_map<unsigned, scc::ordered_semaphore*> id_mtx;
149 tlm_utils::peq_with_get<payload_type> snp_peq{
"snp_peq"};
151 std::unordered_map<void*, tx_state*> snp_state_by_id;
159 sc_core::sc_event any_tx_finished;
161 sc_core::sc_time clk_period{10, sc_core::SC_NS};
163 scc::sc_variable<unsigned> rd_waiting{
"RdWaiting", 0};
164 scc::sc_variable<unsigned> wr_waiting{
"WrWaiting", 0};
165 scc::sc_variable<unsigned> rd_outstanding{
"RdOutstanding", 0};
166 scc::sc_variable<unsigned> wr_outstanding{
"WrOutstanding", 0};
169 sc_core::sc_clock* clk_if{
nullptr};
170 void end_of_elaboration()
override;
171 void clk_counter() { m_clock_counter++; }
172 unsigned get_clk_cnt() {
return m_clock_counter; }
174 tlm::tlm_phase send(payload_type& trans, axi::pe::axi_initiator_b::tx_state* txs, tlm::tlm_phase phase);
176 unsigned m_clock_counter{0};
177 unsigned m_prev_clk_cnt{0};
178 unsigned snoops_in_flight{0};
180 std::array<std::function<void(payload_type&,
bool)>, axi::fsm::CB_CNT> protocol_cb;