Re: KASAN: use-after-free Read in userfaultfd_release (2)

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, Jul 13, 2020 at 08:34:06AM -0700, syzbot wrote:
> syzbot has bisected this bug to:
> 
> commit d08ac70b1e0dc71ac2315007bcc3efb283b2eae4
> Author: Daniel Colascione <dancol@xxxxxxxxxx>
> Date:   Wed Apr 1 21:39:03 2020 +0000
> 
>     Wire UFFD up to SELinux
> 
> bisection log:  https://syzkaller.appspot.com/x/bisect.txt?x=14a79d13100000
> start commit:   89032636 Add linux-next specific files for 20200708
> git tree:       linux-next
> final crash:    https://syzkaller.appspot.com/x/report.txt?x=16a79d13100000
> console output: https://syzkaller.appspot.com/x/log.txt?x=12a79d13100000
> kernel config:  https://syzkaller.appspot.com/x/.config?x=64a250ebabc6c320
> dashboard link: https://syzkaller.appspot.com/bug?extid=75867c44841cb6373570
> syz repro:      https://syzkaller.appspot.com/x/repro.syz?x=13c4c8db100000
> C reproducer:   https://syzkaller.appspot.com/x/repro.c?x=12cbb68f100000
> 
> Reported-by: syzbot+75867c44841cb6373570@xxxxxxxxxxxxxxxxxxxxxxxxx
> Fixes: d08ac70b1e0d ("Wire UFFD up to SELinux")
> 
> For information about bisection process see: https://goo.gl/tpsmEJ#bisection

This is rather easy to reproduce here,

# git clone https://gitlab.com/cailca/linux-mm
# cd linux-mm; make
# ./random -x 0-100 -f

Not sure if this is right fix (nobody reviewed it yet).
https://lore.kernel.org/lkml/20200714161203.31879-1-yanfei.xu@xxxxxxxxxxxxx/

