16#ifndef SIMICS_SYSTEMC_IFACE_PCI_DEVICE_SIMICS_ADAPTER_H
17#define SIMICS_SYSTEMC_IFACE_PCI_DEVICE_SIMICS_ADAPTER_H
19#include <simics/devs/pci.h>
30#define DEPRECATED_FUNC(f) _deprecated_ ## f
33template<
typename TBase,
typename TInterface = PciDeviceInterface>
38 PCI_DEVICE_INTERFACE, init_iface()) {
43 adapter<TBase, TInterface>(obj)->bus_reset();
46 adapter<TBase, TInterface>(obj)->system_error();
49 adapter<TBase, TInterface>(obj)->interrupt_raised(pin);
52 adapter<TBase, TInterface>(obj)->interrupt_lowered(pin);
56 std::vector<std::string> description(conf_object_t *obj,
58 return descriptionBase<TBase, TInterface>(obj, type);
60 pci_device_interface_t init_iface() {
61 pci_device_interface_t iface = {};
63 iface.DEPRECATED_FUNC(interrupt_acknowledge) = NULL;
64 iface.DEPRECATED_FUNC(special_cycle) = NULL;
Adapter for Simics pci_device interface.
Definition: pci_device_simics_adapter.h:34
static void system_error(conf_object_t *obj)
Definition: pci_device_simics_adapter.h:45
static void interrupt_raised(conf_object_t *obj, int pin)
Definition: pci_device_simics_adapter.h:48
static void interrupt_lowered(conf_object_t *obj, int pin)
Definition: pci_device_simics_adapter.h:51
static void bus_reset(conf_object_t *obj)
Definition: pci_device_simics_adapter.h:42
PciDeviceSimicsAdapter()
Definition: pci_device_simics_adapter.h:36
Base class for mapping Simics interface to a C++ interface.
Definition: simics_adapter.h:47
DescriptionType
Definition: description_interface.h:25