16#ifndef SIMICS_SYSTEMC_IFACE_SC_REGISTER_ACCESS_SIMICS_ADAPTER_H
17#define SIMICS_SYSTEMC_IFACE_SC_REGISTER_ACCESS_SIMICS_ADAPTER_H
24#include <systemc-interfaces.h>
34template<
typename TBase,
typename TInterface = ScRegisterAccessInterface>
40 SC_REGISTER_ACCESS_INTERFACE, init_iface()) {
44 static ::exception_type_t
read(conf_object_t *obj, ::uint64 address,
47 return static_cast<::exception_type_t
>(
48 adapter<TBase, TInterface>(obj)->read(address, v));
50 static ::exception_type_t
write(conf_object_t *obj, ::uint64 address,
53 return static_cast<::exception_type_t
>(
54 adapter<TBase, TInterface>(obj)->write(address, v));
58 sc_register_access_interface_t init_iface() {
59 sc_register_access_interface_t iface = {};
Definition: sc_register_access_simics_adapter.h:36
::exception_type_t read(conf_object_t *obj, ::uint64 address, buffer_t value)
Definition: sc_register_access_simics_adapter.h:44
::exception_type_t write(conf_object_t *obj, ::uint64 address, bytes_t value)
Definition: sc_register_access_simics_adapter.h:50
ScRegisterAccessSimicsAdapter()
Definition: sc_register_access_simics_adapter.h:38
Base class for mapping Simics interface to a C++ interface.
Definition: simics_adapter.h:47
Definition: pci_bus_interface.h:24
uint8_t * data
Definition: buffer.h:30
const uint8_t * data
Definition: bytes.h:29