Netdev List
 help / color / mirror / Atom feed
* [PATCH net 1/2] rds: ib: Increment i_fastreg_wrs before bailing out
@ 2025-09-03 16:31 Håkon Bugge
  2025-09-03 16:31 ` [PATCH net 2/2] rds: ib: Remove unused extern definition Håkon Bugge
  2025-09-09 10:54 ` [PATCH net 1/2] rds: ib: Increment i_fastreg_wrs before bailing out Paolo Abeni
  0 siblings, 2 replies; 8+ messages in thread
From: Håkon Bugge @ 2025-09-03 16:31 UTC (permalink / raw)
  To: Allison Henderson, David S. Miller, Eric Dumazet, Jakub Kicinski,
	Paolo Abeni, Simon Horman
  Cc: stable, Håkon Bugge, netdev, linux-rdma, rds-devel,
	linux-kernel

We need to increment i_fastreg_wrs before we bail out from
rds_ib_post_reg_frmr().

Fixes: 1659185fb4d0 ("RDS: IB: Support Fastreg MR (FRMR) memory registration mode")
Fixes: 3a2886cca703 ("net/rds: Keep track of and wait for FRWR segments in use upon shutdown")
Signed-off-by: Håkon Bugge <haakon.bugge@oracle.com>
---
 net/rds/ib_frmr.c | 17 +++++++++++------
 1 file changed, 11 insertions(+), 6 deletions(-)

diff --git a/net/rds/ib_frmr.c b/net/rds/ib_frmr.c
index 28c1b00221780..7e3b04a83904d 100644
--- a/net/rds/ib_frmr.c
+++ b/net/rds/ib_frmr.c
@@ -133,12 +133,15 @@ static int rds_ib_post_reg_frmr(struct rds_ib_mr *ibmr)
 
 	ret = ib_map_mr_sg_zbva(frmr->mr, ibmr->sg, ibmr->sg_dma_len,
 				&off, PAGE_SIZE);
-	if (unlikely(ret != ibmr->sg_dma_len))
-		return ret < 0 ? ret : -EINVAL;
+	if (unlikely(ret != ibmr->sg_dma_len)) {
+		ret = ret < 0 ? ret : -EINVAL;
+		goto out_inc;
+	}
 
-	if (cmpxchg(&frmr->fr_state,
-		    FRMR_IS_FREE, FRMR_IS_INUSE) != FRMR_IS_FREE)
-		return -EBUSY;
+	if (cmpxchg(&frmr->fr_state, FRMR_IS_FREE, FRMR_IS_INUSE) != FRMR_IS_FREE) {
+		ret = -EBUSY;
+		goto out_inc;
+	}
 
 	atomic_inc(&ibmr->ic->i_fastreg_inuse_count);
 
@@ -178,9 +181,11 @@ static int rds_ib_post_reg_frmr(struct rds_ib_mr *ibmr)
 	 * being accessed while registration is still pending.
 	 */
 	wait_event(frmr->fr_reg_done, !frmr->fr_reg);
-
 out:
+	return ret;
 
+out_inc:
+	atomic_inc(&ibmr->ic->i_fastreg_wrs);
 	return ret;
 }
 
-- 
2.43.5


^ permalink raw reply related	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2025-09-09 14:41 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-09-03 16:31 [PATCH net 1/2] rds: ib: Increment i_fastreg_wrs before bailing out Håkon Bugge
2025-09-03 16:31 ` [PATCH net 2/2] rds: ib: Remove unused extern definition Håkon Bugge
2025-09-03 16:38   ` Greg KH
2025-09-03 16:51     ` Haakon Bugge
2025-09-03 16:56       ` Greg KH
2025-09-03 17:22         ` Haakon Bugge
2025-09-09 10:54 ` [PATCH net 1/2] rds: ib: Increment i_fastreg_wrs before bailing out Paolo Abeni
2025-09-09 14:41   ` Haakon Bugge

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox