packet: bail out of packet_snd() if L2 header creation fails
authorChristoph Jaeger <cj@linux.com>
Sun, 11 Jan 2015 18:01:16 +0000 (13:01 -0500)
committerDavid S. Miller <davem@davemloft.net>
Mon, 12 Jan 2015 02:54:03 +0000 (21:54 -0500)
commit46d2cfb192b30d729aef064808ed5ece47cee369
tree94a98b40912ad217baaf9a462f56db788a91e4ed
parent7a05dc64e2e4c611d89007b125b20c0d2a4d31a5
packet: bail out of packet_snd() if L2 header creation fails

Due to a misplaced parenthesis, the expression

  (unlikely(offset) < 0),

which expands to

  (__builtin_expect(!!(offset), 0) < 0),

never evaluates to true. Therefore, when sending packets with
PF_PACKET/SOCK_DGRAM, packet_snd() does not abort as intended
if the creation of the layer 2 header fails.

Spotted by Coverity - CID 1259975 ("Operands don't affect result").

Fixes: 9c7077622dd9 ("packet: make packet_snd fail on len smaller than l2 header")
Signed-off-by: Christoph Jaeger <cj@linux.com>
Acked-by: Eric Dumazet <edumazet@google.com>
Acked-by: Willem de Bruijn <willemb@google.com>
Acked-by: Daniel Borkmann <dborkman@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/packet/af_packet.c