• Jesse Gross's avatar
    tunnels: Remove encapsulation offloads on decap. · 526857ca
    Jesse Gross authored
    commit a09a4c8d upstream.
    
    If a packet is either locally encapsulated or processed through GRO
    it is marked with the offloads that it requires. However, when it is
    decapsulated these tunnel offload indications are not removed. This
    means that if we receive an encapsulated TCP packet, aggregate it with
    GRO, decapsulate, and retransmit the resulting frame on a NIC that does
    not support encapsulation, we won't be able to take advantage of hardware
    offloads even though it is just a simple TCP packet at this point.
    
    This fixes the problem by stripping off encapsulation offload indications
    when packets are decapsulated.
    
    The performance impacts of this bug are significant. In a test where a
    Geneve encapsulated TCP stream is sent to a hypervisor, GRO'ed, decapsulated,
    and bridged to a VM performance is improved by 60% (5Gbps->8Gbps) as a
    result of avoiding unnecessary segmentation at the VM tap interface.
    
    [js] no fou in 3.12 yet
    Reported-by: default avatarRamu Ramamurthy <sramamur@linux.vnet.ibm.com>
    Fixes: 68c33163 ("v4 GRE: Add TCP segmentation offload for GRE")
    Signed-off-by: default avatarJesse Gross <jesse@kernel.org>
    Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
    (backported from commit a09a4c8d)
    [adapt iptunnel_pull_header arguments, avoid 7f290c94]
    Signed-off-by: default avatarStefan Bader <stefan.bader@canonical.com>
    Signed-off-by: default avatarJuerg Haefliger <juerg.haefliger@hpe.com>
    Signed-off-by: default avatarJiri Slaby <jslaby@suse.cz>
    526857ca
ip_tunnels.h 5.09 KB