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: 9c7077622d
("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>
This commit is contained in:
parent
7a05dc64e2
commit
46d2cfb192
|
@ -2517,7 +2517,7 @@ static int packet_snd(struct socket *sock, struct msghdr *msg, size_t len)
|
||||||
err = -EINVAL;
|
err = -EINVAL;
|
||||||
if (sock->type == SOCK_DGRAM) {
|
if (sock->type == SOCK_DGRAM) {
|
||||||
offset = dev_hard_header(skb, dev, ntohs(proto), addr, NULL, len);
|
offset = dev_hard_header(skb, dev, ntohs(proto), addr, NULL, len);
|
||||||
if (unlikely(offset) < 0)
|
if (unlikely(offset < 0))
|
||||||
goto out_free;
|
goto out_free;
|
||||||
} else {
|
} else {
|
||||||
if (ll_header_truncated(dev, len))
|
if (ll_header_truncated(dev, len))
|
||||||
|
|
Loading…
Reference in New Issue