a49531ebd0
Up to now the vfio-platform device has been abstract and could not be instantiated. The integration of a new vfio platform device required creating a dummy derived device which only set the compatible string. Following the few vfio-platform device integrations we have seen the actual requested adaptation happens on device tree node creation (sysbus-fdt). Hence remove the abstract setting, and read the list of compatible values from sysfs if not set by a derived device. Update the amd-xgbe and calxeda-xgmac drivers to fill in the number of compatible values, as there can now be more than one. Note that sysbus-fdt does not support the instantiation of the vfio-platform device yet. Signed-off-by: Eric Auger <eric.auger@redhat.com> [geert: Rebase, set user_creatable=true, use compatible values in sysfs instead of user-supplied manufacturer/model options, reword] Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be> Reviewed-by: Eric Auger <eric.auger@redhat.com> Tested-by: Eric Auger <eric.auger@redhat.com> Signed-off-by: Alex Williamson <alex.williamson@redhat.com>
60 lines
1.7 KiB
C
60 lines
1.7 KiB
C
/*
|
|
* calxeda xgmac VFIO device
|
|
*
|
|
* Copyright Linaro Limited, 2014
|
|
*
|
|
* Authors:
|
|
* Eric Auger <eric.auger@linaro.org>
|
|
*
|
|
* This work is licensed under the terms of the GNU GPL, version 2. See
|
|
* the COPYING file in the top-level directory.
|
|
*
|
|
*/
|
|
|
|
#include "qemu/osdep.h"
|
|
#include "hw/vfio/vfio-calxeda-xgmac.h"
|
|
|
|
static void calxeda_xgmac_realize(DeviceState *dev, Error **errp)
|
|
{
|
|
VFIOPlatformDevice *vdev = VFIO_PLATFORM_DEVICE(dev);
|
|
VFIOCalxedaXgmacDeviceClass *k = VFIO_CALXEDA_XGMAC_DEVICE_GET_CLASS(dev);
|
|
|
|
vdev->compat = g_strdup("calxeda,hb-xgmac");
|
|
vdev->num_compat = 1;
|
|
|
|
k->parent_realize(dev, errp);
|
|
}
|
|
|
|
static const VMStateDescription vfio_platform_calxeda_xgmac_vmstate = {
|
|
.name = TYPE_VFIO_CALXEDA_XGMAC,
|
|
.unmigratable = 1,
|
|
};
|
|
|
|
static void vfio_calxeda_xgmac_class_init(ObjectClass *klass, void *data)
|
|
{
|
|
DeviceClass *dc = DEVICE_CLASS(klass);
|
|
VFIOCalxedaXgmacDeviceClass *vcxc =
|
|
VFIO_CALXEDA_XGMAC_DEVICE_CLASS(klass);
|
|
device_class_set_parent_realize(dc, calxeda_xgmac_realize,
|
|
&vcxc->parent_realize);
|
|
dc->desc = "VFIO Calxeda XGMAC";
|
|
dc->vmsd = &vfio_platform_calxeda_xgmac_vmstate;
|
|
/* Supported by TYPE_VIRT_MACHINE */
|
|
dc->user_creatable = true;
|
|
}
|
|
|
|
static const TypeInfo vfio_calxeda_xgmac_dev_info = {
|
|
.name = TYPE_VFIO_CALXEDA_XGMAC,
|
|
.parent = TYPE_VFIO_PLATFORM,
|
|
.instance_size = sizeof(VFIOCalxedaXgmacDevice),
|
|
.class_init = vfio_calxeda_xgmac_class_init,
|
|
.class_size = sizeof(VFIOCalxedaXgmacDeviceClass),
|
|
};
|
|
|
|
static void register_calxeda_xgmac_dev_type(void)
|
|
{
|
|
type_register_static(&vfio_calxeda_xgmac_dev_info);
|
|
}
|
|
|
|
type_init(register_calxeda_xgmac_dev_type)
|