X-Git-Url: https://gerrit.fd.io/r/gitweb?p=vpp.git;a=blobdiff_plain;f=src%2Fvnet%2Fip%2Fip_types_api.h;h=62764e6c96eb3e9442b01087814473160e113197;hp=be41bf59ec34ca98bf2c477540d4fb5cce597d60;hb=7dd63e5cc;hpb=86327be9751ad54cb24d16c161cacb001dc20772 diff --git a/src/vnet/ip/ip_types_api.h b/src/vnet/ip/ip_types_api.h index be41bf59ec3..62764e6c96e 100644 --- a/src/vnet/ip/ip_types_api.h +++ b/src/vnet/ip/ip_types_api.h @@ -23,28 +23,52 @@ #include #include #include +#include +#include /** - * Forward declarations so we need not #include the API definitions here + * These enum decode/encodes use 'int' as the type for the enum because + * one cannot forward declare an enum */ -struct _vl_api_address; -struct _vl_api_prefix; -struct _vl_api_mprefix; +extern int ip_address_family_decode (vl_api_address_family_t af, + ip_address_family_t * out); +extern vl_api_address_family_t ip_address_family_encode (ip_address_family_t + af); +extern int ip_proto_decode (vl_api_ip_proto_t ipp, ip_protocol_t * out); +extern vl_api_ip_proto_t ip_proto_encode (ip_protocol_t ipp); +extern ip_dscp_t ip_dscp_decode (vl_api_ip_dscp_t _dscp); +extern vl_api_ip_dscp_t ip_dscp_encode (ip_dscp_t dscp); -extern ip46_type_t ip_address_decode (const struct _vl_api_address *in, +/** + * Decode/Encode for struct/union types + */ +extern ip46_type_t ip_address_decode (const vl_api_address_t * in, ip46_address_t * out); +extern void ip_address_decode2 (const vl_api_address_t * in, + ip_address_t * out); extern void ip_address_encode (const ip46_address_t * in, - ip46_type_t type, struct _vl_api_address *out); + ip46_type_t type, vl_api_address_t * out); +extern void ip_address_encode2 (const ip_address_t * in, + vl_api_address_t * out); + +extern void ip6_address_encode (const ip6_address_t * in, + vl_api_ip6_address_t out); +extern void ip6_address_decode (const vl_api_ip6_address_t in, + ip6_address_t * out); +extern void ip4_address_encode (const ip4_address_t * in, + vl_api_ip4_address_t out); +extern void ip4_address_decode (const vl_api_ip4_address_t in, + ip4_address_t * out); -extern void ip_prefix_decode (const struct _vl_api_prefix *in, - fib_prefix_t * out); -extern void ip_prefix_encode (const fib_prefix_t * in, - struct _vl_api_prefix *out); +extern void ip_prefix_decode (const vl_api_prefix_t * in, fib_prefix_t * out); +extern void ip_prefix_encode (const fib_prefix_t * in, vl_api_prefix_t * out); +extern int ip_prefix_decode2 (const vl_api_prefix_t * in, ip_prefix_t * out); +extern void ip_prefix_encode2 (const ip_prefix_t * in, vl_api_prefix_t * out); -extern void ip_mprefix_decode (const struct _vl_api_mprefix *in, +extern void ip_mprefix_decode (const vl_api_mprefix_t * in, mfib_prefix_t * out); extern void ip_mprefix_encode (const mfib_prefix_t * in, - struct _vl_api_mprefix *out); + vl_api_mprefix_t * out); #endif