2 * Copyright (c) 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:
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 #ifndef included_manual_fns_h
17 #define included_manual_fns_h
19 #include <vnet/ip/format.h>
20 #include <vnet/ethernet/ethernet.h>
22 /* Macro to finish up custom dump fns */
25 vl_print (handle, (char *)s); \
29 vl_api_acl_rule_t_array_endian(vl_api_acl_rule_t *rules, u32 count)
32 for(i=0; i<count; i++) {
33 vl_api_acl_rule_t_endian (&rules[i]);
38 vl_api_macip_acl_rule_t_array_endian(vl_api_macip_acl_rule_t *rules, u32 count)
41 for(i=0; i<count; i++) {
42 vl_api_macip_acl_rule_t_endian (&rules[i]);
47 vl_api_acl_details_t_endian (vl_api_acl_details_t * a)
49 a->_vl_msg_id = clib_net_to_host_u16 (a->_vl_msg_id);
50 a->context = clib_net_to_host_u32 (a->context);
51 a->acl_index = clib_net_to_host_u32 (a->acl_index);
52 /* a->tag[0..63] = a->tag[0..63] (no-op) */
53 a->count = clib_net_to_host_u32 (a->count);
54 vl_api_acl_rule_t_array_endian (a->r, a->count);
58 vl_api_macip_acl_details_t_endian (vl_api_macip_acl_details_t * a)
60 a->_vl_msg_id = clib_net_to_host_u16 (a->_vl_msg_id);
61 a->context = clib_net_to_host_u32 (a->context);
62 a->acl_index = clib_net_to_host_u32 (a->acl_index);
63 /* a->tag[0..63] = a->tag[0..63] (no-op) */
64 a->count = clib_net_to_host_u32 (a->count);
65 vl_api_macip_acl_rule_t_array_endian (a->r, a->count);
70 vl_api_acl_add_replace_t_endian (vl_api_acl_add_replace_t * a)
72 a->_vl_msg_id = clib_net_to_host_u16 (a->_vl_msg_id);
73 a->client_index = clib_net_to_host_u32 (a->client_index);
74 a->context = clib_net_to_host_u32 (a->context);
75 a->acl_index = clib_net_to_host_u32 (a->acl_index);
76 /* a->tag[0..63] = a->tag[0..63] (no-op) */
77 a->count = clib_net_to_host_u32 (a->count);
78 vl_api_acl_rule_t_array_endian (a->r, a->count);
82 vl_api_macip_acl_add_t_endian (vl_api_macip_acl_add_t * a)
84 a->_vl_msg_id = clib_net_to_host_u16 (a->_vl_msg_id);
85 a->client_index = clib_net_to_host_u32 (a->client_index);
86 a->context = clib_net_to_host_u32 (a->context);
87 /* a->tag[0..63] = a->tag[0..63] (no-op) */
88 a->count = clib_net_to_host_u32 (a->count);
89 vl_api_macip_acl_rule_t_array_endian (a->r, a->count);
93 vl_api_macip_acl_add_replace_t_endian (vl_api_macip_acl_add_replace_t * a)
95 a->_vl_msg_id = clib_net_to_host_u16 (a->_vl_msg_id);
96 a->client_index = clib_net_to_host_u32 (a->client_index);
97 a->context = clib_net_to_host_u32 (a->context);
98 a->acl_index = clib_net_to_host_u32 (a->acl_index);
99 /* a->tag[0..63] = a->tag[0..63] (no-op) */
100 a->count = clib_net_to_host_u32 (a->count);
101 vl_api_macip_acl_rule_t_array_endian (a->r, a->count);
105 format_acl_action(u8 *s, u8 action)
109 s = format (s, "deny");
112 s = format (s, "permit");
115 s = format (s, "permit+reflect");
118 s = format (s, "action %d", action);
124 vl_api_acl_rule_t_print (vl_api_acl_rule_t * a, void *handle)
128 s = format (0, " %s ", a->is_ipv6 ? "ipv6" : "ipv4");
129 s = format_acl_action (s, a->is_permit);
130 s = format (s, " \\\n");
133 s = format (s, " src %U/%d dst %U/%d \\\n",
134 format_ip6_address, a->src_ip_addr, a->src_ip_prefix_len,
135 format_ip6_address, a->dst_ip_addr, a->dst_ip_prefix_len);
137 s = format (s, " src %U/%d dst %U/%d \\\n",
138 format_ip4_address, a->src_ip_addr, a->src_ip_prefix_len,
139 format_ip4_address, a->dst_ip_addr, a->dst_ip_prefix_len);
140 s = format (s, " proto %d \\\n", a->proto);
141 s = format (s, " sport %d-%d dport %d-%d \\\n",
142 clib_net_to_host_u16 (a->srcport_or_icmptype_first),
143 clib_net_to_host_u16 (a->srcport_or_icmptype_last),
144 clib_net_to_host_u16 (a->dstport_or_icmpcode_first),
145 clib_net_to_host_u16 (a->dstport_or_icmpcode_last));
147 s = format (s, " tcpflags %u mask %u, \\",
148 a->tcp_flags_value, a->tcp_flags_mask);
156 vl_api_macip_acl_rule_t_print (vl_api_macip_acl_rule_t * a, void *handle)
160 s = format (0, " %s %s \\\n", a->is_ipv6 ? "ipv6" : "ipv4",
161 a->is_permit ? "permit" : "deny");
163 s = format (s, " src mac %U mask %U \\\n",
164 format_ethernet_address, a->src_mac,
165 format_ethernet_address, a->src_mac_mask);
168 s = format (s, " src ip %U/%d, \\",
169 format_ip6_address, a->src_ip_addr, a->src_ip_prefix_len);
171 s = format (s, " src ip %U/%d, \\",
172 format_ip4_address, a->src_ip_addr, a->src_ip_prefix_len);
179 vl_api_acl_add_replace_t_print (vl_api_acl_add_replace_t * a, void *handle)
183 u32 acl_index = clib_net_to_host_u32 (a->acl_index);
184 u32 count = clib_net_to_host_u32 (a->count);
185 if (count > 0x100000)
187 s = format (s, "WARN: acl_add_replace count endianness wrong? Fixup to avoid long loop.\n");
191 s = format (s, "SCRIPT: acl_add_replace %d count %d ",
195 s = format (s, "tag %s ", a->tag);
197 s = format(s, "\\\n");
200 for (i = 0; i < count; i++)
201 vl_api_acl_rule_t_print (&a->r[i], handle);
209 vl_api_acl_del_t_print (vl_api_macip_acl_del_t * a, void *handle)
213 s = format (0, "SCRIPT: acl_del %d ",
214 clib_host_to_net_u32 (a->acl_index));
222 vl_api_acl_details_t_print (vl_api_acl_details_t * a, void *handle)
226 u32 acl_index = clib_net_to_host_u32 (a->acl_index);
227 u32 count = clib_net_to_host_u32 (a->count);
228 if (count > 0x100000)
230 s = format (s, "WARN: acl_details count endianness wrong? Fixup to avoid long loop.\n");
234 s = format (s, "acl_details index %d count %d ",
238 s = format (s, "tag %s ", a->tag);
243 for (i = 0; i < count; i++)
244 vl_api_acl_rule_t_print (&a->r[i], handle);
250 vl_api_macip_acl_details_t_print (vl_api_macip_acl_details_t * a,
255 u32 acl_index = clib_net_to_host_u32 (a->acl_index);
256 u32 count = clib_net_to_host_u32 (a->count);
257 if (count > 0x100000)
259 s = format (s, "WARN: macip_acl_details count endianness wrong? Fixup to avoid long loop.\n");
263 s = format (s, "macip_acl_details index %d count %d ",
267 s = format (s, "tag %s ", a->tag);
272 for (i = 0; i < count; i++)
273 vl_api_macip_acl_rule_t_print (&a->r[i], handle);
279 vl_api_macip_acl_add_t_print (vl_api_macip_acl_add_t * a, void *handle)
283 u32 count = clib_net_to_host_u32 (a->count);
284 if (count > 0x100000)
286 s = format (s, "WARN: macip_acl_add count endianness wrong? Fixup to avoid long loop.\n");
290 s = format (s, "SCRIPT: macip_acl_add ");
292 s = format (s, "tag %s ", a->tag);
294 s = format (s, "count %d \\\n", count);
298 for (i = 0; i < count; i++)
299 vl_api_macip_acl_rule_t_print (&a->r[i], handle);
301 s = format (0, "\n");
308 vl_api_macip_acl_add_replace_t_print (vl_api_macip_acl_add_replace_t * a, void *handle)
312 u32 acl_index = clib_net_to_host_u32 (a->acl_index);
313 u32 count = clib_net_to_host_u32 (a->count);
314 if (count > 0x100000)
316 s = format (s, "WARN: macip_acl_add_replace count endianness wrong? Fixup to avoid long loop.\n");
320 s = format (s, "SCRIPT: macip_acl_add_replace %d count %d ",
323 s = format (s, "tag %s ", a->tag);
325 s = format (s, "count %d \\\n", count);
329 for (i = 0; i < count; i++)
330 vl_api_macip_acl_rule_t_print (&a->r[i], handle);
332 s = format (0, "\n");
339 vl_api_acl_interface_set_acl_list_t_print (vl_api_acl_interface_set_acl_list_t
346 (0, "SCRIPT: acl_interface_set_acl_list sw_if_index %d count %d\n",
347 clib_net_to_host_u32 (a->sw_if_index), (u32) a->count);
349 s = format (s, " input ");
351 for (i = 0; i < a->count; i++)
354 s = format (s, "output ");
355 s = format (s, "%d ", clib_net_to_host_u32 (a->acls[i]));
363 vl_api_acl_interface_set_etype_whitelist_t_print (vl_api_acl_interface_set_etype_whitelist_t
370 (0, "SCRIPT: acl_interface_set_etype_whitelist sw_if_index %d count %d\n",
371 clib_net_to_host_u32 (a->sw_if_index), (u32) a->count);
373 s = format (s, " input ");
375 for (i = 0; i < a->count; i++)
378 s = format (s, "output ");
379 s = format (s, "%x ", clib_net_to_host_u16 (a->whitelist[i]));
387 vl_api_acl_interface_add_del_t_print (vl_api_acl_interface_add_del_t * a,
392 s = format (0, "SCRIPT: acl_interface_add_del sw_if_index %d acl %d ",
393 clib_net_to_host_u32 (a->sw_if_index),
394 clib_net_to_host_u32 (a->acl_index));
395 s = format (s, "%s %s",
396 a->is_input ? "input" : "output", a->is_add ? "add" : "del");
402 static inline void *vl_api_macip_acl_interface_add_del_t_print
403 (vl_api_macip_acl_interface_add_del_t * a, void *handle)
409 "SCRIPT: macip_acl_interface_add_del sw_if_index %d acl_index %d ",
410 clib_net_to_host_u32 (a->sw_if_index),
411 clib_net_to_host_u32 (a->acl_index));
412 s = format (s, "%s", a->is_add ? "add" : "del");
420 vl_api_macip_acl_del_t_print (vl_api_macip_acl_del_t * a, void *handle)
424 s = format (0, "SCRIPT: macip_acl_del %d ",
425 clib_host_to_net_u32 (a->acl_index));
432 #endif /* included_manual_fns_h */