16#ifndef SIMICS_SYSTEMC_IFACE_I2C_SLAVE_V2_SIMICS_ADAPTER_H
17#define SIMICS_SYSTEMC_IFACE_I2C_SLAVE_V2_SIMICS_ADAPTER_H
19#include <simics/devs/i2c.h>
23#include <simics/base/attr-value.h>
32template<
typename TBase,
typename TInterface = I2cSlaveV2Interface>
37 I2C_SLAVE_V2_INTERFACE, init_iface()) {
41 static void start(conf_object_t *obj, uint8 address) {
42 adapter<TBase, TInterface>(obj)->start(address);
44 static void read(conf_object_t *obj) {
45 adapter<TBase, TInterface>(obj)->read();
47 static void write(conf_object_t *obj, uint8 value) {
48 adapter<TBase, TInterface>(obj)->write(value);
50 static void stop(conf_object_t *obj) {
51 adapter<TBase, TInterface>(obj)->stop();
55 = adapter<TBase, TInterface>(obj)->addresses();
56 attr_value_t list = SIM_alloc_attr_list(
addresses.size());
57 for (
unsigned i = 0; i <
addresses.size(); ++i)
58 SIM_attr_list_set_item(&list, i,
65 std::vector<std::string> description(conf_object_t *obj,
67 return descriptionBase<TBase, TInterface>(obj, type);
69 i2c_slave_v2_interface_t init_iface() {
70 i2c_slave_v2_interface_t iface = {};
Definition: i2c_slave_v2_simics_adapter.h:33
I2cSlaveV2SimicsAdapter()
Definition: i2c_slave_v2_simics_adapter.h:35
static void start(conf_object_t *obj, uint8 address)
Definition: i2c_slave_v2_simics_adapter.h:41
static void read(conf_object_t *obj)
Definition: i2c_slave_v2_simics_adapter.h:44
static void write(conf_object_t *obj, uint8 value)
Definition: i2c_slave_v2_simics_adapter.h:47
static void stop(conf_object_t *obj)
Definition: i2c_slave_v2_simics_adapter.h:50
static attr_value_t addresses(conf_object_t *obj)
Definition: i2c_slave_v2_simics_adapter.h:53
Base class for mapping Simics interface to a C++ interface.
Definition: simics_adapter.h:47
DescriptionType
Definition: description_interface.h:25
Definition: pci_bus_interface.h:24