16#ifndef SIMICS_SYSTEMC_IFACE_SC_PORT_SIMICS_ADAPTER_H
17#define SIMICS_SYSTEMC_IFACE_SC_PORT_SIMICS_ADAPTER_H
21#include <simics/attribute-traits.h>
23#include <systemc-interfaces.h>
33template<
typename TBase,
typename TInterface = ScPortInterface>
37 SC_PORT_INTERFACE, init_iface()) {
42 auto proxies = adapter<TBase, TInterface>(obj)->port_to_proxies();
43 return simics::std_to_attr(
44 std::vector<simics::ConfObjectRef>(proxies.begin(),
48 return adapter<TBase, TInterface>(obj)->if_typename();
51 return adapter<TBase, TInterface>(obj)->max_number_of_proxies();
55 std::vector<std::string> description(conf_object_t *obj,
57 return descriptionBase<TBase, TInterface>(obj, type);
59 sc_port_interface_t init_iface() {
60 sc_port_interface_t iface = {};
Definition: sc_port_simics_adapter.h:34
static attr_value_t port_to_proxies(conf_object_t *obj)
Definition: sc_port_simics_adapter.h:41
static const char * if_typename(conf_object_t *obj)
Definition: sc_port_simics_adapter.h:47
static int max_number_of_proxies(conf_object_t *obj)
Definition: sc_port_simics_adapter.h:50
ScPortSimicsAdapter()
Definition: sc_port_simics_adapter.h:36
Base class for mapping Simics interface to a C++ interface.
Definition: simics_adapter.h:47
DescriptionType
Definition: description_interface.h:25