• Jason A. Donenfeld's avatar
    net: xdp: pull ethernet header off packet after computing skb->protocol · f8414a8d
    Jason A. Donenfeld authored
    When an XDP program changes the ethernet header protocol field,
    eth_type_trans is used to recalculate skb->protocol. In order for
    eth_type_trans to work correctly, the ethernet header must actually be
    part of the skb data segment, so the code first pushes that onto the
    head of the skb. However, it subsequently forgets to pull it back off,
    making the behavior of the passed-on packet inconsistent between the
    protocol modifying case and the static protocol case. This patch fixes
    the issue by simply pulling the ethernet header back off of the skb
    head.
    
    Fixes: 29724956 ("net: fix generic XDP to handle if eth header was mangled")
    Cc: Jesper Dangaard Brouer <brouer@redhat.com>
    Cc: David S. Miller <davem@davemloft.net>
    Signed-off-by: default avatarJason A. Donenfeld <Jason@zx2c4.com>
    Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
    f8414a8d
dev.c 274 KB