]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
crypto: qat - fix recovery flow for VFs
authorMichal Witwicki <michal.witwicki@intel.com>
Wed, 17 Jul 2024 11:44:58 +0000 (07:44 -0400)
committerHerbert Xu <herbert@gondor.apana.org.au>
Fri, 2 Aug 2024 13:11:20 +0000 (21:11 +0800)
When the PFVF protocol was updated to support version 5, i.e.
ADF_PFVF_COMPAT_FALLBACK, the compatibility version for the VF was
updated without supporting the message RESTARTING_COMPLETE required for
such version.

Add support for the ADF_VF2PF_MSGTYPE_RESTARTING_COMPLETE message in the
VF drivers. This message is sent by the VF driver to the PF to notify
the completion of the shutdown flow.

Fixes: ec26f8e6c784 ("crypto: qat - update PFVF protocol for recovery")
Signed-off-by: Michal Witwicki <michal.witwicki@intel.com>
Reviewed-by: Giovanni Cabiddu <giovanni.cabiddu@intel.com>
Reviewed-by: Przemek Kitszel <przemyslaw.kitszel@intel.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
drivers/crypto/intel/qat/qat_common/adf_pfvf_vf_msg.c
drivers/crypto/intel/qat/qat_common/adf_pfvf_vf_msg.h
drivers/crypto/intel/qat/qat_common/adf_vf_isr.c

index 1141258db4b65ae8afe0862a9f1ff8a06eb7f4dd..10c91e56d6be3b6706920b2819524268c1238b2a 100644 (file)
@@ -48,6 +48,20 @@ void adf_vf2pf_notify_shutdown(struct adf_accel_dev *accel_dev)
 }
 EXPORT_SYMBOL_GPL(adf_vf2pf_notify_shutdown);
 
+void adf_vf2pf_notify_restart_complete(struct adf_accel_dev *accel_dev)
+{
+       struct pfvf_message msg = { .type = ADF_VF2PF_MSGTYPE_RESTARTING_COMPLETE };
+
+       /* Check compatibility version */
+       if (accel_dev->vf.pf_compat_ver < ADF_PFVF_COMPAT_FALLBACK)
+               return;
+
+       if (adf_send_vf2pf_msg(accel_dev, msg))
+               dev_err(&GET_DEV(accel_dev),
+                       "Failed to send Restarting complete event to PF\n");
+}
+EXPORT_SYMBOL_GPL(adf_vf2pf_notify_restart_complete);
+
 int adf_vf2pf_request_version(struct adf_accel_dev *accel_dev)
 {
        u8 pf_version;
index 71bc0e3f1d933578c1c09301a81e30e77c9f4e90..d79340ab3134ff1c389028ca1240721b4a41c0ec 100644 (file)
@@ -6,6 +6,7 @@
 #if defined(CONFIG_PCI_IOV)
 int adf_vf2pf_notify_init(struct adf_accel_dev *accel_dev);
 void adf_vf2pf_notify_shutdown(struct adf_accel_dev *accel_dev);
+void adf_vf2pf_notify_restart_complete(struct adf_accel_dev *accel_dev);
 int adf_vf2pf_request_version(struct adf_accel_dev *accel_dev);
 int adf_vf2pf_get_capabilities(struct adf_accel_dev *accel_dev);
 int adf_vf2pf_get_ring_to_svc(struct adf_accel_dev *accel_dev);
index 783ee8c0fc14d791f595be0a26a8027225b56c48..a4636ec9f9cac0ff996d67a9dda0f1312f80f4d3 100644 (file)
@@ -13,6 +13,7 @@
 #include "adf_cfg.h"
 #include "adf_cfg_strings.h"
 #include "adf_cfg_common.h"
+#include "adf_pfvf_vf_msg.h"
 #include "adf_transport_access_macros.h"
 #include "adf_transport_internal.h"
 
@@ -75,6 +76,7 @@ static void adf_dev_stop_async(struct work_struct *work)
 
        /* Re-enable PF2VF interrupts */
        adf_enable_pf2vf_interrupts(accel_dev);
+       adf_vf2pf_notify_restart_complete(accel_dev);
        kfree(stop_data);
 }