1#ifndef _LINUX_VIRTIO_H
2#define _LINUX_VIRTIO_H
3
4
5#include <linux/types.h>
6#include <linux/scatterlist.h>
7#include <linux/spinlock.h>
8#include <linux/device.h>
9#include <linux/mod_devicetable.h>
10#include <linux/gfp.h>
11#include <linux/vringh.h>
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27struct virtqueue {
28 struct list_head list;
29 void (*callback)(struct virtqueue *vq);
30 const char *name;
31 struct virtio_device *vdev;
32 unsigned int index;
33 unsigned int num_free;
34 void *priv;
35};
36
37int virtqueue_add_outbuf(struct virtqueue *vq,
38 struct scatterlist sg[], unsigned int num,
39 void *data,
40 gfp_t gfp);
41
42int virtqueue_add_inbuf(struct virtqueue *vq,
43 struct scatterlist sg[], unsigned int num,
44 void *data,
45 gfp_t gfp);
46
47int virtqueue_add_sgs(struct virtqueue *vq,
48 struct scatterlist *sgs[],
49 unsigned int out_sgs,
50 unsigned int in_sgs,
51 void *data,
52 gfp_t gfp);
53
54bool virtqueue_kick(struct virtqueue *vq);
55
56bool virtqueue_kick_prepare(struct virtqueue *vq);
57
58bool virtqueue_notify(struct virtqueue *vq);
59
60void *virtqueue_get_buf(struct virtqueue *vq, unsigned int *len);
61
62void virtqueue_disable_cb(struct virtqueue *vq);
63
64bool virtqueue_enable_cb(struct virtqueue *vq);
65
66unsigned virtqueue_enable_cb_prepare(struct virtqueue *vq);
67
68bool virtqueue_poll(struct virtqueue *vq, unsigned);
69
70bool virtqueue_enable_cb_delayed(struct virtqueue *vq);
71
72void *virtqueue_detach_unused_buf(struct virtqueue *vq);
73
74unsigned int virtqueue_get_vring_size(struct virtqueue *vq);
75
76bool virtqueue_is_broken(struct virtqueue *vq);
77
78
79
80
81
82
83
84
85
86
87
88
89struct virtio_device {
90 int index;
91 struct device dev;
92 struct virtio_device_id id;
93 const struct virtio_config_ops *config;
94 const struct vringh_config_ops *vringh_config;
95 struct list_head vqs;
96
97 unsigned long features[1];
98 void *priv;
99};
100
101static inline struct virtio_device *dev_to_virtio(struct device *_dev)
102{
103 return container_of(_dev, struct virtio_device, dev);
104}
105
106int register_virtio_device(struct virtio_device *dev);
107void unregister_virtio_device(struct virtio_device *dev);
108
109void virtio_break_device(struct virtio_device *dev);
110
111
112
113
114
115
116
117
118
119
120
121
122struct virtio_driver {
123 struct device_driver driver;
124 const struct virtio_device_id *id_table;
125 const unsigned int *feature_table;
126 unsigned int feature_table_size;
127 int (*probe)(struct virtio_device *dev);
128 void (*scan)(struct virtio_device *dev);
129 void (*remove)(struct virtio_device *dev);
130 void (*config_changed)(struct virtio_device *dev);
131#ifdef CONFIG_PM
132 int (*freeze)(struct virtio_device *dev);
133 int (*restore)(struct virtio_device *dev);
134#endif
135};
136
137static inline struct virtio_driver *drv_to_virtio(struct device_driver *drv)
138{
139 return container_of(drv, struct virtio_driver, driver);
140}
141
142int register_virtio_driver(struct virtio_driver *drv);
143void unregister_virtio_driver(struct virtio_driver *drv);
144
145
146
147
148
149
150#define module_virtio_driver(__virtio_driver) \
151 module_driver(__virtio_driver, register_virtio_driver, \
152 unregister_virtio_driver)
153#endif
154