1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef _LINUX_IF_TAP_H_
3 #define _LINUX_IF_TAP_H_
6 #include <linux/skb_array.h>
11 #if IS_ENABLED(CONFIG_TAP)
12 struct socket
*tap_get_socket(struct file
*);
13 struct ptr_ring
*tap_get_ptr_ring(struct file
*file
);
15 #include <linux/err.h>
16 #include <linux/errno.h>
17 static inline struct socket
*tap_get_socket(struct file
*f
)
19 return ERR_PTR(-EINVAL
);
21 static inline struct ptr_ring
*tap_get_ptr_ring(struct file
*f
)
23 return ERR_PTR(-EINVAL
);
25 #endif /* CONFIG_TAP */
28 * Maximum times a tap device can be opened. This can be used to
29 * configure the number of receive queue, e.g. for multiqueue virtio.
31 #define MAX_TAP_QUEUES 256
36 struct net_device
*dev
;
38 /* This array tracks active taps. */
39 struct tap_queue __rcu
*taps
[MAX_TAP_QUEUES
];
40 /* This list tracks all taps (both enabled and disabled) */
41 struct list_head queue_list
;
44 netdev_features_t tap_features
;
47 void (*update_features
)(struct tap_dev
*tap
, netdev_features_t features
);
48 void (*count_tx_dropped
)(struct tap_dev
*tap
);
49 void (*count_rx_dropped
)(struct tap_dev
*tap
);
53 * A tap queue is the central object of tap module, it connects
54 * an open character device to virtual interface. There can be
55 * multiple queues on one interface, which map back to queues
56 * implemented in hardware on the underlying device.
58 * tap_proto is used to allocate queues through the sock allocation
67 struct tap_dev __rcu
*tap
;
72 struct list_head next
;
76 rx_handler_result_t
tap_handle_frame(struct sk_buff
**pskb
);
77 void tap_del_queues(struct tap_dev
*tap
);
78 int tap_get_minor(dev_t major
, struct tap_dev
*tap
);
79 void tap_free_minor(dev_t major
, struct tap_dev
*tap
);
80 int tap_queue_resize(struct tap_dev
*tap
);
81 int tap_create_cdev(struct cdev
*tap_cdev
, dev_t
*tap_major
,
82 const char *device_name
, struct module
*module
);
83 void tap_destroy_cdev(dev_t major
, struct cdev
*tap_cdev
);
85 #endif /*_LINUX_IF_TAP_H_*/