Viewing file: if_tap.h (2.21 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* SPDX-License-Identifier: GPL-2.0 */ #ifndef _LINUX_IF_TAP_H_ #define _LINUX_IF_TAP_H_
#include <net/sock.h> #include <linux/skb_array.h>
struct file; struct socket;
#if IS_ENABLED(CONFIG_TAP) struct socket *tap_get_socket(struct file *); struct ptr_ring *tap_get_ptr_ring(struct file *file); #else #include <linux/err.h> #include <linux/errno.h> static inline struct socket *tap_get_socket(struct file *f) { return ERR_PTR(-EINVAL); } static inline struct ptr_ring *tap_get_ptr_ring(struct file *f) { return ERR_PTR(-EINVAL); } #endif /* CONFIG_TAP */
/* * Maximum times a tap device can be opened. This can be used to * configure the number of receive queue, e.g. for multiqueue virtio. */ #define MAX_TAP_QUEUES 256
struct tap_queue;
struct tap_dev { struct net_device *dev; u16 flags; /* This array tracks active taps. */ struct tap_queue __rcu *taps[MAX_TAP_QUEUES]; /* This list tracks all taps (both enabled and disabled) */ struct list_head queue_list; int numvtaps; int numqueues; netdev_features_t tap_features; int minor;
void (*update_features)(struct tap_dev *tap, netdev_features_t features); void (*count_tx_dropped)(struct tap_dev *tap); void (*count_rx_dropped)(struct tap_dev *tap); };
/* * A tap queue is the central object of tap module, it connects * an open character device to virtual interface. There can be * multiple queues on one interface, which map back to queues * implemented in hardware on the underlying device. * * tap_proto is used to allocate queues through the sock allocation * mechanism. * */
struct tap_queue { struct sock sk; struct socket sock; int vnet_hdr_sz; struct tap_dev __rcu *tap; struct file *file; unsigned int flags; u16 queue_index; bool enabled; struct list_head next; struct ptr_ring ring; };
rx_handler_result_t tap_handle_frame(struct sk_buff **pskb); void tap_del_queues(struct tap_dev *tap); int tap_get_minor(dev_t major, struct tap_dev *tap); void tap_free_minor(dev_t major, struct tap_dev *tap); int tap_queue_resize(struct tap_dev *tap); int tap_create_cdev(struct cdev *tap_cdev, dev_t *tap_major, const char *device_name, struct module *module); void tap_destroy_cdev(dev_t major, struct cdev *tap_cdev);
#endif /*_LINUX_IF_TAP_H_*/
|