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: 06059a1a9a4a ("octeontx2-pf: Add XDP support to netdev PF") Signed-off-by: Geetha sowjanya <gakula@marvell.com> Link: https://lore.kernel.org/r/20240130120610.16673-1-gakula@marvell.com Signed-off-by: Paolo Abeni <pabeni@redhat.com>
This commit is contained in:
parent
b59af3045a
commit
04f647c8e4
@ -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)
|
|||||||
/* 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)
|
|||||||
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,
|
|||||||
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,
|
|||||||
|
|
||||||
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);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user