[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[PATCH v6] ARM: Switch to new sys-off handler API



Kernel now supports chained power-off handlers. Use
register_platform_power_off() that registers a platform level power-off
handler. Legacy pm_power_off() will be removed once all drivers and archs
are converted to the new sys-off API.

Signed-off-by: Andrew Davis <afd@xxxxxx>
Reviewed-by: Andre Przywara <andre.przywara@xxxxxxx>
Acked-by: Alexey Charkov <alchark@xxxxxxxxx>
---

Changes for v6:
 - Rebased on v6.16-rc3
 - Squashed series and sent to soc@xxxxxxxxxxxxxxx as suggested by Arnd

Changes for v5:
 - Rebase on v6.15-rc1

Changes for v4:
 - Drop already taken patches
 - Rebase on latest master

Changes for v3:
 - Rebase on v6.12-rc1

Changes for v2:
 - Collect Reviewed/Acked-bys
 - Rebase on v6.11-rc1

 arch/arm/mach-highbank/highbank.c | 2 +-
 arch/arm/mach-pxa/spitz.c         | 2 +-
 arch/arm/mach-sa1100/generic.c    | 2 +-
 arch/arm/mach-vt8500/vt8500.c     | 2 +-
 arch/arm/xen/enlighten.c          | 2 +-
 5 files changed, 5 insertions(+), 5 deletions(-)

diff --git a/arch/arm/mach-highbank/highbank.c 
b/arch/arm/mach-highbank/highbank.c
index 5d4f977ac7d2a..47335c7dadf8d 100644
--- a/arch/arm/mach-highbank/highbank.c
+++ b/arch/arm/mach-highbank/highbank.c
@@ -143,7 +143,7 @@ static void __init highbank_init(void)
        sregs_base = of_iomap(np, 0);
        WARN_ON(!sregs_base);
 
-       pm_power_off = highbank_power_off;
+       register_platform_power_off(highbank_power_off);
        highbank_pm_init();
 
        bus_register_notifier(&platform_bus_type, &highbank_platform_nb);
diff --git a/arch/arm/mach-pxa/spitz.c b/arch/arm/mach-pxa/spitz.c
index 33533e35720f8..c0b1f7e6be874 100644
--- a/arch/arm/mach-pxa/spitz.c
+++ b/arch/arm/mach-pxa/spitz.c
@@ -1096,7 +1096,7 @@ static void __init spitz_init(void)
                software_node_register(&spitz_scoop_2_gpiochip_node);
 
        init_gpio_reset(SPITZ_GPIO_ON_RESET, 1, 0);
-       pm_power_off = spitz_poweroff;
+       register_platform_power_off(spitz_poweroff);
 
        PMCR = 0x00;
 
diff --git a/arch/arm/mach-sa1100/generic.c b/arch/arm/mach-sa1100/generic.c
index 0c586047d130f..5383a26f51169 100644
--- a/arch/arm/mach-sa1100/generic.c
+++ b/arch/arm/mach-sa1100/generic.c
@@ -298,7 +298,7 @@ static struct platform_device *sa11x0_devices[] __initdata 
= {
 static int __init sa1100_init(void)
 {
        struct resource wdt_res = DEFINE_RES_MEM(0x90000000, 0x20);
-       pm_power_off = sa1100_power_off;
+       register_platform_power_off(sa1100_power_off);
 
        regulator_has_full_constraints();
 
diff --git a/arch/arm/mach-vt8500/vt8500.c b/arch/arm/mach-vt8500/vt8500.c
index 0ab40087ae1cc..1d294255d7083 100644
--- a/arch/arm/mach-vt8500/vt8500.c
+++ b/arch/arm/mach-vt8500/vt8500.c
@@ -141,7 +141,7 @@ static void __init vt8500_init(void)
                        pr_err("%s:ioremap(power_off) failed\n", __func__);
        }
        if (pmc_base)
-               pm_power_off = &vt8500_power_off;
+               register_platform_power_off(vt8500_power_off);
        else
                pr_err("%s: PMC Hibernation register could not be remapped, not 
enabling power off!\n", __func__);
 }
diff --git a/arch/arm/xen/enlighten.c b/arch/arm/xen/enlighten.c
index a395b6c0aae2a..8655bc3d36347 100644
--- a/arch/arm/xen/enlighten.c
+++ b/arch/arm/xen/enlighten.c
@@ -541,7 +541,7 @@ static int __init xen_late_init(void)
        if (!xen_domain())
                return -ENODEV;
 
-       pm_power_off = xen_power_off;
+       register_platform_power_off(xen_power_off);
        register_restart_handler(&xen_restart_nb);
        if (!xen_initial_domain()) {
                struct timespec64 ts;
-- 
2.39.2




 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.