X-Git-Url: https://gerrit.fd.io/r/gitweb?p=vpp.git;a=blobdiff_plain;f=src%2Fvnet%2Ffib%2Ffib_api.c;h=d626ae24502930681141d6cba856dfbc36f02711;hp=856271f0bc6f772ce63ec6bc541b6e62e4183f1f;hb=7dd63e5cc;hpb=d3d7ef5ec828ec895c6f90090118782e497b9084 diff --git a/src/vnet/fib/fib_api.c b/src/vnet/fib/fib_api.c index 856271f0bc6..d626ae24502 100644 --- a/src/vnet/fib/fib_api.c +++ b/src/vnet/fib/fib_api.c @@ -21,6 +21,7 @@ #include #include #include +#include #include @@ -214,7 +215,7 @@ fib_api_path_decode (vl_api_fib_path_t *in, break; case FIB_API_PATH_TYPE_CLASSIFY: out->frp_flags |= FIB_ROUTE_PATH_CLASSIFY; - + if (pool_is_free_index (cm->tables, ntohl (in->nh.classify_table_index))) { return VNET_API_ERROR_NO_SUCH_TABLE; @@ -417,6 +418,10 @@ fib_api_path_encode (const fib_route_path_t * rpath, out->type = FIB_API_PATH_TYPE_BIER_IMP; out->nh.obj_id = rpath->frp_bier_imp; } + else if (rpath->frp_flags & FIB_ROUTE_PATH_INTF_RX) + { + out->type = FIB_API_PATH_TYPE_INTERFACE_RX; + } else { out->type = FIB_API_PATH_TYPE_NORMAL; @@ -532,34 +537,35 @@ format_vl_api_fib_path (u8 * s, va_list * args) return (s); } -fib_protocol_t -fib_proto_from_api_address_family (int af) +int +fib_proto_from_api_address_family (vl_api_address_family_t af, fib_protocol_t * out) { - switch (clib_net_to_host_u32 (af)) + switch (af) { case ADDRESS_IP4: - return (FIB_PROTOCOL_IP4); + *out = (FIB_PROTOCOL_IP4); + return (0); case ADDRESS_IP6: - return (FIB_PROTOCOL_IP6); + *out = (FIB_PROTOCOL_IP6); + return (0); } - ASSERT(0); - return (FIB_PROTOCOL_IP4); + return (VNET_API_ERROR_INVALID_ADDRESS_FAMILY); } -int +vl_api_address_family_t fib_proto_to_api_address_family (fib_protocol_t fproto) { switch (fproto) { case FIB_PROTOCOL_IP4: - return (clib_net_to_host_u32 (ADDRESS_IP4)); + return (ADDRESS_IP4); case FIB_PROTOCOL_IP6: - return (clib_net_to_host_u32 (ADDRESS_IP6)); + return (ADDRESS_IP6); default: break; } ASSERT(0); - return (clib_net_to_host_u32 (ADDRESS_IP4)); + return (ADDRESS_IP4); }