/* Hey Emacs use -*- mode: C -*- */ /* * Copyright (c) 2015-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. */ option version = "2.1.0"; import "vnet/interface_types.api"; import "vnet/ip/ip_types.api"; import "vnet/srv6/sr_types.api"; typedef srv6_sid_list { u8 num_sids; u32 weight; vl_api_ip6_address_t sids[16]; }; typedef srv6_sid_list_with_sl_index { u8 num_sids; u32 weight; u32 sl_index; vl_api_ip6_address_t sids[16]; }; /** \brief IPv6 SR LocalSID add/del request @param client_index - opaque cookie to identify the sender @param context - sender context, to match reply w/ request @param is_del Boolean of whether its a delete instruction @param localsid_addr IPv6 address of the localsid @param end_psp Boolean of whether decapsulation is allowed in this function @param behavior Type of behavior (function) for this localsid @param sw_if_index Only for L2/L3 xconnect. OIF. In VRF variant the fib_table. Default:0xffffffff @param vlan_index Only for L2 xconnect. Outgoing VLAN tag. @param fib_table FIB table in which we should install the localsid entry @param nh_addr Next Hop IPv46 address. Only for L2/L3 xconnect. */ autoreply define sr_localsid_add_del { u32 client_index; u32 context; bool is_del [default=false]; vl_api_ip6_address_t localsid; bool end_psp; vl_api_sr_behavior_t behavior; vl_api_interface_index_t sw_if_index [default=0xffffffff]; u32 vlan_index; u32 fib_table; vl_api_address_t nh_addr; }; /** \brief IPv6 SR policy add @param client_index - opaque cookie to identify the sender @param context - sender context, to match reply w/ request @param bsid is the bindingSID of the SR Policy @param weight is the weight of the sid list. optional. @param is_encap is the behavior of the SR policy. (0.SRH insert // 1.Encapsulation) @param is_spray is the type of the SR policy. (0.Default // 1.Spray) @param fib_table is the VRF where to install the FIB entry for the BSID @param sids is a srv6_sid_list object */ autoreply define sr_policy_add { u32 client_index; u32 context; vl_api_ip6_address_t bsid_addr; u32 weight; bool is_encap; bool is_spray; u32 fib_table; vl_api_srv6_sid_list_t sids; }; /** \brief IPv6 SR policy modification @param client_index - opaque cookie to identify the sender @param context - sender context, to match reply w/ request @param bsid is the bindingSID of the SR Policy @param sr_policy_index is the index of the SR policy @param fib_table is the VRF where to install the FIB entry for the BSID @param operation is the operation to perform (among the top ones) @param sl_index is the index of the Segment List to modify/delete @param weight is the weight of the sid list. optional. @param sids is a srv6_sid_list object */ autoreply define sr_policy_mod { u32 client_index; u32 context; vl_api_ip6_address_t bsid_addr; u32 sr_policy_index; u32 fib_table; vl_api_sr_policy_op_t operation; u32 sl_index; u32 weight; vl_api_srv6_sid_list_t sids; }; enum sr_policy_type : u8 { SR_API_POLICY_TYPE_DEFAULT = 0, SR_API_POLICY_TYPE_SPRAY = 1, SR_API_POLICY_TYPE_TEF = 2, }; /** \brief IPv6 SR policy add @param client_index - opaque cookie to identify the sender @param context - sender context, to match reply w/ request @param bsid is the bindingSID of the SR Policy @param weight is the weight of the sid list. optional. @param is_encap is the behavior of the SR policy. (0.SRH insert // 1.Encapsulation) @param type is the SR policy param. (0.Default // 1.Spray // 2.Tef) @param fib_table is the VRF where to install the FIB entry for the BSID @param sids is a srv6_sid_list object @param encap_src is a encaps IPv6 source addr. optional. */ autoreply define sr_policy_add_v2 { u32 client_index; u32 context; vl_api_ip6_address_t bsid_addr; u32 weight; bool is_encap; vl_api_sr_policy_type_t type [default=0x0]; u32 fib_table; vl_api_srv6_sid_list_t sids; vl_api_ip6_address_t encap_src; option status="in_progress"; }; /** \brief IPv6 SR policy modification @param client_index - opaque cookie to identify the sender @param context - sender context, to match reply w/ request @param bsid is the bindingSID of the SR Policy @param sr_policy_index is the index of the SR policy @param fib_table is the VRF where to install the FIB entry for the BSID @param operation is the operation to perform (among the top ones) @param sl_index is the index of the Segment List to modify/delete @param weight is the weight of the sid list. optional. @param sids is a srv6_sid_list object @param encap_src is a encaps IPv6 source addr. optional. */ autoreply define sr_policy_mod_v2 { u32 client_index; u32 context; vl_api_ip6_address_t bsid_addr; u32 sr_policy_index; u32 fib_table; vl_api_sr_policy_op_t operation; u32 sl_index; u32 weight; vl_api_srv6_sid_list_t sids; vl_api_ip6_address_t encap_src; option status="in_progress"; }; /** \brief IPv6 SR policy deletion @param client_index - opaque cookie to identify the sender @param context - sender context, to match reply w/ request @param bsid is the bindingSID of the SR Policy @param index is the index of the SR policy */ autoreply define sr_policy_del { u32 client_index; u32 context; vl_api_ip6_address_t bsid_addr; u32 sr_policy_index; }; /** \brief IPv6 SR Set SRv6 encapsulation source @param client_index - opaque cookie to identify the sender @param context - sender context, to match reply w/ request @param bsid is the bindingSID of the SR Policy @param index is the index of the SR policy */ autoreply define sr_set_encap_source { u32 client_index; u32 context; vl_api_ip6_address_t encaps_source; }; /** \brief IPv6 SR Set SRv6 encapsulation hop-limit @param client_index - opaque cookie to identify the sender @param context - sender context, to match reply w/ request @param hop_limit is the hop-limit value to set */ autoreply define sr_set_encap_hop_limit { u32 client_index; u32 context; u8 hop_limit; }; /** \brief IPv6 SR steering add/del @param client_index - opaque cookie to identify the sender @param context - sender context, to match reply w/ request @param is_del @param bsid is the bindingSID of the SR Policy (alt to sr_policy_index) @param sr_policy is the index of the SR Policy (alt to bsid) @param table_id is the VRF where to install the FIB entry for the BSID @param prefix is the IPv4/v6 address for L3 traffic type @param mask_width is the mask for L3 traffic type @param sw_if_index is the incoming interface for L2 traffic @param traffic_type describes the type of traffic */ autoreply define sr_steering_add_del { u32 client_index; u32 context; bool is_del [default=false]; vl_api_ip6_address_t bsid_addr; u32 sr_policy_index; u32 table_id; vl_api_prefix_t prefix; vl_api_interface_index_t sw_if_index; vl_api_sr_steer_t traffic_type; }; /** \brief Dump the list of SR LocalSIDs @param client_index - opaque cookie to identify the sender @param context - sender context, to match reply w/ request */ define sr_localsids_dump { u32 client_index; u32 context; }; define sr_localsids_details { u32 context; vl_api_ip6_address_t addr; bool end_psp; vl_api_sr_behavior_t behavior; u32 fib_table; u32 vlan_index; vl_api_address_t xconnect_nh_addr; u32 xconnect_iface_or_vrf_table; }; /** \brief Dump the list of SR LocalSIDs along with packet statistics @param client_index - opaque cookie to identify the sender @param context - sender context, to match reply w/ request */ define sr_localsids_with_packet_stats_dump { u32 client_index; u32 context; option status="in_progress"; }; define sr_localsids_with_packet_stats_details { u32 context; vl_api_ip6_address_t addr; bool end_psp; vl_api_sr_behavior_t behavior; u32 fib_table; u32 vlan_index; vl_api_address_t xconnect_nh_addr; u32 xconnect_iface_or_vrf_table; u64 good_traffic_bytes; u64 good_traffic_pkt_count; u64 bad_traffic_bytes; u64 bad_traffic_pkt_count; option status="in_progress"; }; /** \brief Dump the list of SR policies @param client_index - opaque cookie to identify the sender @param context - sender context, to match reply w/ request */ define sr_policies_dump { option deprecated; u32 client_index; u32 context; }; define sr_policies_details { u32 context; vl_api_ip6_address_t bsid; bool is_spray; bool is_encap; u32 fib_table; u8 num_sid_lists; vl_api_srv6_sid_list_t sid_lists[num_sid_lists]; }; /** \brief Dump the list of SR policies v2 @param client_index - opaque cookie to identify the sender @param context - sender context, to match reply w/ request */ define sr_policies_v2_dump { u32 client_index; u32 context; }; define sr_policies_v2_details { u32 context; vl_api_ip6_address_t bsid; vl_api_ip6_address_t encap_src; vl_api_sr_policy_type_t type; bool is_encap; u32 fib_table; u8 num_sid_lists; vl_api_srv6_sid_list_t sid_lists[num_sid_lists]; }; /** \brief Dump the list of SR policies along with actual segment list index on VPP @param client_index - opaque cookie to identify the sender @param context - sender context, to match reply w/ request */ define sr_policies_with_sl_index_dump { u32 client_index; u32 context; option status="in_progress"; }; define sr_policies_with_sl_index_details { u32 context; vl_api_ip6_address_t bsid; bool is_spray; bool is_encap; u32 fib_table; u8 num_sid_lists; vl_api_srv6_sid_list_with_sl_index_t sid_lists[num_sid_lists]; option status="in_progress"; }; /** \brief Dump the steering policies @param client_index - opaque cookie to identify the sender @param context - sender context, to match reply w/ request */ define sr_steering_pol_dump { u32 client_index; u32 context; }; define sr_steering_pol_details { u32 context; vl_api_sr_steer_t traffic_type; u32 fib_table; vl_api_prefix_t prefix; vl_api_interface_index_t sw_if_index; vl_api_ip6_address_t bsid; }; /* * fd.io coding-style-patch-verification: OFF * Local Variables: * eval: (c-set-style "gnu") * End: */