aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/ioc3.h
diff options
context:
space:
mode:
authorJozsef Kadlecsik <kadlec@blackhole.kfki.hu>2009-05-25 11:23:15 -0400
committerPatrick McHardy <kaber@trash.net>2009-05-25 11:23:15 -0400
commitbfcaa50270e18f35220a11d46e98fc6232c24606 (patch)
treedd06bf91db9aff84adf442b6c8aa6be58c923ec0 /include/linux/ioc3.h
parentfecc1133b66af6e0cd49115a248f34bbb01f180a (diff)
netfilter: nf_ct_tcp: fix accepting invalid RST segments
Robert L Mathews discovered that some clients send evil TCP RST segments, which are accepted by netfilter conntrack but discarded by the destination. Thus the conntrack entry is destroyed but the destination retransmits data until timeout. The same technique, i.e. sending properly crafted RST segments, can easily be used to bypass connlimit/connbytes based restrictions (the sample script written by Robert can be found in the netfilter mailing list archives). The patch below adds a new flag and new field to struct ip_ct_tcp_state so that checking RST segments can be made more strict and thus TCP conntrack can catch the invalid ones: the RST segment is accepted only if its sequence number higher than or equal to the highest ack we seen from the other direction. (The last_ack field cannot be reused because it is used to catch resent packets.) Signed-off-by: Jozsef Kadlecsik <kadlec@blackhole.kfki.hu> Signed-off-by: Patrick McHardy <kaber@trash.net>
Diffstat (limited to 'include/linux/ioc3.h')
0 files changed, 0 insertions, 0 deletions