blob: 6e135f97e59a6eee9e0854ddc6c0db35a2ca01e4 [file] [log] [blame]
Yasuyuki Kozakai9fb9cbb2005-11-09 16:38:16 -08001#ifndef _NF_CONNTRACK_TCP_H
2#define _NF_CONNTRACK_TCP_H
3/* TCP tracking. */
4
Arnd Bergmann60c195c2009-02-26 00:51:43 +01005#include <linux/types.h>
6
Yasuyuki Kozakai9fb9cbb2005-11-09 16:38:16 -08007/* This is exposed to userspace (ctnetlink) */
8enum tcp_conntrack {
9 TCP_CONNTRACK_NONE,
10 TCP_CONNTRACK_SYN_SENT,
11 TCP_CONNTRACK_SYN_RECV,
12 TCP_CONNTRACK_ESTABLISHED,
13 TCP_CONNTRACK_FIN_WAIT,
14 TCP_CONNTRACK_CLOSE_WAIT,
15 TCP_CONNTRACK_LAST_ACK,
16 TCP_CONNTRACK_TIME_WAIT,
17 TCP_CONNTRACK_CLOSE,
Jozsef Kadlecsik874ab922009-06-02 13:58:56 +020018 TCP_CONNTRACK_LISTEN, /* obsolete */
19#define TCP_CONNTRACK_SYN_SENT2 TCP_CONNTRACK_LISTEN
Yasuyuki Kozakai9fb9cbb2005-11-09 16:38:16 -080020 TCP_CONNTRACK_MAX,
21 TCP_CONNTRACK_IGNORE
22};
23
24/* Window scaling is advertised by the sender */
25#define IP_CT_TCP_FLAG_WINDOW_SCALE 0x01
26
27/* SACK is permitted by the sender */
28#define IP_CT_TCP_FLAG_SACK_PERM 0x02
29
30/* This sender sent FIN first */
Patrick McHardyf79e7802007-01-09 14:34:14 -080031#define IP_CT_TCP_FLAG_CLOSE_INIT 0x04
Yasuyuki Kozakai9fb9cbb2005-11-09 16:38:16 -080032
Patrick McHardya09113c2007-02-07 15:05:33 -080033/* Be liberal in window checking */
34#define IP_CT_TCP_FLAG_BE_LIBERAL 0x08
35
Patrick McHardyae375042008-07-31 00:38:01 -070036/* Has unacknowledged data */
37#define IP_CT_TCP_FLAG_DATA_UNACKNOWLEDGED 0x10
38
Jozsef Kadlecsikbfcaa5022009-05-25 17:23:15 +020039/* The field td_maxack has been set */
40#define IP_CT_TCP_FLAG_MAXACK_SET 0x20
41
Pablo Neira Ayusoc8e20782007-03-14 16:45:19 -070042struct nf_ct_tcp_flags {
Arnd Bergmann60c195c2009-02-26 00:51:43 +010043 __u8 flags;
44 __u8 mask;
Pablo Neira Ayusoc8e20782007-03-14 16:45:19 -070045};
46
Yasuyuki Kozakai9fb9cbb2005-11-09 16:38:16 -080047#ifdef __KERNEL__
48
49struct ip_ct_tcp_state {
50 u_int32_t td_end; /* max of seq + len */
51 u_int32_t td_maxend; /* max of ack + max(win, 1) */
52 u_int32_t td_maxwin; /* max(win) */
Jozsef Kadlecsikbfcaa5022009-05-25 17:23:15 +020053 u_int32_t td_maxack; /* max of ack */
Yasuyuki Kozakai9fb9cbb2005-11-09 16:38:16 -080054 u_int8_t td_scale; /* window scale factor */
Yasuyuki Kozakai9fb9cbb2005-11-09 16:38:16 -080055 u_int8_t flags; /* per direction options */
56};
57
Eric Dumazetd94d9fe2009-11-04 09:50:58 -080058struct ip_ct_tcp {
Yasuyuki Kozakai9fb9cbb2005-11-09 16:38:16 -080059 struct ip_ct_tcp_state seen[2]; /* connection parameters per direction */
60 u_int8_t state; /* state of the connection (enum tcp_conntrack) */
61 /* For detecting stale connections */
62 u_int8_t last_dir; /* Direction of the last packet (enum ip_conntrack_dir) */
63 u_int8_t retrans; /* Number of retransmitted packets */
64 u_int8_t last_index; /* Index of the last packet */
65 u_int32_t last_seq; /* Last sequence number seen in dir */
66 u_int32_t last_ack; /* Last sequence number seen in opposite dir */
67 u_int32_t last_end; /* Last seq + len */
George Hansperc1fe3ca2006-09-20 12:03:23 -070068 u_int16_t last_win; /* Last window advertisement seen in dir */
Pablo Neira Ayusoc4832c72009-11-23 10:34:39 +010069 /* For SYN packets while we may be out-of-sync */
70 u_int8_t last_wscale; /* Last window scaling factor seen */
71 u_int8_t last_flags; /* Last flags set */
Yasuyuki Kozakai9fb9cbb2005-11-09 16:38:16 -080072};
73
74#endif /* __KERNEL__ */
75
76#endif /* _NF_CONNTRACK_TCP_H */