diff options
author | David S. Miller <davem@davemloft.net> | 2012-06-27 20:05:06 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-06-27 20:05:06 -0400 |
commit | c10237e077cef50e925f052e49f3b4fead9d71f9 (patch) | |
tree | 5b7418f3a31165ea2e7d119782cad0745cd45792 /include | |
parent | e440cf2ca0a1b075c64016240d46c3aa9d877bbf (diff) |
Revert "ipv4: tcp: dont cache unconfirmed intput dst"
This reverts commit c074da2810c118b3812f32d6754bd9ead2f169e7.
This change has several unwanted side effects:
1) Sockets will cache the DST_NOCACHE route in sk->sk_rx_dst and we'll
thus never create a real cached route.
2) All TCP traffic will use DST_NOCACHE and never use the routing
cache at all.
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include')
-rw-r--r-- | include/net/protocol.h | 2 | ||||
-rw-r--r-- | include/net/route.h | 8 | ||||
-rw-r--r-- | include/net/tcp.h | 2 |
3 files changed, 6 insertions, 6 deletions
diff --git a/include/net/protocol.h b/include/net/protocol.h index 7cfc8f76914d..967b926cbfb1 100644 --- a/include/net/protocol.h +++ b/include/net/protocol.h | |||
@@ -37,7 +37,7 @@ | |||
37 | 37 | ||
38 | /* This is used to register protocols. */ | 38 | /* This is used to register protocols. */ |
39 | struct net_protocol { | 39 | struct net_protocol { |
40 | int (*early_demux)(struct sk_buff *skb, bool *nocache); | 40 | int (*early_demux)(struct sk_buff *skb); |
41 | int (*handler)(struct sk_buff *skb); | 41 | int (*handler)(struct sk_buff *skb); |
42 | void (*err_handler)(struct sk_buff *skb, u32 info); | 42 | void (*err_handler)(struct sk_buff *skb, u32 info); |
43 | int (*gso_send_check)(struct sk_buff *skb); | 43 | int (*gso_send_check)(struct sk_buff *skb); |
diff --git a/include/net/route.h b/include/net/route.h index 6361f9335774..47eb25ac1f7f 100644 --- a/include/net/route.h +++ b/include/net/route.h | |||
@@ -201,18 +201,18 @@ static inline struct rtable *ip_route_output_gre(struct net *net, struct flowi4 | |||
201 | } | 201 | } |
202 | 202 | ||
203 | extern int ip_route_input_common(struct sk_buff *skb, __be32 dst, __be32 src, | 203 | extern int ip_route_input_common(struct sk_buff *skb, __be32 dst, __be32 src, |
204 | u8 tos, struct net_device *devin, bool noref, bool nocache); | 204 | u8 tos, struct net_device *devin, bool noref); |
205 | 205 | ||
206 | static inline int ip_route_input(struct sk_buff *skb, __be32 dst, __be32 src, | 206 | static inline int ip_route_input(struct sk_buff *skb, __be32 dst, __be32 src, |
207 | u8 tos, struct net_device *devin) | 207 | u8 tos, struct net_device *devin) |
208 | { | 208 | { |
209 | return ip_route_input_common(skb, dst, src, tos, devin, false, false); | 209 | return ip_route_input_common(skb, dst, src, tos, devin, false); |
210 | } | 210 | } |
211 | 211 | ||
212 | static inline int ip_route_input_noref(struct sk_buff *skb, __be32 dst, __be32 src, | 212 | static inline int ip_route_input_noref(struct sk_buff *skb, __be32 dst, __be32 src, |
213 | u8 tos, struct net_device *devin, bool nocache) | 213 | u8 tos, struct net_device *devin) |
214 | { | 214 | { |
215 | return ip_route_input_common(skb, dst, src, tos, devin, true, nocache); | 215 | return ip_route_input_common(skb, dst, src, tos, devin, true); |
216 | } | 216 | } |
217 | 217 | ||
218 | extern void ipv4_update_pmtu(struct sk_buff *skb, struct net *net, u32 mtu, | 218 | extern void ipv4_update_pmtu(struct sk_buff *skb, struct net *net, u32 mtu, |
diff --git a/include/net/tcp.h b/include/net/tcp.h index 917ed2e55e8c..6660ffc4963d 100644 --- a/include/net/tcp.h +++ b/include/net/tcp.h | |||
@@ -325,7 +325,7 @@ extern void tcp_v4_err(struct sk_buff *skb, u32); | |||
325 | 325 | ||
326 | extern void tcp_shutdown (struct sock *sk, int how); | 326 | extern void tcp_shutdown (struct sock *sk, int how); |
327 | 327 | ||
328 | extern int tcp_v4_early_demux(struct sk_buff *skb, bool *nocache); | 328 | extern int tcp_v4_early_demux(struct sk_buff *skb); |
329 | extern int tcp_v4_rcv(struct sk_buff *skb); | 329 | extern int tcp_v4_rcv(struct sk_buff *skb); |
330 | 330 | ||
331 | extern struct inet_peer *tcp_v4_get_peer(struct sock *sk); | 331 | extern struct inet_peer *tcp_v4_get_peer(struct sock *sk); |