net/mlx5e: Code movements in RX UMR WQE post
authorTariq Toukan <tariqt@mellanox.com>
Tue, 18 Jul 2017 09:07:06 +0000 (12:07 +0300)
committerSaeed Mahameed <saeedm@mellanox.com>
Fri, 30 Mar 2018 23:16:17 +0000 (16:16 -0700)
Gets the process of a UMR WQE post in one function,
in preparation for a downstream patch that inlines
the WQE data.
No functional change here.

Signed-off-by: Tariq Toukan <tariqt@mellanox.com>
Signed-off-by: Saeed Mahameed <saeedm@mellanox.com>
drivers/net/ethernet/mellanox/mlx5/core/en_rx.c

index c0d528f2131b28311bb62e8d3fd1b40a3c8c50a8..8aa94d3cff59b232c03fdeb886f85fd80d38fe44 100644 (file)
@@ -347,39 +347,44 @@ mlx5e_copy_skb_header_mpwqe(struct device *pdev,
        }
 }
 
-static inline void mlx5e_post_umr_wqe(struct mlx5e_rq *rq, u16 ix)
+void mlx5e_free_rx_mpwqe(struct mlx5e_rq *rq, struct mlx5e_mpw_info *wi)
 {
-       struct mlx5e_mpw_info *wi = &rq->mpwqe.info[ix];
-       struct mlx5e_icosq *sq = &rq->channel->icosq;
-       struct mlx5_wq_cyc *wq = &sq->wq;
-       struct mlx5e_umr_wqe *wqe;
-       u8 num_wqebbs = DIV_ROUND_UP(sizeof(*wqe), MLX5_SEND_WQE_BB);
-       u16 pi;
+       int pg_strides = mlx5e_mpwqe_strides_per_page(rq);
+       struct mlx5e_dma_info *dma_info = &wi->umr.dma_info[0];
+       int i;
 
-       /* fill sq edge with nops to avoid wqe wrap around */
-       while ((pi = (sq->pc & wq->sz_m1)) > sq->edge) {
-               sq->db.ico_wqe[pi].opcode = MLX5_OPCODE_NOP;
-               mlx5e_post_nop(wq, sq->sqn, &sq->pc);
+       for (i = 0; i < MLX5_MPWRQ_PAGES_PER_WQE; i++, dma_info++) {
+               page_ref_sub(dma_info->page, pg_strides - wi->skbs_frags[i]);
+               mlx5e_page_release(rq, dma_info, true);
        }
+}
 
-       wqe = mlx5_wq_cyc_get_wqe(wq, pi);
-       memcpy(wqe, &wi->umr.wqe, sizeof(*wqe));
-       wqe->ctrl.opmod_idx_opcode =
-               cpu_to_be32((sq->pc << MLX5_WQE_CTRL_WQE_INDEX_SHIFT) |
-                           MLX5_OPCODE_UMR);
+static void mlx5e_post_rx_mpwqe(struct mlx5e_rq *rq)
+{
+       struct mlx5_wq_ll *wq = &rq->wq;
+       struct mlx5e_rx_wqe *wqe = mlx5_wq_ll_get_wqe(wq, wq->head);
 
-       sq->db.ico_wqe[pi].opcode = MLX5_OPCODE_UMR;
-       sq->pc += num_wqebbs;
-       mlx5e_notify_hw(&sq->wq, sq->pc, sq->uar_map, &wqe->ctrl);
+       rq->mpwqe.umr_in_progress = false;
+
+       mlx5_wq_ll_push(wq, be16_to_cpu(wqe->next.next_wqe_index));
+
+       /* ensure wqes are visible to device before updating doorbell record */
+       dma_wmb();
+
+       mlx5_wq_ll_update_db_record(wq);
 }
 
-static int mlx5e_alloc_rx_umr_mpwqe(struct mlx5e_rq *rq,
-                                   u16 ix)
+static int mlx5e_alloc_rx_mpwqe(struct mlx5e_rq *rq, u16 ix)
 {
        struct mlx5e_mpw_info *wi = &rq->mpwqe.info[ix];
        int pg_strides = mlx5e_mpwqe_strides_per_page(rq);
        struct mlx5e_dma_info *dma_info = &wi->umr.dma_info[0];
+       struct mlx5e_icosq *sq = &rq->channel->icosq;
+       struct mlx5_wq_cyc *wq = &sq->wq;
+       struct mlx5e_umr_wqe *wqe;
+       u8 num_wqebbs = DIV_ROUND_UP(sizeof(*wqe), MLX5_SEND_WQE_BB);
        int err;
+       u16 pi;
        int i;
 
        for (i = 0; i < MLX5_MPWRQ_PAGES_PER_WQE; i++, dma_info++) {
@@ -393,6 +398,24 @@ static int mlx5e_alloc_rx_umr_mpwqe(struct mlx5e_rq *rq,
        memset(wi->skbs_frags, 0, sizeof(*wi->skbs_frags) * MLX5_MPWRQ_PAGES_PER_WQE);
        wi->consumed_strides = 0;
 
+       rq->mpwqe.umr_in_progress = true;
+
+       /* fill sq edge with nops to avoid wqe wrap around */
+       while ((pi = (sq->pc & wq->sz_m1)) > sq->edge) {
+               sq->db.ico_wqe[pi].opcode = MLX5_OPCODE_NOP;
+               mlx5e_post_nop(wq, sq->sqn, &sq->pc);
+       }
+
+       wqe = mlx5_wq_cyc_get_wqe(wq, pi);
+       memcpy(wqe, &wi->umr.wqe, sizeof(*wqe));
+       wqe->ctrl.opmod_idx_opcode =
+               cpu_to_be32((sq->pc << MLX5_WQE_CTRL_WQE_INDEX_SHIFT) |
+                           MLX5_OPCODE_UMR);
+
+       sq->db.ico_wqe[pi].opcode = MLX5_OPCODE_UMR;
+       sq->pc += num_wqebbs;
+       mlx5e_notify_hw(&sq->wq, sq->pc, sq->uar_map, &wqe->ctrl);
+
        return 0;
 
 err_unmap:
@@ -401,51 +424,11 @@ err_unmap:
                page_ref_sub(dma_info->page, pg_strides);
                mlx5e_page_release(rq, dma_info, true);
        }
+       rq->stats.buff_alloc_err++;
 
        return err;
 }
 
-void mlx5e_free_rx_mpwqe(struct mlx5e_rq *rq, struct mlx5e_mpw_info *wi)
-{
-       int pg_strides = mlx5e_mpwqe_strides_per_page(rq);
-       struct mlx5e_dma_info *dma_info = &wi->umr.dma_info[0];
-       int i;
-
-       for (i = 0; i < MLX5_MPWRQ_PAGES_PER_WQE; i++, dma_info++) {
-               page_ref_sub(dma_info->page, pg_strides - wi->skbs_frags[i]);
-               mlx5e_page_release(rq, dma_info, true);
-       }
-}
-
-static void mlx5e_post_rx_mpwqe(struct mlx5e_rq *rq)
-{
-       struct mlx5_wq_ll *wq = &rq->wq;
-       struct mlx5e_rx_wqe *wqe = mlx5_wq_ll_get_wqe(wq, wq->head);
-
-       rq->mpwqe.umr_in_progress = false;
-
-       mlx5_wq_ll_push(wq, be16_to_cpu(wqe->next.next_wqe_index));
-
-       /* ensure wqes are visible to device before updating doorbell record */
-       dma_wmb();
-
-       mlx5_wq_ll_update_db_record(wq);
-}
-
-static int mlx5e_alloc_rx_mpwqe(struct mlx5e_rq *rq, u16 ix)
-{
-       int err;
-
-       err = mlx5e_alloc_rx_umr_mpwqe(rq, ix);
-       if (unlikely(err)) {
-               rq->stats.buff_alloc_err++;
-               return err;
-       }
-       rq->mpwqe.umr_in_progress = true;
-       mlx5e_post_umr_wqe(rq, ix);
-       return 0;
-}
-
 void mlx5e_dealloc_rx_mpwqe(struct mlx5e_rq *rq, u16 ix)
 {
        struct mlx5e_mpw_info *wi = &rq->mpwqe.info[ix];