ipv4: ip_check_defrag must not modify skb before unsharing
authorJohannes Berg <johannes.berg@intel.com>
Sun, 9 Dec 2012 23:41:06 +0000 (23:41 +0000)
committerDavid S. Miller <davem@davemloft.net>
Mon, 10 Dec 2012 18:51:44 +0000 (13:51 -0500)
commit1bf3751ec90cc3174e01f0d701e8449ce163d113
treee625d411db647c59274e74d664c903bb5bb6b502
parent5e1f54201cb481f40a04bc47e1bc8c093a189e23
ipv4: ip_check_defrag must not modify skb before unsharing

ip_check_defrag() might be called from af_packet within the
RX path where shared SKBs are used, so it must not modify
the input SKB before it has unshared it for defragmentation.
Use skb_copy_bits() to get the IP header and only pull in
everything later.

The same is true for the other caller in macvlan as it is
called from dev->rx_handler which can also get a shared SKB.

Reported-by: Eric Leblond <eric@regit.org>
Cc: stable@vger.kernel.org
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/ipv4/ip_fragment.c