blob: 122e9b91a7f41b99b64e5eb2358b61ae2a045ff3 [file] [log] [blame]
Ben Dooks64197112008-12-12 00:24:06 +00001/* 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}