net: ip_tunnel: remove 'csum_help' argument to iptunnel_handle_offloads
All users now pass false, so we can remove it, and remove the code that was conditional upon it. Signed-off-by: Edward Cree <ecree@solarflare.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
53936107ba
commit
6fa79666e2
@@ -787,7 +787,7 @@ int fou_build_header(struct sk_buff *skb, struct ip_tunnel_encap *e,
|
||||
SKB_GSO_UDP_TUNNEL;
|
||||
__be16 sport;
|
||||
|
||||
skb = iptunnel_handle_offloads(skb, false, type);
|
||||
skb = iptunnel_handle_offloads(skb, type);
|
||||
|
||||
if (IS_ERR(skb))
|
||||
return PTR_ERR(skb);
|
||||
@@ -820,7 +820,7 @@ int gue_build_header(struct sk_buff *skb, struct ip_tunnel_encap *e,
|
||||
|
||||
optlen += need_priv ? GUE_LEN_PRIV : 0;
|
||||
|
||||
skb = iptunnel_handle_offloads(skb, false, type);
|
||||
skb = iptunnel_handle_offloads(skb, type);
|
||||
|
||||
if (IS_ERR(skb))
|
||||
return PTR_ERR(skb);
|
||||
|
||||
@@ -503,8 +503,7 @@ static void __gre_xmit(struct sk_buff *skb, struct net_device *dev,
|
||||
static struct sk_buff *gre_handle_offloads(struct sk_buff *skb,
|
||||
bool csum)
|
||||
{
|
||||
return iptunnel_handle_offloads(skb, false,
|
||||
csum ? SKB_GSO_GRE_CSUM : SKB_GSO_GRE);
|
||||
return iptunnel_handle_offloads(skb, csum ? SKB_GSO_GRE_CSUM : SKB_GSO_GRE);
|
||||
}
|
||||
|
||||
static struct rtable *gre_get_rt(struct sk_buff *skb,
|
||||
|
||||
@@ -148,7 +148,6 @@ struct metadata_dst *iptunnel_metadata_reply(struct metadata_dst *md,
|
||||
EXPORT_SYMBOL_GPL(iptunnel_metadata_reply);
|
||||
|
||||
struct sk_buff *iptunnel_handle_offloads(struct sk_buff *skb,
|
||||
bool csum_help,
|
||||
int gso_type_mask)
|
||||
{
|
||||
int err;
|
||||
@@ -166,18 +165,13 @@ struct sk_buff *iptunnel_handle_offloads(struct sk_buff *skb,
|
||||
return skb;
|
||||
}
|
||||
|
||||
/* If packet is not gso and we are not offloading inner checksum,
|
||||
* clear encapsulation flag. This allows setting CHECKSUM_PARTIAL
|
||||
* on the outer header without confusing devices that implement
|
||||
* NETIF_F_IP_CSUM with encapsulation.
|
||||
*/
|
||||
if (skb->ip_summed == CHECKSUM_PARTIAL && csum_help) {
|
||||
skb->encapsulation = 0;
|
||||
err = skb_checksum_help(skb);
|
||||
if (unlikely(err))
|
||||
goto error;
|
||||
} else if (skb->ip_summed != CHECKSUM_PARTIAL) {
|
||||
if (skb->ip_summed != CHECKSUM_PARTIAL) {
|
||||
skb->ip_summed = CHECKSUM_NONE;
|
||||
/* We clear encapsulation here to prevent badly-written
|
||||
* drivers potentially deciding to offload an inner checksum
|
||||
* if we set CHECKSUM_PARTIAL on the outer header.
|
||||
* This should go away when the drivers are all fixed.
|
||||
*/
|
||||
skb->encapsulation = 0;
|
||||
}
|
||||
|
||||
|
||||
@@ -219,7 +219,7 @@ static netdev_tx_t ipip_tunnel_xmit(struct sk_buff *skb, struct net_device *dev)
|
||||
if (unlikely(skb->protocol != htons(ETH_P_IP)))
|
||||
goto tx_error;
|
||||
|
||||
skb = iptunnel_handle_offloads(skb, false, SKB_GSO_IPIP);
|
||||
skb = iptunnel_handle_offloads(skb, SKB_GSO_IPIP);
|
||||
if (IS_ERR(skb))
|
||||
goto out;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user