summaryrefslogtreecommitdiffstats
path: root/src/vnet/tcp/tcp.api
blob: cfef9d628481bc6ab87e5cdfa99ae0d48ce976e4 (plain)
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
/*
 * Copyright (c) 2015-2019 Cisco and/or its affiliates.
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at:
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

option version = "1.0.0";
 
/** \brief Configure TCP source addresses, for active-open TCP sessions

    TCP src/dst ports are 16 bits, with the low-order 1024 ports
    reserved. So, it's necessary to provide a considerable number of
    source IP addresses if one wishes to initiate a large number of
    connections.

    Each of those addresses needs to have a receive adjacency - 
    either a /32 or a /128 - and vpp needs to answer (proxy) arps or
    neighbor discovery requests for the addresses. 

    @param client_index - opaque cookie to identify the sender
    @param context - sender context, to match reply w/ request
    @param is_ipv6 - 1 for ipv6, 0 for ipv4
    @param vrf_id - fib table / vrf id for local adjacencies
    @param first_address - first address that TCP will use
    @param last_address - last address that TCP will use
*/
autoreply define tcp_configure_src_addresses {
    u32 client_index;
    u32 context;
    u8 is_ipv6;
    u32 vrf_id;
    u8 first_address[16];
    u8 last_address[16];
 };
 
_(0, BEGIN, "begin") \ _(1, SELECTED, "selected") \ _(2, STANDBY, "standby") \ _(3, UNSELECTED, "unselected") \ _(4, READY, "ready") \ _(5, SYNC, "sync") typedef enum { #define _(a, b, c) LACP_MUX_EVENT_##b = (a), foreach_lacp_mux_event #undef _ } lacp_mux_event_t; #define foreach_lacp_mux_sm_state \ _(0, DETACHED, "detached") \ _(1, WAITING, "waiting") \ _(2, ATTACHED, "attached") \ _(3, COLLECTING_DISTRIBUTING, "collecting distributing") typedef enum { #define _(a, b, c) LACP_MUX_STATE_##b = (a), foreach_lacp_mux_sm_state #undef _ } lacp_mux_sm_state_t; extern lacp_machine_t lacp_mux_machine; int lacp_mux_action_detached (void *p1, void *p2); int lacp_mux_action_attached (void *p1, void *p2); int lacp_mux_action_waiting (void *p1, void *p2); int lacp_mux_action_collecting_distributing (void *p1, void *p2); void lacp_mux_debug_func (slave_if_t * sif, int event, int state, lacp_fsm_state_t * transition); #define LACP_ACTION_DETACHED LACP_ACTION_ROUTINE(lacp_mux_action_detached) #define LACP_ACTION_ATTACHED LACP_ACTION_ROUTINE(lacp_mux_action_attached) #define LACP_ACTION_WAITING LACP_ACTION_ROUTINE(lacp_mux_action_waiting) #define LACP_ACTION_COLLECTING_DISTRIBUTING \ LACP_ACTION_ROUTINE(lacp_mux_action_collecting_distributing) static inline void lacp_start_wait_while_timer (vlib_main_t * vm, slave_if_t * sif, u8 expiration) { sif->wait_while_timer = vlib_time_now (vm) + expiration; } #endif /* __LACP_MUX_MACHINE_H__ */ /* * fd.io coding-style-patch-verification: ON * * Local Variables: * eval: (c-set-style "gnu") * End: */