Will Shiu
766e56fadd
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:09:55 +02:00
..
2022-08-17 14:24:07 +02:00
2023-02-01 08:27:06 +01:00
2023-06-21 15:59:18 +02:00
2023-09-23 11:09:54 +02:00
2021-08-19 09:02:55 +09:00
2023-09-23 11:09:54 +02:00
2022-07-02 16:41:14 +02:00
2023-08-11 15:13:56 +02:00
2023-08-26 14:23:36 +02:00
2023-03-10 09:39:50 +01:00
2022-12-31 13:14:15 +01:00
2022-11-10 18:15:37 +01:00
2022-12-31 13:14:03 +01:00
2022-02-01 17:27:01 +01:00
2023-09-19 12:22:52 +02:00
2022-07-02 16:41:14 +02:00
2023-09-06 21:28:37 +01:00
2023-08-26 14:23:37 +02:00
2022-06-09 10:23:32 +02:00
2023-08-11 15:13:58 +02:00
2023-09-19 12:23:01 +02:00
2023-07-23 13:47:46 +02:00
2022-06-09 10:22:42 +02:00
2021-10-04 22:13:12 +01:00
2023-09-19 12:23:01 +02:00
2023-09-19 12:22:56 +02:00
2023-03-10 09:39:57 +01:00
2023-05-24 17:36:43 +01:00
2021-08-26 22:28:02 +02:00
2022-12-31 13:14:44 +01:00
2022-06-09 10:22:55 +02:00
2021-11-12 15:05:50 +01:00
2023-09-19 12:23:01 +02:00
2023-07-23 13:47:34 +02:00
2023-09-19 12:22:43 +02:00
2023-07-23 13:47:23 +02:00
2023-09-19 12:22:27 +02:00
2023-09-19 12:22:43 +02:00
2022-04-13 20:59:10 +02:00
2021-12-29 12:28:59 +01:00
2023-09-19 12:22:56 +02:00
2021-10-04 22:02:17 +01:00
2023-09-19 12:22:43 +02:00
2023-09-06 21:28:40 +01:00
2023-09-19 12:22:27 +02:00
2023-07-23 13:47:36 +02:00
2022-11-26 09:24:52 +01:00
2023-08-26 14:23:25 +02:00
2023-09-19 12:22:34 +02:00
2022-12-31 13:14:44 +01:00
2023-09-19 12:22:28 +02:00
2023-09-19 12:22:52 +02:00
2023-09-19 12:22:52 +02:00
2021-09-21 08:36:48 -07:00
2023-09-19 12:22:35 +02:00
2023-07-23 13:47:33 +02:00
2023-09-19 12:22:30 +02:00
2021-12-14 10:57:12 +01:00
2023-02-22 12:57:07 +01:00
2023-08-11 15:13:58 +02:00
2022-09-20 12:39:43 +02:00
2023-05-17 11:50:14 +02:00
2023-09-19 12:22:53 +02:00
2021-08-19 09:02:55 +09:00
2021-09-27 11:26:21 -07:00
2023-09-19 12:22:52 +02:00
2023-06-14 11:13:09 +02:00
2023-04-05 11:25:01 +02:00
2023-02-22 12:57:05 +01:00
2023-08-30 16:18:19 +02:00
2021-08-18 22:08:24 +02:00
2021-09-05 10:15:05 -07:00
2023-01-12 11:58:46 +01:00
2022-11-03 23:59:12 +09:00
2022-06-09 10:22:26 +02:00
2022-12-31 13:14:39 +01:00
2022-11-26 09:24:51 +01:00
2022-12-31 13:14:30 +01:00
2022-04-08 14:24:18 +02:00
2021-09-02 10:07:29 -07:00
2022-09-28 11:11:56 +02:00
2021-09-03 09:58:10 -07:00
2023-09-19 12:22:30 +02:00
2023-06-21 15:59:14 +02:00
2022-11-03 23:59:12 +09:00
2021-09-03 10:08:28 -07:00
2022-10-26 12:34:58 +02:00
2023-08-11 15:13:58 +02:00
2021-08-23 01:25:40 -04:00
2023-07-23 13:47:34 +02:00
2021-09-07 16:07:47 -04:00
2023-05-17 11:50:16 +02:00
2023-07-23 13:47:33 +02:00
2023-08-30 16:18:19 +02:00
2022-05-25 09:57:26 +02:00
2021-09-12 10:10:21 -07:00
2021-10-18 20:22:03 -10:00
2022-12-31 13:14:03 +01:00
2023-09-23 11:09:55 +02:00
2022-12-14 11:37:31 +01:00
2023-01-12 11:59:20 +01:00
2023-09-19 12:22:30 +02:00
2023-04-13 16:48:25 +02:00
2023-08-11 15:13:57 +02:00
2022-06-06 08:43:37 +02:00
2023-01-12 11:58:47 +01:00
2022-07-02 16:41:17 +02:00
2022-07-02 16:41:14 +02:00
2022-12-19 12:36:39 +01:00
2022-07-21 21:24:14 +02:00
2022-01-29 10:58:25 +01:00
2022-07-12 16:35:08 +02:00
2021-12-14 10:57:15 +01:00
2022-10-26 12:34:17 +02:00
2022-04-27 14:38:57 +02:00
2023-05-24 17:36:54 +01:00
2023-08-11 15:13:58 +02:00
2022-04-27 14:38:50 +02:00
2022-10-26 12:34:36 +02:00
2022-12-31 13:14:01 +01:00