24 lacp_pdu_t *lacpdu = (lacp_pdu_t *) mif->
last_rx_pkt;
27 return LACP_ERROR_UNSUPPORTED;
33 if ((lacpdu->actor.tlv_length != sizeof (lacp_actor_partner_t)) ||
34 (lacpdu->partner.tlv_length !=
sizeof (lacp_actor_partner_t)) ||
35 (lacpdu->collector.tlv_length !=
sizeof (lacp_collector_t)) ||
36 (lacpdu->terminator.tlv_length != 0))
37 return (LACP_ERROR_BAD_TLV);
40 LACP_RX_EVENT_PDU_RECEIVED, &mif->
rx_state);
42 return LACP_ERROR_NONE;
50 marker->marker_info = pkt->marker_info;
51 marker->marker_info.tlv_type = MARKER_RESPONSE_INFORMATION;
57 marker->marker_info.tlv_type = MARKER_INFORMATION;
58 marker->marker_info.requester_port = mif->
actor.port_number;
60 marker->marker_info.requester_transaction_id = mif->
marker_tx_id;
69 ethernet_marker_pdu_t *h0;
124 if ((marker->marker_info.tlv_length != sizeof (marker_information_t)) ||
125 (marker->terminator.tlv_length != 0))
126 return (LACP_ERROR_BAD_TLV);
130 return LACP_ERROR_NONE;
143 marker_pdu_t *marker;
144 uword last_packet_signature;
149 if ((mif == 0) || (mif->
mode != BOND_MODE_LACP))
151 return LACP_ERROR_DISABLED;
165 if (nbytes <
sizeof (lacp_pdu_t))
168 return LACP_ERROR_TOO_SMALL;
197 if (nbytes <
sizeof (lacp_pdu_t))
200 return LACP_ERROR_TOO_SMALL;
203 last_packet_signature =
211 e = LACP_ERROR_CACHE_HIT;
247 .runs_after =
VLIB_INITS(
"lacp_periodic_init"),
271 if (t->
len >= sizeof (lacp_pdu_t))
273 switch (lacpdu->subtype)
277 s =
format (s,
" Markerv1\n");
279 s =
format (s,
" Subtype %u, Version %u\n", marker->subtype,
280 marker->version_number);
281 s =
format (s,
" Marker Information TLV: type %u\n",
282 marker->marker_info.tlv_type);
283 s =
format (s,
" Marker Information TLV: length %u\n",
284 marker->marker_info.tlv_length);
285 s =
format (s,
" Requester port: %u\n",
286 ntohs (marker->marker_info.requester_port));
288 marker->marker_info.requester_system);
289 s =
format (s,
" Requester transaction ID: %u\n",
290 ntohl (marker->marker_info.requester_transaction_id));
295 s =
format (s,
" LACPv1\n");
297 s =
format (s,
" Subtype %u, Version %u\n", lacpdu->subtype,
298 lacpdu->version_number);
299 s =
format (s,
" Actor Information TLV: length %u\n",
300 lacpdu->actor.tlv_length);
302 lacpdu->actor.port_info.system);
303 s =
format (s,
" System priority %u\n",
304 ntohs (lacpdu->actor.port_info.system_priority));
305 s =
format (s,
" Key %u\n",
ntohs (lacpdu->actor.port_info.key));
306 s =
format (s,
" Port priority %u\n",
307 ntohs (lacpdu->actor.port_info.port_priority));
308 s =
format (s,
" Port number %u\n",
309 ntohs (lacpdu->actor.port_info.port_number));
310 s =
format (s,
" State 0x%x\n", lacpdu->actor.port_info.state);
312 while (state_entry->
str)
314 if (lacpdu->actor.port_info.state & (1 << state_entry->
bit))
315 s =
format (s,
" %s (%d)\n", state_entry->
str,
320 s =
format (s,
" Partner Information TLV: length %u\n",
321 lacpdu->partner.tlv_length);
323 lacpdu->partner.port_info.system);
324 s =
format (s,
" System priority %u\n",
325 ntohs (lacpdu->partner.port_info.system_priority));
327 format (s,
" Key %u\n",
ntohs (lacpdu->partner.port_info.key));
329 format (s,
" Port priority %u\n",
330 ntohs (lacpdu->partner.port_info.port_priority));
332 format (s,
" Port number %u\n",
333 ntohs (lacpdu->partner.port_info.port_number));
334 s =
format (s,
" State 0x%x\n", lacpdu->partner.port_info.state);
336 while (state_entry->
str)
338 if (lacpdu->partner.port_info.state & (1 << state_entry->
bit))
339 s =
format (s,
" %s (%d)\n", state_entry->
str,
350 if (t->
len > sizeof (lacp_pdu_t))
351 len =
sizeof (lacp_pdu_t);
355 for (i = 0; i <
len; i++)
361 s =
format (s,
" 0x%04x: ", i);
365 s =
format (s,
"%02x", p[i]);
#define vec_validate(V, I)
Make sure vector is long enough for given index (no header, unspecified alignment) ...
u64 marker_bad_pdu_received
vnet_main_t * vnet_get_main(void)
static vnet_hw_interface_t * vnet_get_sup_hw_interface(vnet_main_t *vnm, u32 sw_if_index)
i16 current_data
signed offset in data[], pre_data[] that we are currently processing.
static f64 vlib_time_now(vlib_main_t *vm)
static bond_if_t * bond_get_bond_if_by_dev_instance(u32 dev_instance)
u16 current_length
Nbytes between current data and the end of this buffer.
static uword vlib_buffer_length_in_chain(vlib_main_t *vm, vlib_buffer_t *b)
Get length in bytes of the buffer chain.
format_function_t format_vnet_sw_if_index_name
#define clib_memcpy(d, s, n)
u8 * format_ethernet_address(u8 *s, va_list *args)
void * vlib_packet_template_get_packet(vlib_main_t *vm, vlib_packet_template_t *t, u32 *bi_result)
#define VLIB_INIT_FUNCTION(x)
f64 last_lacpdu_recd_time
vlib_frame_t * vlib_get_frame_to_node(vlib_main_t *vm, u32 to_node_index)
void vlib_put_frame_to_node(vlib_main_t *vm, u32 to_node_index, vlib_frame_t *f)
#define MARKER_PROTOCOL_VERSION
u8 last_packet_signature_valid
static uword vlib_buffer_contents(vlib_main_t *vm, u32 buffer_index, u8 *contents)
Copy buffer contents to memory.
sll srl srl sll sra u16x4 i
static void lacp_start_current_while_timer(vlib_main_t *vm, member_if_t *mif, u8 expiration)
uword last_packet_signature
f64 last_marker_pdu_sent_time
vlib_main_t vlib_node_runtime_t * node
static member_if_t * bond_get_member_by_sw_if_index(u32 sw_if_index)
uword hash_memory(void *p, word n_bytes, uword state)
vlib_packet_template_t marker_packet_templates[MARKER_N_PACKET_TEMPLATES]
lacp_machine_t lacp_rx_machine
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
VLIB buffer representation.
static void * vlib_frame_vector_args(vlib_frame_t *f)
Get pointer to frame vector data.
#define LACP_STEADY_STATE
int lacp_machine_dispatch(lacp_machine_t *machine, vlib_main_t *vm, member_if_t *mif, int event, int *state)
f64 last_marker_pdu_recd_time
u32 total_length_not_including_first_buffer
Only valid for first buffer in chain.
lacp_state_struct lacp_state_array[]
static vlib_buffer_t * vlib_get_buffer(vlib_main_t *vm, u32 buffer_index)
Translate buffer index into buffer pointer.
vl_api_interface_index_t sw_if_index
void stat_segment_set_state_counter(u32 index, u64 value)
#define LACP_ACTOR_LACP_VERSION