blob: 915a187cfabdac61da21a58c9ab00862c9deaae8 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Sainath Grandhi635b8c82017-02-10 16:03:47 -08002#ifndef _LINUX_IF_TAP_H_
3#define _LINUX_IF_TAP_H_
4
Sainath Grandhi9a393b52017-02-10 16:03:51 -08005#if IS_ENABLED(CONFIG_TAP)
Sainath Grandhi635b8c82017-02-10 16:03:47 -08006struct socket *tap_get_socket(struct file *);
Jason Wang5990a302018-01-04 11:14:27 +08007struct ptr_ring *tap_get_ptr_ring(struct file *file);
Sainath Grandhi635b8c82017-02-10 16:03:47 -08008#else
9#include <linux/err.h>
10#include <linux/errno.h>
11struct file;
12struct socket;
13static inline struct socket *tap_get_socket(struct file *f)
14{
15 return ERR_PTR(-EINVAL);
16}
Jason Wang5990a302018-01-04 11:14:27 +080017static inline struct ptr_ring *tap_get_ptr_ring(struct file *f)
Jason Wang49f96fd2017-05-17 12:14:42 +080018{
19 return ERR_PTR(-EINVAL);
20}
Sainath Grandhi9a393b52017-02-10 16:03:51 -080021#endif /* CONFIG_TAP */
Sainath Grandhi635b8c82017-02-10 16:03:47 -080022
Sainath Grandhi6fe3faf2017-02-10 16:03:49 -080023#include <net/sock.h>
24#include <linux/skb_array.h>
25
Girish Moodalbail88ca59d2017-10-25 12:26:43 -070026/*
27 * Maximum times a tap device can be opened. This can be used to
28 * configure the number of receive queue, e.g. for multiqueue virtio.
29 */
Sainath Grandhi6fe3faf2017-02-10 16:03:49 -080030#define MAX_TAP_QUEUES 256
31
32struct tap_queue;
33
34struct tap_dev {
35 struct net_device *dev;
36 u16 flags;
37 /* This array tracks active taps. */
38 struct tap_queue __rcu *taps[MAX_TAP_QUEUES];
39 /* This list tracks all taps (both enabled and disabled) */
40 struct list_head queue_list;
41 int numvtaps;
42 int numqueues;
43 netdev_features_t tap_features;
44 int minor;
45
46 void (*update_features)(struct tap_dev *tap, netdev_features_t features);
47 void (*count_tx_dropped)(struct tap_dev *tap);
48 void (*count_rx_dropped)(struct tap_dev *tap);
49};
50
51/*
52 * A tap queue is the central object of tap module, it connects
53 * an open character device to virtual interface. There can be
54 * multiple queues on one interface, which map back to queues
55 * implemented in hardware on the underlying device.
56 *
57 * tap_proto is used to allocate queues through the sock allocation
58 * mechanism.
59 *
60 */
61
62struct tap_queue {
63 struct sock sk;
64 struct socket sock;
Sainath Grandhi6fe3faf2017-02-10 16:03:49 -080065 int vnet_hdr_sz;
66 struct tap_dev __rcu *tap;
67 struct file *file;
68 unsigned int flags;
69 u16 queue_index;
70 bool enabled;
71 struct list_head next;
Jason Wang5990a302018-01-04 11:14:27 +080072 struct ptr_ring ring;
Sainath Grandhi6fe3faf2017-02-10 16:03:49 -080073};
74
Sainath Grandhi635b8c82017-02-10 16:03:47 -080075rx_handler_result_t tap_handle_frame(struct sk_buff **pskb);
Sainath Grandhi6fe3faf2017-02-10 16:03:49 -080076void tap_del_queues(struct tap_dev *tap);
Sainath Grandhid9f1f612017-02-10 16:03:50 -080077int tap_get_minor(dev_t major, struct tap_dev *tap);
78void tap_free_minor(dev_t major, struct tap_dev *tap);
Sainath Grandhi6fe3faf2017-02-10 16:03:49 -080079int tap_queue_resize(struct tap_dev *tap);
Girish Moodalbaildea6e192017-10-27 00:00:16 -070080int tap_create_cdev(struct cdev *tap_cdev, dev_t *tap_major,
81 const char *device_name, struct module *module);
Sainath Grandhiebc05ba2017-02-10 16:03:48 -080082void tap_destroy_cdev(dev_t major, struct cdev *tap_cdev);
Sainath Grandhi635b8c82017-02-10 16:03:47 -080083
84#endif /*_LINUX_IF_TAP_H_*/