16#ifndef SIMICS_SYSTEMC_IFACE_MII_MANAGEMENT_SIMICS_ADAPTER_H
17#define SIMICS_SYSTEMC_IFACE_MII_MANAGEMENT_SIMICS_ADAPTER_H
19#include <simics/devs/mii.h>
30template<
typename TBase,
typename TInterface = MiiManagementInterface>
36 MII_MANAGEMENT_INTERFACE, init_iface()) {
41 return adapter<TBase, TInterface>(obj)->serial_access(data_in, clock);
44 return adapter<TBase, TInterface>(obj)->read_register(phy, reg);
48 adapter<TBase, TInterface>(obj)->write_register(phy, reg, value);
52 std::vector<std::string> description(conf_object_t *obj,
54 return descriptionBase<TBase, TInterface>(obj, type);
56 mii_management_interface_t init_iface() {
57 mii_management_interface_t iface = {};
Definition: mii_management_simics_adapter.h:32
MiiManagementSimicsAdapter()
Definition: mii_management_simics_adapter.h:34
static void write_register(conf_object_t *obj, int phy, int reg, uint16_t value)
Definition: mii_management_simics_adapter.h:46
static int serial_access(conf_object_t *obj, int data_in, int clock)
Definition: mii_management_simics_adapter.h:40
static uint16_t read_register(conf_object_t *obj, int phy, int reg)
Definition: mii_management_simics_adapter.h:43
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