Will Shiu
a6f4129378
locks: fix KASAN: use-after-free in trace_event_raw_event_filelock_lock
...
[ Upstream commit 74f6f5912693ce454384eaeec48705646a21c74f ]
As following backtrace, the struct file_lock request , in posix_lock_inode
is free before ftrace function using.
Replace the ftrace function ahead free flow could fix the use-after-free
issue.
[name:report&]===============================================
BUG:KASAN: use-after-free in trace_event_raw_event_filelock_lock+0x80/0x12c
[name:report&]Read at addr f6ffff8025622620 by task NativeThread/16753
[name:report_hw_tags&]Pointer tag: [f6], memory tag: [fe]
[name:report&]
BT:
Hardware name: MT6897 (DT)
Call trace:
dump_backtrace+0xf8/0x148
show_stack+0x18/0x24
dump_stack_lvl+0x60/0x7c
print_report+0x2c8/0xa08
kasan_report+0xb0/0x120
__do_kernel_fault+0xc8/0x248
do_bad_area+0x30/0xdc
do_tag_check_fault+0x1c/0x30
do_mem_abort+0x58/0xbc
el1_abort+0x3c/0x5c
el1h_64_sync_handler+0x54/0x90
el1h_64_sync+0x68/0x6c
trace_event_raw_event_filelock_lock+0x80/0x12c
posix_lock_inode+0xd0c/0xd60
do_lock_file_wait+0xb8/0x190
fcntl_setlk+0x2d8/0x440
...
[name:report&]
[name:report&]Allocated by task 16752:
...
slab_post_alloc_hook+0x74/0x340
kmem_cache_alloc+0x1b0/0x2f0
posix_lock_inode+0xb0/0xd60
...
[name:report&]
[name:report&]Freed by task 16752:
...
kmem_cache_free+0x274/0x5b0
locks_dispose_list+0x3c/0x148
posix_lock_inode+0xc40/0xd60
do_lock_file_wait+0xb8/0x190
fcntl_setlk+0x2d8/0x440
do_fcntl+0x150/0xc18
...
Signed-off-by: Will Shiu <Will.Shiu@mediatek.com>
Signed-off-by: Jeff Layton <jlayton@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
2023-09-23 11:01:04 +02:00
..
2022-06-22 14:13:12 +02:00
2020-10-24 12:26:05 -07:00
2023-02-01 08:23:11 +01:00
2023-06-21 15:45:40 +02:00
2023-09-23 11:01:04 +02:00
2021-01-06 14:56:52 +01:00
2023-09-23 11:01:04 +02:00
2021-03-30 14:32:07 +02:00
2023-08-11 11:57:52 +02:00
2023-08-26 15:26:55 +02:00
2023-03-11 16:39:51 +01:00
2023-09-21 09:45:15 +02:00
2022-11-10 18:14:25 +01:00
2023-01-14 10:15:19 +01:00
2022-02-01 17:25:39 +01:00
2023-09-19 12:20:22 +02:00
2021-05-26 12:06:55 +02:00
2020-11-25 16:55:02 +01:00
2023-09-19 12:20:02 +02:00
2023-08-11 11:57:55 +02:00
2023-08-11 11:57:54 +02:00
2023-09-19 12:20:27 +02:00
2023-07-27 08:44:25 +02:00
2022-06-09 10:20:58 +02:00
2021-09-18 13:40:15 +02:00
2023-09-19 12:20:27 +02:00
2023-08-26 15:26:45 +02:00
2023-03-11 16:39:55 +01:00
2023-05-30 12:57:47 +01:00
2021-04-14 08:42:06 +02:00
2023-01-14 10:16:20 +01:00
2022-07-07 17:52:19 +02:00
2021-11-12 14:58:33 +01:00
2023-05-17 11:47:52 +02:00
2023-07-27 08:44:13 +02:00
2023-09-19 12:20:15 +02:00
2023-07-27 08:44:05 +02:00
2023-09-19 12:20:15 +02:00
2022-04-13 21:01:01 +02:00
2023-09-19 12:20:25 +02:00
2020-12-30 11:53:45 +01:00
2023-09-19 12:20:15 +02:00
2023-09-19 12:20:03 +02:00
2023-09-19 12:20:04 +02:00
2023-07-27 08:44:15 +02:00
2022-11-25 17:45:57 +01:00
2023-09-19 12:20:09 +02:00
2023-01-14 10:16:20 +01:00
2023-09-19 12:20:05 +02:00
2023-09-19 12:20:22 +02:00
2023-09-19 12:20:22 +02:00
2021-09-30 10:11:08 +02:00
2023-09-19 12:20:10 +02:00
2023-07-27 08:44:13 +02:00
2023-09-19 12:20:06 +02:00
2020-10-24 12:26:05 -07:00
2023-02-22 12:55:56 +01:00
2023-08-11 11:57:53 +02:00
2022-09-20 12:38:31 +02:00
2023-05-17 11:47:35 +02:00
2023-09-19 12:20:23 +02:00
2020-10-24 12:26:05 -07:00
2021-10-17 10:43:33 +02:00
2023-09-19 12:20:22 +02:00
2023-06-14 11:09:59 +02:00
2023-04-05 11:23:51 +02:00
2023-02-22 12:55:54 +01:00
2023-03-22 13:30:08 +01:00
2023-01-14 10:16:26 +01:00
2022-11-03 23:57:49 +09:00
2022-06-09 10:20:47 +02:00
2023-01-14 10:16:13 +01:00
2021-06-03 09:00:45 +02:00
2022-11-25 17:45:56 +01:00
2023-01-14 10:15:59 +01:00
2023-01-04 11:39:22 +01:00
2020-10-14 14:54:45 -07:00
2022-06-09 10:21:16 +02:00
2021-04-14 08:41:58 +02:00
2023-09-19 12:20:06 +02:00
2023-06-21 15:45:37 +02:00
2022-11-03 23:57:49 +09:00
2022-10-30 09:41:18 +01:00
2022-05-18 10:23:48 +02:00
2023-08-11 11:57:53 +02:00
2023-07-27 08:44:13 +02:00
2020-10-13 18:38:27 -07:00
2023-05-17 11:48:10 +02:00
2023-07-27 08:44:13 +02:00
2023-07-27 08:44:13 +02:00
2022-05-25 09:17:54 +02:00
2021-02-17 11:02:21 +01:00
2021-10-27 09:56:51 +02:00
2023-01-14 10:15:19 +01:00
2023-09-23 11:01:04 +02:00
2023-01-04 11:39:23 +01:00
2023-01-14 10:16:50 +01:00
2023-09-19 12:20:06 +02:00
2021-08-26 08:35:57 -04:00
2023-08-11 11:57:53 +02:00
2022-06-06 08:42:41 +02:00
2023-01-14 10:16:27 +01:00
2021-03-17 17:06:13 +01:00
2020-12-30 11:54:02 +01:00
2022-12-19 12:27:30 +01:00
2021-04-21 13:00:54 +02:00
2022-07-21 21:20:01 +02:00
2022-01-29 10:26:11 +01:00
2021-07-20 16:05:59 +02:00
2022-09-05 10:28:58 +02:00
2022-10-17 17:26:07 +02:00
2022-04-27 13:53:54 +02:00
2023-05-30 12:57:55 +01:00
2023-08-11 11:57:54 +02:00
2022-08-31 17:15:14 +02:00
2022-10-26 13:25:17 +02:00
2023-01-14 10:15:16 +01:00