[PATCH 07/10] PM: Export device_pm_schedule_removal

!MAILaRCHIVE_VOTE_RePLACE
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
To: <linux-kernel@...>
Cc: Rafael J. Wysocki <rjw@...>, Greg Kroah-Hartman <gregkh@...>
Date: Saturday, February 2, 2008 - 7:56 pm

From: Rafael J. Wysocki <rjw@sisk.pl>

Move the declaration of device_pm_schedule_removal() to device.h
and make it exported, as it will be used directly by some drivers
for unregistering device objects during suspend/resume cycles in a
safe way.

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>
---
 drivers/base/power/main.c  |    1 +
 drivers/base/power/power.h |    1 -
 include/linux/device.h     |    6 ++++++
 3 files changed, 7 insertions(+), 1 deletions(-)

diff --git a/drivers/base/power/main.c b/drivers/base/power/main.c
index 200ed5f..bdc03f7 100644
--- a/drivers/base/power/main.c
+++ b/drivers/base/power/main.c
@@ -129,6 +129,7 @@ void device_pm_schedule_removal(struct device *dev)
 	list_move_tail(&dev->power.entry, &dpm_destroy);
 	mutex_unlock(&dpm_list_mtx);
 }
+EXPORT_SYMBOL_GPL(device_pm_schedule_removal);
 
 /**
  *	pm_sleep_lock - mutual exclusion for registration and suspend
diff --git a/drivers/base/power/power.h b/drivers/base/power/power.h
index 6f0dfca..e32d3bd 100644
--- a/drivers/base/power/power.h
+++ b/drivers/base/power/power.h
@@ -13,7 +13,6 @@ static inline struct device *to_device(struct list_head *entry)
 
 extern void device_pm_add(struct device *);
 extern void device_pm_remove(struct device *);
-extern void device_pm_schedule_removal(struct device *);
 extern int pm_sleep_lock(void);
 extern void pm_sleep_unlock(void);
 
diff --git a/include/linux/device.h b/include/linux/device.h
index db375be..479c0b3 100644
--- a/include/linux/device.h
+++ b/include/linux/device.h
@@ -534,11 +534,17 @@ extern struct device *device_create(struct class *cls, struct device *parent,
 extern void device_destroy(struct class *cls, dev_t devt);
 #ifdef CONFIG_PM_SLEEP
 extern void destroy_suspended_device(struct class *cls, dev_t devt);
+extern void device_pm_schedule_removal(struct device *);
 #else /* !CONFIG_PM_SLEEP */
 static inline void destroy_suspended_device(struct class *cls, dev_t devt)
 {
 	device_destroy(cls, devt);
 }
+
+static inline void device_pm_schedule_removal(struct device *dev)
+{
+	device_unregister(dev);
+}
 #endif /* !CONFIG_PM_SLEEP */
 
 /*
-- 
1.5.3.8

--
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
[PATCH 10/10] Driver core: Remove unneeded get_{device,drive..., Greg Kroah-Hartman, (Sat Feb 2, 7:56 pm)
[PATCH 09/10] Driver core: Update some prototypes in platfor..., Greg Kroah-Hartman, (Sat Feb 2, 7:56 pm)
[PATCH 08/10] driver core: convert to use class_find_device ..., Greg Kroah-Hartman, (Sat Feb 2, 7:56 pm)
[PATCH 07/10] PM: Export device_pm_schedule_removal, Greg Kroah-Hartman, (Sat Feb 2, 7:56 pm)
[PATCH 06/10] nozomi: finish constification, Greg Kroah-Hartman, (Sat Feb 2, 7:56 pm)
[PATCH 05/10] nozomi: constify driver, Greg Kroah-Hartman, (Sat Feb 2, 7:55 pm)
[PATCH 04/10] nozomi driver update, Greg Kroah-Hartman, (Sat Feb 2, 7:55 pm)
[PATCH 03/10] Add ja_JP translation of stable_kernel_rules.txt, Greg Kroah-Hartman, (Sat Feb 2, 7:55 pm)
[PATCH 02/10] kobject: kerneldoc comment fix, Greg Kroah-Hartman, (Sat Feb 2, 7:55 pm)
[PATCH 01/10] kobject: Always build in kernel/ksysfs.o., Greg Kroah-Hartman, (Sat Feb 2, 7:55 pm)