syzbot


KCSAN: data-race in ion_page_pool_free / ion_page_pool_shrink (2)

Status: auto-closed as invalid on 2020/08/23 20:17
Subsystems: staging
[Documentation on labels]
First crash: 1385d, last: 1385d
Similar bugs (1)
Kernel Title Repro Cause bisect Fix bisect Count Last Reported Patched Status
upstream KCSAN: data-race in ion_page_pool_free / ion_page_pool_shrink staging 2 1514d 1577d 0/26 auto-closed as invalid on 2020/05/22 00:12

Sample crash report:
==================================================================
BUG: KCSAN: data-race in ion_page_pool_free / ion_page_pool_shrink

write to 0xffff888126bdc204 of 4 bytes by task 9255 on cpu 0:
 ion_page_pool_add drivers/staging/android/ion/ion_page_pool.c:36 [inline]
 ion_page_pool_free+0x10e/0x180 drivers/staging/android/ion/ion_page_pool.c:87
 free_buffer_page drivers/staging/android/ion/ion_system_heap.c:70 [inline]
 ion_system_heap_allocate+0x629/0x6b0 drivers/staging/android/ion/ion_system_heap.c:148
 ion_buffer_create drivers/staging/android/ion/ion.c:57 [inline]
 ion_alloc drivers/staging/android/ion/ion.c:369 [inline]
 ion_ioctl+0x37a/0xa00 drivers/staging/android/ion/ion.c:495
 vfs_ioctl fs/ioctl.c:48 [inline]
 ksys_ioctl fs/ioctl.c:753 [inline]
 __do_sys_ioctl fs/ioctl.c:762 [inline]
 __se_sys_ioctl+0xc9/0x130 fs/ioctl.c:760
 __x64_sys_ioctl+0x3f/0x50 fs/ioctl.c:760
 do_syscall_64+0x51/0xb0 arch/x86/entry/common.c:384
 entry_SYSCALL_64_after_hwframe+0x44/0xa9

read to 0xffff888126bdc204 of 4 bytes by task 2132 on cpu 1:
 ion_page_pool_total drivers/staging/android/ion/ion_page_pool.c:92 [inline]
 ion_page_pool_shrink+0x2b3/0x320 drivers/staging/android/ion/ion_page_pool.c:112
 ion_system_heap_shrink+0xd2/0x120 drivers/staging/android/ion/ion_system_heap.c:186
 ion_heap_shrink_count+0x72/0x90 drivers/staging/android/ion/ion_heap.c:273
 do_shrink_slab+0x86/0x5c0 mm/vmscan.c:436
 shrink_slab+0xea/0x1c0 mm/vmscan.c:679
 shrink_node_memcgs+0x1f9/0x360 mm/vmscan.c:2658
 shrink_node+0x94e/0x1170 mm/vmscan.c:2770
 shrink_zones+0x2af/0x490 mm/vmscan.c:2973
 do_try_to_free_pages+0x1b4/0x6c0 mm/vmscan.c:3026
 try_to_free_pages+0x38d/0x8d0 mm/vmscan.c:3265
 __perform_reclaim mm/page_alloc.c:4223 [inline]
 __alloc_pages_direct_reclaim mm/page_alloc.c:4244 [inline]
 __alloc_pages_slowpath+0x50a/0x970 mm/page_alloc.c:4650
 __alloc_pages_nodemask+0x235/0x390 mm/page_alloc.c:4863
 alloc_pages_current+0x21d/0x310 mm/mempolicy.c:2292
 alloc_pages include/linux/gfp.h:545 [inline]
 __vmalloc_area_node mm/vmalloc.c:2475 [inline]
 __vmalloc_node_range+0x2bf/0x530 mm/vmalloc.c:2541
 alloc_thread_stack_node kernel/fork.c:243 [inline]
 dup_task_struct kernel/fork.c:879 [inline]
 copy_process+0x6e2/0x3300 kernel/fork.c:1937
 _do_fork+0xf1/0x660 kernel/fork.c:2443
 kernel_thread+0x85/0xb0 kernel/fork.c:2531
 call_usermodehelper_exec_work+0x4f/0x1b0 kernel/umh.c:195
 process_one_work+0x3e1/0x9a0 kernel/workqueue.c:2269
 worker_thread+0x665/0xbe0 kernel/workqueue.c:2415
 kthread+0x20d/0x230 kernel/kthread.c:291
 ret_from_fork+0x1f/0x30 arch/x86/entry/entry_64.S:293

Reported by Kernel Concurrency Sanitizer on:
CPU: 1 PID: 2132 Comm: kworker/u4:1 Not tainted 5.8.0-rc5-syzkaller #0
Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011
Workqueue: events_unbound call_usermodehelper_exec_work
==================================================================

Crashes (1):
Time Kernel Commit Syzkaller Config Log Report Syz repro C repro VM info Assets (help?) Manager Title
2020/07/19 20:07 upstream f932d58abc38 9c812472 .config console log report ci2-upstream-kcsan-gce
* Struck through repros no longer work on HEAD.