aboutsummaryrefslogtreecommitdiffstats
path: root/net/ipv4
diff options
context:
space:
mode:
authorOctavian Purdila <octavian.purdila@intel.com>2014-06-25 10:09:59 -0400
committerDavid S. Miller <davem@davemloft.net>2014-06-27 18:53:36 -0400
commit5db92c994982ed826cf38f38d58bd09bc326aef6 (patch)
treea47f81307b287fa65edfef7b1bd94c21d8cd7f1f /net/ipv4
parentd6274bd8d6ea84b7b54cc1c3fde6bcb6143b104f (diff)
tcp: unify tcp_v4_rtx_synack and tcp_v6_rtx_synack
Signed-off-by: Octavian Purdila <octavian.purdila@intel.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4')
-rw-r--r--net/ipv4/tcp_ipv4.c14
-rw-r--r--net/ipv4/tcp_output.c15
2 files changed, 16 insertions, 13 deletions
diff --git a/net/ipv4/tcp_ipv4.c b/net/ipv4/tcp_ipv4.c
index b5945ac50876..597dd9d75210 100644
--- a/net/ipv4/tcp_ipv4.c
+++ b/net/ipv4/tcp_ipv4.c
@@ -845,18 +845,6 @@ static int tcp_v4_send_synack(struct sock *sk, struct dst_entry *dst,
845 return err; 845 return err;
846} 846}
847 847
848static int tcp_v4_rtx_synack(struct sock *sk, struct request_sock *req)
849{
850 const struct tcp_request_sock_ops *af_ops = tcp_rsk(req)->af_specific;
851 int res = af_ops->send_synack(sk, NULL, NULL, req, 0, NULL);
852
853 if (!res) {
854 TCP_INC_STATS_BH(sock_net(sk), TCP_MIB_RETRANSSEGS);
855 NET_INC_STATS_BH(sock_net(sk), LINUX_MIB_TCPSYNRETRANS);
856 }
857 return res;
858}
859
860/* 848/*
861 * IPv4 request_sock destructor. 849 * IPv4 request_sock destructor.
862 */ 850 */
@@ -1269,7 +1257,7 @@ static struct dst_entry *tcp_v4_route_req(struct sock *sk, struct flowi *fl,
1269struct request_sock_ops tcp_request_sock_ops __read_mostly = { 1257struct request_sock_ops tcp_request_sock_ops __read_mostly = {
1270 .family = PF_INET, 1258 .family = PF_INET,
1271 .obj_size = sizeof(struct tcp_request_sock), 1259 .obj_size = sizeof(struct tcp_request_sock),
1272 .rtx_syn_ack = tcp_v4_rtx_synack, 1260 .rtx_syn_ack = tcp_rtx_synack,
1273 .send_ack = tcp_v4_reqsk_send_ack, 1261 .send_ack = tcp_v4_reqsk_send_ack,
1274 .destructor = tcp_v4_reqsk_destructor, 1262 .destructor = tcp_v4_reqsk_destructor,
1275 .send_reset = tcp_v4_send_reset, 1263 .send_reset = tcp_v4_send_reset,
diff --git a/net/ipv4/tcp_output.c b/net/ipv4/tcp_output.c
index d92bce0ea24e..f8f2a944a1ce 100644
--- a/net/ipv4/tcp_output.c
+++ b/net/ipv4/tcp_output.c
@@ -3299,3 +3299,18 @@ void tcp_send_probe0(struct sock *sk)
3299 TCP_RTO_MAX); 3299 TCP_RTO_MAX);
3300 } 3300 }
3301} 3301}
3302
3303int tcp_rtx_synack(struct sock *sk, struct request_sock *req)
3304{
3305 const struct tcp_request_sock_ops *af_ops = tcp_rsk(req)->af_specific;
3306 struct flowi fl;
3307 int res;
3308
3309 res = af_ops->send_synack(sk, NULL, &fl, req, 0, NULL);
3310 if (!res) {
3311 TCP_INC_STATS_BH(sock_net(sk), TCP_MIB_RETRANSSEGS);
3312 NET_INC_STATS_BH(sock_net(sk), LINUX_MIB_TCPSYNRETRANS);
3313 }
3314 return res;
3315}
3316EXPORT_SYMBOL(tcp_rtx_synack);