2 * Copyright (c) 2017 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:
7 * http://www.apache.org/licenses/LICENSE-2.0
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.
16 option version = "1.0.0";
18 /** \brief enable/disable name resolution
20 @param client_index - opaque cookie to identify the sender
21 @param context - sender context, to match reply w/ request
22 @param is_enable - 1 = enable, 0 = disable
24 autoreply define dns_enable_disable {
30 /** \brief add or delete an upstream name server
32 @param client_index - opaque cookie to identify the sender
33 @param context - sender context, to match reply w/ request
34 @param is_ip6 - an ip6 name server
35 @param is_add - add = 1, delete = 0
36 @param server_address - server ip address
38 autoreply define dns_name_server_add_del {
43 u8 server_address[16];
46 /** \brief DNS name resolution request
48 @param client_index - opaque cookie to identify the sender
49 @param context - sender context, to match reply w/ request
50 @param name - the name to resolve
52 define dns_resolve_name {
58 /** \brief DNS name resolution reply
60 @param client_index - opaque cookie to identify the sender
61 @param context - sender context, to match reply w/ request
62 @param retval - return value, 0 => success
63 @param ip4_set - indicates that the ip4 address is valid
64 @param ip6_set - indicates that the ip6 address is valid
65 @param ip4_address - the ip4 name resolution reply
66 @param ip6_address - the ip6 name resolution reply
68 define dns_resolve_name_reply {
77 /** \brief DNS IP -> name resolution request
79 @param client_index - opaque cookie to identify the sender
80 @param context - sender context, to match reply w/ request
81 @param is_ip6 - set if the reverse-DNS request is an ip6 address
82 @param address - the address to map to a name
84 define dns_resolve_ip {
91 /** \brief DNS ip->name resolution reply
93 @param client_index - opaque cookie to identify the sender
94 @param context - sender context, to match reply w/ request
95 @param retval - return value, 0 => success
96 @param name - canonical name for the indicated IP address
98 define dns_resolve_ip_reply {