diff options
author | Rafael J. Wysocki <rjw@sisk.pl> | 2008-03-11 19:59:38 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2008-04-19 22:10:24 -0400 |
commit | 57eee3d23e8833ca18708b374c648235691942ba (patch) | |
tree | 59dc775f05ba7896663e0ab2262f4739f95d22f5 /drivers/base/power | |
parent | 58aca23226a19983571bd3b65167521fc64f5869 (diff) |
Driver core: Call device_pm_add() after bus_add_device() in device_add()
Include dpm_sysfs_add() into device_pm_add(), in analogy with
device_pm_remove(), and modify device_add() to call the latter after
bus_add_device(), to avoid situations in which the PM core may
attempt to suspend a device the registration of which has not been
successful.
Signed-off-by: Rafael J. Wysocki <rjw@sisk.pl>
Acked-by: Pavel Machek <pavel@ucw.cz>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/base/power')
-rw-r--r-- | drivers/base/power/main.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/base/power/main.c b/drivers/base/power/main.c index 0e3991a437c6..93a146940b91 100644 --- a/drivers/base/power/main.c +++ b/drivers/base/power/main.c | |||
@@ -81,7 +81,9 @@ int device_pm_add(struct device *dev) | |||
81 | WARN_ON(true); | 81 | WARN_ON(true); |
82 | error = -EBUSY; | 82 | error = -EBUSY; |
83 | } else { | 83 | } else { |
84 | list_add_tail(&dev->power.entry, &dpm_active); | 84 | error = dpm_sysfs_add(dev); |
85 | if (!error) | ||
86 | list_add_tail(&dev->power.entry, &dpm_active); | ||
85 | } | 87 | } |
86 | mutex_unlock(&dpm_list_mtx); | 88 | mutex_unlock(&dpm_list_mtx); |
87 | return error; | 89 | return error; |