Re: [PATCH net-next 2/3] ipvs: replace the SCTP state machine

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Jun 18, 2013 at 10:08:07AM +0300, Julian Anastasov wrote:
> Convert the SCTP state table, so that it is more readable.
> Change the states to be according to the diagram in RFC 2960
> and add more states suitable for middle box. Still, such
> change in states adds incompatibility if systems in sync
> setup include this change and others do not include it.
> 
> With this change we also have proper transitions in INPUT-ONLY
> mode (DR/TUN) where we see packets only from client. Now
> we should not switch to 10-second CLOSED state at a time
> when we should stay in ESTABLISHED state.
> 
> The short names for states are because we have 16-char space
> in ipvsadm and 11-char limit for the connection list format.
> It is a sequence of the TCP implementation where the longest
> state name is ESTABLISHED.
> 
> Signed-off-by: Julian Anastasov <ja@xxxxxx>

Hi Julian,

I am having trouble applying the first ip_vs_proto_sctp.c hunk.

I have tried against net-next, nf-next and ipvs-next.
Could you rebase it on the later and repost it with the second patch of
this series?

I will take the first patch and see about getting it included in v3.10.

> ---
>  include/net/ip_vs.h                   |   21 +-
>  net/netfilter/ipvs/ip_vs_proto_sctp.c |  854 ++++++---------------------------
>  net/netfilter/ipvs/ip_vs_sync.c       |    7 +-
>  3 files changed, 168 insertions(+), 714 deletions(-)
> 
> diff --git a/include/net/ip_vs.h b/include/net/ip_vs.h
> index 95860df..e667df1 100644
> --- a/include/net/ip_vs.h
> +++ b/include/net/ip_vs.h
> @@ -380,17 +380,18 @@ enum {
>   */
>  enum ip_vs_sctp_states {
>  	IP_VS_SCTP_S_NONE,
> -	IP_VS_SCTP_S_INIT_CLI,
> -	IP_VS_SCTP_S_INIT_SER,
> -	IP_VS_SCTP_S_INIT_ACK_CLI,
> -	IP_VS_SCTP_S_INIT_ACK_SER,
> -	IP_VS_SCTP_S_ECHO_CLI,
> -	IP_VS_SCTP_S_ECHO_SER,
> +	IP_VS_SCTP_S_INIT1,
> +	IP_VS_SCTP_S_INIT,
> +	IP_VS_SCTP_S_COOKIE_SENT,
> +	IP_VS_SCTP_S_COOKIE_REPLIED,
> +	IP_VS_SCTP_S_COOKIE_WAIT,
> +	IP_VS_SCTP_S_COOKIE,
> +	IP_VS_SCTP_S_COOKIE_ECHOED,
>  	IP_VS_SCTP_S_ESTABLISHED,
> -	IP_VS_SCTP_S_SHUT_CLI,
> -	IP_VS_SCTP_S_SHUT_SER,
> -	IP_VS_SCTP_S_SHUT_ACK_CLI,
> -	IP_VS_SCTP_S_SHUT_ACK_SER,
> +	IP_VS_SCTP_S_SHUTDOWN_SENT,
> +	IP_VS_SCTP_S_SHUTDOWN_RECEIVED,
> +	IP_VS_SCTP_S_SHUTDOWN_ACK_SENT,
> +	IP_VS_SCTP_S_REJECTED,
>  	IP_VS_SCTP_S_CLOSED,
>  	IP_VS_SCTP_S_LAST
>  };
> diff --git a/net/netfilter/ipvs/ip_vs_proto_sctp.c b/net/netfilter/ipvs/ip_vs_proto_sctp.c
> index df29d64..3c0da87 100644
> --- a/net/netfilter/ipvs/ip_vs_proto_sctp.c
> +++ b/net/netfilter/ipvs/ip_vs_proto_sctp.c
> @@ -185,710 +185,159 @@ sctp_csum_check(int af, struct sk_buff *skb, struct ip_vs_protocol *pp)
>  	return 1;
>  }
>  
> -struct ipvs_sctp_nextstate {
> -	int next_state;
> -};
>  enum ipvs_sctp_event_t {
> -	IP_VS_SCTP_EVE_DATA_CLI,
> -	IP_VS_SCTP_EVE_DATA_SER,
> -	IP_VS_SCTP_EVE_INIT_CLI,
> -	IP_VS_SCTP_EVE_INIT_SER,
> -	IP_VS_SCTP_EVE_INIT_ACK_CLI,
> -	IP_VS_SCTP_EVE_INIT_ACK_SER,
> -	IP_VS_SCTP_EVE_COOKIE_ECHO_CLI,
> -	IP_VS_SCTP_EVE_COOKIE_ECHO_SER,
> -	IP_VS_SCTP_EVE_COOKIE_ACK_CLI,
> -	IP_VS_SCTP_EVE_COOKIE_ACK_SER,
> -	IP_VS_SCTP_EVE_ABORT_CLI,
> -	IP_VS_SCTP_EVE__ABORT_SER,
> -	IP_VS_SCTP_EVE_SHUT_CLI,
> -	IP_VS_SCTP_EVE_SHUT_SER,
> -	IP_VS_SCTP_EVE_SHUT_ACK_CLI,
> -	IP_VS_SCTP_EVE_SHUT_ACK_SER,
> -	IP_VS_SCTP_EVE_SHUT_COM_CLI,
> -	IP_VS_SCTP_EVE_SHUT_COM_SER,
> -	IP_VS_SCTP_EVE_LAST
> +	IP_VS_SCTP_DATA = 0,		/* DATA, SACK, HEARTBEATs */
> +	IP_VS_SCTP_INIT,
> +	IP_VS_SCTP_INIT_ACK,
> +	IP_VS_SCTP_COOKIE_ECHO,
> +	IP_VS_SCTP_COOKIE_ACK,
> +	IP_VS_SCTP_SHUTDOWN,
> +	IP_VS_SCTP_SHUTDOWN_ACK,
> +	IP_VS_SCTP_SHUTDOWN_COMPLETE,
> +	IP_VS_SCTP_ERROR,
> +	IP_VS_SCTP_ABORT,
> +	IP_VS_SCTP_EVENT_LAST
>  };
>  
> -static enum ipvs_sctp_event_t sctp_events[256] = {
> -	IP_VS_SCTP_EVE_DATA_CLI,
> -	IP_VS_SCTP_EVE_INIT_CLI,
> -	IP_VS_SCTP_EVE_INIT_ACK_CLI,
> -	IP_VS_SCTP_EVE_DATA_CLI,
> -	IP_VS_SCTP_EVE_DATA_CLI,
> -	IP_VS_SCTP_EVE_DATA_CLI,
> -	IP_VS_SCTP_EVE_ABORT_CLI,
> -	IP_VS_SCTP_EVE_SHUT_CLI,
> -	IP_VS_SCTP_EVE_SHUT_ACK_CLI,
> -	IP_VS_SCTP_EVE_DATA_CLI,
> -	IP_VS_SCTP_EVE_COOKIE_ECHO_CLI,
> -	IP_VS_SCTP_EVE_COOKIE_ACK_CLI,
> -	IP_VS_SCTP_EVE_DATA_CLI,
> -	IP_VS_SCTP_EVE_DATA_CLI,
> -	IP_VS_SCTP_EVE_SHUT_COM_CLI,
> +/* RFC 2960, 3.2 Chunk Field Descriptions */
> +static __u8 sctp_events[] = {
> +	[SCTP_CID_DATA]			= IP_VS_SCTP_DATA,
> +	[SCTP_CID_INIT]			= IP_VS_SCTP_INIT,
> +	[SCTP_CID_INIT_ACK]		= IP_VS_SCTP_INIT_ACK,
> +	[SCTP_CID_SACK]			= IP_VS_SCTP_DATA,
> +	[SCTP_CID_HEARTBEAT]		= IP_VS_SCTP_DATA,
> +	[SCTP_CID_HEARTBEAT_ACK]	= IP_VS_SCTP_DATA,
> +	[SCTP_CID_ABORT]		= IP_VS_SCTP_ABORT,
> +	[SCTP_CID_SHUTDOWN]		= IP_VS_SCTP_SHUTDOWN,
> +	[SCTP_CID_SHUTDOWN_ACK]		= IP_VS_SCTP_SHUTDOWN_ACK,
> +	[SCTP_CID_ERROR]		= IP_VS_SCTP_ERROR,
> +	[SCTP_CID_COOKIE_ECHO]		= IP_VS_SCTP_COOKIE_ECHO,
> +	[SCTP_CID_COOKIE_ACK]		= IP_VS_SCTP_COOKIE_ACK,
> +	[SCTP_CID_ECN_ECNE]		= IP_VS_SCTP_DATA,
> +	[SCTP_CID_ECN_CWR]		= IP_VS_SCTP_DATA,
> +	[SCTP_CID_SHUTDOWN_COMPLETE]	= IP_VS_SCTP_SHUTDOWN_COMPLETE,
>  };
>  
> -static struct ipvs_sctp_nextstate
> - sctp_states_table[IP_VS_SCTP_S_LAST][IP_VS_SCTP_EVE_LAST] = {
> -	/*
> -	 * STATE : IP_VS_SCTP_S_NONE
> -	 */
> -	/*next state *//*event */
> -	{{IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_DATA_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_DATA_SER */ },
> -	 {IP_VS_SCTP_S_INIT_CLI /* IP_VS_SCTP_EVE_INIT_CLI */ },
> -	 {IP_VS_SCTP_S_INIT_SER /* IP_VS_SCTP_EVE_INIT_SER */ },
> -	 {IP_VS_SCTP_S_INIT_ACK_CLI /* IP_VS_SCTP_EVE_INIT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_INIT_ACK_SER */ },
> -	 {IP_VS_SCTP_S_ECHO_CLI /* IP_VS_SCTP_EVE_COOKIE_ECHO_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_COOKIE_ECHO_SER */ },
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_COOKIE_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_COOKIE_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_SER */ },
> -	 {IP_VS_SCTP_S_SHUT_CLI /* IP_VS_SCTP_EVE_SHUT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_SER */ },
> -	 {IP_VS_SCTP_S_SHUT_ACK_CLI /* IP_VS_SCTP_EVE_SHUT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_SER */ },
> -	 },
> -	/*
> -	 * STATE : IP_VS_SCTP_S_INIT_CLI
> -	 * Cient sent INIT and is waiting for reply from server(In ECHO_WAIT)
> -	 */
> -	{{IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_DATA_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_DATA_SER */ },
> -	 {IP_VS_SCTP_S_INIT_CLI /* IP_VS_SCTP_EVE_INIT_CLI */ },
> -	 {IP_VS_SCTP_S_INIT_SER /* IP_VS_SCTP_EVE_INIT_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_INIT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_INIT_ACK_SER /* IP_VS_SCTP_EVE_INIT_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ECHO_CLI */ },
> -	 {IP_VS_SCTP_S_INIT_CLI /* IP_VS_SCTP_EVE_ECHO_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_COOKIE_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_INIT_CLI /* IP_VS_SCTP_EVE_COOKIE_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_SER */ }
> -	 },
> -	/*
> -	 * State : IP_VS_SCTP_S_INIT_SER
> -	 * Server sent INIT and waiting for INIT ACK from the client
> -	 */
> -	{{IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_DATA_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_DATA_SER */ },
> -	 {IP_VS_SCTP_S_INIT_CLI /* IP_VS_SCTP_EVE_INIT_CLI */ },
> -	 {IP_VS_SCTP_S_INIT_SER /* IP_VS_SCTP_EVE_INIT_SER */ },
> -	 {IP_VS_SCTP_S_INIT_ACK_CLI /* IP_VS_SCTP_EVE_INIT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_INIT_ACK_SER */ },
> -	 {IP_VS_SCTP_S_INIT_SER /* IP_VS_SCTP_EVE_COOKIE_ECHO_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_COOKIE_ECHO_SER */ },
> -	 {IP_VS_SCTP_S_INIT_SER /* IP_VS_SCTP_EVE_COOKIE_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_COOKIE_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_SER */ }
> -	 },
> -	/*
> -	 * State : IP_VS_SCTP_S_INIT_ACK_CLI
> -	 * Client sent INIT ACK and waiting for ECHO from the server
> -	 */
> -	{{IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_DATA_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_DATA_SER */ },
> -	 /*
> -	  * We have got an INIT from client. From the spec.“Upon receipt of
> -	  * an INIT in the COOKIE-WAIT state, an endpoint MUST respond with
> -	  * an INIT ACK using the same parameters it sent in its  original
> -	  * INIT chunk (including its Initiate Tag, unchanged”).
> -	  */
> -	 {IP_VS_SCTP_S_INIT_CLI /* IP_VS_SCTP_EVE_INIT_CLI */ },
> -	 {IP_VS_SCTP_S_INIT_SER /* IP_VS_SCTP_EVE_INIT_SER */ },
> -	 /*
> -	  * INIT_ACK has been resent by the client, let us stay is in
> -	  * the same state
> -	  */
> -	 {IP_VS_SCTP_S_INIT_ACK_CLI /* IP_VS_SCTP_EVE_INIT_ACK_CLI */ },
> -	 /*
> -	  * INIT_ACK sent by the server, close the connection
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_INIT_ACK_SER */ },
> -	 /*
> -	  * ECHO by client, it should not happen, close the connection
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_COOKIE_ECHO_CLI */ },
> -	 /*
> -	  * ECHO by server, this is what we are expecting, move to ECHO_SER
> -	  */
> -	 {IP_VS_SCTP_S_ECHO_SER /* IP_VS_SCTP_EVE_COOKIE_ECHO_SER */ },
> -	 /*
> -	  * COOKIE ACK from client, it should not happen, close the connection
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_COOKIE_ACK_CLI */ },
> -	 /*
> -	  * Unexpected COOKIE ACK from server, staty in the same state
> -	  */
> -	 {IP_VS_SCTP_S_INIT_ACK_CLI /* IP_VS_SCTP_EVE_COOKIE_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_SER */ }
> -	 },
> -	/*
> -	 * State : IP_VS_SCTP_S_INIT_ACK_SER
> -	 * Server sent INIT ACK and waiting for ECHO from the client
> -	 */
> -	{{IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_DATA_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_DATA_SER */ },
> -	 /*
> -	  * We have got an INIT from client. From the spec.“Upon receipt of
> -	  * an INIT in the COOKIE-WAIT state, an endpoint MUST respond with
> -	  * an INIT ACK using the same parameters it sent in its  original
> -	  * INIT chunk (including its Initiate Tag, unchanged”).
> -	  */
> -	 {IP_VS_SCTP_S_INIT_CLI /* IP_VS_SCTP_EVE_INIT_CLI */ },
> -	 {IP_VS_SCTP_S_INIT_SER /* IP_VS_SCTP_EVE_INIT_SER */ },
> -	 /*
> -	  * Unexpected INIT_ACK by the client, let us close the connection
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_INIT_ACK_CLI */ },
> -	 /*
> -	  * INIT_ACK resent by the server, let us move to same state
> -	  */
> -	 {IP_VS_SCTP_S_INIT_ACK_SER /* IP_VS_SCTP_EVE_INIT_ACK_SER */ },
> -	 /*
> -	  * Client send the ECHO, this is what we are expecting,
> -	  * move to ECHO_CLI
> -	  */
> -	 {IP_VS_SCTP_S_ECHO_CLI /* IP_VS_SCTP_EVE_COOKIE_ECHO_CLI */ },
> -	 /*
> -	  * ECHO received from the server, Not sure what to do,
> -	  * let us close it
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_COOKIE_ECHO_SER */ },
> -	 /*
> -	  * COOKIE ACK from client, let us stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_INIT_ACK_SER /* IP_VS_SCTP_EVE_COOKIE_ACK_CLI */ },
> -	 /*
> -	  * COOKIE ACK from server, hmm... this should not happen, lets close
> -	  * the connection.
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_COOKIE_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_SER */ }
> -	 },
> -	/*
> -	 * State : IP_VS_SCTP_S_ECHO_CLI
> -	 * Cient  sent ECHO and waiting COOKEI ACK from the Server
> -	 */
> -	{{IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_DATA_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_DATA_SER */ },
> -	 /*
> -	  * We have got an INIT from client. From the spec.“Upon receipt of
> -	  * an INIT in the COOKIE-WAIT state, an endpoint MUST respond with
> -	  * an INIT ACK using the same parameters it sent in its  original
> -	  * INIT chunk (including its Initiate Tag, unchanged”).
> -	  */
> -	 {IP_VS_SCTP_S_INIT_CLI /* IP_VS_SCTP_EVE_INIT_CLI */ },
> -	 {IP_VS_SCTP_S_INIT_SER /* IP_VS_SCTP_EVE_INIT_SER */ },
> -	 /*
> -	  * INIT_ACK has been by the client, let us close the connection
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_INIT_ACK_CLI */ },
> -	 /*
> -	  * INIT_ACK sent by the server, Unexpected INIT ACK, spec says,
> -	  * “If an INIT ACK is received by an endpoint in any state other
> -	  * than the COOKIE-WAIT state, the endpoint should discard the
> -	  * INIT ACK chunk”. Stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_ECHO_CLI /* IP_VS_SCTP_EVE_INIT_ACK_SER */ },
> -	 /*
> -	  * Client resent the ECHO, let us stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_ECHO_CLI /* IP_VS_SCTP_EVE_COOKIE_ECHO_CLI */ },
> -	 /*
> -	  * ECHO received from the server, Not sure what to do,
> -	  * let us close it
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_COOKIE_ECHO_SER */ },
> -	 /*
> -	  * COOKIE ACK from client, this shoud not happen, let's close the
> -	  * connection
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_COOKIE_ACK_CLI */ },
> -	 /*
> -	  * COOKIE ACK from server, this is what we are awaiting,lets move to
> -	  * ESTABLISHED.
> -	  */
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_COOKIE_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_SER */ }
> -	 },
> -	/*
> -	 * State : IP_VS_SCTP_S_ECHO_SER
> -	 * Server sent ECHO and waiting COOKEI ACK from the client
> -	 */
> -	{{IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_DATA_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_DATA_SER */ },
> -	 /*
> -	  * We have got an INIT from client. From the spec.“Upon receipt of
> -	  * an INIT in the COOKIE-WAIT state, an endpoint MUST respond with
> -	  * an INIT ACK using the same parameters it sent in its  original
> -	  * INIT chunk (including its Initiate Tag, unchanged”).
> -	  */
> -	 {IP_VS_SCTP_S_INIT_CLI /* IP_VS_SCTP_EVE_INIT_CLI */ },
> -	 {IP_VS_SCTP_S_INIT_SER /* IP_VS_SCTP_EVE_INIT_SER */ },
> -	 /*
> -	  * INIT_ACK sent by the server, Unexpected INIT ACK, spec says,
> -	  * “If an INIT ACK is received by an endpoint in any state other
> -	  * than the COOKIE-WAIT state, the endpoint should discard the
> -	  * INIT ACK chunk”. Stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_ECHO_SER /* IP_VS_SCTP_EVE_INIT_ACK_CLI */ },
> -	 /*
> -	  * INIT_ACK has been by the server, let us close the connection
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_INIT_ACK_SER */ },
> -	 /*
> -	  * Client sent the ECHO, not sure what to do, let's close the
> -	  * connection.
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_COOKIE_ECHO_CLI */ },
> -	 /*
> -	  * ECHO resent by the server, stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_ECHO_SER /* IP_VS_SCTP_EVE_COOKIE_ECHO_SER */ },
> -	 /*
> -	  * COOKIE ACK from client, this is what we are expecting, let's move
> -	  * to ESTABLISHED.
> -	  */
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_COOKIE_ACK_CLI */ },
> -	 /*
> -	  * COOKIE ACK from server, this should not happen, lets close the
> -	  * connection.
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_COOKIE_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_SER */ }
> -	 },
> -	/*
> -	 * State : IP_VS_SCTP_S_ESTABLISHED
> -	 * Association established
> -	 */
> -	{{IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_DATA_CLI */ },
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_DATA_SER */ },
> -	 /*
> -	  * We have got an INIT from client. From the spec.“Upon receipt of
> -	  * an INIT in the COOKIE-WAIT state, an endpoint MUST respond with
> -	  * an INIT ACK using the same parameters it sent in its  original
> -	  * INIT chunk (including its Initiate Tag, unchanged”).
> -	  */
> -	 {IP_VS_SCTP_S_INIT_CLI /* IP_VS_SCTP_EVE_INIT_CLI */ },
> -	 {IP_VS_SCTP_S_INIT_SER /* IP_VS_SCTP_EVE_INIT_SER */ },
> -	 /*
> -	  * INIT_ACK sent by the server, Unexpected INIT ACK, spec says,
> -	  * “If an INIT ACK is received by an endpoint in any state other
> -	  * than the COOKIE-WAIT state, the endpoint should discard the
> -	  * INIT ACK chunk”. Stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_INIT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_INIT_ACK_SER */ },
> -	 /*
> -	  * Client sent ECHO, Spec(sec 5.2.4) says it may be handled by the
> -	  * peer and peer shall move to the ESTABISHED. if it doesn't handle
> -	  * it will send ERROR chunk. So, stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_COOKIE_ECHO_CLI */ },
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_COOKIE_ECHO_SER */ },
> -	 /*
> -	  * COOKIE ACK from client, not sure what to do stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_COOKIE_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_COOKIE_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_SER */ },
> -	 /*
> -	  * SHUTDOWN from the client, move to SHUDDOWN_CLI
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_CLI /* IP_VS_SCTP_EVE_SHUT_CLI */ },
> -	 /*
> -	  * SHUTDOWN from the server, move to SHUTDOWN_SER
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_SER /* IP_VS_SCTP_EVE_SHUT_SER */ },
> -	 /*
> -	  * client sent SHUDTDOWN_ACK, this should not happen, let's close
> -	  * the connection
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_SER */ }
> -	 },
> -	/*
> -	 * State : IP_VS_SCTP_S_SHUT_CLI
> -	 * SHUTDOWN sent from the client, waitinf for SHUT ACK from the server
> -	 */
> -	/*
> -	 * We received the data chuck, keep the state unchanged. I assume
> -	 * that still data chuncks  can be received by both the peers in
> -	 * SHUDOWN state
> -	 */
> -
> -	{{IP_VS_SCTP_S_SHUT_CLI /* IP_VS_SCTP_EVE_DATA_CLI */ },
> -	 {IP_VS_SCTP_S_SHUT_CLI /* IP_VS_SCTP_EVE_DATA_SER */ },
> -	 /*
> -	  * We have got an INIT from client. From the spec.“Upon receipt of
> -	  * an INIT in the COOKIE-WAIT state, an endpoint MUST respond with
> -	  * an INIT ACK using the same parameters it sent in its  original
> -	  * INIT chunk (including its Initiate Tag, unchanged”).
> -	  */
> -	 {IP_VS_SCTP_S_INIT_CLI /* IP_VS_SCTP_EVE_INIT_CLI */ },
> -	 {IP_VS_SCTP_S_INIT_SER /* IP_VS_SCTP_EVE_INIT_SER */ },
> -	 /*
> -	  * INIT_ACK sent by the server, Unexpected INIT ACK, spec says,
> -	  * “If an INIT ACK is received by an endpoint in any state other
> -	  * than the COOKIE-WAIT state, the endpoint should discard the
> -	  * INIT ACK chunk”. Stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_CLI /* IP_VS_SCTP_EVE_INIT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_SHUT_CLI /* IP_VS_SCTP_EVE_INIT_ACK_SER */ },
> -	 /*
> -	  * Client sent ECHO, Spec(sec 5.2.4) says it may be handled by the
> -	  * peer and peer shall move to the ESTABISHED. if it doesn't handle
> -	  * it will send ERROR chunk. So, stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_COOKIE_ECHO_CLI */ },
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_COOKIE_ECHO_SER */ },
> -	 /*
> -	  * COOKIE ACK from client, not sure what to do stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_CLI /* IP_VS_SCTP_EVE_COOKIE_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_SHUT_CLI /* IP_VS_SCTP_EVE_COOKIE_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_SER */ },
> -	 /*
> -	  * SHUTDOWN resent from the client, move to SHUDDOWN_CLI
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_CLI /* IP_VS_SCTP_EVE_SHUT_CLI */ },
> -	 /*
> -	  * SHUTDOWN from the server, move to SHUTDOWN_SER
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_SER /* IP_VS_SCTP_EVE_SHUT_SER */ },
> -	 /*
> -	  * client sent SHUDTDOWN_ACK, this should not happen, let's close
> -	  * the connection
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_CLI */ },
> -	 /*
> -	  * Server sent SHUTDOWN ACK, this is what we are expecting, let's move
> -	  * to SHUDOWN_ACK_SER
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_ACK_SER /* IP_VS_SCTP_EVE_SHUT_ACK_SER */ },
> -	 /*
> -	  * SHUTDOWN COM from client, this should not happen, let's close the
> -	  * connection
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_SER */ }
> -	 },
> -	/*
> -	 * State : IP_VS_SCTP_S_SHUT_SER
> -	 * SHUTDOWN sent from the server, waitinf for SHUTDOWN ACK from client
> -	 */
> -	/*
> -	 * We received the data chuck, keep the state unchanged. I assume
> -	 * that still data chuncks  can be received by both the peers in
> -	 * SHUDOWN state
> -	 */
> -
> -	{{IP_VS_SCTP_S_SHUT_SER /* IP_VS_SCTP_EVE_DATA_CLI */ },
> -	 {IP_VS_SCTP_S_SHUT_SER /* IP_VS_SCTP_EVE_DATA_SER */ },
> -	 /*
> -	  * We have got an INIT from client. From the spec.“Upon receipt of
> -	  * an INIT in the COOKIE-WAIT state, an endpoint MUST respond with
> -	  * an INIT ACK using the same parameters it sent in its  original
> -	  * INIT chunk (including its Initiate Tag, unchanged”).
> -	  */
> -	 {IP_VS_SCTP_S_INIT_CLI /* IP_VS_SCTP_EVE_INIT_CLI */ },
> -	 {IP_VS_SCTP_S_INIT_SER /* IP_VS_SCTP_EVE_INIT_SER */ },
> -	 /*
> -	  * INIT_ACK sent by the server, Unexpected INIT ACK, spec says,
> -	  * “If an INIT ACK is received by an endpoint in any state other
> -	  * than the COOKIE-WAIT state, the endpoint should discard the
> -	  * INIT ACK chunk”. Stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_SER /* IP_VS_SCTP_EVE_INIT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_SHUT_SER /* IP_VS_SCTP_EVE_INIT_ACK_SER */ },
> -	 /*
> -	  * Client sent ECHO, Spec(sec 5.2.4) says it may be handled by the
> -	  * peer and peer shall move to the ESTABISHED. if it doesn't handle
> -	  * it will send ERROR chunk. So, stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_COOKIE_ECHO_CLI */ },
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_COOKIE_ECHO_SER */ },
> -	 /*
> -	  * COOKIE ACK from client, not sure what to do stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_SER /* IP_VS_SCTP_EVE_COOKIE_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_SHUT_SER /* IP_VS_SCTP_EVE_COOKIE_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_SER */ },
> -	 /*
> -	  * SHUTDOWN resent from the client, move to SHUDDOWN_CLI
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_CLI /* IP_VS_SCTP_EVE_SHUT_CLI */ },
> -	 /*
> -	  * SHUTDOWN resent from the server, move to SHUTDOWN_SER
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_SER /* IP_VS_SCTP_EVE_SHUT_SER */ },
> -	 /*
> -	  * client sent SHUDTDOWN_ACK, this is what we are expecting, let's
> -	  * move to SHUT_ACK_CLI
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_ACK_CLI /* IP_VS_SCTP_EVE_SHUT_ACK_CLI */ },
> -	 /*
> -	  * Server sent SHUTDOWN ACK, this should not happen, let's close the
> -	  * connection
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_SER */ },
> -	 /*
> -	  * SHUTDOWN COM from client, this should not happen, let's close the
> -	  * connection
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_SER */ }
> -	 },
> -
> -	/*
> -	 * State : IP_VS_SCTP_S_SHUT_ACK_CLI
> -	 * SHUTDOWN ACK from the client, awaiting for SHUTDOWN COM from server
> -	 */
> -	/*
> -	 * We received the data chuck, keep the state unchanged. I assume
> -	 * that still data chuncks  can be received by both the peers in
> -	 * SHUDOWN state
> -	 */
> -
> -	{{IP_VS_SCTP_S_SHUT_ACK_CLI /* IP_VS_SCTP_EVE_DATA_CLI */ },
> -	 {IP_VS_SCTP_S_SHUT_ACK_CLI /* IP_VS_SCTP_EVE_DATA_SER */ },
> -	 /*
> -	  * We have got an INIT from client. From the spec.“Upon receipt of
> -	  * an INIT in the COOKIE-WAIT state, an endpoint MUST respond with
> -	  * an INIT ACK using the same parameters it sent in its  original
> -	  * INIT chunk (including its Initiate Tag, unchanged”).
> -	  */
> -	 {IP_VS_SCTP_S_INIT_CLI /* IP_VS_SCTP_EVE_INIT_CLI */ },
> -	 {IP_VS_SCTP_S_INIT_SER /* IP_VS_SCTP_EVE_INIT_SER */ },
> -	 /*
> -	  * INIT_ACK sent by the server, Unexpected INIT ACK, spec says,
> -	  * “If an INIT ACK is received by an endpoint in any state other
> -	  * than the COOKIE-WAIT state, the endpoint should discard the
> -	  * INIT ACK chunk”. Stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_ACK_CLI /* IP_VS_SCTP_EVE_INIT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_SHUT_ACK_CLI /* IP_VS_SCTP_EVE_INIT_ACK_SER */ },
> -	 /*
> -	  * Client sent ECHO, Spec(sec 5.2.4) says it may be handled by the
> -	  * peer and peer shall move to the ESTABISHED. if it doesn't handle
> -	  * it will send ERROR chunk. So, stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_COOKIE_ECHO_CLI */ },
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_COOKIE_ECHO_SER */ },
> -	 /*
> -	  * COOKIE ACK from client, not sure what to do stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_ACK_CLI /* IP_VS_SCTP_EVE_COOKIE_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_SHUT_ACK_CLI /* IP_VS_SCTP_EVE_COOKIE_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_SER */ },
> -	 /*
> -	  * SHUTDOWN sent from the client, move to SHUDDOWN_CLI
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_CLI /* IP_VS_SCTP_EVE_SHUT_CLI */ },
> -	 /*
> -	  * SHUTDOWN sent from the server, move to SHUTDOWN_SER
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_SER /* IP_VS_SCTP_EVE_SHUT_SER */ },
> -	 /*
> -	  * client resent SHUDTDOWN_ACK, let's stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_ACK_CLI /* IP_VS_SCTP_EVE_SHUT_ACK_CLI */ },
> -	 /*
> -	  * Server sent SHUTDOWN ACK, this should not happen, let's close the
> -	  * connection
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_SER */ },
> -	 /*
> -	  * SHUTDOWN COM from client, this should not happen, let's close the
> -	  * connection
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_CLI */ },
> -	 /*
> -	  * SHUTDOWN COMPLETE from server this is what we are expecting.
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_SER */ }
> -	 },
> -
> -	/*
> -	 * State : IP_VS_SCTP_S_SHUT_ACK_SER
> -	 * SHUTDOWN ACK from the server, awaiting for SHUTDOWN COM from client
> -	 */
> -	/*
> -	 * We received the data chuck, keep the state unchanged. I assume
> -	 * that still data chuncks  can be received by both the peers in
> -	 * SHUDOWN state
> -	 */
> +/* SCTP States:
> + * See RFC 2960, 4. SCTP Association State Diagram
> + *
> + * New states (not in diagram):
> + * - INIT1 state: use shorter timeout for dropped INIT packets
> + * - REJECTED state: use shorter timeout if INIT is rejected with ABORT
> + * - INIT, COOKIE_SENT, COOKIE_REPLIED, COOKIE states: for better debugging
> + *
> + * The states are as seen in real server. In the diagram, INIT1, INIT,
> + * COOKIE_SENT and COOKIE_REPLIED processing happens in CLOSED state.
> + *
> + * States as per packets from client (C) and server (S):
> + *
> + * Setup of client connection:
> + * IP_VS_SCTP_S_INIT1: First C:INIT sent, wait for S:INIT-ACK
> + * IP_VS_SCTP_S_INIT: Next C:INIT sent, wait for S:INIT-ACK
> + * IP_VS_SCTP_S_COOKIE_SENT: S:INIT-ACK sent, wait for C:COOKIE-ECHO
> + * IP_VS_SCTP_S_COOKIE_REPLIED: C:COOKIE-ECHO sent, wait for S:COOKIE-ACK
> + *
> + * Setup of server connection:
> + * IP_VS_SCTP_S_COOKIE_WAIT: S:INIT sent, wait for C:INIT-ACK
> + * IP_VS_SCTP_S_COOKIE: C:INIT-ACK sent, wait for S:COOKIE-ECHO
> + * IP_VS_SCTP_S_COOKIE_ECHOED: S:COOKIE-ECHO sent, wait for C:COOKIE-ACK
> + */
>  
> -	{{IP_VS_SCTP_S_SHUT_ACK_SER /* IP_VS_SCTP_EVE_DATA_CLI */ },
> -	 {IP_VS_SCTP_S_SHUT_ACK_SER /* IP_VS_SCTP_EVE_DATA_SER */ },
> -	 /*
> -	  * We have got an INIT from client. From the spec.“Upon receipt of
> -	  * an INIT in the COOKIE-WAIT state, an endpoint MUST respond with
> -	  * an INIT ACK using the same parameters it sent in its  original
> -	  * INIT chunk (including its Initiate Tag, unchanged”).
> -	  */
> -	 {IP_VS_SCTP_S_INIT_CLI /* IP_VS_SCTP_EVE_INIT_CLI */ },
> -	 {IP_VS_SCTP_S_INIT_SER /* IP_VS_SCTP_EVE_INIT_SER */ },
> -	 /*
> -	  * INIT_ACK sent by the server, Unexpected INIT ACK, spec says,
> -	  * “If an INIT ACK is received by an endpoint in any state other
> -	  * than the COOKIE-WAIT state, the endpoint should discard the
> -	  * INIT ACK chunk”. Stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_ACK_SER /* IP_VS_SCTP_EVE_INIT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_SHUT_ACK_SER /* IP_VS_SCTP_EVE_INIT_ACK_SER */ },
> -	 /*
> -	  * Client sent ECHO, Spec(sec 5.2.4) says it may be handled by the
> -	  * peer and peer shall move to the ESTABISHED. if it doesn't handle
> -	  * it will send ERROR chunk. So, stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_COOKIE_ECHO_CLI */ },
> -	 {IP_VS_SCTP_S_ESTABLISHED /* IP_VS_SCTP_EVE_COOKIE_ECHO_SER */ },
> -	 /*
> -	  * COOKIE ACK from client, not sure what to do stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_ACK_SER /* IP_VS_SCTP_EVE_COOKIE_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_SHUT_ACK_SER /* IP_VS_SCTP_EVE_COOKIE_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_SER */ },
> -	 /*
> -	  * SHUTDOWN sent from the client, move to SHUDDOWN_CLI
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_CLI /* IP_VS_SCTP_EVE_SHUT_CLI */ },
> -	 /*
> -	  * SHUTDOWN sent from the server, move to SHUTDOWN_SER
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_SER /* IP_VS_SCTP_EVE_SHUT_SER */ },
> -	 /*
> -	  * client sent SHUDTDOWN_ACK, this should not happen let's close
> -	  * the connection.
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_CLI */ },
> -	 /*
> -	  * Server resent SHUTDOWN ACK, stay in the same state
> -	  */
> -	 {IP_VS_SCTP_S_SHUT_ACK_SER /* IP_VS_SCTP_EVE_SHUT_ACK_SER */ },
> -	 /*
> -	  * SHUTDOWN COM from client, this what we are expecting, let's close
> -	  * the connection
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_CLI */ },
> -	 /*
> -	  * SHUTDOWN COMPLETE from server this should not happen.
> -	  */
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_SER */ }
> -	 },
> -	/*
> -	 * State : IP_VS_SCTP_S_CLOSED
> -	 */
> -	{{IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_DATA_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_DATA_SER */ },
> -	 {IP_VS_SCTP_S_INIT_CLI /* IP_VS_SCTP_EVE_INIT_CLI */ },
> -	 {IP_VS_SCTP_S_INIT_SER /* IP_VS_SCTP_EVE_INIT_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_INIT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_INIT_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_COOKIE_ECHO_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_COOKIE_ECHO_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_COOKIE_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_COOKIE_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_ABORT_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_ACK_SER */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_CLI */ },
> -	 {IP_VS_SCTP_S_CLOSED /* IP_VS_SCTP_EVE_SHUT_COM_SER */ }
> -	 }
> +#define sNO IP_VS_SCTP_S_NONE
> +#define sI1 IP_VS_SCTP_S_INIT1
> +#define sIN IP_VS_SCTP_S_INIT
> +#define sCS IP_VS_SCTP_S_COOKIE_SENT
> +#define sCR IP_VS_SCTP_S_COOKIE_REPLIED
> +#define sCW IP_VS_SCTP_S_COOKIE_WAIT
> +#define sCO IP_VS_SCTP_S_COOKIE
> +#define sCE IP_VS_SCTP_S_COOKIE_ECHOED
> +#define sES IP_VS_SCTP_S_ESTABLISHED
> +#define sSS IP_VS_SCTP_S_SHUTDOWN_SENT
> +#define sSR IP_VS_SCTP_S_SHUTDOWN_RECEIVED
> +#define sSA IP_VS_SCTP_S_SHUTDOWN_ACK_SENT
> +#define sRJ IP_VS_SCTP_S_REJECTED
> +#define sCL IP_VS_SCTP_S_CLOSED
> +
> +static const __u8 sctp_states
> +	[IP_VS_DIR_LAST][IP_VS_SCTP_EVENT_LAST][IP_VS_SCTP_S_LAST] = {
> +	{ /* INPUT */
> +/*        sNO, sI1, sIN, sCS, sCR, sCW, sCO, sCE, sES, sSS, sSR, sSA, sRJ, sCL*/
> +/* d   */{sES, sI1, sIN, sCS, sCR, sCW, sCO, sCE, sES, sSS, sSR, sSA, sRJ, sCL},
> +/* i   */{sI1, sIN, sIN, sCS, sCR, sCW, sCO, sCE, sES, sSS, sSR, sSA, sIN, sIN},
> +/* i_a */{sCW, sCW, sCW, sCS, sCR, sCO, sCO, sCE, sES, sSS, sSR, sSA, sRJ, sCL},
> +/* c_e */{sCR, sIN, sIN, sCR, sCR, sCW, sCO, sCE, sES, sSS, sSR, sSA, sRJ, sCL},
> +/* c_a */{sES, sI1, sIN, sCS, sCR, sCW, sCO, sES, sES, sSS, sSR, sSA, sRJ, sCL},
> +/* s   */{sSR, sI1, sIN, sCS, sCR, sCW, sCO, sCE, sSR, sSS, sSR, sSA, sRJ, sCL},
> +/* s_a */{sCL, sIN, sIN, sCS, sCR, sCW, sCO, sCE, sES, sCL, sSR, sCL, sRJ, sCL},
> +/* s_c */{sCL, sCL, sCL, sCS, sCR, sCW, sCO, sCE, sES, sSS, sSR, sCL, sRJ, sCL},
> +/* err */{sCL, sI1, sIN, sCS, sCR, sCW, sCO, sCL, sES, sSS, sSR, sSA, sRJ, sCL},
> +/* ab  */{sCL, sCL, sCL, sCL, sCL, sRJ, sCL, sCL, sCL, sCL, sCL, sCL, sCL, sCL},
> +	},
> +	{ /* OUTPUT */
> +/*        sNO, sI1, sIN, sCS, sCR, sCW, sCO, sCE, sES, sSS, sSR, sSA, sRJ, sCL*/
> +/* d   */{sES, sI1, sIN, sCS, sCR, sCW, sCO, sCE, sES, sSS, sSR, sSA, sRJ, sCL},
> +/* i   */{sCW, sCW, sCW, sCW, sCW, sCW, sCW, sCW, sES, sCW, sCW, sCW, sCW, sCW},
> +/* i_a */{sCS, sCS, sCS, sCS, sCR, sCW, sCO, sCE, sES, sSS, sSR, sSA, sRJ, sCL},
> +/* c_e */{sCE, sCE, sCE, sCE, sCE, sCE, sCE, sCE, sES, sSS, sSR, sSA, sRJ, sCL},
> +/* c_a */{sES, sES, sES, sES, sES, sES, sES, sES, sES, sSS, sSR, sSA, sRJ, sCL},
> +/* s   */{sSS, sSS, sSS, sSS, sSS, sSS, sSS, sSS, sSS, sSS, sSR, sSA, sRJ, sCL},
> +/* s_a */{sSA, sSA, sSA, sSA, sSA, sCW, sCO, sCE, sES, sSA, sSA, sSA, sRJ, sCL},
> +/* s_c */{sCL, sI1, sIN, sCS, sCR, sCW, sCO, sCE, sES, sSS, sSR, sSA, sRJ, sCL},
> +/* err */{sCL, sCL, sCL, sCL, sCL, sCW, sCO, sCE, sES, sSS, sSR, sSA, sRJ, sCL},
> +/* ab  */{sCL, sRJ, sCL, sCL, sCL, sCL, sCL, sCL, sCL, sCL, sCL, sCL, sCL, sCL},
> +	},
> +	{ /* INPUT-ONLY */
> +/*        sNO, sI1, sIN, sCS, sCR, sCW, sCO, sCE, sES, sSS, sSR, sSA, sRJ, sCL*/
> +/* d   */{sES, sI1, sIN, sCS, sCR, sES, sCO, sCE, sES, sSS, sSR, sSA, sRJ, sCL},
> +/* i   */{sI1, sIN, sIN, sIN, sIN, sIN, sCO, sCE, sES, sSS, sSR, sSA, sIN, sIN},
> +/* i_a */{sCE, sCE, sCE, sCE, sCE, sCE, sCO, sCE, sES, sSS, sSR, sSA, sRJ, sCL},
> +/* c_e */{sES, sES, sES, sES, sES, sES, sCO, sCE, sES, sSS, sSR, sSA, sRJ, sCL},
> +/* c_a */{sES, sI1, sIN, sES, sES, sCW, sES, sES, sES, sSS, sSR, sSA, sRJ, sCL},
> +/* s   */{sSR, sI1, sIN, sCS, sCR, sCW, sCO, sCE, sSR, sSS, sSR, sSA, sRJ, sCL},
> +/* s_a */{sCL, sIN, sIN, sCS, sCR, sCW, sCO, sCE, sCL, sCL, sSR, sCL, sRJ, sCL},
> +/* s_c */{sCL, sCL, sCL, sCL, sCL, sCW, sCO, sCE, sES, sSS, sCL, sCL, sRJ, sCL},
> +/* err */{sCL, sI1, sIN, sCS, sCR, sCW, sCO, sCE, sES, sSS, sSR, sSA, sRJ, sCL},
> +/* ab  */{sCL, sCL, sCL, sCL, sCL, sRJ, sCL, sCL, sCL, sCL, sCL, sCL, sCL, sCL},
> +	},
>  };
>  
> -/*
> - *      Timeout table[state]
> - */
> +#define IP_VS_SCTP_MAX_RTO	((60 + 1) * HZ)
> +
> +/* Timeout table[state] */
>  static const int sctp_timeouts[IP_VS_SCTP_S_LAST + 1] = {
> -	[IP_VS_SCTP_S_NONE]         =     2 * HZ,
> -	[IP_VS_SCTP_S_INIT_CLI]     =     1 * 60 * HZ,
> -	[IP_VS_SCTP_S_INIT_SER]     =     1 * 60 * HZ,
> -	[IP_VS_SCTP_S_INIT_ACK_CLI] =     1 * 60 * HZ,
> -	[IP_VS_SCTP_S_INIT_ACK_SER] =     1 * 60 * HZ,
> -	[IP_VS_SCTP_S_ECHO_CLI]     =     1 * 60 * HZ,
> -	[IP_VS_SCTP_S_ECHO_SER]     =     1 * 60 * HZ,
> -	[IP_VS_SCTP_S_ESTABLISHED]  =    15 * 60 * HZ,
> -	[IP_VS_SCTP_S_SHUT_CLI]     =     1 * 60 * HZ,
> -	[IP_VS_SCTP_S_SHUT_SER]     =     1 * 60 * HZ,
> -	[IP_VS_SCTP_S_SHUT_ACK_CLI] =     1 * 60 * HZ,
> -	[IP_VS_SCTP_S_SHUT_ACK_SER] =     1 * 60 * HZ,
> -	[IP_VS_SCTP_S_CLOSED]       =    10 * HZ,
> -	[IP_VS_SCTP_S_LAST]         =     2 * HZ,
> +	[IP_VS_SCTP_S_NONE]			= 2 * HZ,
> +	[IP_VS_SCTP_S_INIT1]			= (0 + 3 + 1) * HZ,
> +	[IP_VS_SCTP_S_INIT]			= IP_VS_SCTP_MAX_RTO,
> +	[IP_VS_SCTP_S_COOKIE_SENT]		= IP_VS_SCTP_MAX_RTO,
> +	[IP_VS_SCTP_S_COOKIE_REPLIED]		= IP_VS_SCTP_MAX_RTO,
> +	[IP_VS_SCTP_S_COOKIE_WAIT]		= IP_VS_SCTP_MAX_RTO,
> +	[IP_VS_SCTP_S_COOKIE]			= IP_VS_SCTP_MAX_RTO,
> +	[IP_VS_SCTP_S_COOKIE_ECHOED]		= IP_VS_SCTP_MAX_RTO,
> +	[IP_VS_SCTP_S_ESTABLISHED]		= 15 * 60 * HZ,
> +	[IP_VS_SCTP_S_SHUTDOWN_SENT]		= IP_VS_SCTP_MAX_RTO,
> +	[IP_VS_SCTP_S_SHUTDOWN_RECEIVED]	= IP_VS_SCTP_MAX_RTO,
> +	[IP_VS_SCTP_S_SHUTDOWN_ACK_SENT]	= IP_VS_SCTP_MAX_RTO,
> +	[IP_VS_SCTP_S_REJECTED]			= (0 + 3 + 1) * HZ,
> +	[IP_VS_SCTP_S_CLOSED]			= IP_VS_SCTP_MAX_RTO,
> +	[IP_VS_SCTP_S_LAST]			= 2 * HZ,
>  };
>  
>  static const char *sctp_state_name_table[IP_VS_SCTP_S_LAST + 1] = {
> -	[IP_VS_SCTP_S_NONE]         =    "NONE",
> -	[IP_VS_SCTP_S_INIT_CLI]     =    "INIT_CLI",
> -	[IP_VS_SCTP_S_INIT_SER]     =    "INIT_SER",
> -	[IP_VS_SCTP_S_INIT_ACK_CLI] =    "INIT_ACK_CLI",
> -	[IP_VS_SCTP_S_INIT_ACK_SER] =    "INIT_ACK_SER",
> -	[IP_VS_SCTP_S_ECHO_CLI]     =    "COOKIE_ECHO_CLI",
> -	[IP_VS_SCTP_S_ECHO_SER]     =    "COOKIE_ECHO_SER",
> -	[IP_VS_SCTP_S_ESTABLISHED]  =    "ESTABISHED",
> -	[IP_VS_SCTP_S_SHUT_CLI]     =    "SHUTDOWN_CLI",
> -	[IP_VS_SCTP_S_SHUT_SER]     =    "SHUTDOWN_SER",
> -	[IP_VS_SCTP_S_SHUT_ACK_CLI] =    "SHUTDOWN_ACK_CLI",
> -	[IP_VS_SCTP_S_SHUT_ACK_SER] =    "SHUTDOWN_ACK_SER",
> -	[IP_VS_SCTP_S_CLOSED]       =    "CLOSED",
> -	[IP_VS_SCTP_S_LAST]         =    "BUG!"
> +	[IP_VS_SCTP_S_NONE]			= "NONE",
> +	[IP_VS_SCTP_S_INIT1]			= "INIT1",
> +	[IP_VS_SCTP_S_INIT]			= "INIT",
> +	[IP_VS_SCTP_S_COOKIE_SENT]		= "C-SENT",
> +	[IP_VS_SCTP_S_COOKIE_REPLIED]		= "C-REPLIED",
> +	[IP_VS_SCTP_S_COOKIE_WAIT]		= "C-WAIT",
> +	[IP_VS_SCTP_S_COOKIE]			= "COOKIE",
> +	[IP_VS_SCTP_S_COOKIE_ECHOED]		= "C-ECHOED",
> +	[IP_VS_SCTP_S_ESTABLISHED]		= "ESTABLISHED",
> +	[IP_VS_SCTP_S_SHUTDOWN_SENT]		= "S-SENT",
> +	[IP_VS_SCTP_S_SHUTDOWN_RECEIVED]	= "S-RECEIVED",
> +	[IP_VS_SCTP_S_SHUTDOWN_ACK_SENT]	= "S-ACK-SENT",
> +	[IP_VS_SCTP_S_REJECTED]			= "REJECTED",
> +	[IP_VS_SCTP_S_CLOSED]			= "CLOSED",
> +	[IP_VS_SCTP_S_LAST]			= "BUG!",
>  };
>  
>  
> @@ -945,17 +394,20 @@ set_sctp_state(struct ip_vs_proto_data *pd, struct ip_vs_conn *cp,
>  		}
>  	}
>  
> -	event = sctp_events[chunk_type];
> +	event = (chunk_type < sizeof(sctp_events)) ?
> +		sctp_events[chunk_type] : IP_VS_SCTP_DATA;
>  
> -	/*
> -	 *  If the direction is IP_VS_DIR_OUTPUT, this event is from server
> -	 */
> -	if (direction == IP_VS_DIR_OUTPUT)
> -		event++;
> -	/*
> -	 * get next state
> +	/* Update direction to INPUT_ONLY if necessary
> +	 * or delete NO_OUTPUT flag if output packet detected
>  	 */
> -	next_state = sctp_states_table[cp->state][event].next_state;
> +	if (cp->flags & IP_VS_CONN_F_NOOUTPUT) {
> +		if (direction == IP_VS_DIR_OUTPUT)
> +			cp->flags &= ~IP_VS_CONN_F_NOOUTPUT;
> +		else
> +			direction = IP_VS_DIR_INPUT_ONLY;
> +	}
> +
> +	next_state = sctp_states[direction][event][cp->state];
>  
>  	if (next_state != cp->state) {
>  		struct ip_vs_dest *dest = cp->dest;
> diff --git a/net/netfilter/ipvs/ip_vs_sync.c b/net/netfilter/ipvs/ip_vs_sync.c
> index f6046d9..2fc6639 100644
> --- a/net/netfilter/ipvs/ip_vs_sync.c
> +++ b/net/netfilter/ipvs/ip_vs_sync.c
> @@ -461,9 +461,10 @@ static int ip_vs_sync_conn_needed(struct netns_ipvs *ipvs,
>  	} else if (unlikely(cp->protocol == IPPROTO_SCTP)) {
>  		if (!((1 << cp->state) &
>  		      ((1 << IP_VS_SCTP_S_ESTABLISHED) |
> -		       (1 << IP_VS_SCTP_S_CLOSED) |
> -		       (1 << IP_VS_SCTP_S_SHUT_ACK_CLI) |
> -		       (1 << IP_VS_SCTP_S_SHUT_ACK_SER))))
> +		       (1 << IP_VS_SCTP_S_SHUTDOWN_SENT) |
> +		       (1 << IP_VS_SCTP_S_SHUTDOWN_RECEIVED) |
> +		       (1 << IP_VS_SCTP_S_SHUTDOWN_ACK_SENT) |
> +		       (1 << IP_VS_SCTP_S_CLOSED))))
>  			return 0;
>  		force = cp->state != cp->old_state;
>  		if (force && cp->state != IP_VS_SCTP_S_ESTABLISHED)
> -- 
> 1.7.3.4
> 
--
To unsubscribe from this list: send the line "unsubscribe lvs-devel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux Filesystem Devel]     [Linux NFS]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux SCSI]     [X.Org]

  Powered by Linux