|
Denis Kirjanov |
159f7e |
From c4075aa54eecb42b16cc9a799b7effdd1b1ad383 Mon Sep 17 00:00:00 2001
|
|
Denis Kirjanov |
159f7e |
From: Tom Rix <trix@redhat.com>
|
|
Denis Kirjanov |
159f7e |
Date: Sat, 5 Mar 2022 07:06:42 -0800
|
|
Denis Kirjanov |
159f7e |
Subject: [PATCH 3/8] qed: return status of qed_iov_get_link
|
|
Denis Kirjanov |
159f7e |
Git-commit: d9dc0c84ad2d4cc911ba252c973d1bf18d5eb9cf
|
|
Denis Kirjanov |
159f7e |
Patch-mainline: v5.17-rc8
|
|
Denis Kirjanov |
159f7e |
References: git-fixes
|
|
Denis Kirjanov |
159f7e |
|
|
Denis Kirjanov |
159f7e |
Clang static analysis reports this issue
|
|
Denis Kirjanov |
159f7e |
qed_sriov.c:4727:19: warning: Assigned value is
|
|
Denis Kirjanov |
159f7e |
garbage or undefined
|
|
Denis Kirjanov |
159f7e |
ivi->max_tx_rate = tx_rate ? tx_rate : link.speed;
|
|
Denis Kirjanov |
159f7e |
^ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
Denis Kirjanov |
159f7e |
|
|
Denis Kirjanov |
159f7e |
link is only sometimes set by the call to qed_iov_get_link()
|
|
Denis Kirjanov |
159f7e |
qed_iov_get_link fails without setting link or returning
|
|
Denis Kirjanov |
159f7e |
status. So change the decl to return status.
|
|
Denis Kirjanov |
159f7e |
|
|
Denis Kirjanov |
159f7e |
Fixes: 73390ac9d82b ("qed*: support ndo_get_vf_config")
|
|
Denis Kirjanov |
159f7e |
Signed-off-by: Tom Rix <trix@redhat.com>
|
|
Denis Kirjanov |
159f7e |
Signed-off-by: David S. Miller <davem@davemloft.net>
|
|
Denis Kirjanov |
159f7e |
Signed-off-by: Denis Kirjanov <denis.kirjanov@suse.com>
|
|
Denis Kirjanov |
159f7e |
---
|
|
Denis Kirjanov |
159f7e |
drivers/net/ethernet/qlogic/qed/qed_sriov.c | 18 +++++++++++-------
|
|
Denis Kirjanov |
159f7e |
1 file changed, 11 insertions(+), 7 deletions(-)
|
|
Denis Kirjanov |
159f7e |
|
|
Denis Kirjanov |
159f7e |
diff --git a/drivers/net/ethernet/qlogic/qed/qed_sriov.c b/drivers/net/ethernet/qlogic/qed/qed_sriov.c
|
|
Denis Kirjanov |
159f7e |
index 7411e23481f2..4cc319a1e1e3 100644
|
|
Denis Kirjanov |
159f7e |
--- a/drivers/net/ethernet/qlogic/qed/qed_sriov.c
|
|
Denis Kirjanov |
159f7e |
+++ b/drivers/net/ethernet/qlogic/qed/qed_sriov.c
|
|
Denis Kirjanov |
159f7e |
@@ -3801,11 +3801,11 @@ bool qed_iov_mark_vf_flr(struct qed_hwfn *p_hwfn, u32 *p_disabled_vfs)
|
|
Denis Kirjanov |
159f7e |
return found;
|
|
Denis Kirjanov |
159f7e |
}
|
|
Denis Kirjanov |
159f7e |
|
|
Denis Kirjanov |
159f7e |
-static void qed_iov_get_link(struct qed_hwfn *p_hwfn,
|
|
Denis Kirjanov |
159f7e |
- u16 vfid,
|
|
Denis Kirjanov |
159f7e |
- struct qed_mcp_link_params *p_params,
|
|
Denis Kirjanov |
159f7e |
- struct qed_mcp_link_state *p_link,
|
|
Denis Kirjanov |
159f7e |
- struct qed_mcp_link_capabilities *p_caps)
|
|
Denis Kirjanov |
159f7e |
+static int qed_iov_get_link(struct qed_hwfn *p_hwfn,
|
|
Denis Kirjanov |
159f7e |
+ u16 vfid,
|
|
Denis Kirjanov |
159f7e |
+ struct qed_mcp_link_params *p_params,
|
|
Denis Kirjanov |
159f7e |
+ struct qed_mcp_link_state *p_link,
|
|
Denis Kirjanov |
159f7e |
+ struct qed_mcp_link_capabilities *p_caps)
|
|
Denis Kirjanov |
159f7e |
{
|
|
Denis Kirjanov |
159f7e |
struct qed_vf_info *p_vf = qed_iov_get_vf_info(p_hwfn,
|
|
Denis Kirjanov |
159f7e |
vfid,
|
|
Denis Kirjanov |
159f7e |
@@ -3813,7 +3813,7 @@ static void qed_iov_get_link(struct qed_hwfn *p_hwfn,
|
|
Denis Kirjanov |
159f7e |
struct qed_bulletin_content *p_bulletin;
|
|
Denis Kirjanov |
159f7e |
|
|
Denis Kirjanov |
159f7e |
if (!p_vf)
|
|
Denis Kirjanov |
159f7e |
- return;
|
|
Denis Kirjanov |
159f7e |
+ return -EINVAL;
|
|
Denis Kirjanov |
159f7e |
|
|
Denis Kirjanov |
159f7e |
p_bulletin = p_vf->bulletin.p_virt;
|
|
Denis Kirjanov |
159f7e |
|
|
Denis Kirjanov |
159f7e |
@@ -3823,6 +3823,7 @@ static void qed_iov_get_link(struct qed_hwfn *p_hwfn,
|
|
Denis Kirjanov |
159f7e |
__qed_vf_get_link_state(p_hwfn, p_link, p_bulletin);
|
|
Denis Kirjanov |
159f7e |
if (p_caps)
|
|
Denis Kirjanov |
159f7e |
__qed_vf_get_link_caps(p_hwfn, p_caps, p_bulletin);
|
|
Denis Kirjanov |
159f7e |
+ return 0;
|
|
Denis Kirjanov |
159f7e |
}
|
|
Denis Kirjanov |
159f7e |
|
|
Denis Kirjanov |
159f7e |
static int
|
|
Denis Kirjanov |
159f7e |
@@ -4684,6 +4685,7 @@ static int qed_get_vf_config(struct qed_dev *cdev,
|
|
Denis Kirjanov |
159f7e |
struct qed_public_vf_info *vf_info;
|
|
Denis Kirjanov |
159f7e |
struct qed_mcp_link_state link;
|
|
Denis Kirjanov |
159f7e |
u32 tx_rate;
|
|
Denis Kirjanov |
159f7e |
+ int ret;
|
|
Denis Kirjanov |
159f7e |
|
|
Denis Kirjanov |
159f7e |
/* Sanitize request */
|
|
Denis Kirjanov |
159f7e |
if (IS_VF(cdev))
|
|
Denis Kirjanov |
159f7e |
@@ -4697,7 +4699,9 @@ static int qed_get_vf_config(struct qed_dev *cdev,
|
|
Denis Kirjanov |
159f7e |
|
|
Denis Kirjanov |
159f7e |
vf_info = qed_iov_get_public_vf_info(hwfn, vf_id, true);
|
|
Denis Kirjanov |
159f7e |
|
|
Denis Kirjanov |
159f7e |
- qed_iov_get_link(hwfn, vf_id, NULL, &link, NULL);
|
|
Denis Kirjanov |
159f7e |
+ ret = qed_iov_get_link(hwfn, vf_id, NULL, &link, NULL);
|
|
Denis Kirjanov |
159f7e |
+ if (ret)
|
|
Denis Kirjanov |
159f7e |
+ return ret;
|
|
Denis Kirjanov |
159f7e |
|
|
Denis Kirjanov |
159f7e |
/* Fill information about VF */
|
|
Denis Kirjanov |
159f7e |
ivi->vf = vf_id;
|
|
Denis Kirjanov |
159f7e |
--
|
|
Denis Kirjanov |
159f7e |
2.16.4
|
|
Denis Kirjanov |
159f7e |
|