imx8: power: Add PD device lookup interface to power domain uclass
authorPeng Fan <peng.fan@nxp.com>
Mon, 4 May 2020 13:16:50 +0000 (21:16 +0800)
committerStefano Babic <sbabic@denx.de>
Sun, 10 May 2020 18:55:20 +0000 (20:55 +0200)
Add power_domain_lookup_name interface to power domain uclass to find
a power domain device by its DTB node name, not using its associated
client device.

Through this interface, we can operate the power domain devices directly.
This is needed for non-DM drivers.

Modified from Ye's NXP downstream patch

only for legacy imx8 power domain driver, since we have not migrated
to use new power domain driver.

Signed-off-by: Ye Li <ye.li@nxp.com>
Signed-off-by: Peng Fan <peng.fan@nxp.com>
arch/arm/include/asm/arch-imx8/sys_proto.h
drivers/power/domain/imx8-power-domain-legacy.c

index 0e981ae950e00fbc5d56627583c00af12f8d7b4b..fc33e6ed184e80260ef9d8110d18d45e7a7d3e21 100644 (file)
@@ -5,6 +5,11 @@
 
 #include <asm/arch/sci/sci.h>
 #include <asm/mach-imx/sys_proto.h>
+#include <asm/arch/power-domain.h>
+#include <dm/platdata.h>
+#include <dm/device-internal.h>
+#include <dm/device.h>
+#include <power-domain.h>
 #include <linux/types.h>
 
 struct pass_over_info_t {
@@ -21,3 +26,5 @@ void build_info(void);
 enum boot_device get_boot_device(void);
 int print_bootinfo(void);
 int sc_pm_setup_uart(sc_rsrc_t uart_rsrc, sc_pm_clock_rate_t clk_rate);
+int imx8_power_domain_lookup_name(const char *name,
+                                 struct power_domain *power_domain);
index 6f01a60b3467a0765d2efc59317d289554a5030d..2c479744d3f2e1eee9b1bdcd4f1ee86a38f8b174 100644 (file)
@@ -19,6 +19,34 @@ struct imx8_power_domain_priv {
        bool state_on;
 };
 
+int imx8_power_domain_lookup_name(const char *name,
+                                 struct power_domain *power_domain)
+{
+       struct udevice *dev;
+       struct power_domain_ops *ops;
+       int ret;
+
+       debug("%s(power_domain=%p name=%s)\n", __func__, power_domain, name);
+
+       ret = uclass_get_device_by_name(UCLASS_POWER_DOMAIN, name, &dev);
+       if (ret) {
+               printf("%s fail: %s, ret = %d\n", __func__, name, ret);
+               return ret;
+       }
+
+       ops = (struct power_domain_ops *)dev->driver->ops;
+       power_domain->dev = dev;
+       ret = ops->request(power_domain);
+       if (ret) {
+               debug("ops->request() failed: %d\n", ret);
+               return ret;
+       }
+
+       debug("%s ok: %s\n", __func__, dev->name);
+
+       return 0;
+}
+
 static int imx8_power_domain_request(struct power_domain *power_domain)
 {
        debug("%s(power_domain=%p)\n", __func__, power_domain);