aboutsummaryrefslogtreecommitdiffstats
path: root/src/plugins/acl/manual_fns.h
diff options
context:
space:
mode:
authorOle Troan <ot@cisco.com>2020-11-18 19:17:48 +0100
committerNeale Ranns <nranns@cisco.com>2020-11-25 08:25:50 +0000
commitdf87f8092f5b6b54eef0d5acf3c27c2e398a401a (patch)
tree762a3da5d6757c6f475ffce6dcfae2b65b2c3850 /src/plugins/acl/manual_fns.h
parentc95cfa218b214bd1c67dc165b4ed1fb7a224bdad (diff)
api: vat2 and json autogeneration for api messages
VAT2: A completely auto-generated replacement of VAT. Reads input message in JSON from stdin and outputs received messages in JSON. A VAT2 plugin is automatically built for a .api file. There no longer a need for a separate _test.c. Example: vat2 show_version {} { "_msgname": "show_version_reply", "retval": 0, "program": "vpe", "version": "21.01-rc0~411-gf6eb348a6", "build_date": "2020-11-19T09:49:25", "build_directory": "/vpp/autogen3" } vat2 sw_interface_dump '{"sw_if_index": -1, "name_filter_valid": 0, "name_filter": ""}' [{ "_msgname": "sw_interface_details", "sw_if_index": 0, "sup_sw_if_index": 0, "l2_address": "00:00:00:00:00:00", "flags": "Invalid ENUM", "type": "IF_API_TYPE_HARDWARE", "link_duplex": "LINK_DUPLEX_API_UNKNOWN", "link_speed": 0, "link_mtu": 0, "mtu": [0, 0, 0, 0], "sub_id": 0, "sub_number_of_tags": 0, "sub_outer_vlan_id": 0, "sub_inner_vlan_id": 0, "sub_if_flags": "Invalid ENUM", "vtr_op": 0, "vtr_push_dot1q": 0, "vtr_tag1": 0, "vtr_tag2": 0, "outer_tag": 0, "b_dmac": "00:00:00:00:00:00", "b_smac": "00:00:00:00:00:00", "b_vlanid": 0, "i_sid": 0, "interface_name": "local0", "interface_dev_type": "local", "tag": "" }] This is the first phase and vat2 is not integrated in packaging yet. Type: feature Signed-off-by: Ole Troan <ot@cisco.com> Change-Id: Ib45ddeafb180ea7da8c5dc274a9274d7a4edc876 Signed-off-by: Ole Troan <ot@cisco.com>
Diffstat (limited to 'src/plugins/acl/manual_fns.h')
-rw-r--r--src/plugins/acl/manual_fns.h433
1 files changed, 0 insertions, 433 deletions
diff --git a/src/plugins/acl/manual_fns.h b/src/plugins/acl/manual_fns.h
deleted file mode 100644
index f2585a9985d..00000000000
--- a/src/plugins/acl/manual_fns.h
+++ /dev/null
@@ -1,433 +0,0 @@
-/*
- * Copyright (c) 2016 Cisco and/or its affiliates.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at:
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-#ifndef included_manual_fns_h
-#define included_manual_fns_h
-
-#include <vnet/ip/format.h>
-#include <vnet/ethernet/ethernet.h>
-#include <vnet/ip/ip_types_api.h>
-
-#define vl_endianfun /* define message structures */
-#include <acl/acl_types.api.h>
-#undef vl_endianfun
-
-/* Macro to finish up custom dump fns */
-#define PRINT_S \
- vec_add1 (s, 0); \
- vl_print (handle, (char *)s); \
- vec_free (s);
-
-static inline void
-vl_api_acl_rule_t_array_endian(vl_api_acl_rule_t *rules, u32 count)
-{
- u32 i;
- for(i=0; i<count; i++) {
- vl_api_acl_rule_t_endian (&rules[i]);
- }
-}
-
-static inline void
-vl_api_macip_acl_rule_t_array_endian(vl_api_macip_acl_rule_t *rules, u32 count)
-{
- u32 i;
- for(i=0; i<count; i++) {
- vl_api_macip_acl_rule_t_endian (&rules[i]);
- }
-}
-
-static inline void
-vl_api_acl_details_t_endian (vl_api_acl_details_t * a)
-{
- a->_vl_msg_id = clib_net_to_host_u16 (a->_vl_msg_id);
- a->context = clib_net_to_host_u32 (a->context);
- a->acl_index = clib_net_to_host_u32 (a->acl_index);
- /* a->tag[0..63] = a->tag[0..63] (no-op) */
- a->count = clib_net_to_host_u32 (a->count);
- vl_api_acl_rule_t_array_endian (a->r, a->count);
-}
-
-static inline void
-vl_api_macip_acl_details_t_endian (vl_api_macip_acl_details_t * a)
-{
- a->_vl_msg_id = clib_net_to_host_u16 (a->_vl_msg_id);
- a->context = clib_net_to_host_u32 (a->context);
- a->acl_index = clib_net_to_host_u32 (a->acl_index);
- /* a->tag[0..63] = a->tag[0..63] (no-op) */
- a->count = clib_net_to_host_u32 (a->count);
- vl_api_macip_acl_rule_t_array_endian (a->r, a->count);
-}
-
-
-static inline void
-vl_api_acl_add_replace_t_endian (vl_api_acl_add_replace_t * a)
-{
- a->_vl_msg_id = clib_net_to_host_u16 (a->_vl_msg_id);
- a->client_index = clib_net_to_host_u32 (a->client_index);
- a->context = clib_net_to_host_u32 (a->context);
- a->acl_index = clib_net_to_host_u32 (a->acl_index);
- /* a->tag[0..63] = a->tag[0..63] (no-op) */
- a->count = clib_net_to_host_u32 (a->count);
- vl_api_acl_rule_t_array_endian (a->r, a->count);
-}
-
-static inline void
-vl_api_macip_acl_add_t_endian (vl_api_macip_acl_add_t * a)
-{
- a->_vl_msg_id = clib_net_to_host_u16 (a->_vl_msg_id);
- a->client_index = clib_net_to_host_u32 (a->client_index);
- a->context = clib_net_to_host_u32 (a->context);
- /* a->tag[0..63] = a->tag[0..63] (no-op) */
- a->count = clib_net_to_host_u32 (a->count);
- vl_api_macip_acl_rule_t_array_endian (a->r, a->count);
-}
-
-static inline void
-vl_api_macip_acl_add_replace_t_endian (vl_api_macip_acl_add_replace_t * a)
-{
- a->_vl_msg_id = clib_net_to_host_u16 (a->_vl_msg_id);
- a->client_index = clib_net_to_host_u32 (a->client_index);
- a->context = clib_net_to_host_u32 (a->context);
- a->acl_index = clib_net_to_host_u32 (a->acl_index);
- /* a->tag[0..63] = a->tag[0..63] (no-op) */
- a->count = clib_net_to_host_u32 (a->count);
- vl_api_macip_acl_rule_t_array_endian (a->r, a->count);
-}
-
-static inline u8 *
-format_acl_action(u8 *s, u8 action)
-{
- switch(action) {
- case 0:
- s = format (s, "deny");
- break;
- case 1:
- s = format (s, "permit");
- break;
- case 2:
- s = format (s, "permit+reflect");
- break;
- default:
- s = format (s, "action %d", action);
- }
- return(s);
-}
-
-static inline void *
-vl_api_acl_rule_t_print (vl_api_acl_rule_t * a, void *handle)
-{
- u8 *s;
- ip_prefix_t src, dst;
-
- ip_prefix_decode2 (&a->src_prefix, &src);
- ip_prefix_decode2 (&a->dst_prefix, &dst);
-
- s = format (0, " %s ", a->src_prefix.address.af ? "ipv6" : "ipv4");
- s = format_acl_action (s, a->is_permit);
- s = format (s, " \\\n");
-
- s = format (s, " src %U dst %U \\\n",
- format_ip_prefix, &src,
- format_ip_prefix, &dst);
- s = format (s, " proto %d \\\n", a->proto);
- s = format (s, " sport %d-%d dport %d-%d \\\n",
- clib_net_to_host_u16 (a->srcport_or_icmptype_first),
- clib_net_to_host_u16 (a->srcport_or_icmptype_last),
- clib_net_to_host_u16 (a->dstport_or_icmpcode_first),
- clib_net_to_host_u16 (a->dstport_or_icmpcode_last));
-
- s = format (s, " tcpflags %u mask %u, \\",
- a->tcp_flags_value, a->tcp_flags_mask);
- PRINT_S;
- return handle;
-}
-
-static inline void *
-vl_api_macip_acl_rule_t_print (vl_api_macip_acl_rule_t * a, void *handle)
-{
- u8 *s;
- ip_prefix_t src;
-
- ip_prefix_decode2 (&a->src_prefix, &src);
-
- s = format (0, " %s %s \\\n", a->src_prefix.address.af ? "ipv6" : "ipv4",
- a->is_permit ? "permit" : "deny");
-
- s = format (s, " src mac %U mask %U \\\n",
- format_ethernet_address, a->src_mac,
- format_ethernet_address, a->src_mac_mask);
-
- s = format (s, " src ip %U, \\",
- format_ip_prefix, &src);
-
- PRINT_S;
- return handle;
-}
-
-static inline void *
-vl_api_acl_add_replace_t_print (vl_api_acl_add_replace_t * a, void *handle)
-{
- u8 *s = 0;
- int i;
- u32 acl_index = clib_net_to_host_u32 (a->acl_index);
- u32 count = clib_net_to_host_u32 (a->count);
- if (count > 0x100000)
- {
- s = format (s, "WARN: acl_add_replace count endianness wrong? Fixup to avoid long loop.\n");
- count = a->count;
- }
-
- s = format (s, "SCRIPT: acl_add_replace %d count %d ",
- acl_index, count);
-
- if (a->tag[0])
- s = format (s, "tag %s ", a->tag);
-
- s = format(s, "\\\n");
- PRINT_S;
-
- for (i = 0; i < count; i++)
- vl_api_acl_rule_t_print (&a->r[i], handle);
-
- s = format(s, "\n");
- PRINT_S;
- return handle;
-}
-
-static inline void *
-vl_api_acl_del_t_print (vl_api_macip_acl_del_t * a, void *handle)
-{
- u8 *s;
-
- s = format (0, "SCRIPT: acl_del %d ",
- clib_host_to_net_u32 (a->acl_index));
-
- PRINT_S;
- return handle;
-}
-
-
-static inline void *
-vl_api_acl_details_t_print (vl_api_acl_details_t * a, void *handle)
-{
- u8 *s = 0;
- int i;
- u32 acl_index = clib_net_to_host_u32 (a->acl_index);
- u32 count = clib_net_to_host_u32 (a->count);
- if (count > 0x100000)
- {
- s = format (s, "WARN: acl_details count endianness wrong? Fixup to avoid long loop.\n");
- count = a->count;
- }
-
- s = format (s, "acl_details index %d count %d ",
- acl_index, count);
-
- if (a->tag[0])
- s = format (s, "tag %s ", a->tag);
-
- s = format(s, "\n");
- PRINT_S;
-
- for (i = 0; i < count; i++)
- vl_api_acl_rule_t_print (&a->r[i], handle);
-
- return handle;
-}
-
-static inline void *
-vl_api_macip_acl_details_t_print (vl_api_macip_acl_details_t * a,
- void *handle)
-{
- u8 *s = 0;
- int i;
- u32 acl_index = clib_net_to_host_u32 (a->acl_index);
- u32 count = clib_net_to_host_u32 (a->count);
- if (count > 0x100000)
- {
- s = format (s, "WARN: macip_acl_details count endianness wrong? Fixup to avoid long loop.\n");
- count = a->count;
- }
-
- s = format (s, "macip_acl_details index %d count %d ",
- acl_index, count);
-
- if (a->tag[0])
- s = format (s, "tag %s ", a->tag);
-
- s = format(s, "\n");
- PRINT_S;
-
- for (i = 0; i < count; i++)
- vl_api_macip_acl_rule_t_print (&a->r[i], handle);
-
- return handle;
-}
-
-static inline void *
-vl_api_macip_acl_add_t_print (vl_api_macip_acl_add_t * a, void *handle)
-{
- u8 *s = 0;
- int i;
- u32 count = clib_net_to_host_u32 (a->count);
- if (count > 0x100000)
- {
- s = format (s, "WARN: macip_acl_add count endianness wrong? Fixup to avoid long loop.\n");
- count = a->count;
- }
-
- s = format (s, "SCRIPT: macip_acl_add ");
- if (a->tag[0])
- s = format (s, "tag %s ", a->tag);
-
- s = format (s, "count %d \\\n", count);
-
- PRINT_S;
-
- for (i = 0; i < count; i++)
- vl_api_macip_acl_rule_t_print (&a->r[i], handle);
-
- s = format (0, "\n");
- PRINT_S;
-
- return handle;
-}
-
-static inline void *
-vl_api_macip_acl_add_replace_t_print (vl_api_macip_acl_add_replace_t * a, void *handle)
-{
- u8 *s = 0;
- int i;
- u32 acl_index = clib_net_to_host_u32 (a->acl_index);
- u32 count = clib_net_to_host_u32 (a->count);
- if (count > 0x100000)
- {
- s = format (s, "WARN: macip_acl_add_replace count endianness wrong? Fixup to avoid long loop.\n");
- count = a->count;
- }
-
- s = format (s, "SCRIPT: macip_acl_add_replace %d count %d ",
- acl_index, count);
- if (a->tag[0])
- s = format (s, "tag %s ", a->tag);
-
- s = format (s, "count %d \\\n", count);
-
- PRINT_S;
-
- for (i = 0; i < count; i++)
- vl_api_macip_acl_rule_t_print (&a->r[i], handle);
-
- s = format (0, "\n");
- PRINT_S;
-
- return handle;
-}
-
-static inline void *
-vl_api_acl_interface_set_acl_list_t_print (vl_api_acl_interface_set_acl_list_t
- * a, void *handle)
-{
- u8 *s;
- int i;
-
- s = format
- (0, "SCRIPT: acl_interface_set_acl_list sw_if_index %d count %d\n",
- clib_net_to_host_u32 (a->sw_if_index), (u32) a->count);
-
- s = format (s, " input ");
-
- for (i = 0; i < a->count; i++)
- {
- if (i == a->n_input)
- s = format (s, "output ");
- s = format (s, "%d ", clib_net_to_host_u32 (a->acls[i]));
- }
-
- PRINT_S;
- return handle;
-}
-
-static inline void *
-vl_api_acl_interface_set_etype_whitelist_t_print (vl_api_acl_interface_set_etype_whitelist_t
- * a, void *handle)
-{
- u8 *s;
- int i;
-
- s = format
- (0, "SCRIPT: acl_interface_set_etype_whitelist sw_if_index %d count %d\n",
- clib_net_to_host_u32 (a->sw_if_index), (u32) a->count);
-
- s = format (s, " input ");
-
- for (i = 0; i < a->count; i++)
- {
- if (i == a->n_input)
- s = format (s, "output ");
- s = format (s, "%x ", clib_net_to_host_u16 (a->whitelist[i]));
- }
-
- PRINT_S;
- return handle;
-}
-
-static inline void *
-vl_api_acl_interface_add_del_t_print (vl_api_acl_interface_add_del_t * a,
- void *handle)
-{
- u8 *s;
-
- s = format (0, "SCRIPT: acl_interface_add_del sw_if_index %d acl %d ",
- clib_net_to_host_u32 (a->sw_if_index),
- clib_net_to_host_u32 (a->acl_index));
- s = format (s, "%s %s",
- a->is_input ? "input" : "output", a->is_add ? "add" : "del");
-
- PRINT_S;
- return handle;
-}
-
-static inline void *vl_api_macip_acl_interface_add_del_t_print
- (vl_api_macip_acl_interface_add_del_t * a, void *handle)
-{
- u8 *s;
-
- s = format
- (0,
- "SCRIPT: macip_acl_interface_add_del sw_if_index %d acl_index %d ",
- clib_net_to_host_u32 (a->sw_if_index),
- clib_net_to_host_u32 (a->acl_index));
- s = format (s, "%s", a->is_add ? "add" : "del");
-
- PRINT_S;
- return handle;
-}
-
-
-static inline void *
-vl_api_macip_acl_del_t_print (vl_api_macip_acl_del_t * a, void *handle)
-{
- u8 *s;
-
- s = format (0, "SCRIPT: macip_acl_del %d ",
- clib_host_to_net_u32 (a->acl_index));
-
- PRINT_S;
- return handle;
-}
-
-
-#endif /* included_manual_fns_h */