diff options
author | KOVACS Krisztian <hidden@sch.bme.hu> | 2008-10-01 10:46:49 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-10-01 10:46:49 -0400 |
commit | a3116ac5c216fc3c145906a46df9ce542ff7dcf2 (patch) | |
tree | 6b2b43b5bacac2b358566e4b7ca0adda45a3e52b /include/net | |
parent | 86b08d867d7de001ab224180ed7865fab93fd56e (diff) |
tcp: Port redirection support for TCP
Current TCP code relies on the local port of the listening socket
being the same as the destination address of the incoming
connection. Port redirection used by many transparent proxying
techniques obviously breaks this, so we have to store the original
destination port address.
This patch extends struct inet_request_sock and stores the incoming
destination port value there. It also modifies the handshake code to
use that value as the source port when sending reply packets.
Signed-off-by: KOVACS Krisztian <hidden@sch.bme.hu>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/net')
-rw-r--r-- | include/net/inet_sock.h | 2 | ||||
-rw-r--r-- | include/net/tcp.h | 1 |
2 files changed, 2 insertions, 1 deletions
diff --git a/include/net/inet_sock.h b/include/net/inet_sock.h index dced3f64f975..de0ecc71cf03 100644 --- a/include/net/inet_sock.h +++ b/include/net/inet_sock.h | |||
@@ -61,8 +61,8 @@ struct inet_request_sock { | |||
61 | struct request_sock req; | 61 | struct request_sock req; |
62 | #if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE) | 62 | #if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE) |
63 | u16 inet6_rsk_offset; | 63 | u16 inet6_rsk_offset; |
64 | /* 2 bytes hole, try to pack */ | ||
65 | #endif | 64 | #endif |
65 | __be16 loc_port; | ||
66 | __be32 loc_addr; | 66 | __be32 loc_addr; |
67 | __be32 rmt_addr; | 67 | __be32 rmt_addr; |
68 | __be16 rmt_port; | 68 | __be16 rmt_port; |
diff --git a/include/net/tcp.h b/include/net/tcp.h index 12c9b4fec040..f6cc34143154 100644 --- a/include/net/tcp.h +++ b/include/net/tcp.h | |||
@@ -976,6 +976,7 @@ static inline void tcp_openreq_init(struct request_sock *req, | |||
976 | ireq->acked = 0; | 976 | ireq->acked = 0; |
977 | ireq->ecn_ok = 0; | 977 | ireq->ecn_ok = 0; |
978 | ireq->rmt_port = tcp_hdr(skb)->source; | 978 | ireq->rmt_port = tcp_hdr(skb)->source; |
979 | ireq->loc_port = tcp_hdr(skb)->dest; | ||
979 | } | 980 | } |
980 | 981 | ||
981 | extern void tcp_enter_memory_pressure(struct sock *sk); | 982 | extern void tcp_enter_memory_pressure(struct sock *sk); |