123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- // SPDX-License-Identifier: GPL-2.0
- /*
- * Copyright (C) 2019 Paul Cercueil <[email protected]>
- */
- #include "cgu.h"
- #include "pm.h"
- #include <linux/io.h>
- #include <linux/syscore_ops.h>
- #define CGU_REG_LCR 0x04
- #define LCR_LOW_POWER_MODE BIT(0)
- static void __iomem * __maybe_unused ingenic_cgu_base;
- static int __maybe_unused ingenic_cgu_pm_suspend(void)
- {
- u32 val = readl(ingenic_cgu_base + CGU_REG_LCR);
- writel(val | LCR_LOW_POWER_MODE, ingenic_cgu_base + CGU_REG_LCR);
- return 0;
- }
- static void __maybe_unused ingenic_cgu_pm_resume(void)
- {
- u32 val = readl(ingenic_cgu_base + CGU_REG_LCR);
- writel(val & ~LCR_LOW_POWER_MODE, ingenic_cgu_base + CGU_REG_LCR);
- }
- static struct syscore_ops __maybe_unused ingenic_cgu_pm_ops = {
- .suspend = ingenic_cgu_pm_suspend,
- .resume = ingenic_cgu_pm_resume,
- };
- void ingenic_cgu_register_syscore_ops(struct ingenic_cgu *cgu)
- {
- if (IS_ENABLED(CONFIG_PM_SLEEP)) {
- ingenic_cgu_base = cgu->base;
- register_syscore_ops(&ingenic_cgu_pm_ops);
- }
- }
|