Possible race in loop.ko
From: Anton Volkov
Date: Fri Jul 28 2017 - 11:55:57 EST
Hello.
While searching for races in Linux kernel I've come across
drivers/block/loop.ko module. Here is the question that I came up with
while analyzing results. Lines are given using the info from Linux v4.12.
In loop_init function additional initialization happens after a
successful call to misc_register() (loop.c: line 1961). Consider the
following case:
Thread 1: Thread 2:
loop_init()
misc_register() loop_control_ioctl
part_shift = 0 -> loop_add
if (max_part > 0) { alloc_disk(1 << part_shift)
part_shift =
<greater than 0>
...
}
In this case alloc_disk() will be called with 1 as a parameter although
part_shift should have been greater than 0. Maybe it would be better to
move the call to a misc_register() function a bit further down (at least
so it could be after the part_shift initialization)?
Thank you for your time.
-- Anton Volkov
Linux Verification Center, ISPRAS
web: http://linuxtesting.org
e-mail: avolkov@xxxxxxxxx