Re: [PATCH 04/20] sysfs: Handle the general case of removing of directories with subdirectories

From: Eric W. Biederman
Date: Sat May 23 2009 - 16:10:23 EST


Kay Sievers <kay.sievers@xxxxxxxx> writes:

> On Sat, May 23, 2009 at 08:33, Eric W. Biederman <ebiederm@xxxxxxxxxxxx> wrote:
>
>> My plan going forward is to fix the ordering problems with deleting
>> /sys/dev/char and /sys/dev/block. ÂAdd a WARN_ON if we delete a
>> non-empty directory. ÂEnsure we don't add something to an already
>> deleted directory.
>
> What's the problem in /sys/dev/? There are just a bunch of symlinks,
> one for every device with a dev_t, and all in flat directories, and no
> directory to remove.

device_shutdown called during reboot removes /sys/dev/block and /sys/dev/char.
The current sysfs_remove_dir (because it empties directories)
removes all of those symlinks.

The problem is that it is the device objects for each individual
device that owns those symlinks, and normally removes those symlinks.

Which means that in theory we could have double deletion going on.

In practice today it doesn't matter because this is at reboot.

And as far as that goes it is wrong to remove anything from sysfs during
device_shutdown so the fix is just to not call kobject_put there.

Eric
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/