session: define connection id length
[vpp.git] / src / vnet / session / transport_types.h
1 /*
2  * Copyright (c) 2016-2019 Cisco and/or its affiliates.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at:
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15
16 #ifndef VNET_VNET_URI_TRANSPORT_TYPES_H_
17 #define VNET_VNET_URI_TRANSPORT_TYPES_H_
18
19 #include <vnet/vnet.h>
20 #include <vnet/ip/ip.h>
21 #include <vnet/tcp/tcp_debug.h>
22
23 #define TRANSPORT_MAX_HDRS_LEN    100   /* Max number of bytes for headers */
24
25 typedef enum transport_dequeue_type_
26 {
27   TRANSPORT_TX_PEEK,            /**< reliable transport protos */
28   TRANSPORT_TX_DEQUEUE,         /**< unreliable transport protos */
29   TRANSPORT_TX_INTERNAL,        /**< apps acting as transports */
30   TRANSPORT_TX_DGRAM,           /**< datagram mode */
31   TRANSPORT_TX_N_FNS
32 } transport_tx_fn_type_t;
33
34 typedef enum transport_service_type_
35 {
36   TRANSPORT_SERVICE_VC,         /**< virtual circuit service */
37   TRANSPORT_SERVICE_CL,         /**< connectionless service */
38   TRANSPORT_SERVICE_APP,        /**< app transport service */
39   TRANSPORT_N_SERVICES
40 } transport_service_type_t;
41
42 typedef enum transport_connection_flags_
43 {
44   TRANSPORT_CONNECTION_F_IS_TX_PACED = 1 << 0,
45   TRANSPORT_CONNECTION_F_NO_LOOKUP = 1 << 1, /**< Don't register connection in lookup
46                                                   Does not apply to local apps and
47                                                   transports using the network layer (udp/tcp) */
48 } transport_connection_flags_t;
49
50 typedef struct _transport_stats
51 {
52   u64 tx_bytes;
53 } transport_stats_t;
54
55 typedef struct _spacer
56 {
57   u64 bucket;
58   u32 max_burst_size;
59   f32 tokens_per_period;
60   u64 last_update;
61 } spacer_t;
62
63 #define TRANSPORT_CONN_ID_LEN   44
64
65 /*
66  * Protocol independent transport properties associated to a session
67  */
68 typedef struct _transport_connection
69 {
70   /** Connection ID */
71   union
72   {
73     /*
74      * Network connection ID tuple
75      */
76     struct
77     {
78       ip46_address_t rmt_ip;    /**< Remote IP */
79       ip46_address_t lcl_ip;    /**< Local IP */
80       u16 rmt_port;             /**< Remote port */
81       u16 lcl_port;             /**< Local port */
82       u32 fib_index;            /**< Network namespace */
83       u8 is_ip4;                /**< Flag if IP4 connection */
84       u8 proto;                 /**< Protocol id */
85       u8 unused[2];             /**< First field after id wants to be
86                                      4-byte aligned) */
87     };
88     /*
89      * Opaque connection ID
90      */
91     u8 opaque_conn_id[TRANSPORT_CONN_ID_LEN];
92   };
93
94   u32 s_index;                  /**< Parent session index */
95   u32 c_index;                  /**< Connection index in transport pool */
96   u32 thread_index;             /**< Worker-thread index */
97   u8 flags;                     /**< Transport specific flags */
98
99   /*fib_node_index_t rmt_fei;
100      dpo_id_t rmt_dpo; */
101
102   transport_stats_t stats;      /**< Transport connection stats */
103   spacer_t pacer;               /**< Simple transport pacer */
104
105 #if TRANSPORT_DEBUG
106   elog_track_t elog_track;      /**< Event logging */
107   u32 cc_stat_tstamp;           /**< CC stats timestamp */
108 #endif
109
110   /** Macros for 'derived classes' where base is named "connection" */
111 #define c_lcl_ip connection.lcl_ip
112 #define c_rmt_ip connection.rmt_ip
113 #define c_lcl_ip4 connection.lcl_ip.ip4
114 #define c_rmt_ip4 connection.rmt_ip.ip4
115 #define c_lcl_ip6 connection.lcl_ip.ip6
116 #define c_rmt_ip6 connection.rmt_ip.ip6
117 #define c_lcl_port connection.lcl_port
118 #define c_rmt_port connection.rmt_port
119 #define c_proto connection.proto
120 #define c_fib_index connection.fib_index
121 #define c_s_index connection.s_index
122 #define c_c_index connection.c_index
123 #define c_is_ip4 connection.is_ip4
124 #define c_thread_index connection.thread_index
125 #define c_elog_track connection.elog_track
126 #define c_cc_stat_tstamp connection.cc_stat_tstamp
127 #define c_rmt_fei connection.rmt_fei
128 #define c_rmt_dpo connection.rmt_dpo
129 #define c_opaque_id connection.opaque_conn_id
130 #define c_stats connection.stats
131 #define c_pacer connection.pacer
132 #define c_flags connection.flags
133 } transport_connection_t;
134
135 STATIC_ASSERT (STRUCT_OFFSET_OF (transport_connection_t, s_index)
136                == TRANSPORT_CONN_ID_LEN, "update conn id len");
137
138 typedef enum _transport_proto
139 {
140   TRANSPORT_PROTO_TCP,
141   TRANSPORT_PROTO_UDP,
142   TRANSPORT_PROTO_SCTP,
143   TRANSPORT_PROTO_NONE,
144   TRANSPORT_PROTO_TLS,
145   TRANSPORT_PROTO_UDPC,
146   TRANSPORT_PROTO_QUIC,
147   TRANSPORT_N_PROTO
148 } transport_proto_t;
149
150 u8 *format_transport_proto (u8 * s, va_list * args);
151 u8 *format_transport_proto_short (u8 * s, va_list * args);
152 u8 *format_transport_connection (u8 * s, va_list * args);
153 u8 *format_transport_listen_connection (u8 * s, va_list * args);
154 u8 *format_transport_half_open_connection (u8 * s, va_list * args);
155
156 uword unformat_transport_proto (unformat_input_t * input, va_list * args);
157
158 #define foreach_transport_endpoint_fields                               \
159   _(ip46_address_t, ip) /**< ip address in net order */                 \
160   _(u16, port)          /**< port in net order */                       \
161   _(u8, is_ip4)         /**< set if ip4 */                              \
162   _(u32, sw_if_index)   /**< interface endpoint is associated with  */  \
163   _(u32, fib_index)     /**< fib table endpoint is associated with */   \
164
165 typedef struct transport_endpoint_
166 {
167 #define _(type, name) type name;
168   foreach_transport_endpoint_fields
169 #undef _
170 } transport_endpoint_t;
171
172 #define foreach_transport_endpoint_cfg_fields                           \
173   foreach_transport_endpoint_fields                                     \
174   _(transport_endpoint_t, peer)                                         \
175
176 typedef struct transport_endpoint_pair_
177 {
178 #define _(type, name) type name;
179   foreach_transport_endpoint_cfg_fields
180 #undef _
181 } transport_endpoint_cfg_t;
182
183 typedef clib_bihash_24_8_t transport_endpoint_table_t;
184
185 #define ENDPOINT_INVALID_INDEX ((u32)~0)
186
187 always_inline u8
188 transport_connection_fib_proto (transport_connection_t * tc)
189 {
190   return tc->is_ip4 ? FIB_PROTOCOL_IP4 : FIB_PROTOCOL_IP6;
191 }
192
193 always_inline u8
194 transport_endpoint_fib_proto (transport_endpoint_t * tep)
195 {
196   return tep->is_ip4 ? FIB_PROTOCOL_IP4 : FIB_PROTOCOL_IP6;
197 }
198
199 u8 transport_protocol_is_cl (transport_proto_t tp);
200 u8 transport_half_open_has_fifos (transport_proto_t tp);
201 transport_service_type_t transport_protocol_service_type (transport_proto_t);
202 transport_tx_fn_type_t transport_protocol_tx_fn_type (transport_proto_t tp);
203
204 #endif /* VNET_VNET_URI_TRANSPORT_TYPES_H_ */
205
206 /*
207  * fd.io coding-style-patch-verification: ON
208  *
209  * Local Variables:
210  * eval: (c-set-style "gnu")
211  * End:
212  */