2021-02-05 08:48:47 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
* Copyright(c) 2020 Intel Corporation.
|
|
|
|
*/
|
|
|
|
|
2022-09-06 04:00:10 +00:00
|
|
|
#ifdef RTE_NET_AF_XDP_LIBXDP
|
|
|
|
#include <xdp/xsk.h>
|
|
|
|
#else
|
2021-02-05 08:48:47 +00:00
|
|
|
#include <bpf/xsk.h>
|
2022-09-06 04:00:10 +00:00
|
|
|
#endif
|
|
|
|
#include <bpf/bpf.h>
|
2021-02-05 08:48:47 +00:00
|
|
|
#include <linux/version.h>
|
2022-09-06 04:00:10 +00:00
|
|
|
#include <poll.h>
|
2021-02-05 08:48:47 +00:00
|
|
|
|
|
|
|
#if KERNEL_VERSION(5, 10, 0) <= LINUX_VERSION_CODE && \
|
2022-09-06 04:00:10 +00:00
|
|
|
defined(RTE_NET_AF_XDP_SHARED_UMEM)
|
2021-02-05 08:48:47 +00:00
|
|
|
#define ETH_AF_XDP_SHARED_UMEM 1
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef ETH_AF_XDP_SHARED_UMEM
|
|
|
|
static __rte_always_inline int
|
|
|
|
create_shared_socket(struct xsk_socket **xsk_ptr,
|
|
|
|
const char *ifname,
|
|
|
|
__u32 queue_id, struct xsk_umem *umem,
|
|
|
|
struct xsk_ring_cons *rx,
|
|
|
|
struct xsk_ring_prod *tx,
|
|
|
|
struct xsk_ring_prod *fill,
|
|
|
|
struct xsk_ring_cons *comp,
|
|
|
|
const struct xsk_socket_config *config)
|
|
|
|
{
|
|
|
|
return xsk_socket__create_shared(xsk_ptr, ifname, queue_id, umem, rx,
|
|
|
|
tx, fill, comp, config);
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
static __rte_always_inline int
|
|
|
|
create_shared_socket(struct xsk_socket **xsk_ptr __rte_unused,
|
|
|
|
const char *ifname __rte_unused,
|
|
|
|
__u32 queue_id __rte_unused,
|
|
|
|
struct xsk_umem *umem __rte_unused,
|
|
|
|
struct xsk_ring_cons *rx __rte_unused,
|
|
|
|
struct xsk_ring_prod *tx __rte_unused,
|
|
|
|
struct xsk_ring_prod *fill __rte_unused,
|
|
|
|
struct xsk_ring_cons *comp __rte_unused,
|
|
|
|
const struct xsk_socket_config *config __rte_unused)
|
|
|
|
{
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
#endif
|
2022-09-06 04:00:10 +00:00
|
|
|
|
|
|
|
#ifdef XDP_USE_NEED_WAKEUP
|
|
|
|
static int
|
|
|
|
tx_syscall_needed(struct xsk_ring_prod *q)
|
|
|
|
{
|
|
|
|
return xsk_ring_prod__needs_wakeup(q);
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
static int
|
|
|
|
tx_syscall_needed(struct xsk_ring_prod *q __rte_unused)
|
|
|
|
{
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef RTE_NET_AF_XDP_LIBBPF_OBJ_OPEN
|
|
|
|
static int load_program(const char *prog_path, struct bpf_object **obj)
|
|
|
|
{
|
|
|
|
struct bpf_program *prog;
|
|
|
|
int err;
|
|
|
|
|
|
|
|
*obj = bpf_object__open_file(prog_path, NULL);
|
|
|
|
err = libbpf_get_error(*obj);
|
|
|
|
if (err)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
err = bpf_object__load(*obj);
|
|
|
|
if (err)
|
|
|
|
goto out;
|
|
|
|
|
|
|
|
prog = bpf_object__next_program(*obj, NULL);
|
|
|
|
if (!prog)
|
|
|
|
goto out;
|
|
|
|
|
|
|
|
return bpf_program__fd(prog);
|
|
|
|
|
|
|
|
out:
|
|
|
|
bpf_object__close(*obj);
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
static int load_program(const char *prog_path, struct bpf_object **obj)
|
|
|
|
{
|
|
|
|
int ret, prog_fd;
|
|
|
|
|
|
|
|
ret = bpf_prog_load(prog_path, BPF_PROG_TYPE_XDP, obj, &prog_fd);
|
|
|
|
if (ret)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
return prog_fd;
|
|
|
|
}
|
|
|
|
#endif
|