Skip to content

Commit

Permalink
idpf: enable XSk features and ndo_xsk_wakeup
Browse files Browse the repository at this point in the history
Now that AF_XDP functionality is fully implemented, advertise XSk XDP
feature and add .ndo_xsk_wakeup() callback to be able to use it with
this driver.

Co-developed-by: Michal Kubiak <michal.kubiak@intel.com>
Signed-off-by: Michal Kubiak <michal.kubiak@intel.com>
Signed-off-by: Alexander Lobakin <aleksander.lobakin@intel.com>
  • Loading branch information
alobakin committed Aug 9, 2024
1 parent ebd7b9c commit 02af331
Show file tree
Hide file tree
Showing 6 changed files with 55 additions and 4 deletions.
2 changes: 2 additions & 0 deletions drivers/net/ethernet/intel/idpf/idpf_lib.c
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
#include "idpf.h"
#include "idpf_virtchnl.h"
#include "xdp.h"
#include "xsk.h"

static const struct net_device_ops idpf_netdev_ops;

Expand Down Expand Up @@ -2366,4 +2367,5 @@ static const struct net_device_ops idpf_netdev_ops = {
.ndo_tx_timeout = idpf_tx_timeout,
.ndo_bpf = idpf_xdp,
.ndo_xdp_xmit = idpf_xdp_xmit,
.ndo_xsk_wakeup = idpf_xsk_wakeup,
};
3 changes: 3 additions & 0 deletions drivers/net/ethernet/intel/idpf/idpf_txrx.c
Original file line number Diff line number Diff line change
Expand Up @@ -1360,6 +1360,8 @@ static int idpf_qp_enable(struct idpf_queue_set *qs, u32 qid)
if (!idpf_queue_has(XSK, q->txq))
continue;

idpf_xsk_init_wakeup(q_vector);

q->txq->q_vector = q_vector;
q_vector->xsksq[q_vector->num_xsksq++] = q->txq;
}
Expand Down Expand Up @@ -4669,6 +4671,7 @@ static void idpf_vport_intr_map_vector_to_qs(struct idpf_vport *vport)
continue;

qv = idpf_find_rxq_vec(vport, i);
idpf_xsk_init_wakeup(qv);

xdpsq->q_vector = qv;
qv->xsksq[qv->num_xsksq++] = xdpsq;
Expand Down
9 changes: 6 additions & 3 deletions drivers/net/ethernet/intel/idpf/idpf_txrx.h
Original file line number Diff line number Diff line change
Expand Up @@ -395,9 +395,10 @@ struct idpf_intr_reg {
* @complq: array of completion queues
* @xsksq: array of XSk send queues
* @intr_reg: See struct idpf_intr_reg
* @napi: napi handler
* @csd: XSk wakeup CSD
* @total_events: Number of interrupts processed
* @wb_on_itr: WB on ITR enabled or not
* @napi: napi handler
* @tx_dim: Data for TX net_dim algorithm
* @tx_itr_value: TX interrupt throttling rate
* @tx_intr_mode: Dynamic ITR or not
Expand Down Expand Up @@ -428,9 +429,11 @@ struct idpf_q_vector {
__cacheline_group_end_aligned(read_mostly);

__cacheline_group_begin_aligned(read_write);
struct napi_struct napi;
call_single_data_t csd;

u16 total_events;
bool wb_on_itr;
struct napi_struct napi;

struct dim tx_dim;
u16 tx_itr_value;
Expand All @@ -450,7 +453,7 @@ struct idpf_q_vector {
__cacheline_group_end_aligned(cold);
};
libeth_cacheline_set_assert(struct idpf_q_vector, 128,
424 + 2 * sizeof(struct dim),
456 + 2 * sizeof(struct dim),
8 + sizeof(cpumask_var_t));

#define IDPF_ITR_DYNAMIC 1
Expand Down
4 changes: 3 additions & 1 deletion drivers/net/ethernet/intel/idpf/xdp.c
Original file line number Diff line number Diff line change
Expand Up @@ -454,7 +454,9 @@ void idpf_xdp_set_features(const struct idpf_vport *vport)
if (!idpf_is_queue_model_split(vport->rxq_model))
return;

libeth_xdp_set_features_noredir(vport->netdev, &idpf_xdpmo);
libeth_xdp_set_features_noredir(vport->netdev, &idpf_xdpmo,
idpf_get_max_tx_bufs(vport->adapter),
libeth_xsktmo);
}

/**
Expand Down
37 changes: 37 additions & 0 deletions drivers/net/ethernet/intel/idpf/xsk.c
Original file line number Diff line number Diff line change
Expand Up @@ -167,6 +167,11 @@ void idpf_xsk_clear_queue(void *q, enum virtchnl2_queue_type type)
}
}

void idpf_xsk_init_wakeup(struct idpf_q_vector *qv)
{
libeth_xsk_init_wakeup(&qv->csd, &qv->napi);
}

static void idpf_xskfqe_init(const struct libeth_xskfq_fp *fq, u32 i)
{
struct virtchnl2_splitq_rx_buf_desc *desc = fq->descs;
Expand Down Expand Up @@ -653,3 +658,35 @@ int idpf_xsk_pool_setup(struct idpf_vport *vport, struct netdev_bpf *bpf)

return ret;
}

/**
* idpf_xsk_wakeup - wake up a queue pair
* @dev: network device
* @qid: queue to wake up
* @flags: wakeup flags
*
* Return: 0 on success, -errno otherwise.
*/
int idpf_xsk_wakeup(struct net_device *dev, u32 qid, u32 flags)
{
const struct idpf_netdev_priv *np = netdev_priv(dev);
const struct idpf_vport *vport = np->vport;
struct idpf_q_vector *q_vector;

if (unlikely(idpf_vport_ctrl_is_locked(dev)))
return -EBUSY;

if (unlikely(!vport->link_up))
return -ENETDOWN;

if (unlikely(!vport->num_xdp_txq))
return -ENXIO;

q_vector = idpf_find_rxq_vec(vport, qid);
if (unlikely(!q_vector->xsksq))
return -ENXIO;

libeth_xsk_wakeup(&q_vector->csd, qid);

return 0;
}
4 changes: 4 additions & 0 deletions drivers/net/ethernet/intel/idpf/xsk.h
Original file line number Diff line number Diff line change
Expand Up @@ -8,14 +8,17 @@

enum virtchnl2_queue_type;
struct idpf_buf_queue;
struct idpf_q_vector;
struct idpf_rx_queue;
struct idpf_tx_queue;
struct idpf_vport;
struct net_device;
struct netdev_bpf;

void idpf_xsk_setup_queue(const struct idpf_vport *vport, void *q,
enum virtchnl2_queue_type type);
void idpf_xsk_clear_queue(void *q, enum virtchnl2_queue_type type);
void idpf_xsk_init_wakeup(struct idpf_q_vector *qv);

int idpf_xsk_bufs_init(struct idpf_buf_queue *bufq);
void idpf_xsk_buf_rel(struct idpf_buf_queue *bufq);
Expand All @@ -25,5 +28,6 @@ int idpf_clean_rx_irq_zc(struct idpf_rx_queue *rxq, u32 budget);
bool idpf_xsk_xmit(struct idpf_tx_queue *xsksq);

int idpf_xsk_pool_setup(struct idpf_vport *vport, struct netdev_bpf *xdp);
int idpf_xsk_wakeup(struct net_device *dev, u32 qid, u32 flags);

#endif /* !_IDPF_XSK_H_ */

0 comments on commit 02af331

Please sign in to comment.