23 lacp_pdu_t *lacpdu = (lacp_pdu_t *) sif->
last_rx_pkt;
26 return LACP_ERROR_UNSUPPORTED;
32 if ((lacpdu->actor.tlv_length != sizeof (lacp_actor_partner_t)) ||
33 (lacpdu->partner.tlv_length !=
sizeof (lacp_actor_partner_t)) ||
34 (lacpdu->collector.tlv_length !=
sizeof (lacp_collector_t)) ||
35 (lacpdu->terminator.tlv_length != 0))
36 return (LACP_ERROR_BAD_TLV);
39 LACP_RX_EVENT_PDU_RECEIVED, &sif->
rx_state);
41 return LACP_ERROR_NONE;
49 marker->marker_info = pkt->marker_info;
50 marker->marker_info.tlv_type = MARKER_RESPONSE_INFORMATION;
56 marker->marker_info.tlv_type = MARKER_INFORMATION;
57 marker->marker_info.requester_port = sif->
actor.port_number;
59 marker->marker_info.requester_transaction_id = sif->
marker_tx_id;
68 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;
148 if ((sif == 0) || (sif->
mode != BOND_MODE_LACP))
150 return LACP_ERROR_DISABLED;
164 if (nbytes <
sizeof (lacp_pdu_t))
167 return LACP_ERROR_TOO_SMALL;
196 if (nbytes <
sizeof (lacp_pdu_t))
199 return LACP_ERROR_TOO_SMALL;
202 last_packet_signature =
211 e = LACP_ERROR_CACHE_HIT;
264 if (t->
len >= sizeof (lacp_pdu_t))
266 switch (lacpdu->subtype)
270 s =
format (s,
" Markerv1\n");
272 s =
format (s,
" Subtype %u, Version %u\n", marker->subtype,
273 marker->version_number);
274 s =
format (s,
" Marker Information TLV: type %u\n",
275 marker->marker_info.tlv_type);
276 s =
format (s,
" Marker Information TLV: length %u\n",
277 marker->marker_info.tlv_length);
278 s =
format (s,
" Requester port: %u\n",
279 marker->marker_info.requester_port);
281 marker->marker_info.requester_system);
282 s =
format (s,
" Requester transaction ID: %u\n",
283 marker->marker_info.requester_transaction_id);
288 s =
format (s,
" LACPv1\n");
290 s =
format (s,
" Subtype %u, Version %u\n", lacpdu->subtype,
291 lacpdu->version_number);
292 s =
format (s,
" Actor Information TLV: length %u\n",
293 lacpdu->actor.tlv_length);
295 lacpdu->actor.port_info.system);
296 s =
format (s,
" System priority %u\n",
297 ntohs (lacpdu->actor.port_info.system_priority));
298 s =
format (s,
" Key %u\n", ntohs (lacpdu->actor.port_info.key));
299 s =
format (s,
" Port priority %u\n",
300 ntohs (lacpdu->actor.port_info.port_priority));
301 s =
format (s,
" Port number %u\n",
302 ntohs (lacpdu->actor.port_info.port_number));
303 s =
format (s,
" State 0x%x\n", lacpdu->actor.port_info.state);
305 while (state_entry->
str)
307 if (lacpdu->actor.port_info.state & (1 << state_entry->
bit))
308 s =
format (s,
" %s (%d)\n", state_entry->
str,
313 s =
format (s,
" Partner Information TLV: length %u\n",
314 lacpdu->partner.tlv_length);
316 lacpdu->partner.port_info.system);
317 s =
format (s,
" System priority %u\n",
318 ntohs (lacpdu->partner.port_info.system_priority));
320 format (s,
" Key %u\n", ntohs (lacpdu->partner.port_info.key));
322 format (s,
" Port priority %u\n",
323 ntohs (lacpdu->partner.port_info.port_priority));
325 format (s,
" Port number %u\n",
326 ntohs (lacpdu->partner.port_info.port_number));
327 s =
format (s,
" State 0x%x\n", lacpdu->partner.port_info.state);
329 while (state_entry->
str)
331 if (lacpdu->partner.port_info.state & (1 << state_entry->
bit))
332 s =
format (s,
" %s (%d)\n", state_entry->
str,
343 if (t->
len > sizeof (lacp_pdu_t))
344 len =
sizeof (lacp_pdu_t);
348 for (i = 0; i <
len; i++)
354 s =
format (s,
" 0x%04x: ", i);
358 s =
format (s,
"%02x", p[i]);
#define vec_validate(V, I)
Make sure vector is long enough for given index (no header, unspecified alignment) ...
u8 last_packet_signature_valid
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)
f64 last_lacpdu_recd_time
i16 current_data
signed offset in data[], pre_data[] that we are currently processing.
static f64 vlib_time_now(vlib_main_t *vm)
u16 current_length
Nbytes between current data and the end of this buffer.
lacp_state_struct lacp_state_array[]
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_marker_pdu_recd_time
vlib_frame_t * vlib_get_frame_to_node(vlib_main_t *vm, u32 to_node_index)
#define vlib_call_init_function(vm, x)
f64 last_marker_pdu_sent_time
void vlib_put_frame_to_node(vlib_main_t *vm, u32 to_node_index, vlib_frame_t *f)
#define MARKER_PROTOCOL_VERSION
static clib_error_t * lacp_periodic_init(vlib_main_t *vm)
static uword vlib_buffer_contents(vlib_main_t *vm, u32 buffer_index, u8 *contents)
Copy buffer contents to memory.
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.
static void lacp_start_current_while_timer(vlib_main_t *vm, slave_if_t *sif, u8 expiration)
#define LACP_STEADY_STATE
static slave_if_t * bond_get_slave_by_sw_if_index(u32 sw_if_index)
u32 total_length_not_including_first_buffer
Only valid for first buffer in chain.
uword last_packet_signature
static vlib_buffer_t * vlib_get_buffer(vlib_main_t *vm, u32 buffer_index)
Translate buffer index into buffer pointer.
u64 marker_bad_pdu_received
int lacp_machine_dispatch(lacp_machine_t *machine, vlib_main_t *vm, slave_if_t *sif, int event, int *state)
#define LACP_ACTOR_LACP_VERSION