Commit 04f647c8 authored by Geetha sowjanya's avatar Geetha sowjanya Committed by Paolo Abeni

octeontx2-pf: Remove xdp queues on program detach

XDP queues are created/destroyed when a XDP program
is attached/detached. In current driver xdp_queues are not
getting destroyed on program exit due to incorrect xdp_queue
and tot_tx_queue count values.

This patch fixes the issue by setting tot_tx_queue and xdp_queue
count to correct values. It also fixes xdp.data_hard_start address.

Fixes: 06059a1a ("octeontx2-pf: Add XDP support to netdev PF")
Signed-off-by: default avatarGeetha sowjanya <gakula@marvell.com>
Link: https://lore.kernel.org/r/20240130120610.16673-1-gakula@marvell.comSigned-off-by: default avatarPaolo Abeni <pabeni@redhat.com>
parent b59af304
...@@ -314,7 +314,6 @@ static int otx2_set_channels(struct net_device *dev, ...@@ -314,7 +314,6 @@ static int otx2_set_channels(struct net_device *dev,
pfvf->hw.tx_queues = channel->tx_count; pfvf->hw.tx_queues = channel->tx_count;
if (pfvf->xdp_prog) if (pfvf->xdp_prog)
pfvf->hw.xdp_queues = channel->rx_count; pfvf->hw.xdp_queues = channel->rx_count;
pfvf->hw.non_qos_queues = pfvf->hw.tx_queues + pfvf->hw.xdp_queues;
if (if_up) if (if_up)
err = dev->netdev_ops->ndo_open(dev); err = dev->netdev_ops->ndo_open(dev);
......
...@@ -1744,6 +1744,7 @@ int otx2_open(struct net_device *netdev) ...@@ -1744,6 +1744,7 @@ int otx2_open(struct net_device *netdev)
/* RQ and SQs are mapped to different CQs, /* RQ and SQs are mapped to different CQs,
* so find out max CQ IRQs (i.e CINTs) needed. * so find out max CQ IRQs (i.e CINTs) needed.
*/ */
pf->hw.non_qos_queues = pf->hw.tx_queues + pf->hw.xdp_queues;
pf->hw.cint_cnt = max3(pf->hw.rx_queues, pf->hw.tx_queues, pf->hw.cint_cnt = max3(pf->hw.rx_queues, pf->hw.tx_queues,
pf->hw.tc_tx_queues); pf->hw.tc_tx_queues);
...@@ -2643,8 +2644,6 @@ static int otx2_xdp_setup(struct otx2_nic *pf, struct bpf_prog *prog) ...@@ -2643,8 +2644,6 @@ static int otx2_xdp_setup(struct otx2_nic *pf, struct bpf_prog *prog)
xdp_features_clear_redirect_target(dev); xdp_features_clear_redirect_target(dev);
} }
pf->hw.non_qos_queues += pf->hw.xdp_queues;
if (if_up) if (if_up)
otx2_open(pf->netdev); otx2_open(pf->netdev);
......
...@@ -1403,7 +1403,7 @@ static bool otx2_xdp_rcv_pkt_handler(struct otx2_nic *pfvf, ...@@ -1403,7 +1403,7 @@ static bool otx2_xdp_rcv_pkt_handler(struct otx2_nic *pfvf,
struct otx2_cq_queue *cq, struct otx2_cq_queue *cq,
bool *need_xdp_flush) bool *need_xdp_flush)
{ {
unsigned char *hard_start, *data; unsigned char *hard_start;
int qidx = cq->cq_idx; int qidx = cq->cq_idx;
struct xdp_buff xdp; struct xdp_buff xdp;
struct page *page; struct page *page;
...@@ -1417,9 +1417,8 @@ static bool otx2_xdp_rcv_pkt_handler(struct otx2_nic *pfvf, ...@@ -1417,9 +1417,8 @@ static bool otx2_xdp_rcv_pkt_handler(struct otx2_nic *pfvf,
xdp_init_buff(&xdp, pfvf->rbsize, &cq->xdp_rxq); xdp_init_buff(&xdp, pfvf->rbsize, &cq->xdp_rxq);
data = (unsigned char *)phys_to_virt(pa); hard_start = (unsigned char *)phys_to_virt(pa);
hard_start = page_address(page); xdp_prepare_buff(&xdp, hard_start, OTX2_HEAD_ROOM,
xdp_prepare_buff(&xdp, hard_start, data - hard_start,
cqe->sg.seg_size, false); cqe->sg.seg_size, false);
act = bpf_prog_run_xdp(prog, &xdp); act = bpf_prog_run_xdp(prog, &xdp);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment