Hoang Le
4d1d3dddcb
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:49:56 +01:00
..
2019-08-25 10:48:05 +02:00
2018-03-23 13:12:18 -04:00
2020-07-29 10:16:47 +02:00
2019-01-09 17:38:34 +01:00
2018-04-20 11:04:05 -04:00
2020-11-10 12:35:53 +01:00
2018-03-31 22:19:52 -04:00
2018-08-29 18:04:54 -07:00
2018-11-23 08:17:03 +01:00
2018-03-23 13:12:17 -04:00
2020-09-26 18:01:30 +02:00
2018-06-30 21:05:42 +09:00
2018-03-22 14:43:35 -04:00
2021-01-23 15:49:56 +01:00
2018-09-29 11:45:14 -07:00
2018-03-22 14:43:35 -04:00
2020-01-27 14:49:52 +01:00
2020-01-27 14:49:52 +01:00
2020-11-05 11:08:33 +01:00
2018-03-23 13:12:18 -04:00
2020-01-27 14:50:00 +01:00
2018-03-31 22:19:52 -04:00
2020-01-27 14:50:00 +01:00
2020-01-27 14:50:00 +01:00
2020-01-27 14:49:52 +01:00
2018-11-23 08:17:03 +01:00
2020-09-03 11:24:17 +02:00
2020-03-18 07:14:18 +01:00
2020-07-29 10:16:47 +02:00
2018-07-11 23:06:14 -07:00
2020-09-26 18:01:30 +02:00
2018-09-06 21:49:18 -07:00
2018-04-12 21:46:10 -04:00
2019-06-04 08:02:34 +02:00
2020-01-27 14:50:39 +01:00
2020-11-18 19:18:51 +01:00
2020-04-29 16:31:17 +02:00
2018-04-20 11:04:05 -04:00