-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'next-s3c24xx' into for-next
- Loading branch information
Showing
12 changed files
with
139 additions
and
9 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,84 @@ | ||
/* linux/arch/arm/mach-s3c2416/pm.c | ||
* | ||
* Copyright (c) 2010 Samsung Electronics Co., Ltd. | ||
* http://www.samsung.com | ||
* | ||
* S3C2416 - PM support (Based on Ben Dooks' S3C2412 PM support) | ||
* | ||
* This program is free software; you can redistribute it and/or modify | ||
* it under the terms of the GNU General Public License version 2 as | ||
* published by the Free Software Foundation. | ||
*/ | ||
|
||
#include <linux/sysdev.h> | ||
#include <linux/io.h> | ||
|
||
#include <asm/cacheflush.h> | ||
|
||
#include <mach/regs-power.h> | ||
#include <mach/regs-s3c2443-clock.h> | ||
|
||
#include <plat/cpu.h> | ||
#include <plat/pm.h> | ||
|
||
extern void s3c2412_sleep_enter(void); | ||
|
||
static void s3c2416_cpu_suspend(void) | ||
{ | ||
flush_cache_all(); | ||
|
||
/* enable wakeup sources regardless of battery state */ | ||
__raw_writel(S3C2443_PWRCFG_SLEEP, S3C2443_PWRCFG); | ||
|
||
/* set the mode as sleep, 2BED represents "Go to BED" */ | ||
__raw_writel(0x2BED, S3C2443_PWRMODE); | ||
|
||
s3c2412_sleep_enter(); | ||
} | ||
|
||
static void s3c2416_pm_prepare(void) | ||
{ | ||
/* | ||
* write the magic value u-boot uses to check for resume into | ||
* the INFORM0 register, and ensure INFORM1 is set to the | ||
* correct address to resume from. | ||
*/ | ||
__raw_writel(0x2BED, S3C2412_INFORM0); | ||
__raw_writel(virt_to_phys(s3c_cpu_resume), S3C2412_INFORM1); | ||
} | ||
|
||
static int s3c2416_pm_add(struct sys_device *sysdev) | ||
{ | ||
pm_cpu_prep = s3c2416_pm_prepare; | ||
pm_cpu_sleep = s3c2416_cpu_suspend; | ||
|
||
return 0; | ||
} | ||
|
||
static int s3c2416_pm_suspend(struct sys_device *dev, pm_message_t state) | ||
{ | ||
return 0; | ||
} | ||
|
||
static int s3c2416_pm_resume(struct sys_device *dev) | ||
{ | ||
/* unset the return-from-sleep amd inform flags */ | ||
__raw_writel(0x0, S3C2443_PWRMODE); | ||
__raw_writel(0x0, S3C2412_INFORM0); | ||
__raw_writel(0x0, S3C2412_INFORM1); | ||
|
||
return 0; | ||
} | ||
|
||
static struct sysdev_driver s3c2416_pm_driver = { | ||
.add = s3c2416_pm_add, | ||
.suspend = s3c2416_pm_suspend, | ||
.resume = s3c2416_pm_resume, | ||
}; | ||
|
||
static __init int s3c2416_pm_init(void) | ||
{ | ||
return sysdev_driver_register(&s3c2416_sysclass, &s3c2416_pm_driver); | ||
} | ||
|
||
arch_initcall(s3c2416_pm_init); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
/* arch/arm/plat-samsung/include/plat/nand-core.h | ||
* | ||
* Copyright (c) 2010 Samsung Electronics Co., Ltd. | ||
* http://www.samsung.com/ | ||
* | ||
* S3C - Nand Controller core functions | ||
* | ||
* This program is free software; you can redistribute it and/or modify | ||
* it under the terms of the GNU General Public License version 2 as | ||
* published by the Free Software Foundation. | ||
*/ | ||
|
||
#ifndef __ASM_ARCH_NAND_CORE_H | ||
#define __ASM_ARCH_NAND_CORE_H __FILE__ | ||
|
||
/* These functions are only for use with the core support code, such as | ||
* the cpu specific initialisation code | ||
*/ | ||
|
||
/* re-define device name depending on support. */ | ||
static inline void s3c_nand_setname(char *name) | ||
{ | ||
#ifdef CONFIG_S3C_DEV_NAND | ||
s3c_device_nand.name = name; | ||
#endif | ||
} | ||
|
||
#endif /* __ASM_ARCH_NAND_CORE_H */ |