2018-05-18 14:00:21 +02:00
/* SPDX-License-Identifier: GPL-2.0 */
/* AF_XDP internal functions
2018-05-02 13:01:23 +02:00
* Copyright ( c ) 2018 Intel Corporation .
*/
# ifndef _LINUX_XDP_SOCK_H
# define _LINUX_XDP_SOCK_H
2018-06-04 14:05:51 +02:00
# include <linux/workqueue.h>
# include <linux/if_xdp.h>
2018-05-02 13:01:23 +02:00
# include <linux/mutex.h>
2018-06-04 14:05:57 +02:00
# include <linux/spinlock.h>
2018-06-04 14:05:51 +02:00
# include <linux/mm.h>
2018-05-02 13:01:23 +02:00
# include <net/sock.h>
2018-05-02 13:01:25 +02:00
struct net_device ;
struct xsk_queue ;
2018-06-04 14:05:51 +02:00
2018-06-04 14:05:52 +02:00
struct xdp_umem_page {
void * addr ;
2018-06-04 14:05:55 +02:00
dma_addr_t dma ;
2018-06-04 14:05:52 +02:00
} ;
2018-06-04 14:05:51 +02:00
struct xdp_umem {
struct xsk_queue * fq ;
struct xsk_queue * cq ;
2018-06-04 14:05:52 +02:00
struct xdp_umem_page * pages ;
2018-08-31 13:40:02 +02:00
u64 chunk_mask ;
u64 size ;
2018-06-04 14:05:51 +02:00
u32 headroom ;
u32 chunk_size_nohr ;
struct user_struct * user ;
struct pid * pid ;
unsigned long address ;
refcount_t users ;
struct work_struct work ;
2018-06-04 14:05:52 +02:00
struct page * * pgs ;
2018-06-04 14:05:51 +02:00
u32 npgs ;
2018-06-04 14:05:55 +02:00
struct net_device * dev ;
u16 queue_id ;
bool zc ;
2018-06-04 14:05:57 +02:00
spinlock_t xsk_list_lock ;
struct list_head xsk_list ;
2018-06-04 14:05:51 +02:00
} ;
2018-05-02 13:01:23 +02:00
struct xdp_sock {
/* struct sock must be the first member of struct xdp_sock */
struct sock sk ;
2018-05-02 13:01:25 +02:00
struct xsk_queue * rx ;
struct net_device * dev ;
2018-05-02 13:01:23 +02:00
struct xdp_umem * umem ;
2018-05-02 13:01:28 +02:00
struct list_head flush_node ;
2018-05-02 13:01:26 +02:00
u16 queue_id ;
2018-05-02 13:01:32 +02:00
struct xsk_queue * tx ____cacheline_aligned_in_smp ;
2018-06-04 14:05:57 +02:00
struct list_head list ;
bool zc ;
2018-05-02 13:01:23 +02:00
/* Protects multiple processes in the control path */
struct mutex mutex ;
2018-06-29 09:48:20 +02:00
/* Mutual exclusion of NAPI TX thread and sendmsg error paths
* in the SKB destructor callback .
*/
spinlock_t tx_completion_lock ;
2018-05-02 13:01:27 +02:00
u64 rx_dropped ;
2018-05-02 13:01:23 +02:00
} ;
2018-05-02 13:01:27 +02:00
struct xdp_buff ;
# ifdef CONFIG_XDP_SOCKETS
int xsk_generic_rcv ( struct xdp_sock * xs , struct xdp_buff * xdp ) ;
int xsk_rcv ( struct xdp_sock * xs , struct xdp_buff * xdp ) ;
void xsk_flush ( struct xdp_sock * xs ) ;
2018-05-02 13:01:28 +02:00
bool xsk_is_setup_for_bpf_map ( struct xdp_sock * xs ) ;
2018-06-04 14:05:57 +02:00
/* Used from netdev driver */
2018-06-04 14:05:55 +02:00
u64 * xsk_umem_peek_addr ( struct xdp_umem * umem , u64 * addr ) ;
void xsk_umem_discard_addr ( struct xdp_umem * umem ) ;
2018-06-04 14:05:57 +02:00
void xsk_umem_complete_tx ( struct xdp_umem * umem , u32 nb_entries ) ;
bool xsk_umem_consume_tx ( struct xdp_umem * umem , dma_addr_t * dma , u32 * len ) ;
void xsk_umem_consume_tx_done ( struct xdp_umem * umem ) ;
2018-08-28 14:44:27 +02:00
static inline char * xdp_umem_get_data ( struct xdp_umem * umem , u64 addr )
{
return umem - > pages [ addr > > PAGE_SHIFT ] . addr + ( addr & ( PAGE_SIZE - 1 ) ) ;
}
static inline dma_addr_t xdp_umem_get_dma ( struct xdp_umem * umem , u64 addr )
{
return umem - > pages [ addr > > PAGE_SHIFT ] . dma + ( addr & ( PAGE_SIZE - 1 ) ) ;
}
2018-05-02 13:01:27 +02:00
# else
static inline int xsk_generic_rcv ( struct xdp_sock * xs , struct xdp_buff * xdp )
{
return - ENOTSUPP ;
}
static inline int xsk_rcv ( struct xdp_sock * xs , struct xdp_buff * xdp )
{
return - ENOTSUPP ;
}
static inline void xsk_flush ( struct xdp_sock * xs )
{
}
2018-05-02 13:01:28 +02:00
static inline bool xsk_is_setup_for_bpf_map ( struct xdp_sock * xs )
{
return false ;
}
2018-08-28 14:44:27 +02:00
static inline u64 * xsk_umem_peek_addr ( struct xdp_umem * umem , u64 * addr )
{
return NULL ;
}
static inline void xsk_umem_discard_addr ( struct xdp_umem * umem )
{
}
static inline void xsk_umem_complete_tx ( struct xdp_umem * umem , u32 nb_entries )
{
}
static inline bool xsk_umem_consume_tx ( struct xdp_umem * umem , dma_addr_t * dma ,
u32 * len )
{
return false ;
}
static inline void xsk_umem_consume_tx_done ( struct xdp_umem * umem )
{
}
static inline char * xdp_umem_get_data ( struct xdp_umem * umem , u64 addr )
{
return NULL ;
}
static inline dma_addr_t xdp_umem_get_dma ( struct xdp_umem * umem , u64 addr )
{
return 0 ;
}
2018-05-02 13:01:27 +02:00
# endif /* CONFIG_XDP_SOCKETS */
2018-05-02 13:01:23 +02:00
# endif /* _LINUX_XDP_SOCK_H */