16#ifndef SIMICS_SYSTEMC_IFACE_I3C_MASTER_SIMICS_ADAPTER_H
17#define SIMICS_SYSTEMC_IFACE_I3C_MASTER_SIMICS_ADAPTER_H
19#include <simics/devs/i3c.h>
31template<
typename TBase,
typename TInterface = I3cMasterInterface>
37 I3C_MASTER_INTERFACE, init_iface()) {
41 static void acknowledge(conf_object_t *obj, ::i3c_ack_t ack) {
42 adapter<TBase, TInterface>(obj)->acknowledge(
46 adapter<TBase, TInterface>(obj)->read_response(value, more);
49 uint8 bcr, uint8 dcr) {
50 adapter<TBase, TInterface>(obj)->daa_response(
id, bcr, dcr);
53 adapter<TBase, TInterface>(obj)->ibi_request();
56 adapter<TBase, TInterface>(obj)->ibi_address(address);
60 std::vector<std::string> description(conf_object_t *obj,
62 return descriptionBase<TBase, TInterface>(obj, type);
64 i3c_master_interface_t init_iface() {
65 i3c_master_interface_t iface = {};
Definition: i3c_master_simics_adapter.h:33
static void read_response(conf_object_t *obj, uint8 value, bool more)
Definition: i3c_master_simics_adapter.h:45
static void daa_response(conf_object_t *obj, ::uint64 id, uint8 bcr, uint8 dcr)
Definition: i3c_master_simics_adapter.h:48
static void ibi_request(conf_object_t *obj)
Definition: i3c_master_simics_adapter.h:52
static void acknowledge(conf_object_t *obj, ::i3c_ack_t ack)
Definition: i3c_master_simics_adapter.h:41
I3cMasterSimicsAdapter()
Definition: i3c_master_simics_adapter.h:35
static void ibi_address(conf_object_t *obj, uint8 address)
Definition: i3c_master_simics_adapter.h:55
Base class for mapping Simics interface to a C++ interface.
Definition: simics_adapter.h:47
DescriptionType
Definition: description_interface.h:25
@ I3C_ack
Definition: i3c_ack.h:23
@ I3C_noack
Definition: i3c_ack.h:24
Definition: pci_bus_interface.h:24