Jason Gunthorpe
f2f2b3bbf0
RDMA/core: Fix missing error check on dev_set_name()
...
If name memory allocation fails the name will be left empty and
device_add_one() will crash:
kobject: (0000000004952746): attempted to be registered with empty name!
WARNING: CPU: 0 PID: 329 at lib/kobject.c:234 kobject_add_internal+0x7ac/0x9a0 lib/kobject.c:234
Kernel panic - not syncing: panic_on_warn set ...
CPU: 0 PID: 329 Comm: syz-executor.5 Not tainted 5.6.0-rc2-syzkaller #0
Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011
Call Trace:
__dump_stack lib/dump_stack.c:77 [inline]
dump_stack+0x197/0x210 lib/dump_stack.c:118
panic+0x2e3/0x75c kernel/panic.c:221
__warn.cold+0x2f/0x3e kernel/panic.c:582
report_bug+0x289/0x300 lib/bug.c:195
fixup_bug arch/x86/kernel/traps.c:174 [inline]
fixup_bug arch/x86/kernel/traps.c:169 [inline]
do_error_trap+0x11b/0x200 arch/x86/kernel/traps.c:267
do_invalid_op+0x37/0x50 arch/x86/kernel/traps.c:286
invalid_op+0x23/0x30 arch/x86/entry/entry_64.S:1027
RIP: 0010:kobject_add_internal+0x7ac/0x9a0 lib/kobject.c:234
Code: 1a 98 ca f9 e9 f0 f8 ff ff 4c 89 f7 e8 6d 98 ca f9 e9 95 f9 ff ff e8 c3 f0 8b f9 4c 89 e6 48 c7 c7 a0 0e 1a 89 e8 e3 41 5c f9 <0f> 0b 41 bd ea ff ff ff e9 52 ff ff ff e8 a2 f0 8b f9 0f 0b e8 9b
RSP: 0018:ffffc90005b27908 EFLAGS: 00010286
RAX: 0000000000000000 RBX: 0000000000000000 RCX: 0000000000000000
RDX: 0000000000040000 RSI: ffffffff815eae46 RDI: fffff52000b64f13
RBP: ffffc90005b27960 R08: ffff88805aeba480 R09: ffffed1015d06659
R10: ffffed1015d06658 R11: ffff8880ae8332c7 R12: ffff8880a37fd000
R13: 0000000000000000 R14: ffff888096691780 R15: 0000000000000001
kobject_add_varg lib/kobject.c:390 [inline]
kobject_add+0x150/0x1c0 lib/kobject.c:442
device_add+0x3be/0x1d00 drivers/base/core.c:2412
add_one_compat_dev drivers/infiniband/core/device.c:901 [inline]
add_one_compat_dev+0x46a/0x7e0 drivers/infiniband/core/device.c:857
rdma_dev_init_net+0x2eb/0x490 drivers/infiniband/core/device.c:1120
ops_init+0xb3/0x420 net/core/net_namespace.c:137
setup_net+0x2d5/0x8b0 net/core/net_namespace.c:327
copy_net_ns+0x29e/0x5a0 net/core/net_namespace.c:468
create_new_namespaces+0x403/0xb50 kernel/nsproxy.c:108
unshare_nsproxy_namespaces+0xc2/0x200 kernel/nsproxy.c:229
ksys_unshare+0x444/0x980 kernel/fork.c:2955
__do_sys_unshare kernel/fork.c:3023 [inline]
__se_sys_unshare kernel/fork.c:3021 [inline]
__x64_sys_unshare+0x31/0x40 kernel/fork.c:3021
do_syscall_64+0xfa/0x790 arch/x86/entry/common.c:294
entry_SYSCALL_64_after_hwframe+0x49/0xbe
Link: https://lore.kernel.org/r/20200309193200.GA10633@ziepe.ca
Cc: stable@kernel.org
Fixes: 4e0f7b907072 ("RDMA/core: Implement compat device/sysfs tree in net namespace")
Reported-by: syzbot+ab4dae63f7d310641ded@syzkaller.appspotmail.com
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
2020-03-13 10:30:11 -03:00
..
2020-01-03 16:02:32 -04:00
2018-12-19 16:28:03 -07:00
2020-01-07 20:18:11 -04:00
2019-06-05 17:36:37 +02:00
2020-01-25 15:11:37 -04:00
2020-02-27 16:43:29 -04:00
2019-07-25 12:07:14 -03:00
2019-02-08 16:14:21 -07:00
2020-01-07 16:10:53 -04:00
2020-01-07 16:10:53 -04:00
2020-02-19 14:25:52 -04:00
2020-03-04 13:43:02 -04:00
2019-12-12 15:38:15 -05:00
2020-01-07 16:10:53 -04:00
2020-03-13 10:30:11 -03:00
2019-08-20 13:27:53 -04:00
2020-01-25 14:48:33 -04:00
2020-03-04 14:28:25 -04:00
2019-08-27 13:09:23 -03:00
2019-08-27 13:09:23 -03:00
2019-10-22 14:45:31 -03:00
2019-03-25 21:14:12 -03:00
2018-12-19 16:28:03 -07:00
2019-11-12 20:20:15 -04:00
2020-01-13 16:20:16 -04:00
2019-06-28 21:18:23 -03:00
2019-05-07 16:06:03 -03:00
2019-10-24 20:49:37 -03:00
2020-03-13 10:23:38 -03:00
2018-12-12 07:40:16 -07:00
2020-01-16 15:55:45 -04:00
2020-01-13 16:20:16 -04:00
2019-10-23 15:58:31 -03:00
2019-10-23 15:58:31 -03:00
2019-06-02 18:06:26 -07:00
2020-02-20 13:19:21 -04:00
2020-01-03 16:02:32 -04:00
2018-10-16 13:34:01 -04:00
2020-02-28 11:16:08 -04:00
2018-12-12 07:40:16 -07:00
2019-11-12 20:20:15 -04:00
2020-01-07 16:10:53 -04:00
2019-06-18 22:44:08 -04:00
2020-03-10 14:29:07 -03:00
2020-01-31 14:40:36 -08:00
2020-02-13 10:00:50 -04:00
2020-03-04 13:43:02 -04:00
2020-01-13 16:20:15 -04:00
2020-01-16 15:55:45 -04:00
2018-06-25 14:19:57 -06:00
2020-01-16 15:55:45 -04:00
2019-04-08 13:05:25 -03:00
2020-01-13 16:20:16 -04:00
2020-01-16 15:55:46 -04:00
2019-04-08 13:05:25 -03:00
2019-04-08 13:05:25 -03:00
2019-06-28 21:18:23 -03:00
2020-02-13 09:44:49 -04:00
2020-01-13 16:20:16 -04:00
2020-01-30 16:28:52 -04:00
2020-03-04 13:43:02 -04:00