Blame view
arch/powerpc/sysdev/fsl_pmc.c
2 KB
4ffd6952a powerpc/85xx/86xx... |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
/* * Suspend/resume support * * Copyright 2009 MontaVista Software, Inc. * * Author: Anton Vorontsov <avorontsov@ru.mvista.com> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. */ #include <linux/init.h> #include <linux/types.h> #include <linux/errno.h> |
66b15db69 powerpc: add expo... |
17 |
#include <linux/export.h> |
4ffd6952a powerpc/85xx/86xx... |
18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 |
#include <linux/suspend.h> #include <linux/delay.h> #include <linux/device.h> #include <linux/of_platform.h> struct pmc_regs { __be32 devdisr; __be32 devdisr2; __be32 :32; __be32 :32; __be32 pmcsr; #define PMCSR_SLP (1 << 17) }; static struct device *pmc_dev; static struct pmc_regs __iomem *pmc_regs; static int pmc_suspend_enter(suspend_state_t state) { int ret; setbits32(&pmc_regs->pmcsr, PMCSR_SLP); /* At this point, the CPU is asleep. */ /* Upon resume, wait for SLP bit to be clear. */ ret = spin_event_timeout((in_be32(&pmc_regs->pmcsr) & PMCSR_SLP) == 0, 10000, 10) ? 0 : -ETIMEDOUT; if (ret) dev_err(pmc_dev, "tired waiting for SLP bit to clear "); return ret; } static int pmc_suspend_valid(suspend_state_t state) { if (state != PM_SUSPEND_STANDBY) return 0; return 1; } |
2f55ac072 suspend: constify... |
57 |
static const struct platform_suspend_ops pmc_suspend_ops = { |
4ffd6952a powerpc/85xx/86xx... |
58 59 60 |
.valid = pmc_suspend_valid, .enter = pmc_suspend_enter, }; |
000061245 dt/powerpc: Elimi... |
61 |
static int pmc_probe(struct platform_device *ofdev) |
4ffd6952a powerpc/85xx/86xx... |
62 |
{ |
61c7a080a of: Always use 's... |
63 |
pmc_regs = of_iomap(ofdev->dev.of_node, 0); |
4ffd6952a powerpc/85xx/86xx... |
64 65 66 67 68 69 70 71 72 73 74 75 76 |
if (!pmc_regs) return -ENOMEM; pmc_dev = &ofdev->dev; suspend_set_ops(&pmc_suspend_ops); return 0; } static const struct of_device_id pmc_ids[] = { { .compatible = "fsl,mpc8548-pmc", }, { .compatible = "fsl,mpc8641d-pmc", }, { }, }; |
000061245 dt/powerpc: Elimi... |
77 |
static struct platform_driver pmc_driver = { |
4018294b5 of: Remove duplic... |
78 79 80 81 82 |
.driver = { .name = "fsl-pmc", .owner = THIS_MODULE, .of_match_table = pmc_ids, }, |
4ffd6952a powerpc/85xx/86xx... |
83 84 85 86 87 |
.probe = pmc_probe, }; static int __init pmc_init(void) { |
000061245 dt/powerpc: Elimi... |
88 |
return platform_driver_register(&pmc_driver); |
4ffd6952a powerpc/85xx/86xx... |
89 90 |
} device_initcall(pmc_init); |