aboutsummaryrefslogtreecommitdiffstats
path: root/net/dccp
diff options
context:
space:
mode:
Diffstat (limited to 'net/dccp')
-rw-r--r--net/dccp/output.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/net/dccp/output.c b/net/dccp/output.c
index c8d843e983fc..6e23d5b57e79 100644
--- a/net/dccp/output.c
+++ b/net/dccp/output.c
@@ -69,7 +69,7 @@ static int dccp_transmit_skb(struct sock *sk, struct sk_buff *skb)
69 69
70 case DCCP_PKT_SYNC: 70 case DCCP_PKT_SYNC:
71 case DCCP_PKT_SYNCACK: 71 case DCCP_PKT_SYNCACK:
72 ackno = dcb->dccpd_seq; 72 ackno = dcb->dccpd_ack_seq;
73 /* fall through */ 73 /* fall through */
74 default: 74 default:
75 /* 75 /*
@@ -507,7 +507,7 @@ void dccp_send_delayed_ack(struct sock *sk)
507 sk_reset_timer(sk, &icsk->icsk_delack_timer, timeout); 507 sk_reset_timer(sk, &icsk->icsk_delack_timer, timeout);
508} 508}
509 509
510void dccp_send_sync(struct sock *sk, const u64 seq, 510void dccp_send_sync(struct sock *sk, const u64 ackno,
511 const enum dccp_pkt_type pkt_type) 511 const enum dccp_pkt_type pkt_type)
512{ 512{
513 /* 513 /*
@@ -517,14 +517,16 @@ void dccp_send_sync(struct sock *sk, const u64 seq,
517 */ 517 */
518 struct sk_buff *skb = alloc_skb(sk->sk_prot->max_header, GFP_ATOMIC); 518 struct sk_buff *skb = alloc_skb(sk->sk_prot->max_header, GFP_ATOMIC);
519 519
520 if (skb == NULL) 520 if (skb == NULL) {
521 /* FIXME: how to make sure the sync is sent? */ 521 /* FIXME: how to make sure the sync is sent? */
522 DCCP_CRIT("could not send %s", dccp_packet_name(pkt_type));
522 return; 523 return;
524 }
523 525
524 /* Reserve space for headers and prepare control bits. */ 526 /* Reserve space for headers and prepare control bits. */
525 skb_reserve(skb, sk->sk_prot->max_header); 527 skb_reserve(skb, sk->sk_prot->max_header);
526 DCCP_SKB_CB(skb)->dccpd_type = pkt_type; 528 DCCP_SKB_CB(skb)->dccpd_type = pkt_type;
527 DCCP_SKB_CB(skb)->dccpd_seq = seq; 529 DCCP_SKB_CB(skb)->dccpd_ack_seq = ackno;
528 530
529 dccp_transmit_skb(sk, skb); 531 dccp_transmit_skb(sk, skb);
530} 532}