X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvnet%2Fsession%2Ftransport_types.h;h=e065ed1fa5968787d93d8103fc3a7861827811bf;hb=d85666fdfd49a2b0a3ce5166c22c9efadf6ca239;hp=459fb0c5833ae3fe5041e75d6377bd782995a8f9;hpb=ff19e3bf4fc10d17e3bafa798e6048ad473c6bd8;p=vpp.git diff --git a/src/vnet/session/transport_types.h b/src/vnet/session/transport_types.h index 459fb0c5833..e065ed1fa59 100644 --- a/src/vnet/session/transport_types.h +++ b/src/vnet/session/transport_types.h @@ -43,9 +43,21 @@ typedef enum transport_service_type_ typedef enum transport_connection_flags_ { TRANSPORT_CONNECTION_F_IS_TX_PACED = 1 << 0, - TRANSPORT_CONNECTION_F_NO_LOOKUP = 1 << 1, /**< Don't register connection in lookup - Does not apply to local apps and - transports using the network layer (udp/tcp) */ + /** + * Don't register connection in lookup. Does not apply to local apps + * and transports using the network layer (udp/tcp) + */ + TRANSPORT_CONNECTION_F_NO_LOOKUP = 1 << 1, + /** + * Connection descheduled by the session layer. + */ + TRANSPORT_CONNECTION_F_DESCHED = 1 << 2, + /** + * Connection is "connection less". Some important implications of that + * are that connections are not pinned to workers and listeners will + * have fifos associated to them + */ + TRANSPORT_CONNECTION_F_CLESS = 1 << 3, } transport_connection_flags_t; typedef struct _spacer @@ -145,7 +157,6 @@ STATIC_ASSERT (sizeof (transport_connection_t) <= 128, #define foreach_transport_proto \ _(TCP, "tcp", "T") \ _(UDP, "udp", "U") \ - _(SCTP, "sctp", "S") \ _(NONE, "ct", "C") \ _(TLS, "tls", "J") \ _(UDPC, "udpc", "U") \ @@ -156,7 +167,6 @@ typedef enum _transport_proto #define _(sym, str, sstr) TRANSPORT_PROTO_ ## sym, foreach_transport_proto #undef _ - TRANSPORT_N_PROTO } transport_proto_t; u8 *format_transport_proto (u8 * s, va_list * args); @@ -166,6 +176,7 @@ u8 *format_transport_listen_connection (u8 * s, va_list * args); u8 *format_transport_half_open_connection (u8 * s, va_list * args); uword unformat_transport_proto (unformat_input_t * input, va_list * args); +u8 *format_transport_protos (u8 * s, va_list * args); #define foreach_transport_endpoint_fields \ _(ip46_address_t, ip) /**< ip address in net order */ \ @@ -181,10 +192,17 @@ typedef struct transport_endpoint_ #undef _ } transport_endpoint_t; +typedef enum transport_endpt_cfg_flags_ +{ + TRANSPORT_CFG_F_CONNECTED = 1 << 0, + TRANSPORT_CFG_F_UNIDIRECTIONAL = 1 << 1, +} transport_endpt_cfg_flags_t; + #define foreach_transport_endpoint_cfg_fields \ foreach_transport_endpoint_fields \ _(transport_endpoint_t, peer) \ _(u16, mss) \ + _(u8, transport_flags) \ typedef struct transport_endpoint_pair_ {