16#ifndef SIMICS_SYSTEMC_IFACE_SC_OBJECT_SIMICS_ADAPTER_H
17#define SIMICS_SYSTEMC_IFACE_SC_OBJECT_SIMICS_ADAPTER_H
21#include <simics/attribute-traits.h>
23#include <systemc-interfaces.h>
33template<
typename TBase,
typename TInterface = ScObjectInterface>
38 SC_OBJECT_INTERFACE, init_iface()) {
42 static attr_value_t
sc_print(conf_object_t *obj) {
43 std::vector<std::string> lines =
44 adapter<TBase, TInterface>(obj)->sc_print();
46 return vectorToAttr(lines);
48 static attr_value_t
sc_dump(conf_object_t *obj) {
49 std::vector<std::string> lines
50 = adapter<TBase, TInterface>(obj)->sc_dump();
52 return vectorToAttr(lines);
54 static attr_value_t
sc_kind(conf_object_t *obj) {
55 return adapter<TBase, TInterface>(obj)->sc_kind();
57 static const char *
sc_name(conf_object_t *obj) {
58 return adapter<TBase, TInterface>(obj)->sc_name();
62 static attr_value_t vectorToAttr(
const std::vector<std::string> &lines) {
63 return simics::std_to_attr(lines);
65 std::vector<std::string> description(conf_object_t *obj,
67 return descriptionBase<TBase, TInterface>(obj, type);
69 sc_object_interface_t init_iface() {
70 sc_object_interface_t iface = {};
Definition: sc_object_simics_adapter.h:34
static const char * sc_name(conf_object_t *obj)
Definition: sc_object_simics_adapter.h:57
ScObjectSimicsAdapter()
Definition: sc_object_simics_adapter.h:36
static attr_value_t sc_print(conf_object_t *obj)
Definition: sc_object_simics_adapter.h:42
static attr_value_t sc_kind(conf_object_t *obj)
Definition: sc_object_simics_adapter.h:54
static attr_value_t sc_dump(conf_object_t *obj)
Definition: sc_object_simics_adapter.h:48
Base class for mapping Simics interface to a C++ interface.
Definition: simics_adapter.h:47
DescriptionType
Definition: description_interface.h:25