diff options
author | Eric Dumazet <edumazet@google.com> | 2017-02-12 17:03:52 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2017-02-12 22:14:49 -0500 |
commit | 8b74d439e1697110c5e5c600643e823eb1dd0762 (patch) | |
tree | edfcfac1f41af2d3c3397eea8a66ae9b53f29ab3 | |
parent | 7f677633379b4abb3281cdbe7e7006f049305c03 (diff) |
net/llc: avoid BUG_ON() in skb_orphan()
It seems nobody used LLC since linux-3.12.
Fortunately fuzzers like syzkaller still know how to run this code,
otherwise it would be no fun.
Setting skb->sk without skb->destructor leads to all kinds of
bugs, we now prefer to be very strict about it.
Ideally here we would use skb_set_owner() but this helper does not exist yet,
only CAN seems to have a private helper for that.
Fixes: 376c7311bdb6 ("net: add a temporary sanity check in skb_orphan()")
Signed-off-by: Eric Dumazet <edumazet@google.com>
Reported-by: Andrey Konovalov <andreyknvl@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | net/llc/llc_conn.c | 3 | ||||
-rw-r--r-- | net/llc/llc_sap.c | 3 |
2 files changed, 6 insertions, 0 deletions
diff --git a/net/llc/llc_conn.c b/net/llc/llc_conn.c index 3e821daf9dd4..8bc5a1bd2d45 100644 --- a/net/llc/llc_conn.c +++ b/net/llc/llc_conn.c | |||
@@ -821,7 +821,10 @@ void llc_conn_handler(struct llc_sap *sap, struct sk_buff *skb) | |||
821 | * another trick required to cope with how the PROCOM state | 821 | * another trick required to cope with how the PROCOM state |
822 | * machine works. -acme | 822 | * machine works. -acme |
823 | */ | 823 | */ |
824 | skb_orphan(skb); | ||
825 | sock_hold(sk); | ||
824 | skb->sk = sk; | 826 | skb->sk = sk; |
827 | skb->destructor = sock_efree; | ||
825 | } | 828 | } |
826 | if (!sock_owned_by_user(sk)) | 829 | if (!sock_owned_by_user(sk)) |
827 | llc_conn_rcv(sk, skb); | 830 | llc_conn_rcv(sk, skb); |
diff --git a/net/llc/llc_sap.c b/net/llc/llc_sap.c index d0e1e804ebd7..5404d0d195cc 100644 --- a/net/llc/llc_sap.c +++ b/net/llc/llc_sap.c | |||
@@ -290,7 +290,10 @@ static void llc_sap_rcv(struct llc_sap *sap, struct sk_buff *skb, | |||
290 | 290 | ||
291 | ev->type = LLC_SAP_EV_TYPE_PDU; | 291 | ev->type = LLC_SAP_EV_TYPE_PDU; |
292 | ev->reason = 0; | 292 | ev->reason = 0; |
293 | skb_orphan(skb); | ||
294 | sock_hold(sk); | ||
293 | skb->sk = sk; | 295 | skb->sk = sk; |
296 | skb->destructor = sock_efree; | ||
294 | llc_sap_state_process(sap, skb); | 297 | llc_sap_state_process(sap, skb); |
295 | } | 298 | } |
296 | 299 | ||