[  748.763634][T11960] BUG: KASAN: use-after-free in userfaultfd_release+0x537/0x6b0
[  748.800768][T11960] Read of size 8 at addr ffff8883a0c7fa08 by task trinity-c11/11960
[  748.838000][T11960] CPU: 2 PID: 11960 Comm: trinity-c11 Not tainted 5.8.0-rc5-next-20200717 #2
[  748.878669][T11960] Hardware name: HP ProLiant BL660c Gen9, BIOS I38 10/17/2018
[  748.913689][T11960] Call Trace:
[  748.928528][T11960]  dump_stack+0x9d/0xe0
[  748.947260][T11960]  ? userfaultfd_release+0x537/0x6b0
[  748.972135][T11960]  print_address_description.constprop.8.cold.9+0x9/0x4fc
[  749.005085][T11960]  ? log_store.cold.34+0x11/0x11
[  749.027014][T11960]  ? debug_check_no_obj_freed+0x1f1/0x3d4
[  749.052665][T11960]  ? userfaultfd_release+0x537/0x6b0
[  749.077264][T11960]  ? userfaultfd_release+0x537/0x6b0
[  749.102057][T11960]  kasan_report.cold.10+0x37/0x7c
[  749.115736][T12010] sock: process `trinity-c4' is using obsolete setsockopt SO_BSDCOMPAT
[  749.124989][T11960]  ? userfaultfd_release+0x537/0x6b0
[  749.124998][T11960]  userfaultfd_release+0x537/0x6b0
[  749.125005][T11960]  ? task_work_run+0xa5/0x170
[  749.125011][T11960]  ? fsnotify_first_mark+0x140/0x140
[  749.125019][T11960]  ? userfaultfd_event_wait_completion+0x970/0x970
[  749.290933][T11960]  __fput+0x1f9/0x7d0
[  749.309578][T11960]  ? trace_hardirqs_on+0x20/0x1b5
[  749.332751][T11960]  task_work_run+0xce/0x170
[  749.353822][T11960]  __prepare_exit_to_usermode+0x100/0x110
[  749.380276][T11960]  do_syscall_64+0x6b/0x310
[  749.401043][T11960]  ? trace_hardirqs_off+0x12/0x1a0
[  749.425256][T11960]  ? asm_exc_page_fault+0x8/0x30
[  749.448720][T11960]  entry_SYSCALL_64_after_hwframe+0x44/0xa9
[  749.476365][T11960] RIP: 0033:0x7f30c9d446ed
[  749.496247][T11960] Code: Bad RIP value.
[  749.514434][T11960] RSP: 002b:00007ffed5eb17d8 EFLAGS: 00000246 ORIG_RAX: 0000000000000143
[  749.553554][T11960] RAX: ffffffffffffffe8 RBX: 0000000000000143 RCX: 00007f30c9d446ed
[  749.589546][T11960] RDX: 0000000000000000 RSI: 0000000000000008 RDI: 0000000000000800
[  749.626635][T11960] RBP: 0000000000000143 R08: 0000110783405b9e R09: 00a07f7843429cfc
[  749.662279][T11960] R10: 0000000000000e92 R11: 0000000000000246 R12: 0000000000000002
[  749.700555][T11960] R13: 00007f30ca3e4058 R14: 00007f30ca4316c0 R15: 00007f30ca3e4000
[  749.738586][T11960] Allocated by task 11960:
[  749.758101][T11960]  kasan_save_stack+0x19/0x40
[  749.780502][T11960]  __kasan_kmalloc.constprop.11+0xc1/0xd0
[  749.808176][T11960]  slab_post_alloc_hook+0x47/0x4e0
[  749.832767][T11960]  kmem_cache_alloc+0xe5/0x2a0
[  749.854802][T11960]  __x64_sys_userfaultfd+0x90/0x42e
[  749.878783][T11960]  do_syscall_64+0x5f/0x310
[  749.899304][T11960]  entry_SYSCALL_64_after_hwframe+0x44/0xa9
[  749.926310][T11960] Freed by task 11960:
[  749.945040][T11960]  kasan_save_stack+0x19/0x40
[  749.966583][T11960]  kasan_set_track+0x1c/0x30
[  749.987533][T11960]  kasan_set_free_info+0x1b/0x30
[  750.010336][T11960]  __kasan_slab_free+0xf4/0x130
[  750.032331][T11960]  slab_free_freelist_hook+0x57/0x1b0
[  750.057157][T11960]  kmem_cache_free+0xe9/0x420
[  750.078387][T11960]  __x64_sys_userfaultfd+0x36e/0x42e
[  750.086326][T12643] splice read not supported for file devices/pci0000:bf/0000:bf:09.0/local_cpus (pid: 12643 comm: trinity-c28)
[  750.103577][T11960]  do_syscall_64+0x5f/0x310
[  750.103581][T11960]  entry_SYSCALL_64_after_hwframe+0x44/0xa9
[  750.103587][T11960] The buggy address belongs to the object at ffff8883a0c7f880
[  750.103587][T11960]  which belongs to the cache userfaultfd_ctx_cache of size 408
[  750.103591][T11960] The buggy address is located 392 bytes inside of
[  750.103591][T11960]  408-byte region [ffff8883a0c7f880, ffff8883a0c7fa18)
[  750.103594][T11960] The buggy address belongs to the page:
[  750.103600][T11960] page:000000003aed2e67 refcount:1 mapcount:0 mapping:0000000000000000 index:0x0 pfn:0x3a0c78
[  750.103607][T11960] head:000000003aed2e67 order:3 compound_mapcount:0 compound_pincount:0
[  750.458247][T11960] flags: 0xbfffc000010200(slab|head)
[  750.483010][T11960] raw: 00bfffc000010200 ffffea0010c3c008 ffff8888078f9ba8 ffff888806fcc900
[  750.523034][T11960] raw: 0000000000000000 0000000000270027 00000001ffffffff 0000000000000000
[  750.562783][T11960] page dumped because: kasan: bad access detected
[  750.593243][T11960] Memory state around the buggy address:
[  750.619628][T11960]  ffff8883a0c7f900: fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb
[  750.657472][T11960]  ffff8883a0c7f980: fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb
[  750.694927][T11960] >ffff8883a0c7fa00: fb fb fb fc fc fc fc fc fc fc fc fc fc fc fc fc
[  750.733031][T11960]                       ^
[  750.752984][T11960]  ffff8883a0c7fa80: fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc
[  750.790776][T11960]  ffff8883a0c7fb00: fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc
[  750.831467][T11960] ==================================================================
[  750.869054][T11960] Disabling lock debugging due to kernel taint
[  750.897800][T11960] ==================================================================
[  750.935726][T11960] BUG: KASAN: double-free or invalid-free in kmem_cache_free+0xe9/0x420
[  750.973793][T11960] CPU: 2 PID: 11960 Comm: trinity-c11 Tainted: G    B             5.8.0-rc5-next-20200717 #2
[  751.021533][T11960] Hardware name: HP ProLiant BL660c Gen9, BIOS I38 10/17/2018
[  751.055710][T11960] Call Trace:
[  751.070746][T11960]  dump_stack+0x9d/0xe0
[  751.089519][T11960]  print_address_description.constprop.8.cold.9+0x9/0x4fc
[  751.123128][T11960]  ? log_store.cold.34+0x11/0x11
[  751.145650][T11960]  ? kmem_cache_free+0xe9/0x420
[  751.167973][T11960]  kasan_report_invalid_free+0x50/0x80
[  751.193005][T11960]  ? kmem_cache_free+0xe9/0x420
[  751.215368][T11960]  __kasan_slab_free+0x123/0x130
[  751.237772][T11960]  slab_free_freelist_hook+0x57/0x1b0
[  751.262582][T11960]  ? userfaultfd_release+0x337/0x6b0
[  751.286825][T11960]  kmem_cache_free+0xe9/0x420
[  751.309669][T11960]  userfaultfd_release+0x337/0x6b0
[  751.335785][T11960]  ? task_work_run+0xa5/0x170
[  751.357946][T11960]  ? fsnotify_first_mark+0x140/0x140
[  751.382109][T11960]  ? userfaultfd_event_wait_completion+0x970/0x970
[  751.412642][T11960]  __fput+0x1f9/0x7d0
[  751.430775][T11960]  ? trace_hardirqs_on+0x20/0x1b5
[  751.453732][T11960]  task_work_run+0xce/0x170
[  751.474992][T11960]  __prepare_exit_to_usermode+0x100/0x110
[  751.501489][T11960]  do_syscall_64+0x6b/0x310
[  751.521985][T11960]  ? trace_hardirqs_off+0x12/0x1a0
[  751.545484][T11960]  ? asm_exc_page_fault+0x8/0x30
[  751.568219][T11960]  entry_SYSCALL_64_after_hwframe+0x44/0xa9
[  751.595779][T11960] RIP: 0033:0x7f30c9d446ed
[  751.616310][T11960] Code: Bad RIP value.
[  751.635437][T11960] RSP: 002b:00007ffed5eb17d8 EFLAGS: 00000246 ORIG_RAX: 0000000000000143
[  751.675839][T11960] RAX: ffffffffffffffe8 RBX: 0000000000000143 RCX: 00007f30c9d446ed
[  751.713515][T11960] RDX: 0000000000000000 RSI: 0000000000000008 RDI: 0000000000000800
[  751.750030][T11960] RBP: 0000000000000143 R08: 0000110783405b9e R09: 00a07f7843429cfc
[  751.786921][T11960] R10: 0000000000000e92 R11: 0000000000000246 R12: 0000000000000002
[  751.824777][T11960] R13: 00007f30ca3e4058 R14: 00007f30ca4316c0 R15: 00007f30ca3e4000
[  751.864847][T11960] Allocated by task 11960:
[  751.884987][T11960]  kasan_save_stack+0x19/0x40
[  751.906294][T11960]  __kasan_kmalloc.constprop.11+0xc1/0xd0
[  751.932455][T11960]  slab_post_alloc_hook+0x47/0x4e0
[  751.955962][T11960]  kmem_cache_alloc+0xe5/0x2a0
[  751.977979][T11960]  __x64_sys_userfaultfd+0x90/0x42e
[  752.001413][T11960]  do_syscall_64+0x5f/0x310
[  752.022167][T11960]  entry_SYSCALL_64_after_hwframe+0x44/0xa9
[  752.049563][T11960] Freed by task 11960:
[  752.068070][T11960]  kasan_save_stack+0x19/0x40
[  752.089305][T11960]  kasan_set_track+0x1c/0x30
[  752.110353][T11960]  kasan_set_free_info+0x1b/0x30
[  752.132781][T11960]  __kasan_slab_free+0xf4/0x130
[  752.155004][T11960]  slab_free_freelist_hook+0x57/0x1b0
[  752.179879][T11960]  kmem_cache_free+0xe9/0x420
[  752.202146][T11960]  __x64_sys_userfaultfd+0x36e/0x42e
[  752.228182][T11960]  do_syscall_64+0x5f/0x310
[  752.248714][T11960]  entry_SYSCALL_64_after_hwframe+0x44/0xa9
[  752.276331][T11960] The buggy address belongs to the object at ffff8883a0c7f880
[  752.276331][T11960]  which belongs to the cache userfaultfd_ctx_cache of size 408
[  752.348047][T11960] The buggy address is located 0 bytes inside of
[  752.348047][T11960]  408-byte region [ffff8883a0c7f880, ffff8883a0c7fa18)
[  752.412451][T11960] The buggy address belongs to the page:
[  752.438706][T11960] page:000000003aed2e67 refcount:1 mapcount:0 mapping:0000000000000000 index:0x0 pfn:0x3a0c78
[  752.485700][T11960] head:000000003aed2e67 order:3 compound_mapcount:0 compound_pincount:0
[  752.524609][T11960] flags: 0xbfffc000010200(slab|head)
[  752.549300][T11960] raw: 00bfffc000010200 ffffea0010c3c008 ffff8888078f9ba8 ffff888806fcc900
[  752.589287][T11960] raw: 0000000000000000 0000000000270027 00000001ffffffff 0000000000000000
[  752.629841][T11960] page dumped because: kasan: bad access detected
[  752.659522][T11960] Memory state around the buggy address:
[  752.685915][T11960]  ffff8883a0c7f780: fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc
[  752.724590][T11960]  ffff8883a0c7f800: fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc
[  752.762413][T11960] >ffff8883a0c7f880: fa fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb
[  752.800022][T11960]                    ^
[  752.818732][T11960]  ffff8883a0c7f900: fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb
[  752.857815][T11960]  ffff8883a0c7f980: fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb
[  752.897699][T11960] ==================================================================
[  753.255121][T11960] ------------[ cut here ]------------
[  753.279452][T11960] WARNING: CPU: 2 PID: 11960 at kernel/fork.c:679 __mmdrop+0x1ff/0x300
[  753.316503][T11960] Modules linked in: kvm_intel kvm irqbypass efivars nls_ascii nls_cp437 vfat fat ip_tables x_tables sd_mod bnx2x hpsa mdio scsi_transport_sas firmware_class dm_mirror dm_region_hash dm_log dm_mod efivarfs
[  753.411968][T11960] CPU: 2 PID: 11960 Comm: trinity-c11 Tainted: G    B             5.8.0-rc5-next-20200717 #2
[  753.458387][T11960] Hardware name: HP ProLiant BL660c Gen9, BIOS I38 10/17/2018
[  753.491586][T11960] RIP: 0010:__mmdrop+0x1ff/0x300
[  753.513019][T11960] Code: 00 01 00 00 49 8b 14 ef 48 89 de 48 c7 c7 80 31 a4 8a e8 cd f1 15 00 e9 4e ff ff ff 0f 0b 48 c7 c7 a0 7e 0f 8b e8 8d af bb 00 <0f> 0b e9 88 fe ff ff 0f 0b e9 49 fe ff ff 48 c7 c7 20 7e 0f 8b e8
[  753.601968][T11960] RSP: 0018:ffffc90021fcf9e0 EFLAGS: 00010246
[  753.629408][T11960] RAX: dffffc0000000000 RBX: ffff8897cfe00040 RCX: ffffffff89a3167e
[  753.665107][T11960] RDX: 1ffff112f89a0070 RSI: 0000000000000004 RDI: ffff8897c4d00380
[  753.701452][T11960] RBP: ffff8897c4d00040 R08: ffffed12f9fc0013 R09: ffffed12f9fc0013
[  753.738794][T11960] R10: ffff8897cfe00093 R11: ffffed12f9fc0012 R12: 00000000000a0003
[  753.775979][T11960] R13: ffff8897c7194140 R14: ffff8890860f8c60 R15: ffff88982da31fd0
[  753.813159][T11960] FS:  0000000000000000(0000) GS:ffff88881e080000(0000) knlGS:0000000000000000
[  753.853965][T11960] CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
[  753.884913][T11960] CR2: 0000000000000008 CR3: 0000000a92614003 CR4: 00000000001706e0
[  753.923791][T11960] DR0: 00007f30c7a00000 DR1: 00007f30c802a000 DR2: 0000000000000000
[  753.959646][T11960] DR3: 0000000000000000 DR6: 00000000ffff0ff0 DR7: 0000000000000600
[  753.995379][T11960] Call Trace:
[  754.009663][T11960]  ? _raw_spin_unlock_irq+0x1f/0x30
[  754.033278][T11960]  userfaultfd_ctx_put+0x317/0x370
[  754.056508][T11960]  userfaultfd_release+0x337/0x6b0
[  754.080202][T11960]  ? fsnotify_first_mark+0x140/0x140
[  754.104819][T11960]  ? debug_object_deactivate+0x3b0/0x3b0
[  754.130879][T11960]  ? userfaultfd_event_wait_completion+0x970/0x970
[  754.160206][T11960]  ? __dentry_kill+0x3d3/0x590
[  754.181320][T11960]  __fput+0x1f9/0x7d0
[  754.198800][T11960]  ? trace_hardirqs_on+0x20/0x1b5
[  754.221003][T11960]  task_work_run+0xce/0x170
[  754.240923][T11960]  do_exit+0x979/0x2580
[  754.259292][T11960]  ? mm_update_next_owner+0x770/0x770
[  754.283147][T11960]  ? lock_downgrade+0x730/0x730
[  754.304657][T11960]  ? rcu_read_unlock+0x50/0x50
[  754.325854][T11960]  ? do_raw_spin_lock+0x121/0x290
[  754.348294][T11960]  ? rwlock_bug.part.1+0x90/0x90
[  754.370156][T11960]  do_group_exit+0xe7/0x2a0
[  754.391722][T11960]  get_signal+0x3b2/0x1f60
[  754.413437][T11960]  ? _down_write_nest_lock+0x150/0x150
[  754.440089][T11960]  do_signal+0x70/0x480
[  754.458414][T11960]  ? task_numa_work+0x6b2/0x910
[  754.479953][T11960]  ? __setup_rt_frame+0x1820/0x1820
[  754.502552][T11960]  ? unlock_page_memcg+0x60/0x60
[  754.524511][T11960]  ? _cond_resched+0x10/0x20
[  754.544897][T11960]  ? task_work_run+0xe6/0x170
[  754.565547][T11960]  ? __prepare_exit_to_usermode+0x97/0x110
[  754.591926][T11960]  __prepare_exit_to_usermode+0xaa/0x110
[  754.617148][T11960]  do_syscall_64+0x6b/0x310
[  754.637097][T11960]  ? trace_hardirqs_off+0x12/0x1a0
[  754.659743][T11960]  ? asm_exc_page_fault+0x8/0x30
[  754.681739][T11960]  entry_SYSCALL_64_after_hwframe+0x44/0xa9
[  754.708333][T11960] RIP: 0033:0x7f30c9d446ed
[  754.728260][T11960] Code: Bad RIP value.
[  754.746087][T11960] RSP: 002b:00007ffed5eb17d8 EFLAGS: 00000246 ORIG_RAX: 0000000000000143
[  754.783883][T11960] RAX: ffffffffffffffe8 RBX: 0000000000000143 RCX: 00007f30c9d446ed
[  754.819590][T11960] RDX: 0000000000000000 RSI: 0000000000000008 RDI: 0000000000000800
[  754.855344][T11960] RBP: 0000000000000143 R08: 0000110783405b9e R09: 00a07f7843429cfc
[  754.890976][T11960] R10: 0000000000000e92 R11: 0000000000000246 R12: 0000000000000002
[  754.930653][T11960] R13: 00007f30ca3e4058 R14: 00007f30ca4316c0 R15: 00007f30ca3e4000
[  754.966737][T11960] irq event stamp: 468838
[  754.985905][T11960] hardirqs last  enabled at (468837): [<ffffffff8a5aa3ff>] _raw_spin_unlock_irq+0x1f/0x30
[  755.030394][T11960] hardirqs last disabled at (468838): [<ffffffff8a5aa24d>] _raw_spin_lock_irqsave+0xd/0x40
[  755.075344][T11960] softirqs last  enabled at (464248): [<ffffffff8a80070f>] __do_softirq+0x70f/0xa9f
[  755.117500][T11960] softirqs last disabled at (464241): [<ffffffff8a600ec2>] asm_call_on_stack+0x12/0x20
[  755.161911][T11960] ---[ end trace 451daddf8267bf7d ]---



[Index of Archives]     [Linux Kernel]     [Linux USB Development]     [Yosemite News]     [Linux SCSI]

  Powered by Linux