#include <net/xsk_buff_pool.h>
#include <net/xdp_sock.h>
#include <net/xdp_sock_drv.h>
#include "xsk_queue.h"
#include "xdp_umem.h"
#include "xsk.h"
void xp_add_xsk(struct xsk_buff_pool *pool, struct xdp_sock *xs)
{ … }
void xp_del_xsk(struct xsk_buff_pool *pool, struct xdp_sock *xs)
{ … }
void xp_destroy(struct xsk_buff_pool *pool)
{ … }
int xp_alloc_tx_descs(struct xsk_buff_pool *pool, struct xdp_sock *xs)
{ … }
struct xsk_buff_pool *xp_create_and_assign_umem(struct xdp_sock *xs,
struct xdp_umem *umem)
{ … }
void xp_set_rxq_info(struct xsk_buff_pool *pool, struct xdp_rxq_info *rxq)
{ … }
EXPORT_SYMBOL(…);
void xp_fill_cb(struct xsk_buff_pool *pool, struct xsk_cb_desc *desc)
{ … }
EXPORT_SYMBOL(…);
static void xp_disable_drv_zc(struct xsk_buff_pool *pool)
{ … }
#define NETDEV_XDP_ACT_ZC …
int xp_assign_dev(struct xsk_buff_pool *pool,
struct net_device *netdev, u16 queue_id, u16 flags)
{ … }
int xp_assign_dev_shared(struct xsk_buff_pool *pool, struct xdp_sock *umem_xs,
struct net_device *dev, u16 queue_id)
{ … }
void xp_clear_dev(struct xsk_buff_pool *pool)
{ … }
static void xp_release_deferred(struct work_struct *work)
{ … }
void xp_get_pool(struct xsk_buff_pool *pool)
{ … }
bool xp_put_pool(struct xsk_buff_pool *pool)
{ … }
static struct xsk_dma_map *xp_find_dma_map(struct xsk_buff_pool *pool)
{ … }
static struct xsk_dma_map *xp_create_dma_map(struct device *dev, struct net_device *netdev,
u32 nr_pages, struct xdp_umem *umem)
{ … }
static void xp_destroy_dma_map(struct xsk_dma_map *dma_map)
{ … }
static void __xp_dma_unmap(struct xsk_dma_map *dma_map, unsigned long attrs)
{ … }
void xp_dma_unmap(struct xsk_buff_pool *pool, unsigned long attrs)
{ … }
EXPORT_SYMBOL(…);
static void xp_check_dma_contiguity(struct xsk_dma_map *dma_map)
{ … }
static int xp_init_dma_info(struct xsk_buff_pool *pool, struct xsk_dma_map *dma_map)
{ … }
int xp_dma_map(struct xsk_buff_pool *pool, struct device *dev,
unsigned long attrs, struct page **pages, u32 nr_pages)
{ … }
EXPORT_SYMBOL(…);
static bool xp_addr_crosses_non_contig_pg(struct xsk_buff_pool *pool,
u64 addr)
{ … }
static bool xp_check_unaligned(struct xsk_buff_pool *pool, u64 *addr)
{ … }
static bool xp_check_aligned(struct xsk_buff_pool *pool, u64 *addr)
{ … }
static struct xdp_buff_xsk *__xp_alloc(struct xsk_buff_pool *pool)
{ … }
struct xdp_buff *xp_alloc(struct xsk_buff_pool *pool)
{ … }
EXPORT_SYMBOL(…);
static u32 xp_alloc_new_from_fq(struct xsk_buff_pool *pool, struct xdp_buff **xdp, u32 max)
{ … }
static u32 xp_alloc_reused(struct xsk_buff_pool *pool, struct xdp_buff **xdp, u32 nb_entries)
{ … }
static u32 xp_alloc_slow(struct xsk_buff_pool *pool, struct xdp_buff **xdp,
u32 max)
{ … }
u32 xp_alloc_batch(struct xsk_buff_pool *pool, struct xdp_buff **xdp, u32 max)
{ … }
EXPORT_SYMBOL(…);
bool xp_can_alloc(struct xsk_buff_pool *pool, u32 count)
{ … }
EXPORT_SYMBOL(…);
void xp_free(struct xdp_buff_xsk *xskb)
{ … }
EXPORT_SYMBOL(…);
void *xp_raw_get_data(struct xsk_buff_pool *pool, u64 addr)
{ … }
EXPORT_SYMBOL(…);
dma_addr_t xp_raw_get_dma(struct xsk_buff_pool *pool, u64 addr)
{ … }
EXPORT_SYMBOL(…);