diff options
Diffstat (limited to 'net/core/dev.c')
| -rw-r--r-- | net/core/dev.c | 16 | 
1 files changed, 11 insertions, 5 deletions
| diff --git a/net/core/dev.c b/net/core/dev.c index c360bb5367e2..449b45b843d4 100644 --- a/net/core/dev.c +++ b/net/core/dev.c @@ -5735,10 +5735,11 @@ static void gro_normal_list(struct napi_struct *napi)  /* Queue one GRO_NORMAL SKB up for list processing. If batch size exceeded,   * pass the whole batch up to the stack.   */ -static void gro_normal_one(struct napi_struct *napi, struct sk_buff *skb) +static void gro_normal_one(struct napi_struct *napi, struct sk_buff *skb, int segs)  {  	list_add_tail(&skb->list, &napi->rx_list); -	if (++napi->rx_count >= gro_normal_batch) +	napi->rx_count += segs; +	if (napi->rx_count >= gro_normal_batch)  		gro_normal_list(napi);  } @@ -5777,7 +5778,7 @@ static int napi_gro_complete(struct napi_struct *napi, struct sk_buff *skb)  	}  out: -	gro_normal_one(napi, skb); +	gro_normal_one(napi, skb, NAPI_GRO_CB(skb)->count);  	return NET_RX_SUCCESS;  } @@ -6067,7 +6068,7 @@ static gro_result_t napi_skb_finish(struct napi_struct *napi,  {  	switch (ret) {  	case GRO_NORMAL: -		gro_normal_one(napi, skb); +		gro_normal_one(napi, skb, 1);  		break;  	case GRO_DROP: @@ -6155,7 +6156,7 @@ static gro_result_t napi_frags_finish(struct napi_struct *napi,  		__skb_push(skb, ETH_HLEN);  		skb->protocol = eth_type_trans(skb, skb->dev);  		if (ret == GRO_NORMAL) -			gro_normal_one(napi, skb); +			gro_normal_one(napi, skb, 1);  		break;  	case GRO_DROP: @@ -9672,6 +9673,11 @@ static netdev_features_t netdev_fix_features(struct net_device *dev,  		}  	} +	if ((features & NETIF_F_HW_TLS_RX) && !(features & NETIF_F_RXCSUM)) { +		netdev_dbg(dev, "Dropping TLS RX HW offload feature since no RXCSUM feature.\n"); +		features &= ~NETIF_F_HW_TLS_RX; +	} +  	return features;  } | 
