.api files Type: feature Make the auto-endian nature explicit, rather than hidden in the x_api.c file. Signed-off-by: Neale Ranns <neale@graphiant.com> Change-Id: Ibe647117ceeaf6f99a38a96576a5a41a3cbb1615
466 lines
12 KiB
Plaintext
466 lines
12 KiB
Plaintext
/*
|
|
* 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.
|
|
*/
|
|
|
|
option version = "4.2.1";
|
|
|
|
import "vnet/ip/ip_types.api";
|
|
import "vnet/interface_types.api";
|
|
|
|
/** \brief Add MAP domains
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param ip6_prefix - Rule IPv6 prefix
|
|
@param ip4_prefix - Rule IPv4 prefix
|
|
@param ip6_src - MAP domain IPv6 BR address / Tunnel source
|
|
@param ea_bits_len - Embedded Address bits length
|
|
@param psid_offset - Port Set Identifier (PSID) offset
|
|
@param psid_length - PSID length
|
|
@param mtu - MTU. default 1280
|
|
@param tag - A user field stored with the MAP
|
|
*/
|
|
autoendian define map_add_domain
|
|
{
|
|
u32 client_index;
|
|
u32 context;
|
|
vl_api_ip6_prefix_t ip6_prefix;
|
|
vl_api_ip4_prefix_t ip4_prefix;
|
|
vl_api_ip6_prefix_t ip6_src;
|
|
u8 ea_bits_len;
|
|
u8 psid_offset;
|
|
u8 psid_length;
|
|
u16 mtu [default=1280];
|
|
string tag[64];
|
|
};
|
|
|
|
/** \brief Reply for MAP domain add
|
|
@param context - returned sender context, to match reply w/ request
|
|
@param index - MAP domain index
|
|
@param retval - return code
|
|
*/
|
|
define map_add_domain_reply
|
|
{
|
|
u32 context;
|
|
u32 index;
|
|
i32 retval;
|
|
};
|
|
|
|
/** \brief Delete MAP domain
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param index - MAP Domain index
|
|
*/
|
|
autoreply define map_del_domain
|
|
{
|
|
u32 client_index;
|
|
u32 context;
|
|
u32 index;
|
|
};
|
|
|
|
|
|
/** \brief Add or Delete MAP rule from a domain (Only used for shared IPv4 per subscriber)
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param index - MAP Domain index
|
|
@param is_add - If 1 add rule, if 0 delete rule
|
|
@param ip6_dst - MAP CE IPv6 address
|
|
@param psid - Rule PSID
|
|
*/
|
|
autoreply define map_add_del_rule
|
|
{
|
|
u32 client_index;
|
|
u32 context;
|
|
u32 index;
|
|
bool is_add;
|
|
vl_api_ip6_address_t ip6_dst;
|
|
u16 psid;
|
|
};
|
|
|
|
|
|
/** \brief Get list of map domains
|
|
@param client_index - opaque cookie to identify the sender
|
|
*/
|
|
service {
|
|
rpc map_domains_get returns map_domains_get_reply
|
|
stream map_domain_details;
|
|
};
|
|
|
|
define map_domains_get
|
|
{
|
|
u32 client_index;
|
|
u32 context;
|
|
u32 cursor;
|
|
};
|
|
|
|
define map_domains_get_reply
|
|
{
|
|
u32 context;
|
|
i32 retval;
|
|
u32 cursor;
|
|
};
|
|
|
|
define map_domain_dump
|
|
{
|
|
option deprecated;
|
|
u32 client_index;
|
|
u32 context;
|
|
};
|
|
|
|
/** \brief Details about a single MAP domain
|
|
@param context - returned sender context, to match reply w/ request
|
|
@param domain_index - MAP domain index
|
|
@param ip6_prefix - Rule IPv6 prefix
|
|
@param ip4_prefix - Rule IPv4 prefix
|
|
@param ip6_src - MAP domain IPv6 BR address / Tunnel source
|
|
@param ea_bits_len - Embedded Address bits length
|
|
@param psid_offset - Port Set Identifier (PSID) offset
|
|
@param psid_length - PSID length
|
|
@param flags -
|
|
@param mtu - MTU
|
|
@param tag - The user field stored with the MAP at creation time
|
|
*/
|
|
define map_domain_details
|
|
{
|
|
u32 context;
|
|
u32 domain_index;
|
|
vl_api_ip6_prefix_t ip6_prefix;
|
|
vl_api_ip4_prefix_t ip4_prefix;
|
|
vl_api_ip6_prefix_t ip6_src;
|
|
u8 ea_bits_len;
|
|
u8 psid_offset;
|
|
u8 psid_length;
|
|
u8 flags;
|
|
u16 mtu;
|
|
string tag[64];
|
|
};
|
|
|
|
define map_rule_dump
|
|
{
|
|
u32 client_index;
|
|
u32 context;
|
|
u32 domain_index;
|
|
};
|
|
|
|
define map_rule_details
|
|
{
|
|
u32 context;
|
|
vl_api_ip6_address_t ip6_dst;
|
|
u16 psid;
|
|
};
|
|
|
|
/** \brief Enable or disable a MAP interface
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param sw_if_index -
|
|
@param is_enable - 0=disable, 1=enable interface
|
|
@param is_translation - 0=encapsulation, 1=translation
|
|
*/
|
|
autoreply define map_if_enable_disable
|
|
{
|
|
u32 client_index;
|
|
u32 context;
|
|
vl_api_interface_index_t sw_if_index;
|
|
bool is_enable;
|
|
bool is_translation; /* 0 - encapsulation, 1 - translation */
|
|
};
|
|
|
|
/** \brief Request for a single block of summary stats
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
*/
|
|
define map_summary_stats
|
|
{
|
|
u32 client_index;
|
|
u32 context;
|
|
};
|
|
|
|
/** \brief Reply for map_summary_stats request
|
|
@param context - sender context, to match reply w/ request
|
|
@param retval - return code for request
|
|
@param total_bindings -
|
|
@param total_pkts -
|
|
@param total_ip4_fragments -
|
|
@param total_security_check -
|
|
*/
|
|
define map_summary_stats_reply
|
|
{
|
|
u32 context;
|
|
i32 retval;
|
|
u64 total_bindings;
|
|
u64 total_pkts[2];
|
|
u64 total_bytes[2];
|
|
u64 total_ip4_fragments;
|
|
u64 total_security_check[2];
|
|
};
|
|
|
|
|
|
/** \brief Set MAP fragmentation parameters
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param inner - 1=frag inner packet, 0=frag tunnel packets
|
|
@param ignore_df - 1=IP4 fragment despite DF bit, 0=honor DF
|
|
*/
|
|
autoreply define map_param_set_fragmentation
|
|
{
|
|
u32 client_index;
|
|
u32 context;
|
|
bool inner;
|
|
bool ignore_df;
|
|
};
|
|
|
|
|
|
/** \brief Set MAP ICMP parameters
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param icmp4_err_relay_src - IPv4 ICMP err relay src address
|
|
*/
|
|
autoreply define map_param_set_icmp
|
|
{
|
|
u32 client_index;
|
|
u32 context;
|
|
vl_api_ip4_address_t ip4_err_relay_src;
|
|
};
|
|
|
|
|
|
/** \brief Set MAP ICMP6 parameters
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param enable_unreachable - 1 = send ICMP unreachable err msgs
|
|
*/
|
|
autoreply define map_param_set_icmp6
|
|
{
|
|
u32 client_index;
|
|
u32 context;
|
|
bool enable_unreachable;
|
|
};
|
|
|
|
|
|
/** \brief Add/delete MAP pre-resolve IP addresses parameters
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param is_add - 1 = Add non-zero IP addresses, 0 = delete
|
|
@param ip4_nh_address - direct IP4 next-hop address
|
|
@param ip6_nh_address - direct IP6 next-hop address
|
|
*/
|
|
autoreply define map_param_add_del_pre_resolve
|
|
{
|
|
u32 client_index;
|
|
u32 context;
|
|
bool is_add;
|
|
vl_api_ip4_address_t ip4_nh_address;
|
|
vl_api_ip6_address_t ip6_nh_address;
|
|
};
|
|
|
|
/** \brief Set MAP security-check parameters
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param enable - 1=enable security check on first inbound packet
|
|
@param fragments - 1=enable check on (subsequent) fragments too
|
|
*/
|
|
autoreply define map_param_set_security_check
|
|
{
|
|
u32 client_index;
|
|
u32 context;
|
|
bool enable;
|
|
bool fragments;
|
|
};
|
|
|
|
|
|
/** \brief Set MAP traffic class parameters
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param copy - 1 = copy packet class/TOS field, 0 = use tc_class instead
|
|
@param tc_class - class field value when copy == 0
|
|
*/
|
|
autoreply define map_param_set_traffic_class
|
|
{
|
|
u32 client_index;
|
|
u32 context;
|
|
bool copy;
|
|
u8 tc_class;
|
|
};
|
|
|
|
|
|
/** \brief Set MAP TCP parameters
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@parma tcp_mss - TCP MSS clamping value
|
|
*/
|
|
autoreply define map_param_set_tcp
|
|
{
|
|
u32 client_index;
|
|
u32 context;
|
|
u16 tcp_mss;
|
|
};
|
|
|
|
|
|
/** \brief Request for a single block of MAP parameters
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
*/
|
|
define map_param_get
|
|
{
|
|
u32 client_index;
|
|
u32 context;
|
|
};
|
|
|
|
|
|
/** \brief Reply for map_param_get request
|
|
@param context - sender context, to match reply w/ request
|
|
@param retval - return code for request
|
|
@param inner - 1=frag inner packet, 0=frag tunnel packets, ~0=untouched
|
|
@param ignore_df - 1=IP4 fragm despite DF bit, 0=honor DF, ~0=untouched
|
|
@param icmp_ip4_err_relay_src - IPv4 ICMP err relay src address
|
|
@param icmp6_enable_unreachable - 1 = send ICMP unreachable err msgs
|
|
@param ip4_nh_address - direct IP4 next-hop address
|
|
@param ip6_nh_address - direct IP6 next-hop address
|
|
@param sec_check_enable - 1=enable security check on first inbound packet
|
|
@param sec_check_fragments - 1=enable check on (subsequent) fragments too
|
|
@param tc_copy - 1 = copy packet class/TOS field, 0 = use class instead
|
|
@param tc_class - class field value when copy == 0
|
|
*/
|
|
define map_param_get_reply
|
|
{
|
|
u32 context;
|
|
i32 retval;
|
|
u8 frag_inner;
|
|
u8 frag_ignore_df;
|
|
vl_api_ip4_address_t icmp_ip4_err_relay_src;
|
|
bool icmp6_enable_unreachable;
|
|
vl_api_ip4_address_t ip4_nh_address;
|
|
vl_api_ip6_address_t ip6_nh_address;
|
|
u16 ip4_lifetime_ms;
|
|
u16 ip4_pool_size;
|
|
u32 ip4_buffers;
|
|
f64 ip4_ht_ratio;
|
|
bool sec_check_enable;
|
|
bool sec_check_fragments;
|
|
bool tc_copy;
|
|
u8 tc_class;
|
|
};
|
|
|
|
/*
|
|
* MAP Error counters/messages
|
|
*/
|
|
counters map {
|
|
none {
|
|
severity info;
|
|
type counter64;
|
|
units "packets";
|
|
description "valid MAP packets";
|
|
};
|
|
bad_protocol {
|
|
severity error;
|
|
type counter64;
|
|
units "packets";
|
|
description "bad protocol";
|
|
};
|
|
sec_check {
|
|
severity error;
|
|
type counter64;
|
|
units "packets";
|
|
description "security check failed";
|
|
};
|
|
encap_sec_check {
|
|
severity error;
|
|
type counter64;
|
|
units "packets";
|
|
description "encap security check failed";
|
|
};
|
|
decap_sec_check {
|
|
severity error;
|
|
type counter64;
|
|
units "packets";
|
|
description "decap security check failed";
|
|
};
|
|
icmp {
|
|
severity error;
|
|
type counter64;
|
|
units "packets";
|
|
description "unable to translate ICMP";
|
|
};
|
|
icmp_relay {
|
|
severity error;
|
|
type counter64;
|
|
units "packets";
|
|
description "unable to relay ICMP";
|
|
};
|
|
unknown {
|
|
severity error;
|
|
type counter64;
|
|
units "packets";
|
|
description "unknown";
|
|
};
|
|
no_binding {
|
|
severity error;
|
|
type counter64;
|
|
units "packets";
|
|
description "no binding";
|
|
};
|
|
no_domain {
|
|
severity error;
|
|
type counter64;
|
|
units "packets";
|
|
description "no domain";
|
|
};
|
|
fragmented {
|
|
severity error;
|
|
type counter64;
|
|
units "packets";
|
|
description "packet is a fragment";
|
|
};
|
|
fragment_memory {
|
|
severity error;
|
|
type counter64;
|
|
units "packets";
|
|
description "could not cache fragment";
|
|
};
|
|
fragment_malformed {
|
|
severity error;
|
|
type counter64;
|
|
units "packets";
|
|
description "fragment has unexpected format";
|
|
};
|
|
fragment_dropped {
|
|
severity error;
|
|
type counter64;
|
|
units "packets";
|
|
description "dropped cached fragment";
|
|
};
|
|
malformed {
|
|
severity error;
|
|
type counter64;
|
|
units "packets";
|
|
description "malformed packet";
|
|
};
|
|
df_set {
|
|
severity error;
|
|
type counter64;
|
|
units "packets";
|
|
description "can't fragment, DF set";
|
|
};
|
|
time_exceeded {
|
|
severity error;
|
|
type counter64;
|
|
units "packets";
|
|
description "time exceeded";
|
|
};
|
|
};
|
|
paths {
|
|
"/err/ip4-map" "map";
|
|
"/err/ip6-map" "map";
|
|
"/err/ip4-t-map" "map";
|
|
"/err/ip6-t-map" "map";
|
|
};
|