#include <linux/virtio.h>
#include <linux/spinlock.h>
#include <linux/virtio_config.h>
#include <linux/virtio_anchor.h>
#include <linux/module.h>
#include <linux/idr.h>
#include <linux/of.h>
#include <uapi/linux/virtio_ids.h>
static DEFINE_IDA(virtio_index_ida);
static ssize_t device_show(struct device *_d,
struct device_attribute *attr, char *buf)
{ … }
static DEVICE_ATTR_RO(device);
static ssize_t vendor_show(struct device *_d,
struct device_attribute *attr, char *buf)
{ … }
static DEVICE_ATTR_RO(vendor);
static ssize_t status_show(struct device *_d,
struct device_attribute *attr, char *buf)
{ … }
static DEVICE_ATTR_RO(status);
static ssize_t modalias_show(struct device *_d,
struct device_attribute *attr, char *buf)
{ … }
static DEVICE_ATTR_RO(modalias);
static ssize_t features_show(struct device *_d,
struct device_attribute *attr, char *buf)
{ … }
static DEVICE_ATTR_RO(features);
static struct attribute *virtio_dev_attrs[] = …;
ATTRIBUTE_GROUPS(…);
static inline int virtio_id_match(const struct virtio_device *dev,
const struct virtio_device_id *id)
{ … }
static int virtio_dev_match(struct device *_dv, const struct device_driver *_dr)
{ … }
static int virtio_uevent(const struct device *_dv, struct kobj_uevent_env *env)
{ … }
void virtio_check_driver_offered_feature(const struct virtio_device *vdev,
unsigned int fbit)
{ … }
EXPORT_SYMBOL_GPL(…);
static void __virtio_config_changed(struct virtio_device *dev)
{ … }
void virtio_config_changed(struct virtio_device *dev)
{ … }
EXPORT_SYMBOL_GPL(…);
void virtio_config_driver_disable(struct virtio_device *dev)
{ … }
EXPORT_SYMBOL_GPL(…);
void virtio_config_driver_enable(struct virtio_device *dev)
{ … }
EXPORT_SYMBOL_GPL(…);
static void virtio_config_core_disable(struct virtio_device *dev)
{ … }
static void virtio_config_core_enable(struct virtio_device *dev)
{ … }
void virtio_add_status(struct virtio_device *dev, unsigned int status)
{ … }
EXPORT_SYMBOL_GPL(…);
static int virtio_features_ok(struct virtio_device *dev)
{ … }
void virtio_reset_device(struct virtio_device *dev)
{ … }
EXPORT_SYMBOL_GPL(…);
static int virtio_dev_probe(struct device *_d)
{ … }
static void virtio_dev_remove(struct device *_d)
{ … }
static const struct bus_type virtio_bus = …;
int __register_virtio_driver(struct virtio_driver *driver, struct module *owner)
{ … }
EXPORT_SYMBOL_GPL(…);
void unregister_virtio_driver(struct virtio_driver *driver)
{ … }
EXPORT_SYMBOL_GPL(…);
static int virtio_device_of_init(struct virtio_device *dev)
{ … }
int register_virtio_device(struct virtio_device *dev)
{ … }
EXPORT_SYMBOL_GPL(…);
bool is_virtio_device(struct device *dev)
{ … }
EXPORT_SYMBOL_GPL(…);
void unregister_virtio_device(struct virtio_device *dev)
{ … }
EXPORT_SYMBOL_GPL(…);
#ifdef CONFIG_PM_SLEEP
int virtio_device_freeze(struct virtio_device *dev)
{ … }
EXPORT_SYMBOL_GPL(…);
int virtio_device_restore(struct virtio_device *dev)
{ … }
EXPORT_SYMBOL_GPL(…);
#endif
static int virtio_init(void)
{ … }
static void __exit virtio_exit(void)
{ … }
core_initcall(virtio_init);
module_exit(virtio_exit);
MODULE_DESCRIPTION(…) …;
MODULE_LICENSE(…) …;