virtio-scsi: Add 'iothread' property to virtio-scsi
Similar to this property in virtio-blk for dataplane, add it as a QOM link in virtio-scsi and an alias in virtio-scsi-pci and virtio-scsi-ccw, in order to assign an iothread to the device. Signed-off-by: Fam Zheng <famz@redhat.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
		
							parent
							
								
									c8075caf19
								
							
						
					
					
						commit
						19d339f11d
					
				@ -938,6 +938,8 @@ static void virtio_ccw_scsi_instance_init(Object *obj)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
 | 
					    virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
 | 
				
			||||||
                                TYPE_VIRTIO_SCSI);
 | 
					                                TYPE_VIRTIO_SCSI);
 | 
				
			||||||
 | 
					    object_property_add_alias(obj, "iothread", OBJECT(&dev->vdev), "iothread",
 | 
				
			||||||
 | 
					                              &error_abort);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef CONFIG_VHOST_SCSI
 | 
					#ifdef CONFIG_VHOST_SCSI
 | 
				
			||||||
 | 
				
			|||||||
@ -728,6 +728,16 @@ static void virtio_scsi_device_realize(DeviceState *dev, Error **errp)
 | 
				
			|||||||
                    virtio_scsi_save, virtio_scsi_load, s);
 | 
					                    virtio_scsi_save, virtio_scsi_load, s);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void virtio_scsi_instance_init(Object *obj)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    VirtIOSCSICommon *vs = VIRTIO_SCSI_COMMON(obj);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    object_property_add_link(obj, "iothread", TYPE_IOTHREAD,
 | 
				
			||||||
 | 
					                             (Object **)&vs->conf.iothread,
 | 
				
			||||||
 | 
					                             qdev_prop_allow_set_link_before_realize,
 | 
				
			||||||
 | 
					                             OBJ_PROP_LINK_UNREF_ON_RELEASE, &error_abort);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void virtio_scsi_common_unrealize(DeviceState *dev, Error **errp)
 | 
					void virtio_scsi_common_unrealize(DeviceState *dev, Error **errp)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    VirtIODevice *vdev = VIRTIO_DEVICE(dev);
 | 
					    VirtIODevice *vdev = VIRTIO_DEVICE(dev);
 | 
				
			||||||
@ -786,6 +796,7 @@ static const TypeInfo virtio_scsi_info = {
 | 
				
			|||||||
    .name = TYPE_VIRTIO_SCSI,
 | 
					    .name = TYPE_VIRTIO_SCSI,
 | 
				
			||||||
    .parent = TYPE_VIRTIO_SCSI_COMMON,
 | 
					    .parent = TYPE_VIRTIO_SCSI_COMMON,
 | 
				
			||||||
    .instance_size = sizeof(VirtIOSCSI),
 | 
					    .instance_size = sizeof(VirtIOSCSI),
 | 
				
			||||||
 | 
					    .instance_init = virtio_scsi_instance_init,
 | 
				
			||||||
    .class_init = virtio_scsi_class_init,
 | 
					    .class_init = virtio_scsi_class_init,
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -1186,6 +1186,8 @@ static void virtio_scsi_pci_instance_init(Object *obj)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
 | 
					    virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
 | 
				
			||||||
                                TYPE_VIRTIO_SCSI);
 | 
					                                TYPE_VIRTIO_SCSI);
 | 
				
			||||||
 | 
					    object_property_add_alias(obj, "iothread", OBJECT(&dev->vdev), "iothread",
 | 
				
			||||||
 | 
					                              &error_abort);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static const TypeInfo virtio_scsi_pci_info = {
 | 
					static const TypeInfo virtio_scsi_pci_info = {
 | 
				
			||||||
 | 
				
			|||||||
@ -151,6 +151,7 @@ struct VirtIOSCSIConf {
 | 
				
			|||||||
    uint32_t cmd_per_lun;
 | 
					    uint32_t cmd_per_lun;
 | 
				
			||||||
    char *vhostfd;
 | 
					    char *vhostfd;
 | 
				
			||||||
    char *wwpn;
 | 
					    char *wwpn;
 | 
				
			||||||
 | 
					    IOThread *iothread;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
typedef struct VirtIOSCSICommon {
 | 
					typedef struct VirtIOSCSICommon {
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user