RDMA/siw: Introduce siw_update_skb_rcvd
authorGuoqing Jiang <guoqing.jiang@linux.dev>
Mon, 13 Nov 2023 11:57:11 +0000 (19:57 +0800)
committerLeon Romanovsky <leon@kernel.org>
Wed, 15 Nov 2023 13:58:13 +0000 (15:58 +0200)
There are some places share the same logic, factor a common
helper for it.

Acked-by: Bernard Metzler <bmt@zurich.ibm.com>
Signed-off-by: Guoqing Jiang <guoqing.jiang@linux.dev>
Link: https://lore.kernel.org/r/20231113115726.12762-3-guoqing.jiang@linux.dev
Signed-off-by: Leon Romanovsky <leon@kernel.org>
drivers/infiniband/sw/siw/siw_qp_rx.c

index 33e0fdb..10805a7 100644 (file)
@@ -881,6 +881,13 @@ error_term:
        return rv;
 }
 
+static void siw_update_skb_rcvd(struct siw_rx_stream *srx, u16 length)
+{
+       srx->skb_offset += length;
+       srx->skb_new -= length;
+       srx->skb_copied += length;
+}
+
 int siw_proc_terminate(struct siw_qp *qp)
 {
        struct siw_rx_stream *srx = &qp->rx_stream;
@@ -925,9 +932,7 @@ int siw_proc_terminate(struct siw_qp *qp)
                goto out;
 
        infop += to_copy;
-       srx->skb_offset += to_copy;
-       srx->skb_new -= to_copy;
-       srx->skb_copied += to_copy;
+       siw_update_skb_rcvd(srx, to_copy);
        srx->fpdu_part_rcvd += to_copy;
        srx->fpdu_part_rem -= to_copy;
 
@@ -949,9 +954,7 @@ int siw_proc_terminate(struct siw_qp *qp)
                           term->flag_m ? "valid" : "invalid");
        }
 out:
-       srx->skb_new -= to_copy;
-       srx->skb_offset += to_copy;
-       srx->skb_copied += to_copy;
+       siw_update_skb_rcvd(srx, to_copy);
        srx->fpdu_part_rcvd += to_copy;
        srx->fpdu_part_rem -= to_copy;
 
@@ -970,9 +973,7 @@ static int siw_get_trailer(struct siw_qp *qp, struct siw_rx_stream *srx)
 
        skb_copy_bits(skb, srx->skb_offset, tbuf, avail);
 
-       srx->skb_new -= avail;
-       srx->skb_offset += avail;
-       srx->skb_copied += avail;
+       siw_update_skb_rcvd(srx, avail);
        srx->fpdu_part_rem -= avail;
 
        if (srx->fpdu_part_rem)
@@ -1023,12 +1024,8 @@ static int siw_get_hdr(struct siw_rx_stream *srx)
                skb_copy_bits(skb, srx->skb_offset,
                              (char *)c_hdr + srx->fpdu_part_rcvd, bytes);
 
+               siw_update_skb_rcvd(srx, bytes);
                srx->fpdu_part_rcvd += bytes;
-
-               srx->skb_new -= bytes;
-               srx->skb_offset += bytes;
-               srx->skb_copied += bytes;
-
                if (srx->fpdu_part_rcvd < MIN_DDP_HDR)
                        return -EAGAIN;
 
@@ -1091,12 +1088,8 @@ static int siw_get_hdr(struct siw_rx_stream *srx)
                skb_copy_bits(skb, srx->skb_offset,
                              (char *)c_hdr + srx->fpdu_part_rcvd, bytes);
 
+               siw_update_skb_rcvd(srx, bytes);
                srx->fpdu_part_rcvd += bytes;
-
-               srx->skb_new -= bytes;
-               srx->skb_offset += bytes;
-               srx->skb_copied += bytes;
-
                if (srx->fpdu_part_rcvd < hdrlen)
                        return -EAGAIN;
        }