diff options
author | Eric Dumazet <eric.dumazet@gmail.com> | 2011-10-24 03:06:21 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2011-10-24 03:06:21 -0400 |
commit | 66b13d99d96a1a69f47a6bc3dc47f45955967377 (patch) | |
tree | c566bee026b5e9703f789d27657aefa7c70c587c /include/net/inet_timewait_sock.h | |
parent | 318cf7aaa0a6d20ecf6be33eb771291e5ff2e3b9 (diff) |
ipv4: tcp: fix TOS value in ACK messages sent from TIME_WAIT
There is a long standing bug in linux tcp stack, about ACK messages sent
on behalf of TIME_WAIT sockets.
In the IP header of the ACK message, we choose to reflect TOS field of
incoming message, and this might break some setups.
Example of things that were broken :
- Routing using TOS as a selector
- Firewalls
- Trafic classification / shaping
We now remember in timewait structure the inet tos field and use it in
ACK generation, and route lookup.
Notes :
- We still reflect incoming TOS in RST messages.
- We could extend MuraliRaja Muniraju patch to report TOS value in
netlink messages for TIME_WAIT sockets.
- A patch is needed for IPv6
Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/net/inet_timewait_sock.h')
-rw-r--r-- | include/net/inet_timewait_sock.h | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/include/net/inet_timewait_sock.h b/include/net/inet_timewait_sock.h index f1a770977c4f..180231c5bbbe 100644 --- a/include/net/inet_timewait_sock.h +++ b/include/net/inet_timewait_sock.h | |||
@@ -126,7 +126,8 @@ struct inet_timewait_sock { | |||
126 | /* And these are ours. */ | 126 | /* And these are ours. */ |
127 | unsigned int tw_ipv6only : 1, | 127 | unsigned int tw_ipv6only : 1, |
128 | tw_transparent : 1, | 128 | tw_transparent : 1, |
129 | tw_pad : 14, /* 14 bits hole */ | 129 | tw_pad : 6, /* 6 bits hole */ |
130 | tw_tos : 8, | ||
130 | tw_ipv6_offset : 16; | 131 | tw_ipv6_offset : 16; |
131 | kmemcheck_bitfield_end(flags); | 132 | kmemcheck_bitfield_end(flags); |
132 | unsigned long tw_ttd; | 133 | unsigned long tw_ttd; |