diff options
Diffstat (limited to 'net/ipv4/tcp_offload.c')
| -rw-r--r-- | net/ipv4/tcp_offload.c | 17 | 
1 files changed, 10 insertions, 7 deletions
| diff --git a/net/ipv4/tcp_offload.c b/net/ipv4/tcp_offload.c index 8cc7c3487330..870b0a335061 100644 --- a/net/ipv4/tcp_offload.c +++ b/net/ipv4/tcp_offload.c @@ -180,9 +180,9 @@ out:  	return segs;  } -struct sk_buff **tcp_gro_receive(struct sk_buff **head, struct sk_buff *skb) +struct sk_buff *tcp_gro_receive(struct list_head *head, struct sk_buff *skb)  { -	struct sk_buff **pp = NULL; +	struct sk_buff *pp = NULL;  	struct sk_buff *p;  	struct tcphdr *th;  	struct tcphdr *th2; @@ -220,7 +220,7 @@ struct sk_buff **tcp_gro_receive(struct sk_buff **head, struct sk_buff *skb)  	len = skb_gro_len(skb);  	flags = tcp_flag_word(th); -	for (; (p = *head); head = &p->next) { +	list_for_each_entry(p, head, list) {  		if (!NAPI_GRO_CB(p)->same_flow)  			continue; @@ -233,7 +233,7 @@ struct sk_buff **tcp_gro_receive(struct sk_buff **head, struct sk_buff *skb)  		goto found;  	} - +	p = NULL;  	goto out_check_final;  found: @@ -262,8 +262,11 @@ found:  	flush |= (len - 1) >= mss;  	flush |= (ntohl(th2->seq) + skb_gro_len(p)) ^ ntohl(th->seq); +#ifdef CONFIG_TLS_DEVICE +	flush |= p->decrypted ^ skb->decrypted; +#endif -	if (flush || skb_gro_receive(head, skb)) { +	if (flush || skb_gro_receive(p, skb)) {  		mss = 1;  		goto out_check_final;  	} @@ -277,7 +280,7 @@ out_check_final:  					TCP_FLAG_FIN));  	if (p && (!NAPI_GRO_CB(skb)->same_flow || flush)) -		pp = head; +		pp = p;  out:  	NAPI_GRO_CB(skb)->flush |= (flush != 0); @@ -302,7 +305,7 @@ int tcp_gro_complete(struct sk_buff *skb)  }  EXPORT_SYMBOL(tcp_gro_complete); -static struct sk_buff **tcp4_gro_receive(struct sk_buff **head, struct sk_buff *skb) +static struct sk_buff *tcp4_gro_receive(struct list_head *head, struct sk_buff *skb)  {  	/* Don't bother verifying checksum if we're going to flush anyway. */  	if (!NAPI_GRO_CB(skb)->flush && | 
