Skip to content

Commit 4609ffb

Browse files
Andre Guedesanguy11
authored andcommitted
igc: Refactor XDP rxq info registration
Refactor XDP rxq info registration code, preparing the driver for AF_XDP zero-copy support which is added by upcoming patches. Currently, xdp_rxq and memory model are both registered during RX resource setup time by igc_xdp_register_rxq_info() helper. With AF_XDP, we want to register the memory model later on while configuring the ring because we will know which memory model type to register (MEM_TYPE_PAGE_SHARED or MEM_TYPE_XSK_BUFF_POOL). The helpers igc_xdp_register_rxq_info() and igc_xdp_unregister_rxq_ info() are not useful anymore so they are removed. Signed-off-by: Andre Guedes <[email protected]> Signed-off-by: Vedang Patel <[email protected]> Signed-off-by: Jithu Joseph <[email protected]> Reviewed-by: Maciej Fijalkowski <[email protected]> Tested-by: Dvora Fuxbrumer <[email protected]> Signed-off-by: Tony Nguyen <[email protected]>
1 parent f485164 commit 4609ffb

File tree

3 files changed

+12
-34
lines changed

3 files changed

+12
-34
lines changed

drivers/net/ethernet/intel/igc/igc_main.c

Lines changed: 12 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -419,7 +419,7 @@ void igc_free_rx_resources(struct igc_ring *rx_ring)
419419
{
420420
igc_clean_rx_ring(rx_ring);
421421

422-
igc_xdp_unregister_rxq_info(rx_ring);
422+
xdp_rxq_info_unreg(&rx_ring->xdp_rxq);
423423

424424
vfree(rx_ring->rx_buffer_info);
425425
rx_ring->rx_buffer_info = NULL;
@@ -458,11 +458,16 @@ int igc_setup_rx_resources(struct igc_ring *rx_ring)
458458
{
459459
struct net_device *ndev = rx_ring->netdev;
460460
struct device *dev = rx_ring->dev;
461+
u8 index = rx_ring->queue_index;
461462
int size, desc_len, res;
462463

463-
res = igc_xdp_register_rxq_info(rx_ring);
464-
if (res < 0)
464+
res = xdp_rxq_info_reg(&rx_ring->xdp_rxq, ndev, index,
465+
rx_ring->q_vector->napi.napi_id);
466+
if (res < 0) {
467+
netdev_err(ndev, "Failed to register xdp_rxq index %u\n",
468+
index);
465469
return res;
470+
}
466471

467472
size = sizeof(struct igc_rx_buffer) * rx_ring->count;
468473
rx_ring->rx_buffer_info = vzalloc(size);
@@ -488,7 +493,7 @@ int igc_setup_rx_resources(struct igc_ring *rx_ring)
488493
return 0;
489494

490495
err:
491-
igc_xdp_unregister_rxq_info(rx_ring);
496+
xdp_rxq_info_unreg(&rx_ring->xdp_rxq);
492497
vfree(rx_ring->rx_buffer_info);
493498
rx_ring->rx_buffer_info = NULL;
494499
netdev_err(ndev, "Unable to allocate memory for Rx descriptor ring\n");
@@ -536,6 +541,9 @@ static void igc_configure_rx_ring(struct igc_adapter *adapter,
536541
u32 srrctl = 0, rxdctl = 0;
537542
u64 rdba = ring->dma;
538543

544+
WARN_ON(xdp_rxq_info_reg_mem_model(&ring->xdp_rxq,
545+
MEM_TYPE_PAGE_SHARED, NULL));
546+
539547
if (igc_xdp_is_enabled(adapter))
540548
set_ring_uses_large_buffer(ring);
541549

drivers/net/ethernet/intel/igc/igc_xdp.c

Lines changed: 0 additions & 27 deletions
Original file line numberDiff line numberDiff line change
@@ -31,30 +31,3 @@ int igc_xdp_set_prog(struct igc_adapter *adapter, struct bpf_prog *prog,
3131

3232
return 0;
3333
}
34-
35-
int igc_xdp_register_rxq_info(struct igc_ring *ring)
36-
{
37-
struct net_device *dev = ring->netdev;
38-
int err;
39-
40-
err = xdp_rxq_info_reg(&ring->xdp_rxq, dev, ring->queue_index, 0);
41-
if (err) {
42-
netdev_err(dev, "Failed to register xdp rxq info\n");
43-
return err;
44-
}
45-
46-
err = xdp_rxq_info_reg_mem_model(&ring->xdp_rxq, MEM_TYPE_PAGE_SHARED,
47-
NULL);
48-
if (err) {
49-
netdev_err(dev, "Failed to register xdp rxq mem model\n");
50-
xdp_rxq_info_unreg(&ring->xdp_rxq);
51-
return err;
52-
}
53-
54-
return 0;
55-
}
56-
57-
void igc_xdp_unregister_rxq_info(struct igc_ring *ring)
58-
{
59-
xdp_rxq_info_unreg(&ring->xdp_rxq);
60-
}

drivers/net/ethernet/intel/igc/igc_xdp.h

Lines changed: 0 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -7,9 +7,6 @@
77
int igc_xdp_set_prog(struct igc_adapter *adapter, struct bpf_prog *prog,
88
struct netlink_ext_ack *extack);
99

10-
int igc_xdp_register_rxq_info(struct igc_ring *ring);
11-
void igc_xdp_unregister_rxq_info(struct igc_ring *ring);
12-
1310
static inline bool igc_xdp_is_enabled(struct igc_adapter *adapter)
1411
{
1512
return !!adapter->xdp_prog;

0 commit comments

Comments
 (0)