diff options
| author | John Fastabend <[email protected]> | 2018-07-05 15:49:59 +0000 |
|---|---|---|
| committer | Alexei Starovoitov <[email protected]> | 2018-07-07 22:19:29 +0000 |
| commit | 0c6bc6e531a6db36f49622f1f115770160f7afb0 (patch) | |
| tree | 77b565cda20fbeeec014f9d7c63b48d1b9c14505 /net/nsh/nsh.c | |
| parent | Merge branch 'sockmap-fixes' (diff) | |
| download | kernel-0c6bc6e531a6db36f49622f1f115770160f7afb0.tar.gz kernel-0c6bc6e531a6db36f49622f1f115770160f7afb0.zip | |
bpf: fix sk_skb programs without skb->dev assigned
Multiple BPF helpers in use by sk_skb programs calculate the max
skb length using the __bpf_skb_max_len function. However, this
calculates the max length using the skb->dev pointer which can be
NULL when an sk_skb program is paired with an sk_msg program.
To force this a sk_msg program needs to redirect into the ingress
path of a sock with an attach sk_skb program. Then the the sk_skb
program would need to call one of the helpers that adjust the skb
size.
To fix the null ptr dereference use SKB_MAX_ALLOC size if no dev
is available.
Fixes: 8934ce2fd081 ("bpf: sockmap redirect ingress support")
Signed-off-by: John Fastabend <[email protected]>
Signed-off-by: Alexei Starovoitov <[email protected]>
Diffstat (limited to 'net/nsh/nsh.c')
0 files changed, 0 insertions, 0 deletions
