VMM: Change virtio header include paths from linux to vmm
[akaros.git] / user / vmm / include / vmm / virtio_input.h
1 #pragma once
2 /* This header is BSD licensed so anyone can use the definitions to implement
3  * compatible drivers/servers.
4  *
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.
13  * 3. Neither the name of IBM nor the names of its contributors
14  *    may be used to endorse or promote products derived from this software
15  *    without specific prior written permission.
16  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
19  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL IBM OR
20  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
23  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
24  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
25  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
26  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27  * SUCH DAMAGE. */
28
29
30 enum virtio_input_config_select {
31         VIRTIO_INPUT_CFG_UNSET      = 0x00,
32         VIRTIO_INPUT_CFG_ID_NAME    = 0x01,
33         VIRTIO_INPUT_CFG_ID_SERIAL  = 0x02,
34         VIRTIO_INPUT_CFG_ID_DEVIDS  = 0x03,
35         VIRTIO_INPUT_CFG_PROP_BITS  = 0x10,
36         VIRTIO_INPUT_CFG_EV_BITS    = 0x11,
37         VIRTIO_INPUT_CFG_ABS_INFO   = 0x12,
38 };
39
40 struct virtio_input_absinfo {
41         __u32 min;
42         __u32 max;
43         __u32 fuzz;
44         __u32 flat;
45         __u32 res;
46 };
47
48 struct virtio_input_devids {
49         __u16 bustype;
50         __u16 vendor;
51         __u16 product;
52         __u16 version;
53 };
54
55 struct virtio_input_config {
56         __u8    select;
57         __u8    subsel;
58         __u8    size;
59         __u8    reserved[5];
60         union {
61                 char string[128];
62                 __u8 bitmap[128];
63                 struct virtio_input_absinfo abs;
64                 struct virtio_input_devids ids;
65         } u;
66 };
67
68 struct virtio_input_event {
69         __le16 type;
70         __le16 code;
71         __le32 value;
72 };
73
74