@@ -1555,6 +1555,23 @@
}
EXPORT_SYMBOL_GPL(pm_runtime_enable);
+bool pm_runtime_blocked(struct device *dev)
+{
+ bool ret;
+
+ /*
+ * dev->power.last_status is a bit field, so in case it is updated via
+ * RMW, read it under the spin lock.
+ */
+ spin_lock_irq(&dev->power.lock);
+
+ ret = dev->power.last_status == RPM_BLOCKED;
+
+ spin_unlock_irq(&dev->power.lock);
+
+ return ret;
+}
+
static void pm_runtime_disable_action(void *data)
{
pm_runtime_dont_use_autosuspend(data);
@@ -81,6 +81,7 @@
extern void pm_runtime_unblock(struct device *dev);
extern void pm_runtime_enable(struct device *dev);
extern void __pm_runtime_disable(struct device *dev, bool check_resume);
+extern bool pm_runtime_blocked(struct device *dev);
extern void pm_runtime_allow(struct device *dev);
extern void pm_runtime_forbid(struct device *dev);
extern void pm_runtime_no_callbacks(struct device *dev);
@@ -277,6 +278,7 @@
static inline void pm_runtime_unblock(struct device *dev) {}
static inline void pm_runtime_enable(struct device *dev) {}
static inline void __pm_runtime_disable(struct device *dev, bool c) {}
+static inline bool pm_runtime_blocked(struct device *dev) { return true; }
static inline void pm_runtime_allow(struct device *dev) {}
static inline void pm_runtime_forbid(struct device *dev) {}