 a49531ebd0
			
		
	
	
		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.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * AMD XGBE VFIO device
 | |
|  *
 | |
|  * Copyright Linaro Limited, 2015
 | |
|  *
 | |
|  * 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-amd-xgbe.h"
 | |
| 
 | |
| static void amd_xgbe_realize(DeviceState *dev, Error **errp)
 | |
| {
 | |
|     VFIOPlatformDevice *vdev = VFIO_PLATFORM_DEVICE(dev);
 | |
|     VFIOAmdXgbeDeviceClass *k = VFIO_AMD_XGBE_DEVICE_GET_CLASS(dev);
 | |
| 
 | |
|     vdev->compat = g_strdup("amd,xgbe-seattle-v1a");
 | |
|     vdev->num_compat = 1;
 | |
| 
 | |
|     k->parent_realize(dev, errp);
 | |
| }
 | |
| 
 | |
| static const VMStateDescription vfio_platform_amd_xgbe_vmstate = {
 | |
|     .name = TYPE_VFIO_AMD_XGBE,
 | |
|     .unmigratable = 1,
 | |
| };
 | |
| 
 | |
| static void vfio_amd_xgbe_class_init(ObjectClass *klass, void *data)
 | |
| {
 | |
|     DeviceClass *dc = DEVICE_CLASS(klass);
 | |
|     VFIOAmdXgbeDeviceClass *vcxc =
 | |
|         VFIO_AMD_XGBE_DEVICE_CLASS(klass);
 | |
|     device_class_set_parent_realize(dc, amd_xgbe_realize,
 | |
|                                     &vcxc->parent_realize);
 | |
|     dc->desc = "VFIO AMD XGBE";
 | |
|     dc->vmsd = &vfio_platform_amd_xgbe_vmstate;
 | |
|     /* Supported by TYPE_VIRT_MACHINE */
 | |
|     dc->user_creatable = true;
 | |
| }
 | |
| 
 | |
| static const TypeInfo vfio_amd_xgbe_dev_info = {
 | |
|     .name = TYPE_VFIO_AMD_XGBE,
 | |
|     .parent = TYPE_VFIO_PLATFORM,
 | |
|     .instance_size = sizeof(VFIOAmdXgbeDevice),
 | |
|     .class_init = vfio_amd_xgbe_class_init,
 | |
|     .class_size = sizeof(VFIOAmdXgbeDeviceClass),
 | |
| };
 | |
| 
 | |
| static void register_amd_xgbe_dev_type(void)
 | |
| {
 | |
|     type_register_static(&vfio_amd_xgbe_dev_info);
 | |
| }
 | |
| 
 | |
| type_init(register_amd_xgbe_dev_type)
 |