[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20251120123647.3522082-5-michal.winiarski@intel.com>
Date: Thu, 20 Nov 2025 13:36:45 +0100
From: Michał Winiarski <michal.winiarski@...el.com>
To: Jason Gunthorpe <jgg@...pe.ca>, Alex Williamson <alex@...zbot.org>, "Kevin
Tian" <kevin.tian@...el.com>, Yishai Hadas <yishaih@...dia.com>, Longfang Liu
<liulongfang@...wei.com>, Shameer Kolothum <skolothumtho@...dia.com>, "Brett
Creeley" <brett.creeley@....com>, Giovanni Cabiddu
<giovanni.cabiddu@...el.com>, <kvm@...r.kernel.org>, <qat-linux@...el.com>,
<virtualization@...ts.linux.dev>, <linux-kernel@...r.kernel.org>
CC: Michał Winiarski <michal.winiarski@...el.com>
Subject: [PATCH 4/6] vfio/qat: Use .migration_reset_state() callback
Move the migration device state reset code from .reset_done() to
dedicated callback.
Signed-off-by: Michał Winiarski <michal.winiarski@...el.com>
---
drivers/vfio/pci/qat/main.c | 36 ++++++++++++++++--------------------
1 file changed, 16 insertions(+), 20 deletions(-)
diff --git a/drivers/vfio/pci/qat/main.c b/drivers/vfio/pci/qat/main.c
index a19b68043eb2e..fe65301a4cdc8 100644
--- a/drivers/vfio/pci/qat/main.c
+++ b/drivers/vfio/pci/qat/main.c
@@ -474,13 +474,6 @@ static struct file *qat_vf_pci_step_device_state(struct qat_vf_core_device *qat_
return ERR_PTR(-EINVAL);
}
-static void qat_vf_reset_done(struct qat_vf_core_device *qat_vdev)
-{
- qat_vdev->mig_state = VFIO_DEVICE_STATE_RUNNING;
- qat_vfmig_reset(qat_vdev->mdev);
- qat_vf_disable_fds(qat_vdev);
-}
-
static struct file *qat_vf_pci_set_device_state(struct vfio_device *vdev,
enum vfio_device_mig_state new_state)
{
@@ -526,6 +519,21 @@ static int qat_vf_pci_get_device_state(struct vfio_device *vdev,
return 0;
}
+static void qat_vf_pci_reset_device_state(struct vfio_device *vdev)
+{
+ struct qat_vf_core_device *qat_vdev = container_of(vdev,
+ struct qat_vf_core_device, core_device.vdev);
+
+ if (!qat_vdev->mdev)
+ return;
+
+ mutex_lock(&qat_vdev->state_mutex);
+ qat_vdev->mig_state = VFIO_DEVICE_STATE_RUNNING;
+ qat_vfmig_reset(qat_vdev->mdev);
+ qat_vf_disable_fds(qat_vdev);
+ mutex_unlock(&qat_vdev->state_mutex);
+}
+
static int qat_vf_pci_get_data_size(struct vfio_device *vdev,
unsigned long *stop_copy_length)
{
@@ -542,6 +550,7 @@ static int qat_vf_pci_get_data_size(struct vfio_device *vdev,
static const struct vfio_migration_ops qat_vf_pci_mig_ops = {
.migration_set_state = qat_vf_pci_set_device_state,
.migration_get_state = qat_vf_pci_get_device_state,
+ .migration_reset_state = qat_vf_pci_reset_device_state,
.migration_get_data_size = qat_vf_pci_get_data_size,
};
@@ -628,18 +637,6 @@ static struct qat_vf_core_device *qat_vf_drvdata(struct pci_dev *pdev)
return container_of(core_device, struct qat_vf_core_device, core_device);
}
-static void qat_vf_pci_aer_reset_done(struct pci_dev *pdev)
-{
- struct qat_vf_core_device *qat_vdev = qat_vf_drvdata(pdev);
-
- if (!qat_vdev->mdev)
- return;
-
- mutex_lock(&qat_vdev->state_mutex);
- qat_vf_reset_done(qat_vdev);
- mutex_unlock(&qat_vdev->state_mutex);
-}
-
static int
qat_vf_vfio_pci_probe(struct pci_dev *pdev, const struct pci_device_id *id)
{
@@ -683,7 +680,6 @@ static const struct pci_device_id qat_vf_vfio_pci_table[] = {
MODULE_DEVICE_TABLE(pci, qat_vf_vfio_pci_table);
static const struct pci_error_handlers qat_vf_err_handlers = {
- .reset_done = qat_vf_pci_aer_reset_done,
.error_detected = vfio_pci_core_aer_err_detected,
};
--
2.51.2
Powered by blists - more mailing lists