linux/net/xdp/xsk.c

// SPDX-License-Identifier: GPL-2.0
/* XDP sockets
 *
 * AF_XDP sockets allows a channel between XDP programs and userspace
 * applications.
 * Copyright(c) 2018 Intel Corporation.
 *
 * Author(s): Björn Töpel <[email protected]>
 *	      Magnus Karlsson <[email protected]>
 */

#define pr_fmt(fmt)

#include <linux/if_xdp.h>
#include <linux/init.h>
#include <linux/sched/mm.h>
#include <linux/sched/signal.h>
#include <linux/sched/task.h>
#include <linux/socket.h>
#include <linux/file.h>
#include <linux/uaccess.h>
#include <linux/net.h>
#include <linux/netdevice.h>
#include <linux/rculist.h>
#include <linux/vmalloc.h>
#include <net/xdp_sock_drv.h>
#include <net/busy_poll.h>
#include <net/netdev_rx_queue.h>
#include <net/xdp.h>

#include "xsk_queue.h"
#include "xdp_umem.h"
#include "xsk.h"

#define TX_BATCH_SIZE
#define MAX_PER_SOCKET_BUDGET

void xsk_set_rx_need_wakeup(struct xsk_buff_pool *pool)
{}
EXPORT_SYMBOL();

void xsk_set_tx_need_wakeup(struct xsk_buff_pool *pool)
{}
EXPORT_SYMBOL();

void xsk_clear_rx_need_wakeup(struct xsk_buff_pool *pool)
{}
EXPORT_SYMBOL();

void xsk_clear_tx_need_wakeup(struct xsk_buff_pool *pool)
{}
EXPORT_SYMBOL();

bool xsk_uses_need_wakeup(struct xsk_buff_pool *pool)
{}
EXPORT_SYMBOL();

struct xsk_buff_pool *xsk_get_pool_from_qid(struct net_device *dev,
					    u16 queue_id)
{}
EXPORT_SYMBOL();

void xsk_clear_pool_at_qid(struct net_device *dev, u16 queue_id)
{}

/* The buffer pool is stored both in the _rx struct and the _tx struct as we do
 * not know if the device has more tx queues than rx, or the opposite.
 * This might also change during run time.
 */
int xsk_reg_pool_at_qid(struct net_device *dev, struct xsk_buff_pool *pool,
			u16 queue_id)
{}

static int __xsk_rcv_zc(struct xdp_sock *xs, struct xdp_buff_xsk *xskb, u32 len,
			u32 flags)
{}

static int xsk_rcv_zc(struct xdp_sock *xs, struct xdp_buff *xdp, u32 len)
{}

static void *xsk_copy_xdp_start(struct xdp_buff *from)
{}

static u32 xsk_copy_xdp(void *to, void **from, u32 to_len,
			u32 *from_len, skb_frag_t **frag, u32 rem)
{}

static int __xsk_rcv(struct xdp_sock *xs, struct xdp_buff *xdp, u32 len)
{}

static bool xsk_tx_writeable(struct xdp_sock *xs)
{}

static bool xsk_is_bound(struct xdp_sock *xs)
{}

static int xsk_rcv_check(struct xdp_sock *xs, struct xdp_buff *xdp, u32 len)
{}

static void xsk_flush(struct xdp_sock *xs)
{}

int xsk_generic_rcv(struct xdp_sock *xs, struct xdp_buff *xdp)
{}

static int xsk_rcv(struct xdp_sock *xs, struct xdp_buff *xdp)
{}

int __xsk_map_redirect(struct xdp_sock *xs, struct xdp_buff *xdp)
{}

void __xsk_map_flush(struct list_head *flush_list)
{}

void xsk_tx_completed(struct xsk_buff_pool *pool, u32 nb_entries)
{}
EXPORT_SYMBOL();

void xsk_tx_release(struct xsk_buff_pool *pool)
{}
EXPORT_SYMBOL();

bool xsk_tx_peek_desc(struct xsk_buff_pool *pool, struct xdp_desc *desc)
{}
EXPORT_SYMBOL();

