Type: fix Signed-off-by: Ole Troan <ot@cisco.com> Change-Id: I8fd870e757e9243d4f0916dfbbe65495f7e1a8c6
126 lines
3.7 KiB
Plaintext
126 lines
3.7 KiB
Plaintext
option version = "1.0.0";
|
|
|
|
import "vnet/interface_types.api";
|
|
|
|
/** \brief /** \brief Set or delete an NSH header entry keyed by NSP/NSI
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param is_add - add address if non-zero, else delete
|
|
@param nsp_nsi - Key for nsh_header_t entry to map to. : 24bit NSP 8bit NSI
|
|
@param md_type - metadata type [1|2] - only MDType1 supported today
|
|
@param ver_o_c - version, O-bit and C-bit (see nsh_packet.h)
|
|
@param ttl - indicates the maximum SFF hops for an SFP
|
|
@param length - header length in n x 32bits, should be 6 for MDtype1
|
|
@param next_protocol - next protocol encapsulated behind NSH header: 1=Ethernet, 2=IP4, 3=IP6
|
|
@param c1 - 32bit Metadata type1 field (context1)
|
|
@param c2 - 32bit Metadata type1 field (context2)
|
|
@param c3 - 32bit Metadata type1 field (context3)
|
|
@param c4 - 32bit Metadata type1 field (context4)
|
|
@param tlvs - Metadata Type 2 only, Type Length Value metadata.
|
|
*/
|
|
define nsh_add_del_entry {
|
|
u32 client_index;
|
|
u32 context;
|
|
bool is_add;
|
|
u32 nsp_nsi;
|
|
u8 md_type;
|
|
u8 ver_o_c;
|
|
u8 ttl;
|
|
u8 length;
|
|
u8 next_protocol;
|
|
u32 c1;
|
|
u32 c2;
|
|
u32 c3;
|
|
u32 c4;
|
|
u8 tlv_length;
|
|
u8 tlv[248];
|
|
};
|
|
|
|
/** \brief Reply from adding NSH entry (nsh_add_del_entry)
|
|
@param context - sender context, to match reply w/ request
|
|
@param retval - 0 means all ok
|
|
*/
|
|
define nsh_add_del_entry_reply {
|
|
u32 context;
|
|
i32 retval;
|
|
u32 entry_index;
|
|
};
|
|
|
|
|
|
define nsh_entry_dump {
|
|
u32 client_index;
|
|
u32 context;
|
|
u32 entry_index;
|
|
};
|
|
|
|
define nsh_entry_details {
|
|
u32 context;
|
|
u32 entry_index;
|
|
u32 nsp_nsi;
|
|
u8 md_type;
|
|
u8 ver_o_c;
|
|
u8 ttl;
|
|
u8 length;
|
|
u8 next_protocol;
|
|
u32 c1;
|
|
u32 c2;
|
|
u32 c3;
|
|
u32 c4;
|
|
u8 tlv_length;
|
|
u8 tlv[248];
|
|
};
|
|
|
|
/** \brief Set or delete a mapping from one NSH header to another and its egress (decap to inner packet, encap NSH with outer header)
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param is_add - add address if non-zero, else delete
|
|
@param nsh_nsi - Key for nsh_header_t entry to map to. : 24bit NSP 8bit NSI
|
|
@param mapped_nsp_nsi - Key for nsh_header_t entry to map to. : 24bit NSP 8bit NSI this may be ~0
|
|
if next action is to decap to NSH next protocol
|
|
Note the following heuristic:
|
|
- if nsp_nsi == mapped_nsp_nsi then use-case is like SFC SFF
|
|
- if nsp_nsi != mapped_nsp_nsi then use-case is like SFC SF
|
|
Note: these are heuristics. Rules about NSI decrement are out of scope
|
|
@param sw_if_index - index number of outer encap for NSH egress
|
|
@param next_node - explicitly which node to send to
|
|
Note the above parameters are instantiated by "encap-gre-intf <x>" means sw_if_index x, next_node gre-input
|
|
*/
|
|
define nsh_add_del_map {
|
|
u32 client_index;
|
|
u32 context;
|
|
bool is_add;
|
|
u32 nsp_nsi;
|
|
u32 mapped_nsp_nsi;
|
|
u32 nsh_action;
|
|
vl_api_interface_index_t sw_if_index;
|
|
vl_api_interface_index_t rx_sw_if_index;
|
|
u32 next_node;
|
|
};
|
|
|
|
/** \brief Reply from adding NSH map (nsh_add_del_map)
|
|
@param context - sender context, to match reply w/ request
|
|
@param retval - 0 means all ok
|
|
*/
|
|
define nsh_add_del_map_reply {
|
|
u32 context;
|
|
i32 retval;
|
|
u32 map_index;
|
|
};
|
|
|
|
define nsh_map_dump {
|
|
u32 client_index;
|
|
u32 context;
|
|
u32 map_index;
|
|
};
|
|
|
|
define nsh_map_details {
|
|
u32 context;
|
|
u32 map_index;
|
|
u32 nsp_nsi;
|
|
u32 mapped_nsp_nsi;
|
|
u32 nsh_action;
|
|
vl_api_interface_index_t sw_if_index;
|
|
vl_api_interface_index_t rx_sw_if_index;
|
|
u32 next_node;
|
|
};
|