69 else if (src_port == stream->
src_port)
98 VLIB_NODE_STATE_DISABLED);
132 b0->
flags |= (VLIB_BUFFER_TOTAL_LENGTH_VALID | VNET_BUFFER_F_FLOW_REPORT);
163 *buffer_indexp = bi0;
177 u32 n_elts,
u32 * stream_indexp)
220 udp->
dst_port = clib_host_to_net_u16 (collector_port);
221 udp->
length = clib_host_to_net_u16 (
vec_len (rewrite) -
sizeof (*ip));
228 for (i = 0; i < n_elts; i++)
250 ip->
length = clib_host_to_net_u16 ((
u8 *) f - (
u8 *) ip);
262 u32 ip4_lookup_node_index;
271 uword *event_data = 0;
277 clib_warning (
"bogus kickoff event received, %d", event_type);
282 ip4_lookup_node_index = ip4_lookup_node->
index;
311 if (template_bi != ~0)
313 to_next[0] = template_bi;
319 nf, to_next, ip4_lookup_node_index);
332 .name =
"flow-report-process",
342 int found_index = ~0;
349 return VNET_API_ERROR_INVALID_VALUE;
350 if (si == -1 && a->
is_add == 0)
351 return VNET_API_ERROR_NO_SUCH_ENTRY;
369 if (found_index != ~0)
378 return VNET_API_ERROR_NO_SUCH_ENTRY;
381 if (found_index != ~0)
382 return VNET_API_ERROR_VALUE_EXIST;
423 case VNET_API_ERROR_NO_SUCH_ENTRY:
425 case VNET_API_ERROR_VALUE_EXIST:
427 case VNET_API_ERROR_INVALID_VALUE:
429 "for both domain_id and src_port " 430 "or already used values for both fields");
471 u32 old_domain_id,
u16 old_src_port,
472 u32 new_domain_id,
u16 new_src_port)
475 if (stream_index < 0)
480 if (old_domain_id != new_domain_id || old_src_port != new_src_port)
492 u16 collector_port = UDP_DST_PORT_ipfix;
499 u32 template_interval = 20;
506 else if (
unformat (input,
"port %u", &collector_port))
510 else if (
unformat (input,
"fib-id %u", &fib_id))
518 else if (
unformat (input,
"path-mtu %u", &path_mtu))
520 else if (
unformat (input,
"template-interval %u", &template_interval))
522 else if (
unformat (input,
"udp-checksum"))
531 if (path_mtu > 1450 )
553 "fib index %d, path MTU %u, " 554 "template resend interval %us, " 558 fib_index, path_mtu, template_interval,
559 udp_checksum ?
"enabled" :
"disabled");
570 .path =
"set ipfix exporter",
571 .short_help =
"set ipfix exporter " 572 "collector <ip4-address> [port <port>] " 573 "src <ip4-address> [fib-id <fib-id>] " 574 "[path-mtu <path-mtu>] " 575 "[template-interval <template-interval>]",
593 .path =
"ipfix flush",
594 .short_help =
"flush the current ipfix data [for make test]",
#define vec_validate(V, I)
Make sure vector is long enough for given index (no header, unspecified alignment) ...
clib_error_t * flow_report_add_del_error_to_clib_error(int error)
static f64 vlib_process_wait_for_event_or_clock(vlib_main_t *vm, f64 dt)
Suspend a cooperative multi-tasking thread Waits for an event, or for the indicated number of seconds...
vlib_node_registration_t flow_report_process_node
(constructor) VLIB_REGISTER_NODE (flow_report_process_node)
u16 udp_checksum(udp_header_t *uh, u32 udp_len, void *ih, u8 version)
vnet_main_t * vnet_get_main(void)
static u32 ipfix_e_id_length(int e, u16 id, u16 length)
static f64 vlib_time_now(vlib_main_t *vm)
static clib_error_t * ipfix_flush_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
int vnet_flow_report_add_del(flow_report_main_t *frm, vnet_flow_report_add_del_args_t *a, u16 *template_id)
#define vec_add2(V, P, N)
Add N elements to end of vector V, return pointer to new elements in P.
ip4_address_t src_address
#define vec_validate_aligned(V, I, A)
Make sure vector is long enough for given index (no header, specified alignment)
#define vec_reset_length(v)
Reset vector length to zero NULL-pointer tolerant.
ip4_address_t ipfix_collector
vlib_node_registration_t ip4_lookup_node
(constructor) VLIB_REGISTER_NODE (ip4_lookup_node)
void vnet_stream_reset(flow_report_main_t *frm, u32 stream_index)
flow_report_stream_t * streams
i16 current_data
signed offset in data[], pre_data[] that we are currently processing.
#define static_always_inline
#define VLIB_INIT_FUNCTION(x)
static uword vlib_process_get_events(vlib_main_t *vm, uword **data_vector)
Return the first event type which has occurred and a vector of per-event data of that type...
vnet_flow_rewrite_callback_t * rewrite_callback
#define vec_elt_at_index(v, i)
Get vector value at index i checking that i is in bounds.
vlib_frame_t * vlib_get_frame_to_node(vlib_main_t *vm, u32 to_node_index)
#define clib_error_return(e, args...)
#define VLIB_BUFFER_DEFAULT_FREE_LIST_BYTES
static uword flow_report_process(vlib_main_t *vm, vlib_node_runtime_t *rt, vlib_frame_t *f)
flow_report_main_t flow_report_main
ipfix_report_element_t * report_elements
uword * fib_index_by_table_id
Hash table mapping table id to fib index.
u16 current_length
Nbytes between current data and the end of this buffer.
static void vlib_process_signal_event(vlib_main_t *vm, uword node_index, uword type_opaque, uword data)
void vlib_put_frame_to_node(vlib_main_t *vm, u32 to_node_index, vlib_frame_t *f)
static void * vlib_buffer_get_current(vlib_buffer_t *b)
Get pointer to current data to process.
#define VLIB_BUFFER_DEFAULT_FREE_LIST_INDEX
static u32 version_length(u16 length)
int send_template_packet(flow_report_main_t *frm, flow_report_t *fr, u32 *buffer_indexp)
static_always_inline flow_report_stream_t * add_stream(void)
#define VLIB_REGISTER_NODE(x,...)
#define vec_free(V)
Free vector's memory (no header).
static u32 ipfix_id_count(u16 id, u16 count)
#define clib_warning(format, args...)
#define clib_memcpy(a, b, c)
static clib_error_t * set_ipfix_exporter_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
vlib_node_t * vlib_get_node_by_name(vlib_main_t *vm, u8 *name)
static_always_inline u8 stream_index_valid(u32 index)
#define VLIB_CLI_COMMAND(x,...)
u16 ip4_tcp_udp_compute_checksum(vlib_main_t *vm, vlib_buffer_t *p0, ip4_header_t *ip0)
#define vec_delete(V, N, M)
Delete N elements starting at element M.
ipfix_report_element_t * report_elements
static_always_inline void delete_stream(u32 index)
void vnet_flow_reports_reset(flow_report_main_t *frm)
static void vlib_node_set_state(vlib_main_t *vm, u32 node_index, vlib_node_state_t new_state)
Set node dispatch state.
vnet_flow_data_callback_t * flow_data_callback
static u32 ipfix_set_id_length(u16 set_id, u16 length)
u8 * vnet_flow_rewrite_generic_callback(flow_report_main_t *frm, flow_report_t *fr, ip4_address_t *collector_address, ip4_address_t *src_address, u16 collector_port, ipfix_report_element_t *report_elts, u32 n_elts, u32 *stream_indexp)
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
#define VLIB_BUFFER_TRACE_TRAJECTORY_INIT(b)
int vnet_stream_change(flow_report_main_t *frm, u32 old_domain_id, u16 old_src_port, u32 new_domain_id, u16 new_src_port)
static void * vlib_frame_vector_args(vlib_frame_t *f)
Get pointer to frame vector data.
vnet_flow_data_callback_t * flow_data_callback
static i32 find_stream(u32 domain_id, u16 src_port)
static void vlib_buffer_init_for_free_list(vlib_buffer_t *dst, vlib_buffer_free_list_t *fl)
ip4_main_t ip4_main
Global ip4 main structure.
vnet_flow_rewrite_callback_t * rewrite_callback
#define vec_foreach(var, vec)
Vector iterator.
static vlib_buffer_free_list_t * vlib_buffer_get_free_list(vlib_main_t *vm, vlib_buffer_free_list_index_t free_list_index)
#define CLIB_CACHE_LINE_BYTES
u32 flags
buffer flags: VLIB_BUFFER_FREE_LIST_INDEX_MASK: bits used to store free list index, VLIB_BUFFER_IS_TRACED: trace this buffer.
static u32 vlib_buffer_alloc(vlib_main_t *vm, u32 *buffers, u32 n_buffers)
Allocate buffers into supplied array.
void vlib_cli_output(vlib_main_t *vm, char *fmt,...)
static vlib_buffer_t * vlib_get_buffer(vlib_main_t *vm, u32 buffer_index)
Translate buffer index into buffer pointer.
static u16 ip4_header_checksum(ip4_header_t *i)
static clib_error_t * flow_report_init(vlib_main_t *vm)