16#ifndef SIMICS_SYSTEMC_IFACE_I2C_MASTER_V2_SIMICS_ADAPTER_H
17#define SIMICS_SYSTEMC_IFACE_I2C_MASTER_V2_SIMICS_ADAPTER_H
19#include <simics/devs/i2c.h>
31template<
typename TBase,
typename TInterface = I2cMasterV2Interface>
37 I2C_MASTER_V2_INTERFACE, init_iface()) {
41 static void acknowledge(conf_object_t *obj, ::i2c_ack_t ack) {
42 adapter<TBase, TInterface>(obj)->acknowledge(
46 adapter<TBase, TInterface>(obj)->read_response(value);
50 std::vector<std::string> description(conf_object_t *obj,
52 return descriptionBase<TBase, TInterface>(obj, type);
54 i2c_master_v2_interface_t init_iface() {
55 i2c_master_v2_interface_t iface = {};
Definition: i2c_master_v2_simics_adapter.h:33
static void acknowledge(conf_object_t *obj, ::i2c_ack_t ack)
Definition: i2c_master_v2_simics_adapter.h:41
I2cMasterV2SimicsAdapter()
Definition: i2c_master_v2_simics_adapter.h:35
static void read_response(conf_object_t *obj, uint8_t value)
Definition: i2c_master_v2_simics_adapter.h:45
Base class for mapping Simics interface to a C++ interface.
Definition: simics_adapter.h:47
DescriptionType
Definition: description_interface.h:25
@ I2C_ack
Definition: i2c_ack.h:23
@ I2C_noack
Definition: i2c_ack.h:24
Definition: pci_bus_interface.h:24