virtio - Get rid of unused flags option in virtio_alloc_virtqueues().
[dragonfly.git] / sys / dev / virtual / virtio / virtio / virtio_bus_if.m
blob3b721cd8e76eadf833c4066e727e73b912d1c5c7
1 #-
2 # Copyright (c) 2011, Bryan Venteicher <bryanv@daemoninthecloset.org>
3 # All rights reserved.
5 # Redistribution and use in source and binary forms, with or without
6 # modification, are permitted provided that the following conditions
7 # are met:
8 # 1. Redistributions of source code must retain the above copyright
9 #    notice, this list of conditions and the following disclaimer.
10 # 2. Redistributions in binary form must reproduce the above copyright
11 #    notice, this list of conditions and the following disclaimer in the
12 #    documentation and/or other materials provided with the distribution.
14 # THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15 # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16 # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17 # ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18 # FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19 # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20 # OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21 # HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23 # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24 # SUCH DAMAGE.
26 # $FreeBSD: src/sys/dev/virtio/virtio_bus_if.m,v 1.1 2011/11/18 05:43:43 grehan Exp $
28 #include <sys/bus.h>
30 INTERFACE virtio_bus;
32 HEADER {
33 struct vq_alloc_info;
36 METHOD uint64_t negotiate_features {
37         device_t        dev;
38         uint64_t        child_features;
41 METHOD int bind_intr {
42         device_t        dev;
43         uint            irq;
44         int             what;
45         driver_intr_t   handler;
46         void            *arg;
49 METHOD int unbind_intr {
50         device_t        dev;
51         int             what;
54 METHOD int with_feature {
55         device_t        dev;
56         uint64_t        feature;
59 METHOD int intr_count {
60         device_t        dev;
63 METHOD int intr_alloc {
64         device_t        dev;
65         int             *cnt;
66         int             use_config;
67         int             *cpus;
70 METHOD int intr_release {
71         device_t        dev;
74 METHOD int alloc_virtqueues {
75         device_t        dev;
76         int             nvqs;
77         struct vq_alloc_info *info;
80 METHOD int setup_intr {
81         device_t                dev;
82         uint                    irq;
83         lwkt_serialize_t        slz;
86 METHOD int teardown_intr {
87         device_t                dev;
88         uint                    irq;
91 METHOD void stop {
92         device_t                dev;
95 METHOD int reinit {
96         device_t                dev;
97         uint64_t                features;
100 METHOD void reinit_complete {
101         device_t                dev;
104 METHOD void notify_vq {
105         device_t                dev;
106         uint16_t                queue;
109 METHOD void read_device_config {
110         device_t                dev;
111         bus_size_t              offset;
112         void                    *dst;
113         int                     len;
116 METHOD void write_device_config {
117         device_t                dev;
118         bus_size_t              offset;
119         void                    *src;
120         int                     len;