summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorUlf Hansson <ulf.hansson@linaro.org>2025-07-01 13:47:18 +0200
committerUlf Hansson <ulf.hansson@linaro.org>2025-07-09 13:29:34 +0200
commit29ea33866d6d905acc45208fdf75da89e2b00000 (patch)
tree0fc301d05f5cb8f6268f180c77870e9c9362ac3d
parent10086a4f391f4b9c969a21e785e7fa0fa6c023e5 (diff)
firmware: xilinx: Use of_genpd_sync_state()
To make sure genpd tries to power off unused PM domains, let's call of_genpd_sync_state() from our own ->sync_state() callback. Cc: Michal Simek <michal.simek@amd.com> Tested-by: Hiago De Franco <hiago.franco@toradex.com> # Colibri iMX8X Tested-by: Tomi Valkeinen <tomi.valkeinen@ideasonboard.com> # TI AM62A,Xilinx ZynqMP ZCU106 Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org> Link: https://lore.kernel.org/r/20250701114733.636510-17-ulf.hansson@linaro.org
-rw-r--r--drivers/firmware/xilinx/zynqmp.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/drivers/firmware/xilinx/zynqmp.c b/drivers/firmware/xilinx/zynqmp.c
index 87ddbb7d11c2..02da3e48bc8f 100644
--- a/drivers/firmware/xilinx/zynqmp.c
+++ b/drivers/firmware/xilinx/zynqmp.c
@@ -20,6 +20,7 @@
#include <linux/of.h>
#include <linux/of_platform.h>
#include <linux/platform_device.h>
+#include <linux/pm_domain.h>
#include <linux/slab.h>
#include <linux/uaccess.h>
#include <linux/hashtable.h>
@@ -2101,9 +2102,13 @@ static void zynqmp_firmware_remove(struct platform_device *pdev)
static void zynqmp_firmware_sync_state(struct device *dev)
{
- if (!of_device_is_compatible(dev->of_node, "xlnx,zynqmp-firmware"))
+ struct device_node *np = dev->of_node;
+
+ if (!of_device_is_compatible(np, "xlnx,zynqmp-firmware"))
return;
+ of_genpd_sync_state(np);
+
if (zynqmp_pm_init_finalize())
dev_warn(dev, "failed to release power management to firmware\n");
}