devices: vhost API cleanup
[vpp.git] / src / vnet / devices / virtio / vhost_user.api
1 /*
2  * Copyright (c) 2015-2016 Cisco and/or its affiliates.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at:
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15
16 option version = "4.0.0";
17
18 import "vnet/interface_types.api";
19 import "vnet/ethernet/ethernet_types.api";
20 import "vnet/devices/virtio/virtio_types.api";
21
22 /** \brief vhost-user interface create request
23     @param client_index - opaque cookie to identify the sender
24     @param is_server - our side is socket server
25     @param sock_filename - unix socket filename, used to speak with frontend
26     @param use_custom_mac - enable or disable the use of the provided hardware address
27     @param disable_mrg_rxbuf - disable the use of merge receive buffers
28     @param disable_indirect_desc - disable the use of indirect descriptors which driver can use
29     @param enable_gso - enable gso support (default 0)
30     @param mac_address - hardware address to use if 'use_custom_mac' is set
31 */
32 define create_vhost_user_if
33 {
34   u32 client_index;
35   u32 context;
36   bool is_server;
37   string sock_filename[256];
38   bool renumber;
39   bool disable_mrg_rxbuf;
40   bool disable_indirect_desc;
41   bool enable_gso;
42   u32 custom_dev_instance;
43   bool use_custom_mac;
44   vl_api_mac_address_t mac_address;
45   string tag[64];
46 };
47
48 /** \brief vhost-user interface create response
49     @param context - sender context, to match reply w/ request
50     @param retval - return code for the request
51     @param sw_if_index - interface the operation is applied to
52 */
53 define create_vhost_user_if_reply
54 {
55   u32 context;
56   i32 retval;
57   vl_api_interface_index_t sw_if_index;
58 };
59
60 /** \brief vhost-user interface modify request
61     @param client_index - opaque cookie to identify the sender
62     @param is_server - our side is socket server
63     @param sock_filename - unix socket filename, used to speak with frontend
64     @param enable_gso - enable gso support (default 0)
65 */
66 autoreply define modify_vhost_user_if
67 {
68   u32 client_index;
69   u32 context;
70   vl_api_interface_index_t sw_if_index;
71   bool is_server;
72   string sock_filename[256];
73   bool renumber;
74   bool enable_gso;
75   u32 custom_dev_instance;
76 };
77
78 /** \brief vhost-user interface delete request
79     @param client_index - opaque cookie to identify the sender
80 */
81 autoreply define delete_vhost_user_if
82 {
83   u32 client_index;
84   u32 context;
85   vl_api_interface_index_t sw_if_index;
86 };
87
88 /** \brief Vhost-user interface details structure (fix this)
89     @param sw_if_index - index of the interface
90     @param interface_name - name of interface
91     @param virtio_net_hdr_sz - net header size
92     @param features_first_32 - interface features, first 32 bits
93     @param features_last_32 - interface features, last 32 bits
94     @param is_server - vhost-user server socket
95     @param sock_filename - socket filename
96     @param num_regions - number of used memory regions
97     @param sock_errno - socket errno
98 */
99 define sw_interface_vhost_user_details
100 {
101   u32 context;
102   vl_api_interface_index_t sw_if_index;
103   string interface_name[64];
104   u32 virtio_net_hdr_sz;
105   vl_api_virtio_net_features_first_32_t features_first_32;
106   vl_api_virtio_net_features_last_32_t features_last_32;
107   bool is_server;
108   string sock_filename[256];
109   u32 num_regions;
110   i32 sock_errno;
111 };
112
113 /** \brief Vhost-user interface dump request
114     @param sw_if_index - filter by sw_if_index UNIMPLEMENTED
115 */
116 define sw_interface_vhost_user_dump
117 {
118   u32 client_index;
119   u32 context;
120   vl_api_interface_index_t sw_if_index [default=0xffffffff];
121 };
122 /*
123  * Local Variables:
124  * eval: (c-set-style "gnu")
125  * End:
126  */