1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
|
/* Define a simple enable-disable binary API to control the feature */
/** \file
This file defines the vpp control-plane API messages
used to control the flowprobe plugin
*/
option version = "2.0.0";
import "vnet/interface_types.api";
enum flowprobe_which_flags : u8
{
FLOWPROBE_WHICH_FLAG_IP4 = 0x1,
FLOWPROBE_WHICH_FLAG_L2 = 0x2,
FLOWPROBE_WHICH_FLAG_IP6 = 0x4,
};
enum flowprobe_which : u8
{
FLOWPROBE_WHICH_IP4 = 0,
FLOWPROBE_WHICH_IP6,
FLOWPROBE_WHICH_L2,
};
enum flowprobe_record_flags : u8
{
FLOWPROBE_RECORD_FLAG_L2 = 0x1,
FLOWPROBE_RECORD_FLAG_L3 = 0x2,
FLOWPROBE_RECORD_FLAG_L4 = 0x4,
};
enum flowprobe_direction : u8
{
FLOWPROBE_DIRECTION_RX = 0,
FLOWPROBE_DIRECTION_TX,
FLOWPROBE_DIRECTION_BOTH,
};
/** \brief Enable / disable per-packet IPFIX recording on an interface
@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 which - flags indicating forwarding path
@param sw_if_index - index of the interface
*/
autoreply define flowprobe_tx_interface_add_del
{
option replaced_by="flowprobe_interface_add_del";
/* Client identifier, set from api_main.my_client_index */
u32 client_index;
/* Arbitrary context, so client can match reply to request */
u32 context;
/* Enable / disable the feature */
bool is_add;
vl_api_flowprobe_which_flags_t which;
/* Interface handle */
vl_api_interface_index_t sw_if_index;
option vat_help = "<intfc> [disable]";
};
/** \brief Enable or disable IPFIX flow record generation on an interface
@param client_index - opaque cookie to identify the sender
@param context - sender context, to match reply w/ request
@param is_add - add interface if non-zero, else delete
@param which - datapath on which to record flows
@param direction - direction of recorded flows
@param sw_if_index - index of the interface
*/
autoreply define flowprobe_interface_add_del
{
option in_progress;
u32 client_index;
u32 context;
bool is_add;
vl_api_flowprobe_which_t which;
vl_api_flowprobe_direction_t direction;
vl_api_interface_index_t sw_if_index;
option vat_help = "(<intfc> | sw_if_index <if-idx>) [(ip4|ip6|l2)] [(rx|tx|both)] [disable]";
};
autoreply define flowprobe_params
{
u32 client_index;
u32 context;
vl_api_flowprobe_record_flags_t record_flags;
u32 active_timer; /* ~0 is off, 0 is default */
u32 passive_timer; /* ~0 is off, 0 is default */
option vat_help = "record <[l2] [l3] [l4]> [active <timer> passive <timer>]";
};
|