misc: ipfix-export unformat u16 collector_port fix
Use %U and unformat_udp_port instead of %u for unformat() call for u16 collector_port number in set_ipfix_exporter_command_fn() to avoid corruption of other variables which can happen if unformat() with %u is used with a 16-bit variable. This avoids crash due to corrupted fib_index value. Type: fix Signed-off-by: Elias Rudberg <elias.rudberg@bahnhof.net> Change-Id: Id54273fcc458a7f9c5aa4025aa91711f160c1c1a (cherry picked from commit 2dca180db989ea7afacdf4e70cc85e4408557382)
This commit is contained in:

committed by
Dave Wallace

parent
fa729ec6cd
commit
49ab961abf
@ -500,7 +500,8 @@ set_ipfix_exporter_command_fn (vlib_main_t * vm,
|
||||
{
|
||||
if (unformat (input, "collector %U", unformat_ip4_address, &collector))
|
||||
;
|
||||
else if (unformat (input, "port %u", &collector_port))
|
||||
else if (unformat (input, "port %U", unformat_udp_port,
|
||||
&collector_port))
|
||||
;
|
||||
else if (unformat (input, "src %U", unformat_ip4_address, &src))
|
||||
;
|
||||
|
@ -281,6 +281,7 @@ format_function_t format_udp_header;
|
||||
format_function_t format_udp_rx_trace;
|
||||
format_function_t format_udp_connection;
|
||||
unformat_function_t unformat_udp_header;
|
||||
unformat_function_t unformat_udp_port;
|
||||
|
||||
void udp_add_dst_port (udp_main_t * um, udp_dst_port_t dst_port,
|
||||
char *dst_port_name, u8 is_ip4);
|
||||
|
@ -82,6 +82,23 @@ format_udp_header (u8 * s, va_list * args)
|
||||
return s;
|
||||
}
|
||||
|
||||
uword
|
||||
unformat_udp_port (unformat_input_t * input, va_list * args)
|
||||
{
|
||||
u16 *result = va_arg (*args, u16 *);
|
||||
int port;
|
||||
|
||||
/* Numeric type. */
|
||||
if (unformat (input, "0x%x", &port) || unformat (input, "%d", &port))
|
||||
{
|
||||
if (port <= 0 || port >= (1 << 16))
|
||||
return 0;
|
||||
*result = port;
|
||||
return 1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
/*
|
||||
* fd.io coding-style-patch-verification: ON
|
||||
*
|
||||
|
Reference in New Issue
Block a user