static u32 xsk_tx_peek_release_fallback(struct xsk_buff_pool *pool, u32 max_entries)
{}

u32 xsk_tx_peek_release_desc_batch(struct xsk_buff_pool *pool, u32 nb_pkts)
{}
EXPORT_SYMBOL();

static int xsk_wakeup(struct xdp_sock *xs, u8 flags)
{}

static int xsk_cq_reserve_addr_locked(struct xdp_sock *xs, u64 addr)
{}

static void xsk_cq_submit_locked(struct xdp_sock *xs, u32 n)
{}

static void xsk_cq_cancel_locked(struct xdp_sock *xs, u32 n)
{}

static u32 xsk_get_num_desc(struct sk_buff *skb)
{}

static void xsk_destruct_skb(struct sk_buff *skb)
{}

static void xsk_set_destructor_arg(struct sk_buff *skb)
{}

static void xsk_consume_skb(struct sk_buff *skb)
{}

static void xsk_drop_skb(struct sk_buff *skb)
{}

static struct sk_buff *xsk_build_skb_zerocopy(struct xdp_sock *xs,
					      struct xdp_desc *desc)
{}

static struct sk_buff *xsk_build_skb(struct xdp_sock *xs,
				     struct xdp_desc *desc)
{}

static int __xsk_generic_xmit(struct sock *sk)
{}

static int xsk_generic_xmit(struct sock *sk)
{}

static bool xsk_no_wakeup(struct sock *sk)
{}

static int xsk_check_common(struct xdp_sock *xs)
{}

static int __xsk_sendmsg(struct socket *sock, struct msghdr *m, size_t total_len)
{}

static int xsk_sendmsg(struct socket *sock, struct msghdr *m, size_t total_len)
{}

static int __xsk_recvmsg(struct socket *sock, struct msghdr *m, size_t len, int flags)
{}

static int xsk_recvmsg(struct socket *sock, struct msghdr *m, size_t len, int flags)
{}

static __poll_t xsk_poll(struct file *file, struct socket *sock,
			     struct poll_table_struct *wait)
{}

static int xsk_init_queue(u32 entries, struct xsk_queue **queue,
			  bool umem_queue)
{}

static void xsk_unbind_dev(struct xdp_sock *xs)
{}

static struct xsk_map *xsk_get_map_list_entry(struct xdp_sock *xs,
					      struct xdp_sock __rcu ***map_entry)
{}

static void xsk_delete_from_maps(struct xdp_sock *xs)
{}

static int xsk_release(struct socket *sock)
{}

static struct socket *xsk_lookup_xsk_from_fd(int fd)
{}

static bool xsk_validate_queues(struct xdp_sock *xs)
{}

static int xsk_bind(struct socket *sock, struct sockaddr *addr, int addr_len)
{}

struct xdp_umem_reg_v1 {};

static int xsk_setsockopt(struct socket *sock, int level, int optname,
			  sockptr_t optval, unsigned int optlen)
{}

static void xsk_enter_rxtx_offsets(struct xdp_ring_offset_v1 *ring)
{}

static void xsk_enter_umem_offsets(struct xdp_ring_offset_v1 *ring)
{}

struct xdp_statistics_v1 {};

static int xsk_getsockopt(struct socket *sock, int level, int optname,
			  char __user *optval, int __user *optlen)
{}

static int xsk_mmap(struct file *file, struct socket *sock,
		    struct vm_area_struct *vma)
{}

static int xsk_notifier(struct notifier_block *this,
			unsigned long msg, void *ptr)
{}

static struct proto xsk_proto =;

static const struct proto_ops xsk_proto_ops =;

static void xsk_destruct(struct sock *sk)
{}

static int xsk_create(struct net *net, struct socket *sock, int protocol,
		      int kern)
{}

static const struct net_proto_family xsk_family_ops =;

static struct notifier_block xsk_netdev_notifier =;

static int __net_init xsk_net_init(struct net *net)
{}

static void __net_exit xsk_net_exit(struct net *net)
{}

static struct pernet_operations xsk_net_ops =;

static int __init xsk_init(void)
{}

fs_initcall(xsk_init);