16#ifndef SIMICS_SYSTEMC_IFACE_DIRECT_MEMORY_UPDATE_SIMICS_ADAPTER_H
17#define SIMICS_SYSTEMC_IFACE_DIRECT_MEMORY_UPDATE_SIMICS_ADAPTER_H
19#include <simics/model-iface/direct-memory.h>
31template<
typename TBase,
32 typename TInterface = DirectMemoryUpdateInterface>
38 DIRECT_MEMORY_UPDATE_INTERFACE, init_iface()) {
43 conf_object_t *target,
44 direct_memory_handle_t handle,
45 direct_memory_ack_id_t
id) {
46 adapter<TBase, TInterface>(obj)->release(target, handle,
id);
49 conf_object_t *target,
50 direct_memory_handle_t handle,
52 access_t lost_permission,
53 access_t lost_inhibit,
54 direct_memory_ack_id_t
id) {
55 adapter<TBase, TInterface>(obj)->update_permission(
56 target, handle, lost_access, lost_permission, lost_inhibit,
id);
59 conf_object_t *target,
60 direct_memory_handle_t handle,
61 access_t conflicting_permission,
62 direct_memory_ack_id_t
id) {
63 adapter<TBase, TInterface>(obj)->conflicting_access(
64 target, handle, conflicting_permission,
id);
68 std::vector<std::string> description(conf_object_t *obj,
70 return descriptionBase<TBase, TInterface>(obj, type);
72 direct_memory_update_interface_t init_iface() {
73 direct_memory_update_interface_t iface = {};
Adapter for Simics direct_memory_update interface.
Definition: direct_memory_update_simics_adapter.h:34
static void release(conf_object_t *obj, conf_object_t *target, direct_memory_handle_t handle, direct_memory_ack_id_t id)
Definition: direct_memory_update_simics_adapter.h:42
static void conflicting_access(conf_object_t *obj, conf_object_t *target, direct_memory_handle_t handle, access_t conflicting_permission, direct_memory_ack_id_t id)
Definition: direct_memory_update_simics_adapter.h:58
DirectMemoryUpdateSimicsAdapter()
Definition: direct_memory_update_simics_adapter.h:36
static void update_permission(conf_object_t *obj, conf_object_t *target, direct_memory_handle_t handle, access_t lost_access, access_t lost_permission, access_t lost_inhibit, direct_memory_ack_id_t id)
Definition: direct_memory_update_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
Definition: pci_bus_interface.h:24