From: Cornelia Huck <[email protected]> As pointed out by Alan Stern, device_move needs to use klist_remove which waits until removal is complete. Signed-off-by: Cornelia Huck <[email protected]> Cc: Alan Stern <[email protected]> Signed-off-by: Greg Kroah-Hartman <[email protected]> --- drivers/base/core.c | 4 ++-- 1 files changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/base/core.c b/drivers/base/core.c index e4eaf46..e4b530e 100644 --- a/drivers/base/core.c +++ b/drivers/base/core.c @@ -1022,7 +1022,7 @@ int device_move(struct device *dev, stru old_parent = dev->parent; dev->parent = new_parent; if (old_parent) - klist_del(&dev->knode_parent); + klist_remove(&dev->knode_parent); klist_add_tail(&dev->knode_parent, &new_parent->klist_children); if (!dev->class) goto out_put; @@ -1031,7 +1031,7 @@ int device_move(struct device *dev, stru /* We ignore errors on cleanup since we're hosed anyway... */ device_move_class_links(dev, new_parent, old_parent); if (!kobject_move(&dev->kobj, &old_parent->kobj)) { - klist_del(&dev->knode_parent); + klist_remove(&dev->knode_parent); if (old_parent) klist_add_tail(&dev->knode_parent, &old_parent->klist_children); -- 1.4.4.1 - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [email protected] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
- Follow-Ups:
- References:
- [GIT PATCH] Driver core patches for 2.6.19
- From: Greg KH <[email protected]>
- [PATCH 1/36] Driver core: add notification of bus events
- From: Greg KH <[email protected]>
- [PATCH 2/36] Driver core: fix "driver" symlink timing
- From: Greg KH <[email protected]>
- [PATCH 3/36] Driver Core: Move virtual_device_parent() to core.c
- From: Greg KH <[email protected]>
- [PATCH 4/36] CONFIG_SYSFS_DEPRECATED
- From: Greg KH <[email protected]>
- [PATCH 5/36] Driver core: make old versions of udev work properly
- From: Greg KH <[email protected]>
- [PATCH 6/36] CONFIG_SYSFS_DEPRECATED - bus symlinks
- From: Greg KH <[email protected]>
- [PATCH 7/36] CONFIG_SYSFS_DEPRECATED - device symlinks
- From: Greg KH <[email protected]>
- [PATCH 8/36] CONFIG_SYSFS_DEPRECATED - PHYSDEV* uevent variables
- From: Greg KH <[email protected]>
- [PATCH 9/36] CONFIG_SYSFS_DEPRECATED - class symlinks
- From: Greg KH <[email protected]>
- [PATCH 10/36] Driver core: convert vt code to use struct device
- From: Greg KH <[email protected]>
- [PATCH 11/36] Driver core: convert vc code to use struct device
- From: Greg KH <[email protected]>
- [PATCH 12/36] Driver core: change misc class_devices to be real devices
- From: Greg KH <[email protected]>
- [PATCH 13/36] Driver core: convert tty core to use struct device
- From: Greg KH <[email protected]>
- [PATCH 14/36] Driver core: convert raw device code to use struct device
- From: Greg KH <[email protected]>
- [PATCH 15/36] I2C: convert i2c-dev to use struct device instead of struct class_device
- From: Greg KH <[email protected]>
- [PATCH 16/36] Driver core: convert msr code to use struct device
- From: Greg KH <[email protected]>
- [PATCH 17/36] Driver core: convert cpuid code to use struct device
- From: Greg KH <[email protected]>
- [PATCH 18/36] Driver core: convert PPP code to use struct device
- From: Greg KH <[email protected]>
- [PATCH 19/36] Driver core: convert ppdev code to use struct device
- From: Greg KH <[email protected]>
- [PATCH 20/36] Driver core: convert mmc code to use struct device
- From: Greg KH <[email protected]>
- [PATCH 22/36] Driver core: convert fb code to use struct device
- From: Greg KH <[email protected]>
- [PATCH 23/36] Driver core: change mem class_devices to be real devices
- From: Greg KH <[email protected]>
- [PATCH 24/36] Driver core: convert sound core to use struct device
- From: Greg KH <[email protected]>
- [PATCH 25/36] Driver core: add dev_archdata to struct device
- From: Greg KH <[email protected]>
- [PATCH 26/36] ACPI: Change ACPI to use dev_archdata instead of firmware_data
- From: Greg KH <[email protected]>
- [PATCH 27/36] Driver core: Call platform_notify_remove later
- From: Greg KH <[email protected]>
- [PATCH 28/36] cpu topology: consider sysfs_create_group return value
- From: Greg KH <[email protected]>
- [PATCH 29/36] sysfs: sysfs_write_file() writes zero terminated data
- From: Greg KH <[email protected]>
- [PATCH 30/36] driver core: Introduce device_find_child().
- From: Greg KH <[email protected]>
- [PATCH 31/36] Driver core: make drivers/base/core.c:setup_parent() static
- From: Greg KH <[email protected]>
- [PATCH 32/36] driver core: Introduce device_move(): move a device to a new parent.
- From: Greg KH <[email protected]>
- [GIT PATCH] Driver core patches for 2.6.19
- Prev by Date: [PATCH 35/36] Documentation/driver-model/platform.txt update/rewrite
- Next by Date: [PATCH 14/36] Driver core: convert raw device code to use struct device
- Previous by thread: [PATCH 32/36] driver core: Introduce device_move(): move a device to a new parent.
- Next by thread: [PATCH 34/36] Driver core: platform_driver_probe(), can save codespace
- Index(es):