[ Upstream commit 65197a4 ]
Library expects ilog2 of psn_size while calculating the stride.
ilog32 returns log2(v) + 1 and the calculation fails since
the psn size is a power of 2 value. Fix by passing psn_size - 1.
Fixes: 0a0e0d0 ("bnxt_re/lib: Adds MSN table capability for Gen P7 adapters")
Signed-off-by: Selvin Xavier <selvin.xavier@broadcom.com>
Signed-off-by: Nicolas Morey <nmorey@suse.com>
(cherry picked from commit ac4be7ab029ef79b45c1055fb7504643fd129194)
32 lines
1.3 KiB
Diff
32 lines
1.3 KiB
Diff
From 05b65d96296f07baca079acef1a5bbb3c71fffb6 Mon Sep 17 00:00:00 2001
|
|
From: Selvin Xavier <selvin.xavier@broadcom.com>
|
|
Date: Wed, 17 Jul 2024 10:34:23 +0800
|
|
Subject: [PATCH] Fix the stride calculation for MSN/PSN area [ Upstream commit
|
|
65197a4 ] Library expects ilog2 of psn_size while calculating the stride.
|
|
ilog32 returns log2(v) + 1 and the calculation fails since the psn size is a
|
|
power of 2 value. Fix by passing psn_size - 1.
|
|
|
|
Fixes: 0a0e0d0 ("bnxt_re/lib: Adds MSN table capability for Gen P7 adapters")
|
|
Signed-off-by: Selvin Xavier <selvin.xavier@broadcom.com>
|
|
Signed-off-by: Nicolas Morey <nmorey@suse.com>
|
|
---
|
|
providers/bnxt_re/verbs.c | 2 +-
|
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
|
|
|
diff --git a/providers/bnxt_re/verbs.c b/providers/bnxt_re/verbs.c
|
|
index 55d5284..a74d32c 100644
|
|
--- a/providers/bnxt_re/verbs.c
|
|
+++ b/providers/bnxt_re/verbs.c
|
|
@@ -1233,7 +1233,7 @@ static int bnxt_re_alloc_queues(struct bnxt_re_context *cntx,
|
|
/* psn_depth extra entries of size que->stride */
|
|
psn_size = bnxt_re_get_psne_size(qp->cntx);
|
|
psn_depth = (nswr * psn_size) / que->stride;
|
|
- que->pad_stride_log2 = (uint32_t)ilog32(psn_size);
|
|
+ que->pad_stride_log2 = ilog32(psn_size - 1);
|
|
if ((nswr * psn_size) % que->stride)
|
|
psn_depth++;
|
|
que->depth += psn_depth;
|
|
--
|
|
2.27.0
|
|
|