aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/plat-s3c/pm.c
diff options
context:
space:
mode:
authorBen Dooks <ben-linux@fluff.org>2008-12-11 19:24:06 -0500
committerBen Dooks <ben-linux@fluff.org>2009-03-08 08:23:51 -0400
commit6419711a164ba1304fa8fbb75ae9485455e04dcd (patch)
tree15fe79b0ffff33d253258b849f1b69ac4c2c3bbe /arch/arm/plat-s3c/pm.c
parenta3f66351b3cc89011e8a34068c245b413ce696d6 (diff)
[ARM] S3C: Move PM support functions to common location
Start moving the PM code by moving all the common support functions to a common location in arch/arm/plat-s3c. With the move we rename the functions from s3cxxx_ to s3c_ to fit the new location. Signed-off-by: Ben Dooks <ben-linux@fluff.org>
Diffstat (limited to 'arch/arm/plat-s3c/pm.c')
-rw-r--r--arch/arm/plat-s3c/pm.c97
1 files changed, 97 insertions, 0 deletions
diff --git a/arch/arm/plat-s3c/pm.c b/arch/arm/plat-s3c/pm.c
new file mode 100644
index 000000000000..122e9b91a7f4
--- /dev/null
+++ b/arch/arm/plat-s3c/pm.c
@@ -0,0 +1,97 @@
1/* linux/arch/arm/plat-s3c/pm.c
2 *
3 * Copyright 2008 Openmoko, Inc.
4 * Copyright 2004,2006,2008 Simtec Electronics
5 * Ben Dooks <ben@simtec.co.uk>
6 * http://armlinux.simtec.co.uk/
7 *
8 * S3C common power management (suspend to ram) support.
9 *
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License version 2 as
12 * published by the Free Software Foundation.
13*/
14
15#include <linux/init.h>
16#include <linux/suspend.h>
17#include <linux/errno.h>
18#include <linux/io.h>
19
20#include <plat/pm.h>
21
22/* for external use */
23
24unsigned long s3c_pm_flags;
25
26#ifdef CONFIG_S3C2410_PM_DEBUG
27extern void printascii(const char *);
28
29void s3c_pm_dbg(const char *fmt, ...)
30{
31 va_list va;
32 char buff[256];
33
34 va_start(va, fmt);
35 vsprintf(buff, fmt, va);
36 va_end(va);
37
38 printascii(buff);
39}
40#endif /* CONFIG_S3C2410_PM_DEBUG */
41
42
43/* helper functions to save and restore register state */
44
45/**
46 * s3c_pm_do_save() - save a set of registers for restoration on resume.
47 * @ptr: Pointer to an array of registers.
48 * @count: Size of the ptr array.
49 *
50 * Run through the list of registers given, saving their contents in the
51 * array for later restoration when we wakeup.
52 */
53void s3c_pm_do_save(struct sleep_save *ptr, int count)
54{
55 for (; count > 0; count--, ptr++) {
56 ptr->val = __raw_readl(ptr->reg);
57 S3C_PMDBG("saved %p value %08lx\n", ptr->reg, ptr->val);
58 }
59}
60
61/**
62 * s3c_pm_do_restore() - restore register values from the save list.
63 * @ptr: Pointer to an array of registers.
64 * @count: Size of the ptr array.
65 *
66 * Restore the register values saved from s3c_pm_do_save().
67 *
68 * Note, we do not use S3C_PMDBG() in here, as the system may not have
69 * restore the UARTs state yet
70*/
71
72void s3c_pm_do_restore(struct sleep_save *ptr, int count)
73{
74 for (; count > 0; count--, ptr++) {
75 printk(KERN_DEBUG "restore %p (restore %08lx, was %08x)\n",
76 ptr->reg, ptr->val, __raw_readl(ptr->reg));
77
78 __raw_writel(ptr->val, ptr->reg);
79 }
80}
81
82/**
83 * s3c_pm_do_restore_core() - early restore register values from save list.
84 *
85 * This is similar to s3c_pm_do_restore() except we try and minimise the
86 * side effects of the function in case registers that hardware might need
87 * to work has been restored.
88 *
89 * WARNING: Do not put any debug in here that may effect memory or use
90 * peripherals, as things may be changing!
91*/
92
93void s3c_pm_do_restore_core(struct sleep_save *ptr, int count)
94{
95 for (; count > 0; count--, ptr++)
96 __raw_writel(ptr->val, ptr->reg);
97}