|
Torsten Duwe |
e5c367 |
From c35c76c6919ebcaac590f5f3afa6b8924ad305f4 Mon Sep 17 00:00:00 2001
|
|
Torsten Duwe |
e5c367 |
From: Marco Chiappero <marco.chiappero@intel.com>
|
|
Torsten Duwe |
e5c367 |
Date: Wed, 17 Nov 2021 14:30:55 +0000
|
|
Torsten Duwe |
e5c367 |
Subject: [PATCH] crypto: qat - refactor pfvf version request messages
|
|
Torsten Duwe |
e5c367 |
Git-commit: c35c76c6919ebcaac590f5f3afa6b8924ad305f4
|
|
Torsten Duwe |
e5c367 |
Patch-mainline: v5.17-rc1
|
|
Torsten Duwe |
e5c367 |
References: jsc#PED-1073
|
|
Torsten Duwe |
e5c367 |
|
|
Torsten Duwe |
e5c367 |
Refactor version handling logic for ADF_VF2PF_MSGTYPE_COMPAT_VER_REQ
|
|
Torsten Duwe |
e5c367 |
and ADF_VF2PF_MSGTYPE_VERSION_REQ on the PF.
|
|
Torsten Duwe |
e5c367 |
Response messages are now filled only after fully parsing the request,
|
|
Torsten Duwe |
e5c367 |
in a consisted way with the rest of the PFVF codebase.
|
|
Torsten Duwe |
e5c367 |
|
|
Torsten Duwe |
e5c367 |
This patch also fixes a harmless double setting for VERSION in the
|
|
Torsten Duwe |
e5c367 |
response for ADF_VF2PF_MSGTYPE_VERSION_REQ.
|
|
Torsten Duwe |
e5c367 |
|
|
Torsten Duwe |
e5c367 |
Signed-off-by: Marco Chiappero <marco.chiappero@intel.com>
|
|
Torsten Duwe |
e5c367 |
Co-developed-by: Giovanni Cabiddu <giovanni.cabiddu@intel.com>
|
|
Torsten Duwe |
e5c367 |
Signed-off-by: Giovanni Cabiddu <giovanni.cabiddu@intel.com>
|
|
Torsten Duwe |
e5c367 |
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
|
|
Torsten Duwe |
e5c367 |
Signed-off-by: Torsten Duwe <duwe@suse.de>
|
|
Torsten Duwe |
e5c367 |
|
|
Torsten Duwe |
e5c367 |
---
|
|
Torsten Duwe |
e5c367 |
.../crypto/qat/qat_common/adf_pfvf_pf_proto.c | 42 ++++++++++---------
|
|
Torsten Duwe |
e5c367 |
1 file changed, 23 insertions(+), 19 deletions(-)
|
|
Torsten Duwe |
e5c367 |
|
|
Torsten Duwe |
e5c367 |
diff --git a/drivers/crypto/qat/qat_common/adf_pfvf_pf_proto.c b/drivers/crypto/qat/qat_common/adf_pfvf_pf_proto.c
|
|
Torsten Duwe |
e5c367 |
index ac6a54cf17f6d..c0844fbd896c0 100644
|
|
Torsten Duwe |
e5c367 |
--- a/drivers/crypto/qat/qat_common/adf_pfvf_pf_proto.c
|
|
Torsten Duwe |
e5c367 |
+++ b/drivers/crypto/qat/qat_common/adf_pfvf_pf_proto.c
|
|
Torsten Duwe |
e5c367 |
@@ -47,12 +47,7 @@ static int adf_handle_vf2pf_msg(struct adf_accel_dev *accel_dev, u32 vf_nr,
|
|
Torsten Duwe |
e5c367 |
case ADF_VF2PF_MSGTYPE_COMPAT_VER_REQ:
|
|
Torsten Duwe |
e5c367 |
{
|
|
Torsten Duwe |
e5c367 |
u8 vf_compat_ver = msg >> ADF_VF2PF_COMPAT_VER_REQ_SHIFT;
|
|
Torsten Duwe |
e5c367 |
-
|
|
Torsten Duwe |
e5c367 |
- resp = (ADF_PF2VF_MSGORIGIN_SYSTEM |
|
|
Torsten Duwe |
e5c367 |
- (ADF_PF2VF_MSGTYPE_VERSION_RESP <<
|
|
Torsten Duwe |
e5c367 |
- ADF_PF2VF_MSGTYPE_SHIFT) |
|
|
Torsten Duwe |
e5c367 |
- (ADF_PFVF_COMPAT_THIS_VERSION <<
|
|
Torsten Duwe |
e5c367 |
- ADF_PF2VF_VERSION_RESP_VERS_SHIFT));
|
|
Torsten Duwe |
e5c367 |
+ u8 compat;
|
|
Torsten Duwe |
e5c367 |
|
|
Torsten Duwe |
e5c367 |
dev_dbg(&GET_DEV(accel_dev),
|
|
Torsten Duwe |
e5c367 |
"Compatibility Version Request from VF%d vers=%u\n",
|
|
Torsten Duwe |
e5c367 |
@@ -62,37 +57,46 @@ static int adf_handle_vf2pf_msg(struct adf_accel_dev *accel_dev, u32 vf_nr,
|
|
Torsten Duwe |
e5c367 |
dev_err(&GET_DEV(accel_dev),
|
|
Torsten Duwe |
e5c367 |
"VF (vers %d) incompatible with PF (vers %d)\n",
|
|
Torsten Duwe |
e5c367 |
vf_compat_ver, ADF_PFVF_COMPAT_THIS_VERSION);
|
|
Torsten Duwe |
e5c367 |
- resp |= ADF_PF2VF_VF_INCOMPATIBLE <<
|
|
Torsten Duwe |
e5c367 |
- ADF_PF2VF_VERSION_RESP_RESULT_SHIFT;
|
|
Torsten Duwe |
e5c367 |
+ compat = ADF_PF2VF_VF_INCOMPATIBLE;
|
|
Torsten Duwe |
e5c367 |
} else if (vf_compat_ver > ADF_PFVF_COMPAT_THIS_VERSION) {
|
|
Torsten Duwe |
e5c367 |
dev_err(&GET_DEV(accel_dev),
|
|
Torsten Duwe |
e5c367 |
"VF (vers %d) compat with PF (vers %d) unkn.\n",
|
|
Torsten Duwe |
e5c367 |
vf_compat_ver, ADF_PFVF_COMPAT_THIS_VERSION);
|
|
Torsten Duwe |
e5c367 |
- resp |= ADF_PF2VF_VF_COMPAT_UNKNOWN <<
|
|
Torsten Duwe |
e5c367 |
- ADF_PF2VF_VERSION_RESP_RESULT_SHIFT;
|
|
Torsten Duwe |
e5c367 |
+ compat = ADF_PF2VF_VF_COMPAT_UNKNOWN;
|
|
Torsten Duwe |
e5c367 |
} else {
|
|
Torsten Duwe |
e5c367 |
dev_dbg(&GET_DEV(accel_dev),
|
|
Torsten Duwe |
e5c367 |
"VF (vers %d) compatible with PF (vers %d)\n",
|
|
Torsten Duwe |
e5c367 |
vf_compat_ver, ADF_PFVF_COMPAT_THIS_VERSION);
|
|
Torsten Duwe |
e5c367 |
- resp |= ADF_PF2VF_VF_COMPATIBLE <<
|
|
Torsten Duwe |
e5c367 |
- ADF_PF2VF_VERSION_RESP_RESULT_SHIFT;
|
|
Torsten Duwe |
e5c367 |
+ compat = ADF_PF2VF_VF_COMPATIBLE;
|
|
Torsten Duwe |
e5c367 |
}
|
|
Torsten Duwe |
e5c367 |
+
|
|
Torsten Duwe |
e5c367 |
+ resp = ADF_PF2VF_MSGORIGIN_SYSTEM;
|
|
Torsten Duwe |
e5c367 |
+ resp |= ADF_PF2VF_MSGTYPE_VERSION_RESP <<
|
|
Torsten Duwe |
e5c367 |
+ ADF_PF2VF_MSGTYPE_SHIFT;
|
|
Torsten Duwe |
e5c367 |
+ resp |= ADF_PFVF_COMPAT_THIS_VERSION <<
|
|
Torsten Duwe |
e5c367 |
+ ADF_PF2VF_VERSION_RESP_VERS_SHIFT;
|
|
Torsten Duwe |
e5c367 |
+ resp |= compat << ADF_PF2VF_VERSION_RESP_RESULT_SHIFT;
|
|
Torsten Duwe |
e5c367 |
}
|
|
Torsten Duwe |
e5c367 |
break;
|
|
Torsten Duwe |
e5c367 |
case ADF_VF2PF_MSGTYPE_VERSION_REQ:
|
|
Torsten Duwe |
e5c367 |
+ {
|
|
Torsten Duwe |
e5c367 |
+ u8 compat;
|
|
Torsten Duwe |
e5c367 |
+
|
|
Torsten Duwe |
e5c367 |
dev_dbg(&GET_DEV(accel_dev),
|
|
Torsten Duwe |
e5c367 |
"Legacy VersionRequest received from VF%d 0x%x\n",
|
|
Torsten Duwe |
e5c367 |
vf_nr + 1, msg);
|
|
Torsten Duwe |
e5c367 |
- resp = (ADF_PF2VF_MSGORIGIN_SYSTEM |
|
|
Torsten Duwe |
e5c367 |
- (ADF_PF2VF_MSGTYPE_VERSION_RESP <<
|
|
Torsten Duwe |
e5c367 |
- ADF_PF2VF_MSGTYPE_SHIFT) |
|
|
Torsten Duwe |
e5c367 |
- (ADF_PFVF_COMPAT_THIS_VERSION <<
|
|
Torsten Duwe |
e5c367 |
- ADF_PF2VF_VERSION_RESP_VERS_SHIFT));
|
|
Torsten Duwe |
e5c367 |
- resp |= ADF_PF2VF_VF_COMPATIBLE <<
|
|
Torsten Duwe |
e5c367 |
- ADF_PF2VF_VERSION_RESP_RESULT_SHIFT;
|
|
Torsten Duwe |
e5c367 |
+
|
|
Torsten Duwe |
e5c367 |
+ /* PF always newer than legacy VF */
|
|
Torsten Duwe |
e5c367 |
+ compat = ADF_PF2VF_VF_COMPATIBLE;
|
|
Torsten Duwe |
e5c367 |
+
|
|
Torsten Duwe |
e5c367 |
+ resp = ADF_PF2VF_MSGORIGIN_SYSTEM;
|
|
Torsten Duwe |
e5c367 |
+ resp |= ADF_PF2VF_MSGTYPE_VERSION_RESP <<
|
|
Torsten Duwe |
e5c367 |
+ ADF_PF2VF_MSGTYPE_SHIFT;
|
|
Torsten Duwe |
e5c367 |
/* Set legacy major and minor version num */
|
|
Torsten Duwe |
e5c367 |
resp |= 1 << ADF_PF2VF_MAJORVERSION_SHIFT |
|
|
Torsten Duwe |
e5c367 |
1 << ADF_PF2VF_MINORVERSION_SHIFT;
|
|
Torsten Duwe |
e5c367 |
+ resp |= compat << ADF_PF2VF_VERSION_RESP_RESULT_SHIFT;
|
|
Torsten Duwe |
e5c367 |
+ }
|
|
Torsten Duwe |
e5c367 |
break;
|
|
Torsten Duwe |
e5c367 |
case ADF_VF2PF_MSGTYPE_INIT:
|
|
Torsten Duwe |
e5c367 |
{
|
|
Torsten Duwe |
e5c367 |
--
|
|
Torsten Duwe |
e5c367 |
2.35.3
|
|
Torsten Duwe |
e5c367 |
|