mirror of
				https://github.com/kata-containers/kata-containers.git
				synced 2025-10-25 14:23:11 +00:00 
			
		
		
		
	clh: Support VFIO device unplug
This patch adds the support of VFIO device unplug when using cloud-hypervisor. Fixes: #860 Signed-off-by: Bo Chen <chen.bo@intel.com>
This commit is contained in:
		| @@ -463,7 +463,7 @@ func (clh *cloudHypervisor) hotPlugVFIODevice(device config.VFIODev) error { | |||||||
| 	ctx, cancel := context.WithTimeout(context.Background(), clhHotPlugAPITimeout*time.Second) | 	ctx, cancel := context.WithTimeout(context.Background(), clhHotPlugAPITimeout*time.Second) | ||||||
| 	defer cancel() | 	defer cancel() | ||||||
|  |  | ||||||
| 	_, _, err := cl.VmAddDevicePut(ctx, chclient.VmAddDevice{Path: device.SysfsDev}) | 	_, _, err := cl.VmAddDevicePut(ctx, chclient.VmAddDevice{Path: device.SysfsDev, Id: device.ID}) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		err = fmt.Errorf("Failed to hotplug device %+v %s", device, openAPIClientError(err)) | 		err = fmt.Errorf("Failed to hotplug device %+v %s", device, openAPIClientError(err)) | ||||||
| 	} | 	} | ||||||
| @@ -507,6 +507,20 @@ func (clh *cloudHypervisor) hotplugRemoveBlockDevice(drive *config.BlockDrive) e | |||||||
| 	return err | 	return err | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func (clh *cloudHypervisor) hotplugRemoveVfioDevice(device *config.VFIODev) error { | ||||||
|  | 	cl := clh.client() | ||||||
|  | 	ctx, cancel := context.WithTimeout(context.Background(), clhHotPlugAPITimeout*time.Second) | ||||||
|  | 	defer cancel() | ||||||
|  |  | ||||||
|  | 	_, err := cl.VmRemoveDevicePut(ctx, chclient.VmRemoveDevice{Id: device.ID}) | ||||||
|  |  | ||||||
|  | 	if err != nil { | ||||||
|  | 		err = fmt.Errorf("failed to hotplug remove vfio device %+v %s", device, openAPIClientError(err)) | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	return err | ||||||
|  | } | ||||||
|  |  | ||||||
| func (clh *cloudHypervisor) hotplugRemoveDevice(devInfo interface{}, devType deviceType) (interface{}, error) { | func (clh *cloudHypervisor) hotplugRemoveDevice(devInfo interface{}, devType deviceType) (interface{}, error) { | ||||||
| 	span, _ := clh.trace("hotplugRemoveDevice") | 	span, _ := clh.trace("hotplugRemoveDevice") | ||||||
| 	defer span.Finish() | 	defer span.Finish() | ||||||
| @@ -514,6 +528,8 @@ func (clh *cloudHypervisor) hotplugRemoveDevice(devInfo interface{}, devType dev | |||||||
| 	switch devType { | 	switch devType { | ||||||
| 	case blockDev: | 	case blockDev: | ||||||
| 		return nil, clh.hotplugRemoveBlockDevice(devInfo.(*config.BlockDrive)) | 		return nil, clh.hotplugRemoveBlockDevice(devInfo.(*config.BlockDrive)) | ||||||
|  | 	case vfioDev: | ||||||
|  | 		return nil, clh.hotplugRemoveVfioDevice(devInfo.(*config.VFIODev)) | ||||||
| 	default: | 	default: | ||||||
| 		clh.Logger().WithFields(log.Fields{"devInfo": devInfo, | 		clh.Logger().WithFields(log.Fields{"devInfo": devInfo, | ||||||
| 			"deviceType": devType}).Error("hotplugRemoveDevice: unsupported device") | 			"deviceType": devType}).Error("hotplugRemoveDevice: unsupported device") | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user