Skip to content

Commit a045d2f

Browse files
mfijalkoAlexei Starovoitov
authored andcommitted
i40e: set xdp_rxq_info::frag_size
i40e support XDP multi-buffer so it is supposed to use __xdp_rxq_info_reg() instead of xdp_rxq_info_reg() and set the frag_size. It can not be simply converted at existing callsite because rx_buf_len could be un-initialized, so let us register xdp_rxq_info within i40e_configure_rx_ring(), which happen to be called with already initialized rx_buf_len value. Commit 5180ff1 ("i40e: use int for i40e_status") converted 'err' to int, so two variables to deal with return codes are not needed within i40e_configure_rx_ring(). Remove 'ret' and use 'err' to handle status from xdp_rxq_info registration. Fixes: e213ced ("i40e: add support for XDP multi-buffer Rx") Signed-off-by: Maciej Fijalkowski <maciej.fijalkowski@intel.com> Link: https://lore.kernel.org/r/20240124191602.566724-11-maciej.fijalkowski@intel.com Signed-off-by: Alexei Starovoitov <ast@kernel.org>
1 parent fbadd83 commit a045d2f

File tree

2 files changed

+24
-25
lines changed

2 files changed

+24
-25
lines changed

drivers/net/ethernet/intel/i40e/i40e_main.c

Lines changed: 24 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -3588,40 +3588,48 @@ static int i40e_configure_rx_ring(struct i40e_ring *ring)
35883588
struct i40e_hmc_obj_rxq rx_ctx;
35893589
int err = 0;
35903590
bool ok;
3591-
int ret;
35923591

35933592
bitmap_zero(ring->state, __I40E_RING_STATE_NBITS);
35943593

35953594
/* clear the context structure first */
35963595
memset(&rx_ctx, 0, sizeof(rx_ctx));
35973596

3598-
if (ring->vsi->type == I40E_VSI_MAIN)
3599-
xdp_rxq_info_unreg_mem_model(&ring->xdp_rxq);
3597+
ring->rx_buf_len = vsi->rx_buf_len;
3598+
3599+
/* XDP RX-queue info only needed for RX rings exposed to XDP */
3600+
if (ring->vsi->type != I40E_VSI_MAIN)
3601+
goto skip;
3602+
3603+
if (!xdp_rxq_info_is_reg(&ring->xdp_rxq)) {
3604+
err = __xdp_rxq_info_reg(&ring->xdp_rxq, ring->netdev,
3605+
ring->queue_index,
3606+
ring->q_vector->napi.napi_id,
3607+
ring->rx_buf_len);
3608+
if (err)
3609+
return err;
3610+
}
36003611

36013612
ring->xsk_pool = i40e_xsk_pool(ring);
36023613
if (ring->xsk_pool) {
3603-
ring->rx_buf_len =
3604-
xsk_pool_get_rx_frame_size(ring->xsk_pool);
3605-
ret = xdp_rxq_info_reg_mem_model(&ring->xdp_rxq,
3614+
ring->rx_buf_len = xsk_pool_get_rx_frame_size(ring->xsk_pool);
3615+
err = xdp_rxq_info_reg_mem_model(&ring->xdp_rxq,
36063616
MEM_TYPE_XSK_BUFF_POOL,
36073617
NULL);
3608-
if (ret)
3609-
return ret;
3618+
if (err)
3619+
return err;
36103620
dev_info(&vsi->back->pdev->dev,
36113621
"Registered XDP mem model MEM_TYPE_XSK_BUFF_POOL on Rx ring %d\n",
36123622
ring->queue_index);
36133623

36143624
} else {
3615-
ring->rx_buf_len = vsi->rx_buf_len;
3616-
if (ring->vsi->type == I40E_VSI_MAIN) {
3617-
ret = xdp_rxq_info_reg_mem_model(&ring->xdp_rxq,
3618-
MEM_TYPE_PAGE_SHARED,
3619-
NULL);
3620-
if (ret)
3621-
return ret;
3622-
}
3625+
err = xdp_rxq_info_reg_mem_model(&ring->xdp_rxq,
3626+
MEM_TYPE_PAGE_SHARED,
3627+
NULL);
3628+
if (err)
3629+
return err;
36233630
}
36243631

3632+
skip:
36253633
xdp_init_buff(&ring->xdp, i40e_rx_pg_size(ring) / 2, &ring->xdp_rxq);
36263634

36273635
rx_ctx.dbuff = DIV_ROUND_UP(ring->rx_buf_len,

drivers/net/ethernet/intel/i40e/i40e_txrx.c

Lines changed: 0 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -1548,7 +1548,6 @@ void i40e_free_rx_resources(struct i40e_ring *rx_ring)
15481548
int i40e_setup_rx_descriptors(struct i40e_ring *rx_ring)
15491549
{
15501550
struct device *dev = rx_ring->dev;
1551-
int err;
15521551

15531552
u64_stats_init(&rx_ring->syncp);
15541553

@@ -1569,14 +1568,6 @@ int i40e_setup_rx_descriptors(struct i40e_ring *rx_ring)
15691568
rx_ring->next_to_process = 0;
15701569
rx_ring->next_to_use = 0;
15711570

1572-
/* XDP RX-queue info only needed for RX rings exposed to XDP */
1573-
if (rx_ring->vsi->type == I40E_VSI_MAIN) {
1574-
err = xdp_rxq_info_reg(&rx_ring->xdp_rxq, rx_ring->netdev,
1575-
rx_ring->queue_index, rx_ring->q_vector->napi.napi_id);
1576-
if (err < 0)
1577-
return err;
1578-
}
1579-
15801571
rx_ring->xdp_prog = rx_ring->vsi->xdp_prog;
15811572

15821573
rx_ring->rx_bi =

0 commit comments

Comments
 (0)