Hoang Le
310014f572
tipc: fix NULL deref in tipc_link_xmit()
...
[ Upstream commit b77413446408fdd256599daf00d5be72b5f3e7c6 ]
The buffer list can have zero skb as following path:
tipc_named_node_up()->tipc_node_xmit()->tipc_link_xmit(), so
we need to check the list before casting an &sk_buff.
Fault report:
[] tipc: Bulk publication failure
[] general protection fault, probably for non-canonical [#1 ] PREEMPT [...]
[] KASAN: null-ptr-deref in range [0x00000000000000c8-0x00000000000000cf]
[] CPU: 0 PID: 0 Comm: swapper/0 Kdump: loaded Not tainted 5.10.0-rc4+ #2
[] Hardware name: Bochs ..., BIOS Bochs 01/01/2011
[] RIP: 0010:tipc_link_xmit+0xc1/0x2180
[] Code: 24 b8 00 00 00 00 4d 39 ec 4c 0f 44 e8 e8 d7 0a 10 f9 48 [...]
[] RSP: 0018:ffffc90000006ea0 EFLAGS: 00010202
[] RAX: dffffc0000000000 RBX: ffff8880224da000 RCX: 1ffff11003d3cc0d
[] RDX: 0000000000000019 RSI: ffffffff886007b9 RDI: 00000000000000c8
[] RBP: ffffc90000007018 R08: 0000000000000001 R09: fffff52000000ded
[] R10: 0000000000000003 R11: fffff52000000dec R12: ffffc90000007148
[] R13: 0000000000000000 R14: 0000000000000000 R15: ffffc90000007018
[] FS: 0000000000000000(0000) GS:ffff888037400000(0000) knlGS:000[...]
[] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
[] CR2: 00007fffd2db5000 CR3: 000000002b08f000 CR4: 00000000000006f0
Fixes: af9b028e270fd ("tipc: make media xmit call outside node spinlock context")
Acked-by: Jon Maloy <jmaloy@redhat.com>
Signed-off-by: Hoang Le <hoang.h.le@dektech.com.au>
Link: https://lore.kernel.org/r/20210108071337.3598-1-hoang.h.le@dektech.com.au
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2021-01-23 15:38:19 +01:00
..
2020-01-29 10:24:22 +01:00
2020-11-10 10:23:54 +01:00
2020-01-12 11:24:27 +01:00
2019-12-21 10:41:45 +01:00
2020-10-01 20:40:12 +02:00
2020-07-31 16:44:06 +02:00
2020-12-02 08:31:27 +01:00
2020-12-29 13:44:53 +01:00
2020-12-29 13:44:48 +01:00
2019-05-08 07:19:07 +02:00
2019-07-10 09:55:33 +02:00
2020-11-10 10:23:59 +01:00
2021-01-23 15:38:18 +01:00
2021-01-23 15:38:18 +01:00
2020-05-20 08:15:30 +02:00
2019-12-05 15:35:12 +01:00
2018-07-22 14:27:39 +02:00
2020-04-13 10:32:53 +02:00
2020-01-12 11:24:19 +01:00
2020-10-01 20:40:01 +02:00
2020-03-20 09:07:39 +01:00
2021-01-17 13:57:53 +01:00
2021-01-23 15:38:18 +01:00
2017-05-25 15:44:41 +02:00
2018-09-15 09:43:01 +02:00
2020-12-11 13:37:56 +01:00
2019-04-17 08:36:44 +02:00
2020-10-01 20:39:59 +02:00
2021-01-09 13:35:49 +01:00
2019-06-22 08:17:22 +02:00
2020-07-22 09:10:47 +02:00
2020-12-29 13:44:48 +01:00
2020-10-01 20:40:18 +02:00
2020-05-20 08:15:30 +02:00
2021-01-12 19:49:01 +01:00
2021-01-23 15:38:18 +01:00
2020-11-24 13:02:56 +01:00
2020-07-22 09:10:48 +02:00
2020-05-02 17:23:08 +02:00
2020-10-29 09:05:32 +01:00
2020-10-14 09:48:16 +02:00
2020-10-14 09:48:13 +02:00
2019-03-23 13:19:44 +01:00
2020-06-03 08:16:29 +02:00
2020-08-21 11:01:49 +02:00
2020-01-12 11:24:23 +01:00
2020-12-11 13:37:56 +01:00
2021-01-23 15:38:19 +01:00
2021-01-12 19:49:02 +01:00
2020-11-24 13:02:58 +01:00
2018-04-29 11:32:02 +02:00
2021-01-23 15:38:18 +01:00
2016-10-19 10:58:04 -04:00
2021-01-23 15:38:19 +01:00
2020-10-01 20:40:06 +02:00
2020-11-10 10:24:03 +01:00
2020-12-29 13:45:02 +01:00
2020-12-11 13:37:57 +01:00
2020-11-18 18:26:23 +01:00
2020-08-21 11:02:08 +02:00
2020-08-21 11:02:04 +02:00
2016-10-06 09:52:23 -07:00