Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux
1
fork

Configure Feed

Select the types of activity you want to include in your feed.

at ee9dce44362b2d8132c32964656ab6dff7dfbc6a 84 lines 2.3 kB view raw
1/* SPDX-License-Identifier: GPL-2.0 */ 2#ifndef _LINUX_NETDEV_RX_QUEUE_H 3#define _LINUX_NETDEV_RX_QUEUE_H 4 5#include <linux/kobject.h> 6#include <linux/netdevice.h> 7#include <linux/sysfs.h> 8#include <net/xdp.h> 9#include <net/page_pool/types.h> 10#include <net/netdev_queues.h> 11#include <net/rps-types.h> 12 13/* This structure contains an instance of an RX queue. */ 14struct netdev_rx_queue { 15 struct xdp_rxq_info xdp_rxq; 16#ifdef CONFIG_RPS 17 struct rps_map __rcu *rps_map; 18 rps_tag_ptr rps_flow_table; 19#endif 20 struct kobject kobj; 21 const struct attribute_group **groups; 22 struct net_device *dev; 23 netdevice_tracker dev_tracker; 24 25 /* All fields below are "ops protected", 26 * see comment about net_device::lock 27 */ 28#ifdef CONFIG_XDP_SOCKETS 29 struct xsk_buff_pool *pool; 30#endif 31 struct napi_struct *napi; 32 struct netdev_queue_config qcfg; 33 struct pp_memory_provider_params mp_params; 34 35 /* If a queue is leased, then the lease pointer is always 36 * valid. From the physical device it points to the virtual 37 * queue, and from the virtual device it points to the 38 * physical queue. 39 */ 40 struct netdev_rx_queue *lease; 41 netdevice_tracker lease_tracker; 42} ____cacheline_aligned_in_smp; 43 44/* 45 * RX queue sysfs structures and functions. 46 */ 47struct rx_queue_attribute { 48 struct attribute attr; 49 ssize_t (*show)(struct netdev_rx_queue *queue, char *buf); 50 ssize_t (*store)(struct netdev_rx_queue *queue, 51 const char *buf, size_t len); 52}; 53 54static inline struct netdev_rx_queue * 55__netif_get_rx_queue(struct net_device *dev, unsigned int rxq) 56{ 57 return dev->_rx + rxq; 58} 59 60static inline unsigned int 61get_netdev_rx_queue_index(struct netdev_rx_queue *queue) 62{ 63 struct net_device *dev = queue->dev; 64 int index = queue - dev->_rx; 65 66 BUG_ON(index >= dev->num_rx_queues); 67 return index; 68} 69 70enum netif_lease_dir { 71 NETIF_VIRT_TO_PHYS, 72 NETIF_PHYS_TO_VIRT, 73}; 74 75struct netdev_rx_queue * 76__netif_get_rx_queue_lease(struct net_device **dev, unsigned int *rxq, 77 enum netif_lease_dir dir); 78 79int netdev_rx_queue_restart(struct net_device *dev, unsigned int rxq); 80void netdev_rx_queue_lease(struct netdev_rx_queue *rxq_dst, 81 struct netdev_rx_queue *rxq_src); 82void netdev_rx_queue_unlease(struct netdev_rx_queue *rxq_dst, 83 struct netdev_rx_queue *rxq_src); 84#endif /* _LINUX_NETDEV_RX_QUEUE_H */