vfio: register container for cpr
Define entry points to perform per-container cpr-specific initialization and teardown. Signed-off-by: Steve Sistare <steven.sistare@oracle.com> Reviewed-by: Cédric Le Goater <clg@redhat.com>
This commit is contained in:
parent
cbccded4a2
commit
d9fa4223b3
@ -621,10 +621,15 @@ static int vfio_connect_container(VFIOGroup *group, AddressSpace *as,
|
|||||||
goto free_container_exit;
|
goto free_container_exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ret = vfio_cpr_register_container(bcontainer, errp);
|
||||||
|
if (ret) {
|
||||||
|
goto free_container_exit;
|
||||||
|
}
|
||||||
|
|
||||||
ret = vfio_ram_block_discard_disable(container, true);
|
ret = vfio_ram_block_discard_disable(container, true);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
error_setg_errno(errp, -ret, "Cannot set discarding of RAM broken");
|
error_setg_errno(errp, -ret, "Cannot set discarding of RAM broken");
|
||||||
goto free_container_exit;
|
goto unregister_container_exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
assert(bcontainer->ops->setup);
|
assert(bcontainer->ops->setup);
|
||||||
@ -667,6 +672,9 @@ listener_release_exit:
|
|||||||
enable_discards_exit:
|
enable_discards_exit:
|
||||||
vfio_ram_block_discard_disable(container, false);
|
vfio_ram_block_discard_disable(container, false);
|
||||||
|
|
||||||
|
unregister_container_exit:
|
||||||
|
vfio_cpr_unregister_container(bcontainer);
|
||||||
|
|
||||||
free_container_exit:
|
free_container_exit:
|
||||||
g_free(container);
|
g_free(container);
|
||||||
|
|
||||||
@ -710,6 +718,7 @@ static void vfio_disconnect_container(VFIOGroup *group)
|
|||||||
vfio_container_destroy(bcontainer);
|
vfio_container_destroy(bcontainer);
|
||||||
|
|
||||||
trace_vfio_disconnect_container(container->fd);
|
trace_vfio_disconnect_container(container->fd);
|
||||||
|
vfio_cpr_unregister_container(bcontainer);
|
||||||
close(container->fd);
|
close(container->fd);
|
||||||
g_free(container);
|
g_free(container);
|
||||||
|
|
||||||
|
19
hw/vfio/cpr.c
Normal file
19
hw/vfio/cpr.c
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2021-2024 Oracle and/or its affiliates.
|
||||||
|
*
|
||||||
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
||||||
|
* See the COPYING file in the top-level directory.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "qemu/osdep.h"
|
||||||
|
#include "hw/vfio/vfio-common.h"
|
||||||
|
#include "qapi/error.h"
|
||||||
|
|
||||||
|
int vfio_cpr_register_container(VFIOContainerBase *bcontainer, Error **errp)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void vfio_cpr_unregister_container(VFIOContainerBase *bcontainer)
|
||||||
|
{
|
||||||
|
}
|
@ -411,6 +411,11 @@ found_container:
|
|||||||
goto err_listener_register;
|
goto err_listener_register;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ret = vfio_cpr_register_container(bcontainer, errp);
|
||||||
|
if (ret) {
|
||||||
|
goto err_listener_register;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* TODO: examine RAM_BLOCK_DISCARD stuff, should we do group level
|
* TODO: examine RAM_BLOCK_DISCARD stuff, should we do group level
|
||||||
* for discarding incompatibility check as well?
|
* for discarding incompatibility check as well?
|
||||||
@ -461,6 +466,7 @@ static void iommufd_cdev_detach(VFIODevice *vbasedev)
|
|||||||
iommufd_cdev_ram_block_discard_disable(false);
|
iommufd_cdev_ram_block_discard_disable(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
vfio_cpr_unregister_container(bcontainer);
|
||||||
iommufd_cdev_detach_container(vbasedev, container);
|
iommufd_cdev_detach_container(vbasedev, container);
|
||||||
iommufd_cdev_container_destroy(container);
|
iommufd_cdev_container_destroy(container);
|
||||||
vfio_put_address_space(space);
|
vfio_put_address_space(space);
|
||||||
|
@ -5,6 +5,7 @@ vfio_ss.add(files(
|
|||||||
'container-base.c',
|
'container-base.c',
|
||||||
'container.c',
|
'container.c',
|
||||||
'migration.c',
|
'migration.c',
|
||||||
|
'cpr.c',
|
||||||
))
|
))
|
||||||
vfio_ss.add(when: 'CONFIG_PSERIES', if_true: files('spapr.c'))
|
vfio_ss.add(when: 'CONFIG_PSERIES', if_true: files('spapr.c'))
|
||||||
vfio_ss.add(when: 'CONFIG_IOMMUFD', if_true: files(
|
vfio_ss.add(when: 'CONFIG_IOMMUFD', if_true: files(
|
||||||
|
@ -205,6 +205,9 @@ void vfio_detach_device(VFIODevice *vbasedev);
|
|||||||
int vfio_kvm_device_add_fd(int fd, Error **errp);
|
int vfio_kvm_device_add_fd(int fd, Error **errp);
|
||||||
int vfio_kvm_device_del_fd(int fd, Error **errp);
|
int vfio_kvm_device_del_fd(int fd, Error **errp);
|
||||||
|
|
||||||
|
int vfio_cpr_register_container(VFIOContainerBase *bcontainer, Error **errp);
|
||||||
|
void vfio_cpr_unregister_container(VFIOContainerBase *bcontainer);
|
||||||
|
|
||||||
extern const MemoryRegionOps vfio_region_ops;
|
extern const MemoryRegionOps vfio_region_ops;
|
||||||
typedef QLIST_HEAD(VFIOGroupList, VFIOGroup) VFIOGroupList;
|
typedef QLIST_HEAD(VFIOGroupList, VFIOGroup) VFIOGroupList;
|
||||||
typedef QLIST_HEAD(VFIODeviceList, VFIODevice) VFIODeviceList;
|
typedef QLIST_HEAD(VFIODeviceList, VFIODevice) VFIODeviceList;
|
||||||
|
Loading…
Reference in New Issue
Block a user