Nikita Zhandarovich
772a7def98
do_sys_name_to_handle(): use kzalloc() to fix kernel-infoleak
...
[ Upstream commit 3948abaa4e2be938ccdfc289385a27342fb13d43 ]
syzbot identified a kernel information leak vulnerability in
do_sys_name_to_handle() and issued the following report [1].
[1]
"BUG: KMSAN: kernel-infoleak in instrument_copy_to_user include/linux/instrumented.h:114 [inline]
BUG: KMSAN: kernel-infoleak in _copy_to_user+0xbc/0x100 lib/usercopy.c:40
instrument_copy_to_user include/linux/instrumented.h:114 [inline]
_copy_to_user+0xbc/0x100 lib/usercopy.c:40
copy_to_user include/linux/uaccess.h:191 [inline]
do_sys_name_to_handle fs/fhandle.c:73 [inline]
__do_sys_name_to_handle_at fs/fhandle.c:112 [inline]
__se_sys_name_to_handle_at+0x949/0xb10 fs/fhandle.c:94
__x64_sys_name_to_handle_at+0xe4/0x140 fs/fhandle.c:94
...
Uninit was created at:
slab_post_alloc_hook+0x129/0xa70 mm/slab.h:768
slab_alloc_node mm/slub.c:3478 [inline]
__kmem_cache_alloc_node+0x5c9/0x970 mm/slub.c:3517
__do_kmalloc_node mm/slab_common.c:1006 [inline]
__kmalloc+0x121/0x3c0 mm/slab_common.c:1020
kmalloc include/linux/slab.h:604 [inline]
do_sys_name_to_handle fs/fhandle.c:39 [inline]
__do_sys_name_to_handle_at fs/fhandle.c:112 [inline]
__se_sys_name_to_handle_at+0x441/0xb10 fs/fhandle.c:94
__x64_sys_name_to_handle_at+0xe4/0x140 fs/fhandle.c:94
...
Bytes 18-19 of 20 are uninitialized
Memory access of size 20 starts at ffff888128a46380
Data copied to user address 0000000020000240"
Per Chuck Lever's suggestion, use kzalloc() instead of kmalloc() to
solve the problem.
Fixes: 990d6c2d7aee ("vfs: Add name to file handle conversion support")
Suggested-by: Chuck Lever III <chuck.lever@oracle.com>
Reported-and-tested-by: <syzbot+09b349b3066c2e0b1e96@syzkaller.appspotmail.com>
Signed-off-by: Nikita Zhandarovich <n.zhandarovich@fintech.ru>
Link: https://lore.kernel.org/r/20240119153906.4367-1-n.zhandarovich@fintech.ru
Reviewed-by: Jan Kara <jack@suse.cz>
Signed-off-by: Christian Brauner <brauner@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
2024-03-26 18:22:13 -04:00
..
2022-06-22 14:11:02 +02:00
2023-02-06 07:52:36 +01:00
2024-03-06 14:36:09 +00:00
2023-09-23 11:00:02 +02:00
2021-01-06 14:48:39 +01:00
2024-03-26 18:22:13 -04:00
2024-03-06 14:36:10 +00:00
2024-02-23 08:25:03 +01:00
2024-01-08 11:29:47 +01:00
2023-03-11 16:43:56 +01:00
2023-01-18 11:41:09 +01:00
2021-09-12 08:56:38 +02:00
2023-09-23 10:59:40 +02:00
2022-02-01 17:24:34 +01:00
2023-09-23 10:59:55 +02:00
2024-02-23 08:24:56 +01:00
2020-12-02 08:49:53 +01:00
2023-09-23 10:59:36 +02:00
2023-09-23 11:00:04 +02:00
2024-03-01 13:13:33 +01:00
2024-02-23 08:25:00 +01:00
2023-06-09 10:29:01 +02:00
2021-09-22 12:26:25 +02:00
2023-09-23 11:00:00 +02:00
2024-01-25 14:34:24 -08:00
2023-03-11 16:43:59 +01:00
2023-06-09 10:29:01 +02:00
2021-04-14 08:24:14 +02:00
2024-03-06 14:36:10 +00:00
2024-03-01 13:13:35 +01:00
2023-06-09 10:29:01 +02:00
2024-01-25 14:34:20 -08:00
2023-07-27 08:37:25 +02:00
2024-02-23 08:24:55 +01:00
2024-02-23 08:25:03 +01:00
2023-09-23 10:59:48 +02:00
2022-04-15 14:18:35 +02:00
2024-01-25 14:34:24 -08:00
2020-12-30 11:51:22 +01:00
2023-11-28 16:50:21 +00:00
2024-03-01 13:13:32 +01:00
2023-09-23 10:59:38 +02:00
2023-07-27 08:37:26 +02:00
2022-11-25 17:42:22 +01:00
2024-02-23 08:24:49 +01:00
2023-06-09 10:29:01 +02:00
2023-01-18 11:41:39 +01:00
2023-12-08 08:44:27 +01:00
2023-09-23 10:59:55 +02:00
2024-02-23 08:24:55 +01:00
2021-09-30 10:09:26 +02:00
2023-11-28 16:50:19 +00:00
2020-10-29 09:57:53 +01:00
2023-09-23 10:59:40 +02:00
2020-08-26 10:40:51 +02:00
2023-02-22 12:50:39 +01:00
2021-03-07 12:20:48 +01:00
2023-08-11 11:53:59 +02:00
2023-09-23 11:00:06 +02:00
2024-02-23 08:24:49 +01:00
2023-09-23 10:59:56 +02:00
2020-08-21 13:05:37 +02:00
2023-09-23 10:59:55 +02:00
2023-06-28 10:18:42 +02:00
2024-03-01 13:13:38 +01:00
2023-09-23 11:00:06 +02:00
2023-01-18 11:41:46 +01:00
2023-10-10 21:46:42 +02:00
2021-10-06 15:42:35 +02:00
2023-01-18 11:41:46 +01:00
2023-01-18 11:41:33 +01:00
2024-01-08 11:29:48 +01:00
2022-11-25 17:42:22 +01:00
2023-01-18 11:41:25 +01:00
2024-02-23 08:25:15 +01:00
2020-12-11 13:23:30 +01:00
2020-10-29 09:57:45 +01:00
2022-06-14 18:11:41 +02:00
2024-02-23 08:25:00 +01:00
2021-04-14 08:24:11 +02:00
2023-09-23 10:59:40 +02:00
2023-06-28 10:18:35 +02:00
2022-06-06 08:33:50 +02:00
2021-09-15 09:47:28 +02:00
2024-03-26 18:22:13 -04:00
2022-05-25 09:14:34 +02:00
2023-03-17 08:32:47 +01:00
2020-04-17 10:50:21 +02:00
2023-07-27 08:37:25 +02:00
2023-05-17 11:35:58 +02:00
2024-02-23 08:24:49 +01:00
2023-07-27 08:37:26 +02:00
2024-03-26 18:22:12 -04:00
2023-01-18 11:40:55 +01:00
2023-09-23 11:00:02 +02:00
2023-01-18 11:41:59 +01:00
2024-02-23 08:24:49 +01:00
2021-08-26 08:36:22 -04:00
2020-03-18 07:17:51 +01:00
2021-08-12 13:21:02 +02:00
2023-01-18 11:41:44 +01:00
2021-03-17 17:03:33 +01:00
2021-04-21 12:56:16 +02:00
2022-01-29 10:25:11 +01:00
2021-07-20 16:10:54 +02:00
2022-09-05 10:27:47 +02:00
2022-10-17 17:24:32 +02:00
2022-04-27 13:50:48 +02:00
2023-05-30 12:44:07 +01:00
2023-08-11 11:53:59 +02:00
2023-12-08 08:44:27 +01:00
2022-10-26 13:22:21 +02:00
2023-01-18 11:40:53 +01:00