16#ifndef SIMICS_SYSTEMC_IFACE_INJECTION_SC_TLM_FW_TRANSPORT_SIMICS_ADAPTER_H
17#define SIMICS_SYSTEMC_IFACE_INJECTION_SC_TLM_FW_TRANSPORT_SIMICS_ADAPTER_H
24#include <systemc-interfaces.h>
36template<
typename TBase,
37 typename TYPES = tlm::tlm_base_protocol_types,
38 typename TInterface = tlm::tlm_fw_transport_if<TYPES> >
45 SC_TLM_FW_TRANSPORT_INTERFACE, init_iface()) {
50 ::uint64 phase, ::uint64 t) {
52 typename TYPES::tlm_phase_type p;
53 p =
static_cast<typename TYPES::tlm_phase_type
>(phase);
54 sc_core::sc_time t2 = sc_core::sc_time::from_value(t);
58 return SC_TLM_ATTR_ERROR;
60 tlm::tlm_sync_enum ret =
61 adapter<TBase, TInterface>(obj)->nb_transport_fw(*payload, p, t2);
63 return static_cast<sc_tlm_sync_enum_t
>(ret);
65 static void b_transport(conf_object_t *obj, attr_value_t trans,
68 sc_core::sc_time t2 = sc_core::sc_time::from_value(t);
75 adapter<TBase, TInterface>(obj)->b_transport(*payload, t2);
80 attr_value_t dmi_data) {
95 bool ret = adapter<TBase, TInterface>(obj)->get_direct_mem_ptr(*payload,
107 ::uint64 ret = adapter<TBase, TInterface>(obj)->transport_dbg(*payload);
113 std::vector<std::string> description(conf_object_t *obj,
115 return descriptionBase<TBase, TInterface>(obj, type);
117 sc_tlm_fw_transport_interface_t init_iface() {
118 sc_tlm_fw_transport_interface_t iface = {};
Base class for mapping Simics interface to a C++ interface.
Definition: simics_adapter.h:47
Definition: sc_tlm_fw_transport_simics_adapter.h:40
static void b_transport(conf_object_t *obj, attr_value_t trans, ::uint64 t)
Definition: sc_tlm_fw_transport_simics_adapter.h:65
::uint64 transport_dbg(conf_object_t *obj, attr_value_t trans)
Definition: sc_tlm_fw_transport_simics_adapter.h:100
static bool get_direct_mem_ptr(conf_object_t *obj, attr_value_t trans, attr_value_t dmi_data)
Definition: sc_tlm_fw_transport_simics_adapter.h:79
static sc_tlm_sync_enum_t nb_transport_fw(conf_object_t *obj, attr_value_t trans, ::uint64 phase, ::uint64 t)
Definition: sc_tlm_fw_transport_simics_adapter.h:48
ScTlmFwTransportSimicsAdapter()
Definition: sc_tlm_fw_transport_simics_adapter.h:43
TYPES::tlm_payload_type transaction_type
Definition: sc_tlm_fw_transport_simics_adapter.h:42
Definition: attr_dict_parser.h:40
bool parse(ParserInterface *parser)
bool reportInvalidAttrs()
Definition: attr_dmi.h:32
Definition: inject_registry.h:37
TPAYLOAD * attrToPayload(conf_object_t *obj, attr_value_t *attr)
Definition: inject_registry.h:39
DescriptionType
Definition: description_interface.h:25
Definition: pci_bus_interface.h:24