power: domain: add dev_power_domain_on
authorPeng Fan <peng.fan@nxp.com>
Tue, 17 Sep 2019 09:29:19 +0000 (09:29 +0000)
committerSimon Glass <sjg@chromium.org>
Tue, 15 Oct 2019 14:40:02 +0000 (08:40 -0600)
Add this new API to power on multiple domains attached
to a device.

Signed-off-by: Peng Fan <peng.fan@nxp.com>
Reviewed-by: Lokesh Vutla <lokeshvutla@ti.com>
Changed to static inline and added a condition into C file:
Signed-off-by: Simon Glass <sjg@chromium.org>
drivers/power/domain/power-domain-uclass.c
include/power-domain.h

index 2ea0ff24c7ae4651a4dfd0e11099da90449e4c6f..c961436d62fa9b71492c54a2f54f092ac121b57e 100644 (file)
@@ -107,6 +107,27 @@ int power_domain_off(struct power_domain *power_domain)
        return ops->off(power_domain);
 }
 
+#if !CONFIG_IS_ENABLED(OF_PLATDATA)
+int dev_power_domain_on(struct udevice *dev)
+{
+       struct power_domain pd;
+       int i, count, ret;
+
+       count = dev_count_phandle_with_args(dev, "power-domains",
+                                           "#power-domain-cells");
+       for (i = 0; i < count; i++) {
+               ret = power_domain_get_by_index(dev, &pd, i);
+               if (ret)
+                       return ret;
+               ret = power_domain_on(&pd);
+               if (ret)
+                       return ret;
+       }
+
+       return 0;
+}
+#endif
+
 UCLASS_DRIVER(power_domain) = {
        .id             = UCLASS_POWER_DOMAIN,
        .name           = "power_domain",
index ef15dc9f607cbbeb6994f44d9429b7a999eeab0b..490fedbb12842485fc32a3278087a047cdd06996 100644 (file)
@@ -155,4 +155,21 @@ static inline int power_domain_off(struct power_domain *power_domain)
 }
 #endif
 
+/**
+ * dev_power_domain_on - Enable power domains for a device .
+ *
+ * @dev:               The client device.
+ *
+ * @return 0 if OK, or a negative error code.
+ */
+#if (CONFIG_IS_ENABLED(OF_CONTROL) && !CONFIG_IS_ENABLED(OF_PLATDATA)) && \
+       CONFIG_IS_ENABLED(POWER_DOMAIN)
+int dev_power_domain_on(struct udevice *dev);
+#else
+static inline int dev_power_domain_on(struct udevice *dev)
+{
+       return 0;
+}
+#endif
+
 #endif