diff options
Diffstat (limited to 'arch')
127 files changed, 6304 insertions, 2353 deletions
diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig index 166efa2a19cd..eed07eac3a5f 100644 --- a/arch/arm/Kconfig +++ b/arch/arm/Kconfig | |||
@@ -715,7 +715,8 @@ config ARCH_S5P64X0 | |||
715 | select GENERIC_GPIO | 715 | select GENERIC_GPIO |
716 | select HAVE_CLK | 716 | select HAVE_CLK |
717 | select HAVE_S3C2410_WATCHDOG if WATCHDOG | 717 | select HAVE_S3C2410_WATCHDOG if WATCHDOG |
718 | select ARCH_USES_GETTIMEOFFSET | 718 | select GENERIC_CLOCKEVENTS |
719 | select HAVE_SCHED_CLOCK | ||
719 | select HAVE_S3C2410_I2C if I2C | 720 | select HAVE_S3C2410_I2C if I2C |
720 | select HAVE_S3C_RTC if RTC_CLASS | 721 | select HAVE_S3C_RTC if RTC_CLASS |
721 | help | 722 | help |
@@ -753,15 +754,16 @@ config ARCH_S5PV210 | |||
753 | select HAVE_CLK | 754 | select HAVE_CLK |
754 | select ARM_L1_CACHE_SHIFT_6 | 755 | select ARM_L1_CACHE_SHIFT_6 |
755 | select ARCH_HAS_CPUFREQ | 756 | select ARCH_HAS_CPUFREQ |
756 | select ARCH_USES_GETTIMEOFFSET | 757 | select GENERIC_CLOCKEVENTS |
758 | select HAVE_SCHED_CLOCK | ||
757 | select HAVE_S3C2410_I2C if I2C | 759 | select HAVE_S3C2410_I2C if I2C |
758 | select HAVE_S3C_RTC if RTC_CLASS | 760 | select HAVE_S3C_RTC if RTC_CLASS |
759 | select HAVE_S3C2410_WATCHDOG if WATCHDOG | 761 | select HAVE_S3C2410_WATCHDOG if WATCHDOG |
760 | help | 762 | help |
761 | Samsung S5PV210/S5PC110 series based systems | 763 | Samsung S5PV210/S5PC110 series based systems |
762 | 764 | ||
763 | config ARCH_S5PV310 | 765 | config ARCH_EXYNOS4 |
764 | bool "Samsung S5PV310/S5PC210" | 766 | bool "Samsung EXYNOS4" |
765 | select CPU_V7 | 767 | select CPU_V7 |
766 | select ARCH_SPARSEMEM_ENABLE | 768 | select ARCH_SPARSEMEM_ENABLE |
767 | select GENERIC_GPIO | 769 | select GENERIC_GPIO |
@@ -772,7 +774,7 @@ config ARCH_S5PV310 | |||
772 | select HAVE_S3C2410_I2C if I2C | 774 | select HAVE_S3C2410_I2C if I2C |
773 | select HAVE_S3C2410_WATCHDOG if WATCHDOG | 775 | select HAVE_S3C2410_WATCHDOG if WATCHDOG |
774 | help | 776 | help |
775 | Samsung S5PV310 series based systems | 777 | Samsung EXYNOS4 series based systems |
776 | 778 | ||
777 | config ARCH_SHARK | 779 | config ARCH_SHARK |
778 | bool "Shark" | 780 | bool "Shark" |
@@ -991,7 +993,7 @@ source "arch/arm/mach-s5pc100/Kconfig" | |||
991 | 993 | ||
992 | source "arch/arm/mach-s5pv210/Kconfig" | 994 | source "arch/arm/mach-s5pv210/Kconfig" |
993 | 995 | ||
994 | source "arch/arm/mach-s5pv310/Kconfig" | 996 | source "arch/arm/mach-exynos4/Kconfig" |
995 | 997 | ||
996 | source "arch/arm/mach-shmobile/Kconfig" | 998 | source "arch/arm/mach-shmobile/Kconfig" |
997 | 999 | ||
@@ -1278,7 +1280,7 @@ config SMP | |||
1278 | depends on GENERIC_CLOCKEVENTS | 1280 | depends on GENERIC_CLOCKEVENTS |
1279 | depends on REALVIEW_EB_ARM11MP || REALVIEW_EB_A9MP || \ | 1281 | depends on REALVIEW_EB_ARM11MP || REALVIEW_EB_A9MP || \ |
1280 | MACH_REALVIEW_PB11MP || MACH_REALVIEW_PBX || ARCH_OMAP4 || \ | 1282 | MACH_REALVIEW_PB11MP || MACH_REALVIEW_PBX || ARCH_OMAP4 || \ |
1281 | ARCH_S5PV310 || ARCH_TEGRA || ARCH_U8500 || ARCH_VEXPRESS_CA9X4 || \ | 1283 | ARCH_EXYNOS4 || ARCH_TEGRA || ARCH_U8500 || ARCH_VEXPRESS_CA9X4 || \ |
1282 | ARCH_MSM_SCORPIONMP || ARCH_SHMOBILE | 1284 | ARCH_MSM_SCORPIONMP || ARCH_SHMOBILE |
1283 | select USE_GENERIC_SMP_HELPERS | 1285 | select USE_GENERIC_SMP_HELPERS |
1284 | select HAVE_ARM_SCU if !ARCH_MSM_SCORPIONMP | 1286 | select HAVE_ARM_SCU if !ARCH_MSM_SCORPIONMP |
@@ -1366,7 +1368,7 @@ config LOCAL_TIMERS | |||
1366 | bool "Use local timer interrupts" | 1368 | bool "Use local timer interrupts" |
1367 | depends on SMP | 1369 | depends on SMP |
1368 | default y | 1370 | default y |
1369 | select HAVE_ARM_TWD if !ARCH_MSM_SCORPIONMP | 1371 | select HAVE_ARM_TWD if (!ARCH_MSM_SCORPIONMP && !EXYNOS4_MCT) |
1370 | help | 1372 | help |
1371 | Enable support for local timers on SMP platforms, rather then the | 1373 | Enable support for local timers on SMP platforms, rather then the |
1372 | legacy IPI broadcast method. Local timers allows the system | 1374 | legacy IPI broadcast method. Local timers allows the system |
@@ -1378,7 +1380,7 @@ source kernel/Kconfig.preempt | |||
1378 | config HZ | 1380 | config HZ |
1379 | int | 1381 | int |
1380 | default 200 if ARCH_EBSA110 || ARCH_S3C2410 || ARCH_S5P64X0 || \ | 1382 | default 200 if ARCH_EBSA110 || ARCH_S3C2410 || ARCH_S5P64X0 || \ |
1381 | ARCH_S5P6442 || ARCH_S5PV210 || ARCH_S5PV310 | 1383 | ARCH_S5P6442 || ARCH_S5PV210 || ARCH_EXYNOS4 |
1382 | default OMAP_32K_TIMER_HZ if ARCH_OMAP && OMAP_32K_TIMER | 1384 | default OMAP_32K_TIMER_HZ if ARCH_OMAP && OMAP_32K_TIMER |
1383 | default AT91_TIMER_HZ if ARCH_AT91 | 1385 | default AT91_TIMER_HZ if ARCH_AT91 |
1384 | default SHMOBILE_TIMER_HZ if ARCH_SHMOBILE | 1386 | default SHMOBILE_TIMER_HZ if ARCH_SHMOBILE |
diff --git a/arch/arm/Makefile b/arch/arm/Makefile index 6f7b29294c80..40aa0225877f 100644 --- a/arch/arm/Makefile +++ b/arch/arm/Makefile | |||
@@ -178,7 +178,7 @@ machine-$(CONFIG_ARCH_S5P64X0) := s5p64x0 | |||
178 | machine-$(CONFIG_ARCH_S5P6442) := s5p6442 | 178 | machine-$(CONFIG_ARCH_S5P6442) := s5p6442 |
179 | machine-$(CONFIG_ARCH_S5PC100) := s5pc100 | 179 | machine-$(CONFIG_ARCH_S5PC100) := s5pc100 |
180 | machine-$(CONFIG_ARCH_S5PV210) := s5pv210 | 180 | machine-$(CONFIG_ARCH_S5PV210) := s5pv210 |
181 | machine-$(CONFIG_ARCH_S5PV310) := s5pv310 | 181 | machine-$(CONFIG_ARCH_EXYNOS4) := exynos4 |
182 | machine-$(CONFIG_ARCH_SA1100) := sa1100 | 182 | machine-$(CONFIG_ARCH_SA1100) := sa1100 |
183 | machine-$(CONFIG_ARCH_SHARK) := shark | 183 | machine-$(CONFIG_ARCH_SHARK) := shark |
184 | machine-$(CONFIG_ARCH_SHMOBILE) := shmobile | 184 | machine-$(CONFIG_ARCH_SHMOBILE) := shmobile |
diff --git a/arch/arm/configs/exynos4_defconfig b/arch/arm/configs/exynos4_defconfig new file mode 100644 index 000000000000..2ffba24d2e2a --- /dev/null +++ b/arch/arm/configs/exynos4_defconfig | |||
@@ -0,0 +1,70 @@ | |||
1 | CONFIG_EXPERIMENTAL=y | ||
2 | CONFIG_BLK_DEV_INITRD=y | ||
3 | CONFIG_KALLSYMS_ALL=y | ||
4 | CONFIG_MODULES=y | ||
5 | CONFIG_MODULE_UNLOAD=y | ||
6 | # CONFIG_BLK_DEV_BSG is not set | ||
7 | CONFIG_ARCH_EXYNOS4=y | ||
8 | CONFIG_S3C_LOWLEVEL_UART_PORT=1 | ||
9 | CONFIG_MACH_SMDKC210=y | ||
10 | CONFIG_MACH_SMDKV310=y | ||
11 | CONFIG_MACH_UNIVERSAL_C210=y | ||
12 | CONFIG_NO_HZ=y | ||
13 | CONFIG_HIGH_RES_TIMERS=y | ||
14 | CONFIG_SMP=y | ||
15 | CONFIG_NR_CPUS=2 | ||
16 | CONFIG_HOTPLUG_CPU=y | ||
17 | CONFIG_PREEMPT=y | ||
18 | CONFIG_AEABI=y | ||
19 | CONFIG_CMDLINE="root=/dev/ram0 rw ramdisk=8192 initrd=0x41000000,8M console=ttySAC1,115200 init=/linuxrc mem=256M" | ||
20 | CONFIG_VFP=y | ||
21 | CONFIG_NEON=y | ||
22 | CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" | ||
23 | CONFIG_BLK_DEV_LOOP=y | ||
24 | CONFIG_BLK_DEV_RAM=y | ||
25 | CONFIG_BLK_DEV_RAM_SIZE=8192 | ||
26 | CONFIG_SCSI=y | ||
27 | CONFIG_BLK_DEV_SD=y | ||
28 | CONFIG_CHR_DEV_SG=y | ||
29 | CONFIG_INPUT_EVDEV=y | ||
30 | # CONFIG_INPUT_KEYBOARD is not set | ||
31 | # CONFIG_INPUT_MOUSE is not set | ||
32 | CONFIG_INPUT_TOUCHSCREEN=y | ||
33 | CONFIG_SERIAL_8250=y | ||
34 | CONFIG_SERIAL_SAMSUNG=y | ||
35 | CONFIG_SERIAL_SAMSUNG_CONSOLE=y | ||
36 | CONFIG_HW_RANDOM=y | ||
37 | CONFIG_I2C=y | ||
38 | # CONFIG_HWMON is not set | ||
39 | # CONFIG_MFD_SUPPORT is not set | ||
40 | # CONFIG_HID_SUPPORT is not set | ||
41 | # CONFIG_USB_SUPPORT is not set | ||
42 | CONFIG_EXT2_FS=y | ||
43 | CONFIG_MSDOS_FS=y | ||
44 | CONFIG_VFAT_FS=y | ||
45 | CONFIG_TMPFS=y | ||
46 | CONFIG_TMPFS_POSIX_ACL=y | ||
47 | CONFIG_CRAMFS=y | ||
48 | CONFIG_ROMFS_FS=y | ||
49 | CONFIG_PARTITION_ADVANCED=y | ||
50 | CONFIG_BSD_DISKLABEL=y | ||
51 | CONFIG_SOLARIS_X86_PARTITION=y | ||
52 | CONFIG_NLS_CODEPAGE_437=y | ||
53 | CONFIG_NLS_ASCII=y | ||
54 | CONFIG_NLS_ISO8859_1=y | ||
55 | CONFIG_MAGIC_SYSRQ=y | ||
56 | CONFIG_DEBUG_KERNEL=y | ||
57 | CONFIG_DETECT_HUNG_TASK=y | ||
58 | CONFIG_DEBUG_RT_MUTEXES=y | ||
59 | CONFIG_DEBUG_SPINLOCK=y | ||
60 | CONFIG_DEBUG_MUTEXES=y | ||
61 | CONFIG_DEBUG_SPINLOCK_SLEEP=y | ||
62 | CONFIG_DEBUG_INFO=y | ||
63 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | ||
64 | CONFIG_SYSCTL_SYSCALL_CHECK=y | ||
65 | CONFIG_DEBUG_USER=y | ||
66 | CONFIG_DEBUG_ERRORS=y | ||
67 | CONFIG_DEBUG_LL=y | ||
68 | CONFIG_EARLY_PRINTK=y | ||
69 | CONFIG_DEBUG_S3C_UART=1 | ||
70 | CONFIG_CRC_CCITT=y | ||
diff --git a/arch/arm/configs/s5p64x0_defconfig b/arch/arm/configs/s5p64x0_defconfig index 2993ecd35145..ad6b61b0bd11 100644 --- a/arch/arm/configs/s5p64x0_defconfig +++ b/arch/arm/configs/s5p64x0_defconfig | |||
@@ -10,6 +10,8 @@ CONFIG_S3C_BOOT_ERROR_RESET=y | |||
10 | CONFIG_S3C_LOWLEVEL_UART_PORT=1 | 10 | CONFIG_S3C_LOWLEVEL_UART_PORT=1 |
11 | CONFIG_MACH_SMDK6440=y | 11 | CONFIG_MACH_SMDK6440=y |
12 | CONFIG_MACH_SMDK6450=y | 12 | CONFIG_MACH_SMDK6450=y |
13 | CONFIG_NO_HZ=y | ||
14 | CONFIG_HIGH_RES_TIMERS=y | ||
13 | CONFIG_CPU_32v6K=y | 15 | CONFIG_CPU_32v6K=y |
14 | CONFIG_AEABI=y | 16 | CONFIG_AEABI=y |
15 | CONFIG_CMDLINE="root=/dev/ram0 rw ramdisk=8192 initrd=0x20800000,8M console=ttySAC1,115200 init=/linuxrc" | 17 | CONFIG_CMDLINE="root=/dev/ram0 rw ramdisk=8192 initrd=0x20800000,8M console=ttySAC1,115200 init=/linuxrc" |
diff --git a/arch/arm/configs/s5pv210_defconfig b/arch/arm/configs/s5pv210_defconfig index 0488a1eb4d7d..fa989902236d 100644 --- a/arch/arm/configs/s5pv210_defconfig +++ b/arch/arm/configs/s5pv210_defconfig | |||
@@ -13,6 +13,8 @@ CONFIG_MACH_AQUILA=y | |||
13 | CONFIG_MACH_GONI=y | 13 | CONFIG_MACH_GONI=y |
14 | CONFIG_MACH_SMDKC110=y | 14 | CONFIG_MACH_SMDKC110=y |
15 | CONFIG_MACH_SMDKV210=y | 15 | CONFIG_MACH_SMDKV210=y |
16 | CONFIG_NO_HZ=y | ||
17 | CONFIG_HIGH_RES_TIMERS=y | ||
16 | CONFIG_VMSPLIT_2G=y | 18 | CONFIG_VMSPLIT_2G=y |
17 | CONFIG_PREEMPT=y | 19 | CONFIG_PREEMPT=y |
18 | CONFIG_AEABI=y | 20 | CONFIG_AEABI=y |
diff --git a/arch/arm/mach-exynos4/Kconfig b/arch/arm/mach-exynos4/Kconfig new file mode 100644 index 000000000000..a021b5240bba --- /dev/null +++ b/arch/arm/mach-exynos4/Kconfig | |||
@@ -0,0 +1,195 @@ | |||
1 | # arch/arm/mach-exynos4/Kconfig | ||
2 | # | ||
3 | # Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. | ||
4 | # http://www.samsung.com/ | ||
5 | # | ||
6 | # Licensed under GPLv2 | ||
7 | |||
8 | # Configuration options for the EXYNOS4 | ||
9 | |||
10 | if ARCH_EXYNOS4 | ||
11 | |||
12 | config CPU_EXYNOS4210 | ||
13 | bool | ||
14 | select S3C_PL330_DMA | ||
15 | help | ||
16 | Enable EXYNOS4210 CPU support | ||
17 | |||
18 | config EXYNOS4_MCT | ||
19 | bool "Kernel timer support by MCT" | ||
20 | help | ||
21 | Use MCT (Multi Core Timer) as kernel timers | ||
22 | |||
23 | config EXYNOS4_DEV_PD | ||
24 | bool | ||
25 | help | ||
26 | Compile in platform device definitions for Power Domain | ||
27 | |||
28 | config EXYNOS4_DEV_SYSMMU | ||
29 | bool | ||
30 | help | ||
31 | Common setup code for SYSTEM MMU in EXYNOS4 | ||
32 | |||
33 | config EXYNOS4_SETUP_I2C1 | ||
34 | bool | ||
35 | help | ||
36 | Common setup code for i2c bus 1. | ||
37 | |||
38 | config EXYNOS4_SETUP_I2C2 | ||
39 | bool | ||
40 | help | ||
41 | Common setup code for i2c bus 2. | ||
42 | |||
43 | config EXYNOS4_SETUP_I2C3 | ||
44 | bool | ||
45 | help | ||
46 | Common setup code for i2c bus 3. | ||
47 | |||
48 | config EXYNOS4_SETUP_I2C4 | ||
49 | bool | ||
50 | help | ||
51 | Common setup code for i2c bus 4. | ||
52 | |||
53 | config EXYNOS4_SETUP_I2C5 | ||
54 | bool | ||
55 | help | ||
56 | Common setup code for i2c bus 5. | ||
57 | |||
58 | config EXYNOS4_SETUP_I2C6 | ||
59 | bool | ||
60 | help | ||
61 | Common setup code for i2c bus 6. | ||
62 | |||
63 | config EXYNOS4_SETUP_I2C7 | ||
64 | bool | ||
65 | help | ||
66 | Common setup code for i2c bus 7. | ||
67 | |||
68 | config EXYNOS4_SETUP_KEYPAD | ||
69 | bool | ||
70 | help | ||
71 | Common setup code for keypad. | ||
72 | |||
73 | config EXYNOS4_SETUP_SDHCI | ||
74 | bool | ||
75 | select EXYNOS4_SETUP_SDHCI_GPIO | ||
76 | help | ||
77 | Internal helper functions for EXYNOS4 based SDHCI systems. | ||
78 | |||
79 | config EXYNOS4_SETUP_SDHCI_GPIO | ||
80 | bool | ||
81 | help | ||
82 | Common setup code for SDHCI gpio. | ||
83 | |||
84 | config EXYNOS4_SETUP_FIMC | ||
85 | bool | ||
86 | help | ||
87 | Common setup code for the camera interfaces. | ||
88 | |||
89 | # machine support | ||
90 | |||
91 | menu "EXYNOS4 Machines" | ||
92 | |||
93 | config MACH_SMDKC210 | ||
94 | bool "SMDKC210" | ||
95 | select CPU_EXYNOS4210 | ||
96 | select S3C_DEV_RTC | ||
97 | select S3C_DEV_WDT | ||
98 | select S3C_DEV_I2C1 | ||
99 | select S3C_DEV_HSMMC | ||
100 | select S3C_DEV_HSMMC1 | ||
101 | select S3C_DEV_HSMMC2 | ||
102 | select S3C_DEV_HSMMC3 | ||
103 | select EXYNOS4_DEV_PD | ||
104 | select EXYNOS4_DEV_SYSMMU | ||
105 | select EXYNOS4_SETUP_I2C1 | ||
106 | select EXYNOS4_SETUP_SDHCI | ||
107 | help | ||
108 | Machine support for Samsung SMDKC210 | ||
109 | |||
110 | config MACH_SMDKV310 | ||
111 | bool "SMDKV310" | ||
112 | select CPU_EXYNOS4210 | ||
113 | select S3C_DEV_RTC | ||
114 | select S3C_DEV_WDT | ||
115 | select S3C_DEV_I2C1 | ||
116 | select S3C_DEV_HSMMC | ||
117 | select S3C_DEV_HSMMC1 | ||
118 | select S3C_DEV_HSMMC2 | ||
119 | select S3C_DEV_HSMMC3 | ||
120 | select SAMSUNG_DEV_KEYPAD | ||
121 | select EXYNOS4_DEV_PD | ||
122 | select EXYNOS4_DEV_SYSMMU | ||
123 | select EXYNOS4_SETUP_I2C1 | ||
124 | select EXYNOS4_SETUP_KEYPAD | ||
125 | select EXYNOS4_SETUP_SDHCI | ||
126 | help | ||
127 | Machine support for Samsung SMDKV310 | ||
128 | |||
129 | config MACH_ARMLEX4210 | ||
130 | bool "ARMLEX4210" | ||
131 | select CPU_EXYNOS4210 | ||
132 | select S3C_DEV_RTC | ||
133 | select S3C_DEV_WDT | ||
134 | select S3C_DEV_HSMMC | ||
135 | select S3C_DEV_HSMMC2 | ||
136 | select S3C_DEV_HSMMC3 | ||
137 | select EXYNOS4_DEV_SYSMMU | ||
138 | select EXYNOS4_SETUP_SDHCI | ||
139 | select SATA_AHCI_PLATFORM | ||
140 | help | ||
141 | Machine support for Samsung ARMLEX4210 based on EXYNOS4210 | ||
142 | |||
143 | config MACH_UNIVERSAL_C210 | ||
144 | bool "Mobile UNIVERSAL_C210 Board" | ||
145 | select CPU_EXYNOS4210 | ||
146 | select S3C_DEV_HSMMC | ||
147 | select S3C_DEV_HSMMC2 | ||
148 | select S3C_DEV_HSMMC3 | ||
149 | select S3C_DEV_I2C1 | ||
150 | select S3C_DEV_I2C5 | ||
151 | select S5P_DEV_ONENAND | ||
152 | select EXYNOS4_SETUP_I2C1 | ||
153 | select EXYNOS4_SETUP_I2C5 | ||
154 | select EXYNOS4_SETUP_SDHCI | ||
155 | help | ||
156 | Machine support for Samsung Mobile Universal S5PC210 Reference | ||
157 | Board. | ||
158 | |||
159 | config MACH_NURI | ||
160 | bool "Mobile NURI Board" | ||
161 | select CPU_EXYNOS4210 | ||
162 | select S3C_DEV_WDT | ||
163 | select S3C_DEV_HSMMC | ||
164 | select S3C_DEV_HSMMC2 | ||
165 | select S3C_DEV_HSMMC3 | ||
166 | select S3C_DEV_I2C1 | ||
167 | select S3C_DEV_I2C5 | ||
168 | select EXYNOS4_SETUP_I2C1 | ||
169 | select EXYNOS4_SETUP_I2C5 | ||
170 | select EXYNOS4_SETUP_SDHCI | ||
171 | select SAMSUNG_DEV_PWM | ||
172 | help | ||
173 | Machine support for Samsung Mobile NURI Board. | ||
174 | |||
175 | endmenu | ||
176 | |||
177 | comment "Configuration for HSMMC bus width" | ||
178 | |||
179 | menu "Use 8-bit bus width" | ||
180 | |||
181 | config EXYNOS4_SDHCI_CH0_8BIT | ||
182 | bool "Channel 0 with 8-bit bus" | ||
183 | help | ||
184 | Support HSMMC Channel 0 8-bit bus. | ||
185 | If selected, Channel 1 is disabled. | ||
186 | |||
187 | config EXYNOS4_SDHCI_CH2_8BIT | ||
188 | bool "Channel 2 with 8-bit bus" | ||
189 | help | ||
190 | Support HSMMC Channel 2 8-bit bus. | ||
191 | If selected, Channel 3 is disabled. | ||
192 | |||
193 | endmenu | ||
194 | |||
195 | endif | ||
diff --git a/arch/arm/mach-exynos4/Makefile b/arch/arm/mach-exynos4/Makefile new file mode 100644 index 000000000000..b8f0e7d82d7e --- /dev/null +++ b/arch/arm/mach-exynos4/Makefile | |||
@@ -0,0 +1,56 @@ | |||
1 | # arch/arm/mach-exynos4/Makefile | ||
2 | # | ||
3 | # Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. | ||
4 | # http://www.samsung.com/ | ||
5 | # | ||
6 | # Licensed under GPLv2 | ||
7 | |||
8 | obj-y := | ||
9 | obj-m := | ||
10 | obj-n := | ||
11 | obj- := | ||
12 | |||
13 | # Core support for EXYNOS4 system | ||
14 | |||
15 | obj-$(CONFIG_CPU_EXYNOS4210) += cpu.o init.o clock.o irq-combiner.o | ||
16 | obj-$(CONFIG_CPU_EXYNOS4210) += setup-i2c0.o gpiolib.o irq-eint.o dma.o | ||
17 | obj-$(CONFIG_PM) += pm.o sleep.o | ||
18 | obj-$(CONFIG_CPU_FREQ) += cpufreq.o | ||
19 | |||
20 | obj-$(CONFIG_SMP) += platsmp.o headsmp.o | ||
21 | |||
22 | ifeq ($(CONFIG_EXYNOS4_MCT),y) | ||
23 | obj-y += mct.o | ||
24 | else | ||
25 | obj-y += time.o | ||
26 | obj-$(CONFIG_LOCAL_TIMERS) += localtimer.o | ||
27 | endif | ||
28 | |||
29 | obj-$(CONFIG_HOTPLUG_CPU) += hotplug.o | ||
30 | |||
31 | # machine support | ||
32 | |||
33 | obj-$(CONFIG_MACH_SMDKC210) += mach-smdkc210.o | ||
34 | obj-$(CONFIG_MACH_SMDKV310) += mach-smdkv310.o | ||
35 | obj-$(CONFIG_MACH_ARMLEX4210) += mach-armlex4210.o | ||
36 | obj-$(CONFIG_MACH_UNIVERSAL_C210) += mach-universal_c210.o | ||
37 | obj-$(CONFIG_MACH_NURI) += mach-nuri.o | ||
38 | |||
39 | # device support | ||
40 | |||
41 | obj-y += dev-audio.o | ||
42 | obj-$(CONFIG_EXYNOS4_DEV_PD) += dev-pd.o | ||
43 | obj-$(CONFIG_EXYNOS4_DEV_SYSMMU) += dev-sysmmu.o | ||
44 | |||
45 | obj-$(CONFIG_EXYNOS4_SETUP_FIMC) += setup-fimc.o | ||
46 | obj-$(CONFIG_EXYNOS4_SETUP_I2C1) += setup-i2c1.o | ||
47 | obj-$(CONFIG_EXYNOS4_SETUP_I2C2) += setup-i2c2.o | ||
48 | obj-$(CONFIG_EXYNOS4_SETUP_I2C3) += setup-i2c3.o | ||
49 | obj-$(CONFIG_EXYNOS4_SETUP_I2C4) += setup-i2c4.o | ||
50 | obj-$(CONFIG_EXYNOS4_SETUP_I2C5) += setup-i2c5.o | ||
51 | obj-$(CONFIG_EXYNOS4_SETUP_I2C6) += setup-i2c6.o | ||
52 | obj-$(CONFIG_EXYNOS4_SETUP_I2C7) += setup-i2c7.o | ||
53 | obj-$(CONFIG_EXYNOS4_SETUP_KEYPAD) += setup-keypad.o | ||
54 | obj-$(CONFIG_EXYNOS4_SETUP_SDHCI) += setup-sdhci.o | ||
55 | obj-$(CONFIG_EXYNOS4_SETUP_SDHCI_GPIO) += setup-sdhci-gpio.o | ||
56 | obj-$(CONFIG_SATA_AHCI_PLATFORM) += dev-ahci.o | ||
diff --git a/arch/arm/mach-s5pv310/Makefile.boot b/arch/arm/mach-exynos4/Makefile.boot index d65956ffb43d..d65956ffb43d 100644 --- a/arch/arm/mach-s5pv310/Makefile.boot +++ b/arch/arm/mach-exynos4/Makefile.boot | |||
diff --git a/arch/arm/mach-s5pv310/clock.c b/arch/arm/mach-exynos4/clock.c index fc7c2f8d165e..871f9d508fde 100644 --- a/arch/arm/mach-s5pv310/clock.c +++ b/arch/arm/mach-exynos4/clock.c | |||
@@ -1,9 +1,9 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/clock.c | 1 | /* linux/arch/arm/mach-exynos4/clock.c |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * S5PV310 - Clock support | 6 | * EXYNOS4 - Clock support |
7 | * | 7 | * |
8 | * This program is free software; you can redistribute it and/or modify | 8 | * This program is free software; you can redistribute it and/or modify |
9 | * it under the terms of the GNU General Public License version 2 as | 9 | * it under the terms of the GNU General Public License version 2 as |
@@ -23,6 +23,7 @@ | |||
23 | 23 | ||
24 | #include <mach/map.h> | 24 | #include <mach/map.h> |
25 | #include <mach/regs-clock.h> | 25 | #include <mach/regs-clock.h> |
26 | #include <mach/sysmmu.h> | ||
26 | 27 | ||
27 | static struct clk clk_sclk_hdmi27m = { | 28 | static struct clk clk_sclk_hdmi27m = { |
28 | .name = "sclk_hdmi27m", | 29 | .name = "sclk_hdmi27m", |
@@ -46,72 +47,82 @@ static struct clk clk_sclk_usbphy1 = { | |||
46 | .id = -1, | 47 | .id = -1, |
47 | }; | 48 | }; |
48 | 49 | ||
49 | static int s5pv310_clksrc_mask_top_ctrl(struct clk *clk, int enable) | 50 | static int exynos4_clksrc_mask_top_ctrl(struct clk *clk, int enable) |
50 | { | 51 | { |
51 | return s5p_gatectrl(S5P_CLKSRC_MASK_TOP, clk, enable); | 52 | return s5p_gatectrl(S5P_CLKSRC_MASK_TOP, clk, enable); |
52 | } | 53 | } |
53 | 54 | ||
54 | static int s5pv310_clksrc_mask_cam_ctrl(struct clk *clk, int enable) | 55 | static int exynos4_clksrc_mask_cam_ctrl(struct clk *clk, int enable) |
55 | { | 56 | { |
56 | return s5p_gatectrl(S5P_CLKSRC_MASK_CAM, clk, enable); | 57 | return s5p_gatectrl(S5P_CLKSRC_MASK_CAM, clk, enable); |
57 | } | 58 | } |
58 | 59 | ||
59 | static int s5pv310_clksrc_mask_lcd0_ctrl(struct clk *clk, int enable) | 60 | static int exynos4_clksrc_mask_lcd0_ctrl(struct clk *clk, int enable) |
60 | { | 61 | { |
61 | return s5p_gatectrl(S5P_CLKSRC_MASK_LCD0, clk, enable); | 62 | return s5p_gatectrl(S5P_CLKSRC_MASK_LCD0, clk, enable); |
62 | } | 63 | } |
63 | 64 | ||
64 | static int s5pv310_clksrc_mask_lcd1_ctrl(struct clk *clk, int enable) | 65 | static int exynos4_clksrc_mask_lcd1_ctrl(struct clk *clk, int enable) |
65 | { | 66 | { |
66 | return s5p_gatectrl(S5P_CLKSRC_MASK_LCD1, clk, enable); | 67 | return s5p_gatectrl(S5P_CLKSRC_MASK_LCD1, clk, enable); |
67 | } | 68 | } |
68 | 69 | ||
69 | static int s5pv310_clksrc_mask_fsys_ctrl(struct clk *clk, int enable) | 70 | static int exynos4_clksrc_mask_fsys_ctrl(struct clk *clk, int enable) |
70 | { | 71 | { |
71 | return s5p_gatectrl(S5P_CLKSRC_MASK_FSYS, clk, enable); | 72 | return s5p_gatectrl(S5P_CLKSRC_MASK_FSYS, clk, enable); |
72 | } | 73 | } |
73 | 74 | ||
74 | static int s5pv310_clksrc_mask_peril0_ctrl(struct clk *clk, int enable) | 75 | static int exynos4_clksrc_mask_peril0_ctrl(struct clk *clk, int enable) |
75 | { | 76 | { |
76 | return s5p_gatectrl(S5P_CLKSRC_MASK_PERIL0, clk, enable); | 77 | return s5p_gatectrl(S5P_CLKSRC_MASK_PERIL0, clk, enable); |
77 | } | 78 | } |
78 | 79 | ||
79 | static int s5pv310_clksrc_mask_peril1_ctrl(struct clk *clk, int enable) | 80 | static int exynos4_clksrc_mask_peril1_ctrl(struct clk *clk, int enable) |
80 | { | 81 | { |
81 | return s5p_gatectrl(S5P_CLKSRC_MASK_PERIL1, clk, enable); | 82 | return s5p_gatectrl(S5P_CLKSRC_MASK_PERIL1, clk, enable); |
82 | } | 83 | } |
83 | 84 | ||
84 | static int s5pv310_clk_ip_cam_ctrl(struct clk *clk, int enable) | 85 | static int exynos4_clk_ip_mfc_ctrl(struct clk *clk, int enable) |
86 | { | ||
87 | return s5p_gatectrl(S5P_CLKGATE_IP_MFC, clk, enable); | ||
88 | } | ||
89 | |||
90 | static int exynos4_clk_ip_cam_ctrl(struct clk *clk, int enable) | ||
85 | { | 91 | { |
86 | return s5p_gatectrl(S5P_CLKGATE_IP_CAM, clk, enable); | 92 | return s5p_gatectrl(S5P_CLKGATE_IP_CAM, clk, enable); |
87 | } | 93 | } |
88 | 94 | ||
89 | static int s5pv310_clk_ip_image_ctrl(struct clk *clk, int enable) | 95 | static int exynos4_clk_ip_tv_ctrl(struct clk *clk, int enable) |
96 | { | ||
97 | return s5p_gatectrl(S5P_CLKGATE_IP_TV, clk, enable); | ||
98 | } | ||
99 | |||
100 | static int exynos4_clk_ip_image_ctrl(struct clk *clk, int enable) | ||
90 | { | 101 | { |
91 | return s5p_gatectrl(S5P_CLKGATE_IP_IMAGE, clk, enable); | 102 | return s5p_gatectrl(S5P_CLKGATE_IP_IMAGE, clk, enable); |
92 | } | 103 | } |
93 | 104 | ||
94 | static int s5pv310_clk_ip_lcd0_ctrl(struct clk *clk, int enable) | 105 | static int exynos4_clk_ip_lcd0_ctrl(struct clk *clk, int enable) |
95 | { | 106 | { |
96 | return s5p_gatectrl(S5P_CLKGATE_IP_LCD0, clk, enable); | 107 | return s5p_gatectrl(S5P_CLKGATE_IP_LCD0, clk, enable); |
97 | } | 108 | } |
98 | 109 | ||
99 | static int s5pv310_clk_ip_lcd1_ctrl(struct clk *clk, int enable) | 110 | static int exynos4_clk_ip_lcd1_ctrl(struct clk *clk, int enable) |
100 | { | 111 | { |
101 | return s5p_gatectrl(S5P_CLKGATE_IP_LCD1, clk, enable); | 112 | return s5p_gatectrl(S5P_CLKGATE_IP_LCD1, clk, enable); |
102 | } | 113 | } |
103 | 114 | ||
104 | static int s5pv310_clk_ip_fsys_ctrl(struct clk *clk, int enable) | 115 | static int exynos4_clk_ip_fsys_ctrl(struct clk *clk, int enable) |
105 | { | 116 | { |
106 | return s5p_gatectrl(S5P_CLKGATE_IP_FSYS, clk, enable); | 117 | return s5p_gatectrl(S5P_CLKGATE_IP_FSYS, clk, enable); |
107 | } | 118 | } |
108 | 119 | ||
109 | static int s5pv310_clk_ip_peril_ctrl(struct clk *clk, int enable) | 120 | static int exynos4_clk_ip_peril_ctrl(struct clk *clk, int enable) |
110 | { | 121 | { |
111 | return s5p_gatectrl(S5P_CLKGATE_IP_PERIL, clk, enable); | 122 | return s5p_gatectrl(S5P_CLKGATE_IP_PERIL, clk, enable); |
112 | } | 123 | } |
113 | 124 | ||
114 | static int s5pv310_clk_ip_perir_ctrl(struct clk *clk, int enable) | 125 | static int exynos4_clk_ip_perir_ctrl(struct clk *clk, int enable) |
115 | { | 126 | { |
116 | return s5p_gatectrl(S5P_CLKGATE_IP_PERIR, clk, enable); | 127 | return s5p_gatectrl(S5P_CLKGATE_IP_PERIR, clk, enable); |
117 | } | 128 | } |
@@ -358,7 +369,7 @@ static struct clksrc_clk clk_vpllsrc = { | |||
358 | .clk = { | 369 | .clk = { |
359 | .name = "vpll_src", | 370 | .name = "vpll_src", |
360 | .id = -1, | 371 | .id = -1, |
361 | .enable = s5pv310_clksrc_mask_top_ctrl, | 372 | .enable = exynos4_clksrc_mask_top_ctrl, |
362 | .ctrlbit = (1 << 0), | 373 | .ctrlbit = (1 << 0), |
363 | }, | 374 | }, |
364 | .sources = &clkset_vpllsrc, | 375 | .sources = &clkset_vpllsrc, |
@@ -389,239 +400,322 @@ static struct clk init_clocks_off[] = { | |||
389 | .name = "timers", | 400 | .name = "timers", |
390 | .id = -1, | 401 | .id = -1, |
391 | .parent = &clk_aclk_100.clk, | 402 | .parent = &clk_aclk_100.clk, |
392 | .enable = s5pv310_clk_ip_peril_ctrl, | 403 | .enable = exynos4_clk_ip_peril_ctrl, |
393 | .ctrlbit = (1<<24), | 404 | .ctrlbit = (1<<24), |
394 | }, { | 405 | }, { |
395 | .name = "csis", | 406 | .name = "csis", |
396 | .id = 0, | 407 | .id = 0, |
397 | .enable = s5pv310_clk_ip_cam_ctrl, | 408 | .enable = exynos4_clk_ip_cam_ctrl, |
398 | .ctrlbit = (1 << 4), | 409 | .ctrlbit = (1 << 4), |
399 | }, { | 410 | }, { |
400 | .name = "csis", | 411 | .name = "csis", |
401 | .id = 1, | 412 | .id = 1, |
402 | .enable = s5pv310_clk_ip_cam_ctrl, | 413 | .enable = exynos4_clk_ip_cam_ctrl, |
403 | .ctrlbit = (1 << 5), | 414 | .ctrlbit = (1 << 5), |
404 | }, { | 415 | }, { |
405 | .name = "fimc", | 416 | .name = "fimc", |
406 | .id = 0, | 417 | .id = 0, |
407 | .enable = s5pv310_clk_ip_cam_ctrl, | 418 | .enable = exynos4_clk_ip_cam_ctrl, |
408 | .ctrlbit = (1 << 0), | 419 | .ctrlbit = (1 << 0), |
409 | }, { | 420 | }, { |
410 | .name = "fimc", | 421 | .name = "fimc", |
411 | .id = 1, | 422 | .id = 1, |
412 | .enable = s5pv310_clk_ip_cam_ctrl, | 423 | .enable = exynos4_clk_ip_cam_ctrl, |
413 | .ctrlbit = (1 << 1), | 424 | .ctrlbit = (1 << 1), |
414 | }, { | 425 | }, { |
415 | .name = "fimc", | 426 | .name = "fimc", |
416 | .id = 2, | 427 | .id = 2, |
417 | .enable = s5pv310_clk_ip_cam_ctrl, | 428 | .enable = exynos4_clk_ip_cam_ctrl, |
418 | .ctrlbit = (1 << 2), | 429 | .ctrlbit = (1 << 2), |
419 | }, { | 430 | }, { |
420 | .name = "fimc", | 431 | .name = "fimc", |
421 | .id = 3, | 432 | .id = 3, |
422 | .enable = s5pv310_clk_ip_cam_ctrl, | 433 | .enable = exynos4_clk_ip_cam_ctrl, |
423 | .ctrlbit = (1 << 3), | 434 | .ctrlbit = (1 << 3), |
424 | }, { | 435 | }, { |
425 | .name = "fimd", | 436 | .name = "fimd", |
426 | .id = 0, | 437 | .id = 0, |
427 | .enable = s5pv310_clk_ip_lcd0_ctrl, | 438 | .enable = exynos4_clk_ip_lcd0_ctrl, |
428 | .ctrlbit = (1 << 0), | 439 | .ctrlbit = (1 << 0), |
429 | }, { | 440 | }, { |
430 | .name = "fimd", | 441 | .name = "fimd", |
431 | .id = 1, | 442 | .id = 1, |
432 | .enable = s5pv310_clk_ip_lcd1_ctrl, | 443 | .enable = exynos4_clk_ip_lcd1_ctrl, |
433 | .ctrlbit = (1 << 0), | 444 | .ctrlbit = (1 << 0), |
434 | }, { | 445 | }, { |
446 | .name = "sataphy", | ||
447 | .id = -1, | ||
448 | .parent = &clk_aclk_133.clk, | ||
449 | .enable = exynos4_clk_ip_fsys_ctrl, | ||
450 | .ctrlbit = (1 << 3), | ||
451 | }, { | ||
435 | .name = "hsmmc", | 452 | .name = "hsmmc", |
436 | .id = 0, | 453 | .id = 0, |
437 | .parent = &clk_aclk_133.clk, | 454 | .parent = &clk_aclk_133.clk, |
438 | .enable = s5pv310_clk_ip_fsys_ctrl, | 455 | .enable = exynos4_clk_ip_fsys_ctrl, |
439 | .ctrlbit = (1 << 5), | 456 | .ctrlbit = (1 << 5), |
440 | }, { | 457 | }, { |
441 | .name = "hsmmc", | 458 | .name = "hsmmc", |
442 | .id = 1, | 459 | .id = 1, |
443 | .parent = &clk_aclk_133.clk, | 460 | .parent = &clk_aclk_133.clk, |
444 | .enable = s5pv310_clk_ip_fsys_ctrl, | 461 | .enable = exynos4_clk_ip_fsys_ctrl, |
445 | .ctrlbit = (1 << 6), | 462 | .ctrlbit = (1 << 6), |
446 | }, { | 463 | }, { |
447 | .name = "hsmmc", | 464 | .name = "hsmmc", |
448 | .id = 2, | 465 | .id = 2, |
449 | .parent = &clk_aclk_133.clk, | 466 | .parent = &clk_aclk_133.clk, |
450 | .enable = s5pv310_clk_ip_fsys_ctrl, | 467 | .enable = exynos4_clk_ip_fsys_ctrl, |
451 | .ctrlbit = (1 << 7), | 468 | .ctrlbit = (1 << 7), |
452 | }, { | 469 | }, { |
453 | .name = "hsmmc", | 470 | .name = "hsmmc", |
454 | .id = 3, | 471 | .id = 3, |
455 | .parent = &clk_aclk_133.clk, | 472 | .parent = &clk_aclk_133.clk, |
456 | .enable = s5pv310_clk_ip_fsys_ctrl, | 473 | .enable = exynos4_clk_ip_fsys_ctrl, |
457 | .ctrlbit = (1 << 8), | 474 | .ctrlbit = (1 << 8), |
458 | }, { | 475 | }, { |
459 | .name = "hsmmc", | 476 | .name = "hsmmc", |
460 | .id = 4, | 477 | .id = 4, |
461 | .parent = &clk_aclk_133.clk, | 478 | .parent = &clk_aclk_133.clk, |
462 | .enable = s5pv310_clk_ip_fsys_ctrl, | 479 | .enable = exynos4_clk_ip_fsys_ctrl, |
463 | .ctrlbit = (1 << 9), | 480 | .ctrlbit = (1 << 9), |
464 | }, { | 481 | }, { |
465 | .name = "sata", | 482 | .name = "sata", |
466 | .id = -1, | 483 | .id = -1, |
467 | .enable = s5pv310_clk_ip_fsys_ctrl, | 484 | .parent = &clk_aclk_133.clk, |
485 | .enable = exynos4_clk_ip_fsys_ctrl, | ||
468 | .ctrlbit = (1 << 10), | 486 | .ctrlbit = (1 << 10), |
469 | }, { | 487 | }, { |
470 | .name = "pdma", | 488 | .name = "pdma", |
471 | .id = 0, | 489 | .id = 0, |
472 | .enable = s5pv310_clk_ip_fsys_ctrl, | 490 | .enable = exynos4_clk_ip_fsys_ctrl, |
473 | .ctrlbit = (1 << 0), | 491 | .ctrlbit = (1 << 0), |
474 | }, { | 492 | }, { |
475 | .name = "pdma", | 493 | .name = "pdma", |
476 | .id = 1, | 494 | .id = 1, |
477 | .enable = s5pv310_clk_ip_fsys_ctrl, | 495 | .enable = exynos4_clk_ip_fsys_ctrl, |
478 | .ctrlbit = (1 << 1), | 496 | .ctrlbit = (1 << 1), |
479 | }, { | 497 | }, { |
480 | .name = "adc", | 498 | .name = "adc", |
481 | .id = -1, | 499 | .id = -1, |
482 | .enable = s5pv310_clk_ip_peril_ctrl, | 500 | .enable = exynos4_clk_ip_peril_ctrl, |
483 | .ctrlbit = (1 << 15), | 501 | .ctrlbit = (1 << 15), |
484 | }, { | 502 | }, { |
503 | .name = "keypad", | ||
504 | .id = -1, | ||
505 | .enable = exynos4_clk_ip_perir_ctrl, | ||
506 | .ctrlbit = (1 << 16), | ||
507 | }, { | ||
485 | .name = "rtc", | 508 | .name = "rtc", |
486 | .id = -1, | 509 | .id = -1, |
487 | .enable = s5pv310_clk_ip_perir_ctrl, | 510 | .enable = exynos4_clk_ip_perir_ctrl, |
488 | .ctrlbit = (1 << 15), | 511 | .ctrlbit = (1 << 15), |
489 | }, { | 512 | }, { |
490 | .name = "watchdog", | 513 | .name = "watchdog", |
491 | .id = -1, | 514 | .id = -1, |
492 | .enable = s5pv310_clk_ip_perir_ctrl, | 515 | .parent = &clk_aclk_100.clk, |
516 | .enable = exynos4_clk_ip_perir_ctrl, | ||
493 | .ctrlbit = (1 << 14), | 517 | .ctrlbit = (1 << 14), |
494 | }, { | 518 | }, { |
495 | .name = "usbhost", | 519 | .name = "usbhost", |
496 | .id = -1, | 520 | .id = -1, |
497 | .enable = s5pv310_clk_ip_fsys_ctrl , | 521 | .enable = exynos4_clk_ip_fsys_ctrl , |
498 | .ctrlbit = (1 << 12), | 522 | .ctrlbit = (1 << 12), |
499 | }, { | 523 | }, { |
500 | .name = "otg", | 524 | .name = "otg", |
501 | .id = -1, | 525 | .id = -1, |
502 | .enable = s5pv310_clk_ip_fsys_ctrl, | 526 | .enable = exynos4_clk_ip_fsys_ctrl, |
503 | .ctrlbit = (1 << 13), | 527 | .ctrlbit = (1 << 13), |
504 | }, { | 528 | }, { |
505 | .name = "spi", | 529 | .name = "spi", |
506 | .id = 0, | 530 | .id = 0, |
507 | .enable = s5pv310_clk_ip_peril_ctrl, | 531 | .enable = exynos4_clk_ip_peril_ctrl, |
508 | .ctrlbit = (1 << 16), | 532 | .ctrlbit = (1 << 16), |
509 | }, { | 533 | }, { |
510 | .name = "spi", | 534 | .name = "spi", |
511 | .id = 1, | 535 | .id = 1, |
512 | .enable = s5pv310_clk_ip_peril_ctrl, | 536 | .enable = exynos4_clk_ip_peril_ctrl, |
513 | .ctrlbit = (1 << 17), | 537 | .ctrlbit = (1 << 17), |
514 | }, { | 538 | }, { |
515 | .name = "spi", | 539 | .name = "spi", |
516 | .id = 2, | 540 | .id = 2, |
517 | .enable = s5pv310_clk_ip_peril_ctrl, | 541 | .enable = exynos4_clk_ip_peril_ctrl, |
518 | .ctrlbit = (1 << 18), | 542 | .ctrlbit = (1 << 18), |
519 | }, { | 543 | }, { |
520 | .name = "iis", | 544 | .name = "iis", |
521 | .id = 0, | 545 | .id = 0, |
522 | .enable = s5pv310_clk_ip_peril_ctrl, | 546 | .enable = exynos4_clk_ip_peril_ctrl, |
523 | .ctrlbit = (1 << 19), | 547 | .ctrlbit = (1 << 19), |
524 | }, { | 548 | }, { |
525 | .name = "iis", | 549 | .name = "iis", |
526 | .id = 1, | 550 | .id = 1, |
527 | .enable = s5pv310_clk_ip_peril_ctrl, | 551 | .enable = exynos4_clk_ip_peril_ctrl, |
528 | .ctrlbit = (1 << 20), | 552 | .ctrlbit = (1 << 20), |
529 | }, { | 553 | }, { |
530 | .name = "iis", | 554 | .name = "iis", |
531 | .id = 2, | 555 | .id = 2, |
532 | .enable = s5pv310_clk_ip_peril_ctrl, | 556 | .enable = exynos4_clk_ip_peril_ctrl, |
533 | .ctrlbit = (1 << 21), | 557 | .ctrlbit = (1 << 21), |
534 | }, { | 558 | }, { |
535 | .name = "ac97", | 559 | .name = "ac97", |
536 | .id = -1, | 560 | .id = -1, |
537 | .enable = s5pv310_clk_ip_peril_ctrl, | 561 | .enable = exynos4_clk_ip_peril_ctrl, |
538 | .ctrlbit = (1 << 27), | 562 | .ctrlbit = (1 << 27), |
539 | }, { | 563 | }, { |
540 | .name = "fimg2d", | 564 | .name = "fimg2d", |
541 | .id = -1, | 565 | .id = -1, |
542 | .enable = s5pv310_clk_ip_image_ctrl, | 566 | .enable = exynos4_clk_ip_image_ctrl, |
543 | .ctrlbit = (1 << 0), | 567 | .ctrlbit = (1 << 0), |
544 | }, { | 568 | }, { |
545 | .name = "i2c", | 569 | .name = "i2c", |
546 | .id = 0, | 570 | .id = 0, |
547 | .parent = &clk_aclk_100.clk, | 571 | .parent = &clk_aclk_100.clk, |
548 | .enable = s5pv310_clk_ip_peril_ctrl, | 572 | .enable = exynos4_clk_ip_peril_ctrl, |
549 | .ctrlbit = (1 << 6), | 573 | .ctrlbit = (1 << 6), |
550 | }, { | 574 | }, { |
551 | .name = "i2c", | 575 | .name = "i2c", |
552 | .id = 1, | 576 | .id = 1, |
553 | .parent = &clk_aclk_100.clk, | 577 | .parent = &clk_aclk_100.clk, |
554 | .enable = s5pv310_clk_ip_peril_ctrl, | 578 | .enable = exynos4_clk_ip_peril_ctrl, |
555 | .ctrlbit = (1 << 7), | 579 | .ctrlbit = (1 << 7), |
556 | }, { | 580 | }, { |
557 | .name = "i2c", | 581 | .name = "i2c", |
558 | .id = 2, | 582 | .id = 2, |
559 | .parent = &clk_aclk_100.clk, | 583 | .parent = &clk_aclk_100.clk, |
560 | .enable = s5pv310_clk_ip_peril_ctrl, | 584 | .enable = exynos4_clk_ip_peril_ctrl, |
561 | .ctrlbit = (1 << 8), | 585 | .ctrlbit = (1 << 8), |
562 | }, { | 586 | }, { |
563 | .name = "i2c", | 587 | .name = "i2c", |
564 | .id = 3, | 588 | .id = 3, |
565 | .parent = &clk_aclk_100.clk, | 589 | .parent = &clk_aclk_100.clk, |
566 | .enable = s5pv310_clk_ip_peril_ctrl, | 590 | .enable = exynos4_clk_ip_peril_ctrl, |
567 | .ctrlbit = (1 << 9), | 591 | .ctrlbit = (1 << 9), |
568 | }, { | 592 | }, { |
569 | .name = "i2c", | 593 | .name = "i2c", |
570 | .id = 4, | 594 | .id = 4, |
571 | .parent = &clk_aclk_100.clk, | 595 | .parent = &clk_aclk_100.clk, |
572 | .enable = s5pv310_clk_ip_peril_ctrl, | 596 | .enable = exynos4_clk_ip_peril_ctrl, |
573 | .ctrlbit = (1 << 10), | 597 | .ctrlbit = (1 << 10), |
574 | }, { | 598 | }, { |
575 | .name = "i2c", | 599 | .name = "i2c", |
576 | .id = 5, | 600 | .id = 5, |
577 | .parent = &clk_aclk_100.clk, | 601 | .parent = &clk_aclk_100.clk, |
578 | .enable = s5pv310_clk_ip_peril_ctrl, | 602 | .enable = exynos4_clk_ip_peril_ctrl, |
579 | .ctrlbit = (1 << 11), | 603 | .ctrlbit = (1 << 11), |
580 | }, { | 604 | }, { |
581 | .name = "i2c", | 605 | .name = "i2c", |
582 | .id = 6, | 606 | .id = 6, |
583 | .parent = &clk_aclk_100.clk, | 607 | .parent = &clk_aclk_100.clk, |
584 | .enable = s5pv310_clk_ip_peril_ctrl, | 608 | .enable = exynos4_clk_ip_peril_ctrl, |
585 | .ctrlbit = (1 << 12), | 609 | .ctrlbit = (1 << 12), |
586 | }, { | 610 | }, { |
587 | .name = "i2c", | 611 | .name = "i2c", |
588 | .id = 7, | 612 | .id = 7, |
589 | .parent = &clk_aclk_100.clk, | 613 | .parent = &clk_aclk_100.clk, |
590 | .enable = s5pv310_clk_ip_peril_ctrl, | 614 | .enable = exynos4_clk_ip_peril_ctrl, |
591 | .ctrlbit = (1 << 13), | 615 | .ctrlbit = (1 << 13), |
592 | }, | 616 | }, { |
617 | .name = "SYSMMU_MDMA", | ||
618 | .id = -1, | ||
619 | .enable = exynos4_clk_ip_image_ctrl, | ||
620 | .ctrlbit = (1 << 5), | ||
621 | }, { | ||
622 | .name = "SYSMMU_FIMC0", | ||
623 | .id = -1, | ||
624 | .enable = exynos4_clk_ip_cam_ctrl, | ||
625 | .ctrlbit = (1 << 7), | ||
626 | }, { | ||
627 | .name = "SYSMMU_FIMC1", | ||
628 | .id = -1, | ||
629 | .enable = exynos4_clk_ip_cam_ctrl, | ||
630 | .ctrlbit = (1 << 8), | ||
631 | }, { | ||
632 | .name = "SYSMMU_FIMC2", | ||
633 | .id = -1, | ||
634 | .enable = exynos4_clk_ip_cam_ctrl, | ||
635 | .ctrlbit = (1 << 9), | ||
636 | }, { | ||
637 | .name = "SYSMMU_FIMC3", | ||
638 | .id = -1, | ||
639 | .enable = exynos4_clk_ip_cam_ctrl, | ||
640 | .ctrlbit = (1 << 10), | ||
641 | }, { | ||
642 | .name = "SYSMMU_JPEG", | ||
643 | .id = -1, | ||
644 | .enable = exynos4_clk_ip_cam_ctrl, | ||
645 | .ctrlbit = (1 << 11), | ||
646 | }, { | ||
647 | .name = "SYSMMU_FIMD0", | ||
648 | .id = -1, | ||
649 | .enable = exynos4_clk_ip_lcd0_ctrl, | ||
650 | .ctrlbit = (1 << 4), | ||
651 | }, { | ||
652 | .name = "SYSMMU_FIMD1", | ||
653 | .id = -1, | ||
654 | .enable = exynos4_clk_ip_lcd1_ctrl, | ||
655 | .ctrlbit = (1 << 4), | ||
656 | }, { | ||
657 | .name = "SYSMMU_PCIe", | ||
658 | .id = -1, | ||
659 | .enable = exynos4_clk_ip_fsys_ctrl, | ||
660 | .ctrlbit = (1 << 18), | ||
661 | }, { | ||
662 | .name = "SYSMMU_G2D", | ||
663 | .id = -1, | ||
664 | .enable = exynos4_clk_ip_image_ctrl, | ||
665 | .ctrlbit = (1 << 3), | ||
666 | }, { | ||
667 | .name = "SYSMMU_ROTATOR", | ||
668 | .id = -1, | ||
669 | .enable = exynos4_clk_ip_image_ctrl, | ||
670 | .ctrlbit = (1 << 4), | ||
671 | }, { | ||
672 | .name = "SYSMMU_TV", | ||
673 | .id = -1, | ||
674 | .enable = exynos4_clk_ip_tv_ctrl, | ||
675 | .ctrlbit = (1 << 4), | ||
676 | }, { | ||
677 | .name = "SYSMMU_MFC_L", | ||
678 | .id = -1, | ||
679 | .enable = exynos4_clk_ip_mfc_ctrl, | ||
680 | .ctrlbit = (1 << 1), | ||
681 | }, { | ||
682 | .name = "SYSMMU_MFC_R", | ||
683 | .id = -1, | ||
684 | .enable = exynos4_clk_ip_mfc_ctrl, | ||
685 | .ctrlbit = (1 << 2), | ||
686 | } | ||
593 | }; | 687 | }; |
594 | 688 | ||
595 | static struct clk init_clocks[] = { | 689 | static struct clk init_clocks[] = { |
596 | { | 690 | { |
597 | .name = "uart", | 691 | .name = "uart", |
598 | .id = 0, | 692 | .id = 0, |
599 | .enable = s5pv310_clk_ip_peril_ctrl, | 693 | .enable = exynos4_clk_ip_peril_ctrl, |
600 | .ctrlbit = (1 << 0), | 694 | .ctrlbit = (1 << 0), |
601 | }, { | 695 | }, { |
602 | .name = "uart", | 696 | .name = "uart", |
603 | .id = 1, | 697 | .id = 1, |
604 | .enable = s5pv310_clk_ip_peril_ctrl, | 698 | .enable = exynos4_clk_ip_peril_ctrl, |
605 | .ctrlbit = (1 << 1), | 699 | .ctrlbit = (1 << 1), |
606 | }, { | 700 | }, { |
607 | .name = "uart", | 701 | .name = "uart", |
608 | .id = 2, | 702 | .id = 2, |
609 | .enable = s5pv310_clk_ip_peril_ctrl, | 703 | .enable = exynos4_clk_ip_peril_ctrl, |
610 | .ctrlbit = (1 << 2), | 704 | .ctrlbit = (1 << 2), |
611 | }, { | 705 | }, { |
612 | .name = "uart", | 706 | .name = "uart", |
613 | .id = 3, | 707 | .id = 3, |
614 | .enable = s5pv310_clk_ip_peril_ctrl, | 708 | .enable = exynos4_clk_ip_peril_ctrl, |
615 | .ctrlbit = (1 << 3), | 709 | .ctrlbit = (1 << 3), |
616 | }, { | 710 | }, { |
617 | .name = "uart", | 711 | .name = "uart", |
618 | .id = 4, | 712 | .id = 4, |
619 | .enable = s5pv310_clk_ip_peril_ctrl, | 713 | .enable = exynos4_clk_ip_peril_ctrl, |
620 | .ctrlbit = (1 << 4), | 714 | .ctrlbit = (1 << 4), |
621 | }, { | 715 | }, { |
622 | .name = "uart", | 716 | .name = "uart", |
623 | .id = 5, | 717 | .id = 5, |
624 | .enable = s5pv310_clk_ip_peril_ctrl, | 718 | .enable = exynos4_clk_ip_peril_ctrl, |
625 | .ctrlbit = (1 << 5), | 719 | .ctrlbit = (1 << 5), |
626 | } | 720 | } |
627 | }; | 721 | }; |
@@ -746,7 +840,7 @@ static struct clksrc_clk clksrcs[] = { | |||
746 | .clk = { | 840 | .clk = { |
747 | .name = "uclk1", | 841 | .name = "uclk1", |
748 | .id = 0, | 842 | .id = 0, |
749 | .enable = s5pv310_clksrc_mask_peril0_ctrl, | 843 | .enable = exynos4_clksrc_mask_peril0_ctrl, |
750 | .ctrlbit = (1 << 0), | 844 | .ctrlbit = (1 << 0), |
751 | }, | 845 | }, |
752 | .sources = &clkset_group, | 846 | .sources = &clkset_group, |
@@ -756,7 +850,7 @@ static struct clksrc_clk clksrcs[] = { | |||
756 | .clk = { | 850 | .clk = { |
757 | .name = "uclk1", | 851 | .name = "uclk1", |
758 | .id = 1, | 852 | .id = 1, |
759 | .enable = s5pv310_clksrc_mask_peril0_ctrl, | 853 | .enable = exynos4_clksrc_mask_peril0_ctrl, |
760 | .ctrlbit = (1 << 4), | 854 | .ctrlbit = (1 << 4), |
761 | }, | 855 | }, |
762 | .sources = &clkset_group, | 856 | .sources = &clkset_group, |
@@ -766,7 +860,7 @@ static struct clksrc_clk clksrcs[] = { | |||
766 | .clk = { | 860 | .clk = { |
767 | .name = "uclk1", | 861 | .name = "uclk1", |
768 | .id = 2, | 862 | .id = 2, |
769 | .enable = s5pv310_clksrc_mask_peril0_ctrl, | 863 | .enable = exynos4_clksrc_mask_peril0_ctrl, |
770 | .ctrlbit = (1 << 8), | 864 | .ctrlbit = (1 << 8), |
771 | }, | 865 | }, |
772 | .sources = &clkset_group, | 866 | .sources = &clkset_group, |
@@ -776,7 +870,7 @@ static struct clksrc_clk clksrcs[] = { | |||
776 | .clk = { | 870 | .clk = { |
777 | .name = "uclk1", | 871 | .name = "uclk1", |
778 | .id = 3, | 872 | .id = 3, |
779 | .enable = s5pv310_clksrc_mask_peril0_ctrl, | 873 | .enable = exynos4_clksrc_mask_peril0_ctrl, |
780 | .ctrlbit = (1 << 12), | 874 | .ctrlbit = (1 << 12), |
781 | }, | 875 | }, |
782 | .sources = &clkset_group, | 876 | .sources = &clkset_group, |
@@ -786,7 +880,7 @@ static struct clksrc_clk clksrcs[] = { | |||
786 | .clk = { | 880 | .clk = { |
787 | .name = "sclk_pwm", | 881 | .name = "sclk_pwm", |
788 | .id = -1, | 882 | .id = -1, |
789 | .enable = s5pv310_clksrc_mask_peril0_ctrl, | 883 | .enable = exynos4_clksrc_mask_peril0_ctrl, |
790 | .ctrlbit = (1 << 24), | 884 | .ctrlbit = (1 << 24), |
791 | }, | 885 | }, |
792 | .sources = &clkset_group, | 886 | .sources = &clkset_group, |
@@ -796,7 +890,7 @@ static struct clksrc_clk clksrcs[] = { | |||
796 | .clk = { | 890 | .clk = { |
797 | .name = "sclk_csis", | 891 | .name = "sclk_csis", |
798 | .id = 0, | 892 | .id = 0, |
799 | .enable = s5pv310_clksrc_mask_cam_ctrl, | 893 | .enable = exynos4_clksrc_mask_cam_ctrl, |
800 | .ctrlbit = (1 << 24), | 894 | .ctrlbit = (1 << 24), |
801 | }, | 895 | }, |
802 | .sources = &clkset_group, | 896 | .sources = &clkset_group, |
@@ -806,7 +900,7 @@ static struct clksrc_clk clksrcs[] = { | |||
806 | .clk = { | 900 | .clk = { |
807 | .name = "sclk_csis", | 901 | .name = "sclk_csis", |
808 | .id = 1, | 902 | .id = 1, |
809 | .enable = s5pv310_clksrc_mask_cam_ctrl, | 903 | .enable = exynos4_clksrc_mask_cam_ctrl, |
810 | .ctrlbit = (1 << 28), | 904 | .ctrlbit = (1 << 28), |
811 | }, | 905 | }, |
812 | .sources = &clkset_group, | 906 | .sources = &clkset_group, |
@@ -816,7 +910,7 @@ static struct clksrc_clk clksrcs[] = { | |||
816 | .clk = { | 910 | .clk = { |
817 | .name = "sclk_cam", | 911 | .name = "sclk_cam", |
818 | .id = 0, | 912 | .id = 0, |
819 | .enable = s5pv310_clksrc_mask_cam_ctrl, | 913 | .enable = exynos4_clksrc_mask_cam_ctrl, |
820 | .ctrlbit = (1 << 16), | 914 | .ctrlbit = (1 << 16), |
821 | }, | 915 | }, |
822 | .sources = &clkset_group, | 916 | .sources = &clkset_group, |
@@ -826,7 +920,7 @@ static struct clksrc_clk clksrcs[] = { | |||
826 | .clk = { | 920 | .clk = { |
827 | .name = "sclk_cam", | 921 | .name = "sclk_cam", |
828 | .id = 1, | 922 | .id = 1, |
829 | .enable = s5pv310_clksrc_mask_cam_ctrl, | 923 | .enable = exynos4_clksrc_mask_cam_ctrl, |
830 | .ctrlbit = (1 << 20), | 924 | .ctrlbit = (1 << 20), |
831 | }, | 925 | }, |
832 | .sources = &clkset_group, | 926 | .sources = &clkset_group, |
@@ -836,7 +930,7 @@ static struct clksrc_clk clksrcs[] = { | |||
836 | .clk = { | 930 | .clk = { |
837 | .name = "sclk_fimc", | 931 | .name = "sclk_fimc", |
838 | .id = 0, | 932 | .id = 0, |
839 | .enable = s5pv310_clksrc_mask_cam_ctrl, | 933 | .enable = exynos4_clksrc_mask_cam_ctrl, |
840 | .ctrlbit = (1 << 0), | 934 | .ctrlbit = (1 << 0), |
841 | }, | 935 | }, |
842 | .sources = &clkset_group, | 936 | .sources = &clkset_group, |
@@ -846,7 +940,7 @@ static struct clksrc_clk clksrcs[] = { | |||
846 | .clk = { | 940 | .clk = { |
847 | .name = "sclk_fimc", | 941 | .name = "sclk_fimc", |
848 | .id = 1, | 942 | .id = 1, |
849 | .enable = s5pv310_clksrc_mask_cam_ctrl, | 943 | .enable = exynos4_clksrc_mask_cam_ctrl, |
850 | .ctrlbit = (1 << 4), | 944 | .ctrlbit = (1 << 4), |
851 | }, | 945 | }, |
852 | .sources = &clkset_group, | 946 | .sources = &clkset_group, |
@@ -856,7 +950,7 @@ static struct clksrc_clk clksrcs[] = { | |||
856 | .clk = { | 950 | .clk = { |
857 | .name = "sclk_fimc", | 951 | .name = "sclk_fimc", |
858 | .id = 2, | 952 | .id = 2, |
859 | .enable = s5pv310_clksrc_mask_cam_ctrl, | 953 | .enable = exynos4_clksrc_mask_cam_ctrl, |
860 | .ctrlbit = (1 << 8), | 954 | .ctrlbit = (1 << 8), |
861 | }, | 955 | }, |
862 | .sources = &clkset_group, | 956 | .sources = &clkset_group, |
@@ -866,7 +960,7 @@ static struct clksrc_clk clksrcs[] = { | |||
866 | .clk = { | 960 | .clk = { |
867 | .name = "sclk_fimc", | 961 | .name = "sclk_fimc", |
868 | .id = 3, | 962 | .id = 3, |
869 | .enable = s5pv310_clksrc_mask_cam_ctrl, | 963 | .enable = exynos4_clksrc_mask_cam_ctrl, |
870 | .ctrlbit = (1 << 12), | 964 | .ctrlbit = (1 << 12), |
871 | }, | 965 | }, |
872 | .sources = &clkset_group, | 966 | .sources = &clkset_group, |
@@ -876,7 +970,7 @@ static struct clksrc_clk clksrcs[] = { | |||
876 | .clk = { | 970 | .clk = { |
877 | .name = "sclk_fimd", | 971 | .name = "sclk_fimd", |
878 | .id = 0, | 972 | .id = 0, |
879 | .enable = s5pv310_clksrc_mask_lcd0_ctrl, | 973 | .enable = exynos4_clksrc_mask_lcd0_ctrl, |
880 | .ctrlbit = (1 << 0), | 974 | .ctrlbit = (1 << 0), |
881 | }, | 975 | }, |
882 | .sources = &clkset_group, | 976 | .sources = &clkset_group, |
@@ -886,7 +980,7 @@ static struct clksrc_clk clksrcs[] = { | |||
886 | .clk = { | 980 | .clk = { |
887 | .name = "sclk_fimd", | 981 | .name = "sclk_fimd", |
888 | .id = 1, | 982 | .id = 1, |
889 | .enable = s5pv310_clksrc_mask_lcd1_ctrl, | 983 | .enable = exynos4_clksrc_mask_lcd1_ctrl, |
890 | .ctrlbit = (1 << 0), | 984 | .ctrlbit = (1 << 0), |
891 | }, | 985 | }, |
892 | .sources = &clkset_group, | 986 | .sources = &clkset_group, |
@@ -896,7 +990,7 @@ static struct clksrc_clk clksrcs[] = { | |||
896 | .clk = { | 990 | .clk = { |
897 | .name = "sclk_sata", | 991 | .name = "sclk_sata", |
898 | .id = -1, | 992 | .id = -1, |
899 | .enable = s5pv310_clksrc_mask_fsys_ctrl, | 993 | .enable = exynos4_clksrc_mask_fsys_ctrl, |
900 | .ctrlbit = (1 << 24), | 994 | .ctrlbit = (1 << 24), |
901 | }, | 995 | }, |
902 | .sources = &clkset_mout_corebus, | 996 | .sources = &clkset_mout_corebus, |
@@ -906,7 +1000,7 @@ static struct clksrc_clk clksrcs[] = { | |||
906 | .clk = { | 1000 | .clk = { |
907 | .name = "sclk_spi", | 1001 | .name = "sclk_spi", |
908 | .id = 0, | 1002 | .id = 0, |
909 | .enable = s5pv310_clksrc_mask_peril1_ctrl, | 1003 | .enable = exynos4_clksrc_mask_peril1_ctrl, |
910 | .ctrlbit = (1 << 16), | 1004 | .ctrlbit = (1 << 16), |
911 | }, | 1005 | }, |
912 | .sources = &clkset_group, | 1006 | .sources = &clkset_group, |
@@ -916,7 +1010,7 @@ static struct clksrc_clk clksrcs[] = { | |||
916 | .clk = { | 1010 | .clk = { |
917 | .name = "sclk_spi", | 1011 | .name = "sclk_spi", |
918 | .id = 1, | 1012 | .id = 1, |
919 | .enable = s5pv310_clksrc_mask_peril1_ctrl, | 1013 | .enable = exynos4_clksrc_mask_peril1_ctrl, |
920 | .ctrlbit = (1 << 20), | 1014 | .ctrlbit = (1 << 20), |
921 | }, | 1015 | }, |
922 | .sources = &clkset_group, | 1016 | .sources = &clkset_group, |
@@ -926,7 +1020,7 @@ static struct clksrc_clk clksrcs[] = { | |||
926 | .clk = { | 1020 | .clk = { |
927 | .name = "sclk_spi", | 1021 | .name = "sclk_spi", |
928 | .id = 2, | 1022 | .id = 2, |
929 | .enable = s5pv310_clksrc_mask_peril1_ctrl, | 1023 | .enable = exynos4_clksrc_mask_peril1_ctrl, |
930 | .ctrlbit = (1 << 24), | 1024 | .ctrlbit = (1 << 24), |
931 | }, | 1025 | }, |
932 | .sources = &clkset_group, | 1026 | .sources = &clkset_group, |
@@ -945,7 +1039,7 @@ static struct clksrc_clk clksrcs[] = { | |||
945 | .name = "sclk_mmc", | 1039 | .name = "sclk_mmc", |
946 | .id = 0, | 1040 | .id = 0, |
947 | .parent = &clk_dout_mmc0.clk, | 1041 | .parent = &clk_dout_mmc0.clk, |
948 | .enable = s5pv310_clksrc_mask_fsys_ctrl, | 1042 | .enable = exynos4_clksrc_mask_fsys_ctrl, |
949 | .ctrlbit = (1 << 0), | 1043 | .ctrlbit = (1 << 0), |
950 | }, | 1044 | }, |
951 | .reg_div = { .reg = S5P_CLKDIV_FSYS1, .shift = 8, .size = 8 }, | 1045 | .reg_div = { .reg = S5P_CLKDIV_FSYS1, .shift = 8, .size = 8 }, |
@@ -954,7 +1048,7 @@ static struct clksrc_clk clksrcs[] = { | |||
954 | .name = "sclk_mmc", | 1048 | .name = "sclk_mmc", |
955 | .id = 1, | 1049 | .id = 1, |
956 | .parent = &clk_dout_mmc1.clk, | 1050 | .parent = &clk_dout_mmc1.clk, |
957 | .enable = s5pv310_clksrc_mask_fsys_ctrl, | 1051 | .enable = exynos4_clksrc_mask_fsys_ctrl, |
958 | .ctrlbit = (1 << 4), | 1052 | .ctrlbit = (1 << 4), |
959 | }, | 1053 | }, |
960 | .reg_div = { .reg = S5P_CLKDIV_FSYS1, .shift = 24, .size = 8 }, | 1054 | .reg_div = { .reg = S5P_CLKDIV_FSYS1, .shift = 24, .size = 8 }, |
@@ -963,7 +1057,7 @@ static struct clksrc_clk clksrcs[] = { | |||
963 | .name = "sclk_mmc", | 1057 | .name = "sclk_mmc", |
964 | .id = 2, | 1058 | .id = 2, |
965 | .parent = &clk_dout_mmc2.clk, | 1059 | .parent = &clk_dout_mmc2.clk, |
966 | .enable = s5pv310_clksrc_mask_fsys_ctrl, | 1060 | .enable = exynos4_clksrc_mask_fsys_ctrl, |
967 | .ctrlbit = (1 << 8), | 1061 | .ctrlbit = (1 << 8), |
968 | }, | 1062 | }, |
969 | .reg_div = { .reg = S5P_CLKDIV_FSYS2, .shift = 8, .size = 8 }, | 1063 | .reg_div = { .reg = S5P_CLKDIV_FSYS2, .shift = 8, .size = 8 }, |
@@ -972,7 +1066,7 @@ static struct clksrc_clk clksrcs[] = { | |||
972 | .name = "sclk_mmc", | 1066 | .name = "sclk_mmc", |
973 | .id = 3, | 1067 | .id = 3, |
974 | .parent = &clk_dout_mmc3.clk, | 1068 | .parent = &clk_dout_mmc3.clk, |
975 | .enable = s5pv310_clksrc_mask_fsys_ctrl, | 1069 | .enable = exynos4_clksrc_mask_fsys_ctrl, |
976 | .ctrlbit = (1 << 12), | 1070 | .ctrlbit = (1 << 12), |
977 | }, | 1071 | }, |
978 | .reg_div = { .reg = S5P_CLKDIV_FSYS2, .shift = 24, .size = 8 }, | 1072 | .reg_div = { .reg = S5P_CLKDIV_FSYS2, .shift = 24, .size = 8 }, |
@@ -981,7 +1075,7 @@ static struct clksrc_clk clksrcs[] = { | |||
981 | .name = "sclk_mmc", | 1075 | .name = "sclk_mmc", |
982 | .id = 4, | 1076 | .id = 4, |
983 | .parent = &clk_dout_mmc4.clk, | 1077 | .parent = &clk_dout_mmc4.clk, |
984 | .enable = s5pv310_clksrc_mask_fsys_ctrl, | 1078 | .enable = exynos4_clksrc_mask_fsys_ctrl, |
985 | .ctrlbit = (1 << 16), | 1079 | .ctrlbit = (1 << 16), |
986 | }, | 1080 | }, |
987 | .reg_div = { .reg = S5P_CLKDIV_FSYS3, .shift = 8, .size = 8 }, | 1081 | .reg_div = { .reg = S5P_CLKDIV_FSYS3, .shift = 8, .size = 8 }, |
@@ -1022,16 +1116,16 @@ static struct clksrc_clk *sysclks[] = { | |||
1022 | 1116 | ||
1023 | static int xtal_rate; | 1117 | static int xtal_rate; |
1024 | 1118 | ||
1025 | static unsigned long s5pv310_fout_apll_get_rate(struct clk *clk) | 1119 | static unsigned long exynos4_fout_apll_get_rate(struct clk *clk) |
1026 | { | 1120 | { |
1027 | return s5p_get_pll45xx(xtal_rate, __raw_readl(S5P_APLL_CON0), pll_4508); | 1121 | return s5p_get_pll45xx(xtal_rate, __raw_readl(S5P_APLL_CON0), pll_4508); |
1028 | } | 1122 | } |
1029 | 1123 | ||
1030 | static struct clk_ops s5pv310_fout_apll_ops = { | 1124 | static struct clk_ops exynos4_fout_apll_ops = { |
1031 | .get_rate = s5pv310_fout_apll_get_rate, | 1125 | .get_rate = exynos4_fout_apll_get_rate, |
1032 | }; | 1126 | }; |
1033 | 1127 | ||
1034 | void __init_or_cpufreq s5pv310_setup_clocks(void) | 1128 | void __init_or_cpufreq exynos4_setup_clocks(void) |
1035 | { | 1129 | { |
1036 | struct clk *xtal_clk; | 1130 | struct clk *xtal_clk; |
1037 | unsigned long apll; | 1131 | unsigned long apll; |
@@ -1070,12 +1164,12 @@ void __init_or_cpufreq s5pv310_setup_clocks(void) | |||
1070 | vpll = s5p_get_pll46xx(vpllsrc, __raw_readl(S5P_VPLL_CON0), | 1164 | vpll = s5p_get_pll46xx(vpllsrc, __raw_readl(S5P_VPLL_CON0), |
1071 | __raw_readl(S5P_VPLL_CON1), pll_4650); | 1165 | __raw_readl(S5P_VPLL_CON1), pll_4650); |
1072 | 1166 | ||
1073 | clk_fout_apll.ops = &s5pv310_fout_apll_ops; | 1167 | clk_fout_apll.ops = &exynos4_fout_apll_ops; |
1074 | clk_fout_mpll.rate = mpll; | 1168 | clk_fout_mpll.rate = mpll; |
1075 | clk_fout_epll.rate = epll; | 1169 | clk_fout_epll.rate = epll; |
1076 | clk_fout_vpll.rate = vpll; | 1170 | clk_fout_vpll.rate = vpll; |
1077 | 1171 | ||
1078 | printk(KERN_INFO "S5PV310: PLL settings, A=%ld, M=%ld, E=%ld V=%ld", | 1172 | printk(KERN_INFO "EXYNOS4: PLL settings, A=%ld, M=%ld, E=%ld V=%ld", |
1079 | apll, mpll, epll, vpll); | 1173 | apll, mpll, epll, vpll); |
1080 | 1174 | ||
1081 | armclk = clk_get_rate(&clk_armclk.clk); | 1175 | armclk = clk_get_rate(&clk_armclk.clk); |
@@ -1086,7 +1180,7 @@ void __init_or_cpufreq s5pv310_setup_clocks(void) | |||
1086 | aclk_160 = clk_get_rate(&clk_aclk_160.clk); | 1180 | aclk_160 = clk_get_rate(&clk_aclk_160.clk); |
1087 | aclk_133 = clk_get_rate(&clk_aclk_133.clk); | 1181 | aclk_133 = clk_get_rate(&clk_aclk_133.clk); |
1088 | 1182 | ||
1089 | printk(KERN_INFO "S5PV310: ARMCLK=%ld, DMC=%ld, ACLK200=%ld\n" | 1183 | printk(KERN_INFO "EXYNOS4: ARMCLK=%ld, DMC=%ld, ACLK200=%ld\n" |
1090 | "ACLK100=%ld, ACLK160=%ld, ACLK133=%ld\n", | 1184 | "ACLK100=%ld, ACLK160=%ld, ACLK133=%ld\n", |
1091 | armclk, sclk_dmc, aclk_200, | 1185 | armclk, sclk_dmc, aclk_200, |
1092 | aclk_100, aclk_160, aclk_133); | 1186 | aclk_100, aclk_160, aclk_133); |
@@ -1103,7 +1197,7 @@ static struct clk *clks[] __initdata = { | |||
1103 | /* Nothing here yet */ | 1197 | /* Nothing here yet */ |
1104 | }; | 1198 | }; |
1105 | 1199 | ||
1106 | void __init s5pv310_register_clocks(void) | 1200 | void __init exynos4_register_clocks(void) |
1107 | { | 1201 | { |
1108 | int ptr; | 1202 | int ptr; |
1109 | 1203 | ||
diff --git a/arch/arm/mach-s5pv310/cpu.c b/arch/arm/mach-exynos4/cpu.c index 0db0fb65bd70..793011391943 100644 --- a/arch/arm/mach-s5pv310/cpu.c +++ b/arch/arm/mach-exynos4/cpu.c | |||
@@ -1,7 +1,7 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/cpu.c | 1 | /* linux/arch/arm/mach-exynos4/cpu.c |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * This program is free software; you can redistribute it and/or modify | 6 | * This program is free software; you can redistribute it and/or modify |
7 | * it under the terms of the GNU General Public License version 2 as | 7 | * it under the terms of the GNU General Public License version 2 as |
@@ -19,8 +19,10 @@ | |||
19 | 19 | ||
20 | #include <plat/cpu.h> | 20 | #include <plat/cpu.h> |
21 | #include <plat/clock.h> | 21 | #include <plat/clock.h> |
22 | #include <plat/s5pv310.h> | 22 | #include <plat/exynos4.h> |
23 | #include <plat/sdhci.h> | 23 | #include <plat/sdhci.h> |
24 | #include <plat/devs.h> | ||
25 | #include <plat/fimc-core.h> | ||
24 | 26 | ||
25 | #include <mach/regs-irq.h> | 27 | #include <mach/regs-irq.h> |
26 | 28 | ||
@@ -29,55 +31,60 @@ extern int combiner_init(unsigned int combiner_nr, void __iomem *base, | |||
29 | extern void combiner_cascade_irq(unsigned int combiner_nr, unsigned int irq); | 31 | extern void combiner_cascade_irq(unsigned int combiner_nr, unsigned int irq); |
30 | 32 | ||
31 | /* Initial IO mappings */ | 33 | /* Initial IO mappings */ |
32 | static struct map_desc s5pv310_iodesc[] __initdata = { | 34 | static struct map_desc exynos4_iodesc[] __initdata = { |
33 | { | 35 | { |
36 | .virtual = (unsigned long)S5P_VA_SYSTIMER, | ||
37 | .pfn = __phys_to_pfn(EXYNOS4_PA_SYSTIMER), | ||
38 | .length = SZ_4K, | ||
39 | .type = MT_DEVICE, | ||
40 | }, { | ||
34 | .virtual = (unsigned long)S5P_VA_SYSRAM, | 41 | .virtual = (unsigned long)S5P_VA_SYSRAM, |
35 | .pfn = __phys_to_pfn(S5PV310_PA_SYSRAM), | 42 | .pfn = __phys_to_pfn(EXYNOS4_PA_SYSRAM), |
36 | .length = SZ_4K, | 43 | .length = SZ_4K, |
37 | .type = MT_DEVICE, | 44 | .type = MT_DEVICE, |
38 | }, { | 45 | }, { |
39 | .virtual = (unsigned long)S5P_VA_CMU, | 46 | .virtual = (unsigned long)S5P_VA_CMU, |
40 | .pfn = __phys_to_pfn(S5PV310_PA_CMU), | 47 | .pfn = __phys_to_pfn(EXYNOS4_PA_CMU), |
41 | .length = SZ_128K, | 48 | .length = SZ_128K, |
42 | .type = MT_DEVICE, | 49 | .type = MT_DEVICE, |
43 | }, { | 50 | }, { |
44 | .virtual = (unsigned long)S5P_VA_PMU, | 51 | .virtual = (unsigned long)S5P_VA_PMU, |
45 | .pfn = __phys_to_pfn(S5PV310_PA_PMU), | 52 | .pfn = __phys_to_pfn(EXYNOS4_PA_PMU), |
46 | .length = SZ_64K, | 53 | .length = SZ_64K, |
47 | .type = MT_DEVICE, | 54 | .type = MT_DEVICE, |
48 | }, { | 55 | }, { |
49 | .virtual = (unsigned long)S5P_VA_COMBINER_BASE, | 56 | .virtual = (unsigned long)S5P_VA_COMBINER_BASE, |
50 | .pfn = __phys_to_pfn(S5PV310_PA_COMBINER), | 57 | .pfn = __phys_to_pfn(EXYNOS4_PA_COMBINER), |
51 | .length = SZ_4K, | 58 | .length = SZ_4K, |
52 | .type = MT_DEVICE, | 59 | .type = MT_DEVICE, |
53 | }, { | 60 | }, { |
54 | .virtual = (unsigned long)S5P_VA_COREPERI_BASE, | 61 | .virtual = (unsigned long)S5P_VA_COREPERI_BASE, |
55 | .pfn = __phys_to_pfn(S5PV310_PA_COREPERI), | 62 | .pfn = __phys_to_pfn(EXYNOS4_PA_COREPERI), |
56 | .length = SZ_8K, | 63 | .length = SZ_8K, |
57 | .type = MT_DEVICE, | 64 | .type = MT_DEVICE, |
58 | }, { | 65 | }, { |
59 | .virtual = (unsigned long)S5P_VA_L2CC, | 66 | .virtual = (unsigned long)S5P_VA_L2CC, |
60 | .pfn = __phys_to_pfn(S5PV310_PA_L2CC), | 67 | .pfn = __phys_to_pfn(EXYNOS4_PA_L2CC), |
61 | .length = SZ_4K, | 68 | .length = SZ_4K, |
62 | .type = MT_DEVICE, | 69 | .type = MT_DEVICE, |
63 | }, { | 70 | }, { |
64 | .virtual = (unsigned long)S5P_VA_GPIO1, | 71 | .virtual = (unsigned long)S5P_VA_GPIO1, |
65 | .pfn = __phys_to_pfn(S5PV310_PA_GPIO1), | 72 | .pfn = __phys_to_pfn(EXYNOS4_PA_GPIO1), |
66 | .length = SZ_4K, | 73 | .length = SZ_4K, |
67 | .type = MT_DEVICE, | 74 | .type = MT_DEVICE, |
68 | }, { | 75 | }, { |
69 | .virtual = (unsigned long)S5P_VA_GPIO2, | 76 | .virtual = (unsigned long)S5P_VA_GPIO2, |
70 | .pfn = __phys_to_pfn(S5PV310_PA_GPIO2), | 77 | .pfn = __phys_to_pfn(EXYNOS4_PA_GPIO2), |
71 | .length = SZ_4K, | 78 | .length = SZ_4K, |
72 | .type = MT_DEVICE, | 79 | .type = MT_DEVICE, |
73 | }, { | 80 | }, { |
74 | .virtual = (unsigned long)S5P_VA_GPIO3, | 81 | .virtual = (unsigned long)S5P_VA_GPIO3, |
75 | .pfn = __phys_to_pfn(S5PV310_PA_GPIO3), | 82 | .pfn = __phys_to_pfn(EXYNOS4_PA_GPIO3), |
76 | .length = SZ_256, | 83 | .length = SZ_256, |
77 | .type = MT_DEVICE, | 84 | .type = MT_DEVICE, |
78 | }, { | 85 | }, { |
79 | .virtual = (unsigned long)S5P_VA_DMC0, | 86 | .virtual = (unsigned long)S5P_VA_DMC0, |
80 | .pfn = __phys_to_pfn(S5PV310_PA_DMC0), | 87 | .pfn = __phys_to_pfn(EXYNOS4_PA_DMC0), |
81 | .length = SZ_4K, | 88 | .length = SZ_4K, |
82 | .type = MT_DEVICE, | 89 | .type = MT_DEVICE, |
83 | }, { | 90 | }, { |
@@ -87,13 +94,13 @@ static struct map_desc s5pv310_iodesc[] __initdata = { | |||
87 | .type = MT_DEVICE, | 94 | .type = MT_DEVICE, |
88 | }, { | 95 | }, { |
89 | .virtual = (unsigned long)S5P_VA_SROMC, | 96 | .virtual = (unsigned long)S5P_VA_SROMC, |
90 | .pfn = __phys_to_pfn(S5PV310_PA_SROMC), | 97 | .pfn = __phys_to_pfn(EXYNOS4_PA_SROMC), |
91 | .length = SZ_4K, | 98 | .length = SZ_4K, |
92 | .type = MT_DEVICE, | 99 | .type = MT_DEVICE, |
93 | }, | 100 | }, |
94 | }; | 101 | }; |
95 | 102 | ||
96 | static void s5pv310_idle(void) | 103 | static void exynos4_idle(void) |
97 | { | 104 | { |
98 | if (!need_resched()) | 105 | if (!need_resched()) |
99 | cpu_do_idle(); | 106 | cpu_do_idle(); |
@@ -101,32 +108,38 @@ static void s5pv310_idle(void) | |||
101 | local_irq_enable(); | 108 | local_irq_enable(); |
102 | } | 109 | } |
103 | 110 | ||
104 | /* s5pv310_map_io | 111 | /* |
112 | * exynos4_map_io | ||
105 | * | 113 | * |
106 | * register the standard cpu IO areas | 114 | * register the standard cpu IO areas |
107 | */ | 115 | */ |
108 | void __init s5pv310_map_io(void) | 116 | void __init exynos4_map_io(void) |
109 | { | 117 | { |
110 | iotable_init(s5pv310_iodesc, ARRAY_SIZE(s5pv310_iodesc)); | 118 | iotable_init(exynos4_iodesc, ARRAY_SIZE(exynos4_iodesc)); |
111 | 119 | ||
112 | /* initialize device information early */ | 120 | /* initialize device information early */ |
113 | s5pv310_default_sdhci0(); | 121 | exynos4_default_sdhci0(); |
114 | s5pv310_default_sdhci1(); | 122 | exynos4_default_sdhci1(); |
115 | s5pv310_default_sdhci2(); | 123 | exynos4_default_sdhci2(); |
116 | s5pv310_default_sdhci3(); | 124 | exynos4_default_sdhci3(); |
125 | |||
126 | s3c_fimc_setname(0, "exynos4-fimc"); | ||
127 | s3c_fimc_setname(1, "exynos4-fimc"); | ||
128 | s3c_fimc_setname(2, "exynos4-fimc"); | ||
129 | s3c_fimc_setname(3, "exynos4-fimc"); | ||
117 | } | 130 | } |
118 | 131 | ||
119 | void __init s5pv310_init_clocks(int xtal) | 132 | void __init exynos4_init_clocks(int xtal) |
120 | { | 133 | { |
121 | printk(KERN_DEBUG "%s: initializing clocks\n", __func__); | 134 | printk(KERN_DEBUG "%s: initializing clocks\n", __func__); |
122 | 135 | ||
123 | s3c24xx_register_baseclocks(xtal); | 136 | s3c24xx_register_baseclocks(xtal); |
124 | s5p_register_clocks(xtal); | 137 | s5p_register_clocks(xtal); |
125 | s5pv310_register_clocks(); | 138 | exynos4_register_clocks(); |
126 | s5pv310_setup_clocks(); | 139 | exynos4_setup_clocks(); |
127 | } | 140 | } |
128 | 141 | ||
129 | void __init s5pv310_init_irq(void) | 142 | void __init exynos4_init_irq(void) |
130 | { | 143 | { |
131 | int irq; | 144 | int irq; |
132 | 145 | ||
@@ -148,29 +161,29 @@ void __init s5pv310_init_irq(void) | |||
148 | } | 161 | } |
149 | 162 | ||
150 | /* The parameters of s5p_init_irq() are for VIC init. | 163 | /* The parameters of s5p_init_irq() are for VIC init. |
151 | * Theses parameters should be NULL and 0 because S5PV310 | 164 | * Theses parameters should be NULL and 0 because EXYNOS4 |
152 | * uses GIC instead of VIC. | 165 | * uses GIC instead of VIC. |
153 | */ | 166 | */ |
154 | s5p_init_irq(NULL, 0); | 167 | s5p_init_irq(NULL, 0); |
155 | } | 168 | } |
156 | 169 | ||
157 | struct sysdev_class s5pv310_sysclass = { | 170 | struct sysdev_class exynos4_sysclass = { |
158 | .name = "s5pv310-core", | 171 | .name = "exynos4-core", |
159 | }; | 172 | }; |
160 | 173 | ||
161 | static struct sys_device s5pv310_sysdev = { | 174 | static struct sys_device exynos4_sysdev = { |
162 | .cls = &s5pv310_sysclass, | 175 | .cls = &exynos4_sysclass, |
163 | }; | 176 | }; |
164 | 177 | ||
165 | static int __init s5pv310_core_init(void) | 178 | static int __init exynos4_core_init(void) |
166 | { | 179 | { |
167 | return sysdev_class_register(&s5pv310_sysclass); | 180 | return sysdev_class_register(&exynos4_sysclass); |
168 | } | 181 | } |
169 | 182 | ||
170 | core_initcall(s5pv310_core_init); | 183 | core_initcall(exynos4_core_init); |
171 | 184 | ||
172 | #ifdef CONFIG_CACHE_L2X0 | 185 | #ifdef CONFIG_CACHE_L2X0 |
173 | static int __init s5pv310_l2x0_cache_init(void) | 186 | static int __init exynos4_l2x0_cache_init(void) |
174 | { | 187 | { |
175 | /* TAG, Data Latency Control: 2cycle */ | 188 | /* TAG, Data Latency Control: 2cycle */ |
176 | __raw_writel(0x110, S5P_VA_L2CC + L2X0_TAG_LATENCY_CTRL); | 189 | __raw_writel(0x110, S5P_VA_L2CC + L2X0_TAG_LATENCY_CTRL); |
@@ -188,15 +201,15 @@ static int __init s5pv310_l2x0_cache_init(void) | |||
188 | return 0; | 201 | return 0; |
189 | } | 202 | } |
190 | 203 | ||
191 | early_initcall(s5pv310_l2x0_cache_init); | 204 | early_initcall(exynos4_l2x0_cache_init); |
192 | #endif | 205 | #endif |
193 | 206 | ||
194 | int __init s5pv310_init(void) | 207 | int __init exynos4_init(void) |
195 | { | 208 | { |
196 | printk(KERN_INFO "S5PV310: Initializing architecture\n"); | 209 | printk(KERN_INFO "EXYNOS4: Initializing architecture\n"); |
197 | 210 | ||
198 | /* set idle function */ | 211 | /* set idle function */ |
199 | pm_idle = s5pv310_idle; | 212 | pm_idle = exynos4_idle; |
200 | 213 | ||
201 | return sysdev_register(&s5pv310_sysdev); | 214 | return sysdev_register(&exynos4_sysdev); |
202 | } | 215 | } |
diff --git a/arch/arm/mach-s5pv310/cpufreq.c b/arch/arm/mach-exynos4/cpufreq.c index b04cbc731128..a16ac35747a9 100644 --- a/arch/arm/mach-s5pv310/cpufreq.c +++ b/arch/arm/mach-exynos4/cpufreq.c | |||
@@ -1,9 +1,9 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/cpufreq.c | 1 | /* linux/arch/arm/mach-exynos4/cpufreq.c |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * S5PV310 - CPU frequency scaling support | 6 | * EXYNOS4 - CPU frequency scaling support |
7 | * | 7 | * |
8 | * This program is free software; you can redistribute it and/or modify | 8 | * This program is free software; you can redistribute it and/or modify |
9 | * it under the terms of the GNU General Public License version 2 as | 9 | * it under the terms of the GNU General Public License version 2 as |
@@ -31,15 +31,13 @@ static struct clk *moutcore; | |||
31 | static struct clk *mout_mpll; | 31 | static struct clk *mout_mpll; |
32 | static struct clk *mout_apll; | 32 | static struct clk *mout_apll; |
33 | 33 | ||
34 | #ifdef CONFIG_REGULATOR | ||
35 | static struct regulator *arm_regulator; | 34 | static struct regulator *arm_regulator; |
36 | static struct regulator *int_regulator; | 35 | static struct regulator *int_regulator; |
37 | #endif | ||
38 | 36 | ||
39 | static struct cpufreq_freqs freqs; | 37 | static struct cpufreq_freqs freqs; |
40 | static unsigned int memtype; | 38 | static unsigned int memtype; |
41 | 39 | ||
42 | enum s5pv310_memory_type { | 40 | enum exynos4_memory_type { |
43 | DDR2 = 4, | 41 | DDR2 = 4, |
44 | LPDDR2, | 42 | LPDDR2, |
45 | DDR3, | 43 | DDR3, |
@@ -49,7 +47,7 @@ enum cpufreq_level_index { | |||
49 | L0, L1, L2, L3, CPUFREQ_LEVEL_END, | 47 | L0, L1, L2, L3, CPUFREQ_LEVEL_END, |
50 | }; | 48 | }; |
51 | 49 | ||
52 | static struct cpufreq_frequency_table s5pv310_freq_table[] = { | 50 | static struct cpufreq_frequency_table exynos4_freq_table[] = { |
53 | {L0, 1000*1000}, | 51 | {L0, 1000*1000}, |
54 | {L1, 800*1000}, | 52 | {L1, 800*1000}, |
55 | {L2, 400*1000}, | 53 | {L2, 400*1000}, |
@@ -160,7 +158,7 @@ struct cpufreq_voltage_table { | |||
160 | unsigned int int_volt; | 158 | unsigned int int_volt; |
161 | }; | 159 | }; |
162 | 160 | ||
163 | static struct cpufreq_voltage_table s5pv310_volt_table[CPUFREQ_LEVEL_END] = { | 161 | static struct cpufreq_voltage_table exynos4_volt_table[CPUFREQ_LEVEL_END] = { |
164 | { | 162 | { |
165 | .index = L0, | 163 | .index = L0, |
166 | .arm_volt = 1200000, | 164 | .arm_volt = 1200000, |
@@ -180,7 +178,7 @@ static struct cpufreq_voltage_table s5pv310_volt_table[CPUFREQ_LEVEL_END] = { | |||
180 | }, | 178 | }, |
181 | }; | 179 | }; |
182 | 180 | ||
183 | static unsigned int s5pv310_apll_pms_table[CPUFREQ_LEVEL_END] = { | 181 | static unsigned int exynos4_apll_pms_table[CPUFREQ_LEVEL_END] = { |
184 | /* APLL FOUT L0: 1000MHz */ | 182 | /* APLL FOUT L0: 1000MHz */ |
185 | ((250 << 16) | (6 << 8) | 1), | 183 | ((250 << 16) | (6 << 8) | 1), |
186 | 184 | ||
@@ -194,17 +192,17 @@ static unsigned int s5pv310_apll_pms_table[CPUFREQ_LEVEL_END] = { | |||
194 | ((200 << 16) | (6 << 8) | 4), | 192 | ((200 << 16) | (6 << 8) | 4), |
195 | }; | 193 | }; |
196 | 194 | ||
197 | int s5pv310_verify_speed(struct cpufreq_policy *policy) | 195 | int exynos4_verify_speed(struct cpufreq_policy *policy) |
198 | { | 196 | { |
199 | return cpufreq_frequency_table_verify(policy, s5pv310_freq_table); | 197 | return cpufreq_frequency_table_verify(policy, exynos4_freq_table); |
200 | } | 198 | } |
201 | 199 | ||
202 | unsigned int s5pv310_getspeed(unsigned int cpu) | 200 | unsigned int exynos4_getspeed(unsigned int cpu) |
203 | { | 201 | { |
204 | return clk_get_rate(cpu_clk) / 1000; | 202 | return clk_get_rate(cpu_clk) / 1000; |
205 | } | 203 | } |
206 | 204 | ||
207 | void s5pv310_set_clkdiv(unsigned int div_index) | 205 | void exynos4_set_clkdiv(unsigned int div_index) |
208 | { | 206 | { |
209 | unsigned int tmp; | 207 | unsigned int tmp; |
210 | 208 | ||
@@ -321,7 +319,7 @@ void s5pv310_set_clkdiv(unsigned int div_index) | |||
321 | } while (tmp & 0x11); | 319 | } while (tmp & 0x11); |
322 | } | 320 | } |
323 | 321 | ||
324 | static void s5pv310_set_apll(unsigned int index) | 322 | static void exynos4_set_apll(unsigned int index) |
325 | { | 323 | { |
326 | unsigned int tmp; | 324 | unsigned int tmp; |
327 | 325 | ||
@@ -340,7 +338,7 @@ static void s5pv310_set_apll(unsigned int index) | |||
340 | /* 3. Change PLL PMS values */ | 338 | /* 3. Change PLL PMS values */ |
341 | tmp = __raw_readl(S5P_APLL_CON0); | 339 | tmp = __raw_readl(S5P_APLL_CON0); |
342 | tmp &= ~((0x3ff << 16) | (0x3f << 8) | (0x7 << 0)); | 340 | tmp &= ~((0x3ff << 16) | (0x3f << 8) | (0x7 << 0)); |
343 | tmp |= s5pv310_apll_pms_table[index]; | 341 | tmp |= exynos4_apll_pms_table[index]; |
344 | __raw_writel(tmp, S5P_APLL_CON0); | 342 | __raw_writel(tmp, S5P_APLL_CON0); |
345 | 343 | ||
346 | /* 4. wait_lock_time */ | 344 | /* 4. wait_lock_time */ |
@@ -357,99 +355,95 @@ static void s5pv310_set_apll(unsigned int index) | |||
357 | } while (tmp != (0x1 << S5P_CLKSRC_CPU_MUXCORE_SHIFT)); | 355 | } while (tmp != (0x1 << S5P_CLKSRC_CPU_MUXCORE_SHIFT)); |
358 | } | 356 | } |
359 | 357 | ||
360 | static void s5pv310_set_frequency(unsigned int old_index, unsigned int new_index) | 358 | static void exynos4_set_frequency(unsigned int old_index, unsigned int new_index) |
361 | { | 359 | { |
362 | unsigned int tmp; | 360 | unsigned int tmp; |
363 | 361 | ||
364 | if (old_index > new_index) { | 362 | if (old_index > new_index) { |
365 | /* The frequency changing to L0 needs to change apll */ | 363 | /* The frequency changing to L0 needs to change apll */ |
366 | if (freqs.new == s5pv310_freq_table[L0].frequency) { | 364 | if (freqs.new == exynos4_freq_table[L0].frequency) { |
367 | /* 1. Change the system clock divider values */ | 365 | /* 1. Change the system clock divider values */ |
368 | s5pv310_set_clkdiv(new_index); | 366 | exynos4_set_clkdiv(new_index); |
369 | 367 | ||
370 | /* 2. Change the apll m,p,s value */ | 368 | /* 2. Change the apll m,p,s value */ |
371 | s5pv310_set_apll(new_index); | 369 | exynos4_set_apll(new_index); |
372 | } else { | 370 | } else { |
373 | /* 1. Change the system clock divider values */ | 371 | /* 1. Change the system clock divider values */ |
374 | s5pv310_set_clkdiv(new_index); | 372 | exynos4_set_clkdiv(new_index); |
375 | 373 | ||
376 | /* 2. Change just s value in apll m,p,s value */ | 374 | /* 2. Change just s value in apll m,p,s value */ |
377 | tmp = __raw_readl(S5P_APLL_CON0); | 375 | tmp = __raw_readl(S5P_APLL_CON0); |
378 | tmp &= ~(0x7 << 0); | 376 | tmp &= ~(0x7 << 0); |
379 | tmp |= (s5pv310_apll_pms_table[new_index] & 0x7); | 377 | tmp |= (exynos4_apll_pms_table[new_index] & 0x7); |
380 | __raw_writel(tmp, S5P_APLL_CON0); | 378 | __raw_writel(tmp, S5P_APLL_CON0); |
381 | } | 379 | } |
382 | } | 380 | } |
383 | 381 | ||
384 | else if (old_index < new_index) { | 382 | else if (old_index < new_index) { |
385 | /* The frequency changing from L0 needs to change apll */ | 383 | /* The frequency changing from L0 needs to change apll */ |
386 | if (freqs.old == s5pv310_freq_table[L0].frequency) { | 384 | if (freqs.old == exynos4_freq_table[L0].frequency) { |
387 | /* 1. Change the apll m,p,s value */ | 385 | /* 1. Change the apll m,p,s value */ |
388 | s5pv310_set_apll(new_index); | 386 | exynos4_set_apll(new_index); |
389 | 387 | ||
390 | /* 2. Change the system clock divider values */ | 388 | /* 2. Change the system clock divider values */ |
391 | s5pv310_set_clkdiv(new_index); | 389 | exynos4_set_clkdiv(new_index); |
392 | } else { | 390 | } else { |
393 | /* 1. Change just s value in apll m,p,s value */ | 391 | /* 1. Change just s value in apll m,p,s value */ |
394 | tmp = __raw_readl(S5P_APLL_CON0); | 392 | tmp = __raw_readl(S5P_APLL_CON0); |
395 | tmp &= ~(0x7 << 0); | 393 | tmp &= ~(0x7 << 0); |
396 | tmp |= (s5pv310_apll_pms_table[new_index] & 0x7); | 394 | tmp |= (exynos4_apll_pms_table[new_index] & 0x7); |
397 | __raw_writel(tmp, S5P_APLL_CON0); | 395 | __raw_writel(tmp, S5P_APLL_CON0); |
398 | 396 | ||
399 | /* 2. Change the system clock divider values */ | 397 | /* 2. Change the system clock divider values */ |
400 | s5pv310_set_clkdiv(new_index); | 398 | exynos4_set_clkdiv(new_index); |
401 | } | 399 | } |
402 | } | 400 | } |
403 | } | 401 | } |
404 | 402 | ||
405 | static int s5pv310_target(struct cpufreq_policy *policy, | 403 | static int exynos4_target(struct cpufreq_policy *policy, |
406 | unsigned int target_freq, | 404 | unsigned int target_freq, |
407 | unsigned int relation) | 405 | unsigned int relation) |
408 | { | 406 | { |
409 | unsigned int index, old_index; | 407 | unsigned int index, old_index; |
410 | unsigned int arm_volt, int_volt; | 408 | unsigned int arm_volt, int_volt; |
411 | 409 | ||
412 | freqs.old = s5pv310_getspeed(policy->cpu); | 410 | freqs.old = exynos4_getspeed(policy->cpu); |
413 | 411 | ||
414 | if (cpufreq_frequency_table_target(policy, s5pv310_freq_table, | 412 | if (cpufreq_frequency_table_target(policy, exynos4_freq_table, |
415 | freqs.old, relation, &old_index)) | 413 | freqs.old, relation, &old_index)) |
416 | return -EINVAL; | 414 | return -EINVAL; |
417 | 415 | ||
418 | if (cpufreq_frequency_table_target(policy, s5pv310_freq_table, | 416 | if (cpufreq_frequency_table_target(policy, exynos4_freq_table, |
419 | target_freq, relation, &index)) | 417 | target_freq, relation, &index)) |
420 | return -EINVAL; | 418 | return -EINVAL; |
421 | 419 | ||
422 | freqs.new = s5pv310_freq_table[index].frequency; | 420 | freqs.new = exynos4_freq_table[index].frequency; |
423 | freqs.cpu = policy->cpu; | 421 | freqs.cpu = policy->cpu; |
424 | 422 | ||
425 | if (freqs.new == freqs.old) | 423 | if (freqs.new == freqs.old) |
426 | return 0; | 424 | return 0; |
427 | 425 | ||
428 | /* get the voltage value */ | 426 | /* get the voltage value */ |
429 | arm_volt = s5pv310_volt_table[index].arm_volt; | 427 | arm_volt = exynos4_volt_table[index].arm_volt; |
430 | int_volt = s5pv310_volt_table[index].int_volt; | 428 | int_volt = exynos4_volt_table[index].int_volt; |
431 | 429 | ||
432 | cpufreq_notify_transition(&freqs, CPUFREQ_PRECHANGE); | 430 | cpufreq_notify_transition(&freqs, CPUFREQ_PRECHANGE); |
433 | 431 | ||
434 | /* control regulator */ | 432 | /* control regulator */ |
435 | if (freqs.new > freqs.old) { | 433 | if (freqs.new > freqs.old) { |
436 | /* Voltage up */ | 434 | /* Voltage up */ |
437 | #ifdef CONFIG_REGULATOR | ||
438 | regulator_set_voltage(arm_regulator, arm_volt, arm_volt); | 435 | regulator_set_voltage(arm_regulator, arm_volt, arm_volt); |
439 | regulator_set_voltage(int_regulator, int_volt, int_volt); | 436 | regulator_set_voltage(int_regulator, int_volt, int_volt); |
440 | #endif | ||
441 | } | 437 | } |
442 | 438 | ||
443 | /* Clock Configuration Procedure */ | 439 | /* Clock Configuration Procedure */ |
444 | s5pv310_set_frequency(old_index, index); | 440 | exynos4_set_frequency(old_index, index); |
445 | 441 | ||
446 | /* control regulator */ | 442 | /* control regulator */ |
447 | if (freqs.new < freqs.old) { | 443 | if (freqs.new < freqs.old) { |
448 | /* Voltage down */ | 444 | /* Voltage down */ |
449 | #ifdef CONFIG_REGULATOR | ||
450 | regulator_set_voltage(arm_regulator, arm_volt, arm_volt); | 445 | regulator_set_voltage(arm_regulator, arm_volt, arm_volt); |
451 | regulator_set_voltage(int_regulator, int_volt, int_volt); | 446 | regulator_set_voltage(int_regulator, int_volt, int_volt); |
452 | #endif | ||
453 | } | 447 | } |
454 | 448 | ||
455 | cpufreq_notify_transition(&freqs, CPUFREQ_POSTCHANGE); | 449 | cpufreq_notify_transition(&freqs, CPUFREQ_POSTCHANGE); |
@@ -458,52 +452,52 @@ static int s5pv310_target(struct cpufreq_policy *policy, | |||
458 | } | 452 | } |
459 | 453 | ||
460 | #ifdef CONFIG_PM | 454 | #ifdef CONFIG_PM |
461 | static int s5pv310_cpufreq_suspend(struct cpufreq_policy *policy, | 455 | static int exynos4_cpufreq_suspend(struct cpufreq_policy *policy, |
462 | pm_message_t pmsg) | 456 | pm_message_t pmsg) |
463 | { | 457 | { |
464 | return 0; | 458 | return 0; |
465 | } | 459 | } |
466 | 460 | ||
467 | static int s5pv310_cpufreq_resume(struct cpufreq_policy *policy) | 461 | static int exynos4_cpufreq_resume(struct cpufreq_policy *policy) |
468 | { | 462 | { |
469 | return 0; | 463 | return 0; |
470 | } | 464 | } |
471 | #endif | 465 | #endif |
472 | 466 | ||
473 | static int s5pv310_cpufreq_cpu_init(struct cpufreq_policy *policy) | 467 | static int exynos4_cpufreq_cpu_init(struct cpufreq_policy *policy) |
474 | { | 468 | { |
475 | policy->cur = policy->min = policy->max = s5pv310_getspeed(policy->cpu); | 469 | policy->cur = policy->min = policy->max = exynos4_getspeed(policy->cpu); |
476 | 470 | ||
477 | cpufreq_frequency_table_get_attr(s5pv310_freq_table, policy->cpu); | 471 | cpufreq_frequency_table_get_attr(exynos4_freq_table, policy->cpu); |
478 | 472 | ||
479 | /* set the transition latency value */ | 473 | /* set the transition latency value */ |
480 | policy->cpuinfo.transition_latency = 100000; | 474 | policy->cpuinfo.transition_latency = 100000; |
481 | 475 | ||
482 | /* | 476 | /* |
483 | * S5PV310 multi-core processors has 2 cores | 477 | * EXYNOS4 multi-core processors has 2 cores |
484 | * that the frequency cannot be set independently. | 478 | * that the frequency cannot be set independently. |
485 | * Each cpu is bound to the same speed. | 479 | * Each cpu is bound to the same speed. |
486 | * So the affected cpu is all of the cpus. | 480 | * So the affected cpu is all of the cpus. |
487 | */ | 481 | */ |
488 | cpumask_setall(policy->cpus); | 482 | cpumask_setall(policy->cpus); |
489 | 483 | ||
490 | return cpufreq_frequency_table_cpuinfo(policy, s5pv310_freq_table); | 484 | return cpufreq_frequency_table_cpuinfo(policy, exynos4_freq_table); |
491 | } | 485 | } |
492 | 486 | ||
493 | static struct cpufreq_driver s5pv310_driver = { | 487 | static struct cpufreq_driver exynos4_driver = { |
494 | .flags = CPUFREQ_STICKY, | 488 | .flags = CPUFREQ_STICKY, |
495 | .verify = s5pv310_verify_speed, | 489 | .verify = exynos4_verify_speed, |
496 | .target = s5pv310_target, | 490 | .target = exynos4_target, |
497 | .get = s5pv310_getspeed, | 491 | .get = exynos4_getspeed, |
498 | .init = s5pv310_cpufreq_cpu_init, | 492 | .init = exynos4_cpufreq_cpu_init, |
499 | .name = "s5pv310_cpufreq", | 493 | .name = "exynos4_cpufreq", |
500 | #ifdef CONFIG_PM | 494 | #ifdef CONFIG_PM |
501 | .suspend = s5pv310_cpufreq_suspend, | 495 | .suspend = exynos4_cpufreq_suspend, |
502 | .resume = s5pv310_cpufreq_resume, | 496 | .resume = exynos4_cpufreq_resume, |
503 | #endif | 497 | #endif |
504 | }; | 498 | }; |
505 | 499 | ||
506 | static int __init s5pv310_cpufreq_init(void) | 500 | static int __init exynos4_cpufreq_init(void) |
507 | { | 501 | { |
508 | cpu_clk = clk_get(NULL, "armclk"); | 502 | cpu_clk = clk_get(NULL, "armclk"); |
509 | if (IS_ERR(cpu_clk)) | 503 | if (IS_ERR(cpu_clk)) |
@@ -521,7 +515,6 @@ static int __init s5pv310_cpufreq_init(void) | |||
521 | if (IS_ERR(mout_apll)) | 515 | if (IS_ERR(mout_apll)) |
522 | goto out; | 516 | goto out; |
523 | 517 | ||
524 | #ifdef CONFIG_REGULATOR | ||
525 | arm_regulator = regulator_get(NULL, "vdd_arm"); | 518 | arm_regulator = regulator_get(NULL, "vdd_arm"); |
526 | if (IS_ERR(arm_regulator)) { | 519 | if (IS_ERR(arm_regulator)) { |
527 | printk(KERN_ERR "failed to get resource %s\n", "vdd_arm"); | 520 | printk(KERN_ERR "failed to get resource %s\n", "vdd_arm"); |
@@ -533,7 +526,6 @@ static int __init s5pv310_cpufreq_init(void) | |||
533 | printk(KERN_ERR "failed to get resource %s\n", "vdd_int"); | 526 | printk(KERN_ERR "failed to get resource %s\n", "vdd_int"); |
534 | goto out; | 527 | goto out; |
535 | } | 528 | } |
536 | #endif | ||
537 | 529 | ||
538 | /* | 530 | /* |
539 | * Check DRAM type. | 531 | * Check DRAM type. |
@@ -550,7 +542,7 @@ static int __init s5pv310_cpufreq_init(void) | |||
550 | printk(KERN_DEBUG "%s: memtype= 0x%x\n", __func__, memtype); | 542 | printk(KERN_DEBUG "%s: memtype= 0x%x\n", __func__, memtype); |
551 | } | 543 | } |
552 | 544 | ||
553 | return cpufreq_register_driver(&s5pv310_driver); | 545 | return cpufreq_register_driver(&exynos4_driver); |
554 | 546 | ||
555 | out: | 547 | out: |
556 | if (!IS_ERR(cpu_clk)) | 548 | if (!IS_ERR(cpu_clk)) |
@@ -565,16 +557,14 @@ out: | |||
565 | if (!IS_ERR(mout_apll)) | 557 | if (!IS_ERR(mout_apll)) |
566 | clk_put(mout_apll); | 558 | clk_put(mout_apll); |
567 | 559 | ||
568 | #ifdef CONFIG_REGULATOR | ||
569 | if (!IS_ERR(arm_regulator)) | 560 | if (!IS_ERR(arm_regulator)) |
570 | regulator_put(arm_regulator); | 561 | regulator_put(arm_regulator); |
571 | 562 | ||
572 | if (!IS_ERR(int_regulator)) | 563 | if (!IS_ERR(int_regulator)) |
573 | regulator_put(int_regulator); | 564 | regulator_put(int_regulator); |
574 | #endif | ||
575 | 565 | ||
576 | printk(KERN_ERR "%s: failed initialization\n", __func__); | 566 | printk(KERN_ERR "%s: failed initialization\n", __func__); |
577 | 567 | ||
578 | return -EINVAL; | 568 | return -EINVAL; |
579 | } | 569 | } |
580 | late_initcall(s5pv310_cpufreq_init); | 570 | late_initcall(exynos4_cpufreq_init); |
diff --git a/arch/arm/mach-exynos4/dev-ahci.c b/arch/arm/mach-exynos4/dev-ahci.c new file mode 100644 index 000000000000..f57a3de8e1d2 --- /dev/null +++ b/arch/arm/mach-exynos4/dev-ahci.c | |||
@@ -0,0 +1,263 @@ | |||
1 | /* linux/arch/arm/mach-exynos4/dev-ahci.c | ||
2 | * | ||
3 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * EXYNOS4 - AHCI support | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #include <linux/clk.h> | ||
14 | #include <linux/delay.h> | ||
15 | #include <linux/dma-mapping.h> | ||
16 | #include <linux/platform_device.h> | ||
17 | #include <linux/ahci_platform.h> | ||
18 | |||
19 | #include <plat/cpu.h> | ||
20 | |||
21 | #include <mach/irqs.h> | ||
22 | #include <mach/map.h> | ||
23 | #include <mach/regs-pmu.h> | ||
24 | |||
25 | /* PHY Control Register */ | ||
26 | #define SATA_CTRL0 0x0 | ||
27 | /* PHY Link Control Register */ | ||
28 | #define SATA_CTRL1 0x4 | ||
29 | /* PHY Status Register */ | ||
30 | #define SATA_PHY_STATUS 0x8 | ||
31 | |||
32 | #define SATA_CTRL0_RX_DATA_VALID(x) (x << 27) | ||
33 | #define SATA_CTRL0_SPEED_MODE (1 << 26) | ||
34 | #define SATA_CTRL0_M_PHY_CAL (1 << 19) | ||
35 | #define SATA_CTRL0_PHY_CMU_RST_N (1 << 10) | ||
36 | #define SATA_CTRL0_M_PHY_LN_RST_N (1 << 9) | ||
37 | #define SATA_CTRL0_PHY_POR_N (1 << 8) | ||
38 | |||
39 | #define SATA_CTRL1_RST_PMALIVE_N (1 << 8) | ||
40 | #define SATA_CTRL1_RST_RXOOB_N (1 << 7) | ||
41 | #define SATA_CTRL1_RST_RX_N (1 << 6) | ||
42 | #define SATA_CTRL1_RST_TX_N (1 << 5) | ||
43 | |||
44 | #define SATA_PHY_STATUS_CMU_OK (1 << 18) | ||
45 | #define SATA_PHY_STATUS_LANE_OK (1 << 16) | ||
46 | |||
47 | #define LANE0 0x200 | ||
48 | #define COM_LANE 0xA00 | ||
49 | |||
50 | #define HOST_PORTS_IMPL 0xC | ||
51 | #define SCLK_SATA_FREQ (67 * MHZ) | ||
52 | |||
53 | static void __iomem *phy_base, *phy_ctrl; | ||
54 | |||
55 | struct phy_reg { | ||
56 | u8 reg; | ||
57 | u8 val; | ||
58 | }; | ||
59 | |||
60 | /* SATA PHY setup */ | ||
61 | static const struct phy_reg exynos4_sataphy_cmu[] = { | ||
62 | { 0x00, 0x06 }, { 0x02, 0x80 }, { 0x22, 0xa0 }, { 0x23, 0x42 }, | ||
63 | { 0x2e, 0x04 }, { 0x2f, 0x50 }, { 0x30, 0x70 }, { 0x31, 0x02 }, | ||
64 | { 0x32, 0x25 }, { 0x33, 0x40 }, { 0x34, 0x01 }, { 0x35, 0x40 }, | ||
65 | { 0x61, 0x2e }, { 0x63, 0x5e }, { 0x65, 0x42 }, { 0x66, 0xd1 }, | ||
66 | { 0x67, 0x20 }, { 0x68, 0x28 }, { 0x69, 0x78 }, { 0x6a, 0x04 }, | ||
67 | { 0x6b, 0xc8 }, { 0x6c, 0x06 }, | ||
68 | }; | ||
69 | |||
70 | static const struct phy_reg exynos4_sataphy_lane[] = { | ||
71 | { 0x00, 0x02 }, { 0x05, 0x10 }, { 0x06, 0x84 }, { 0x07, 0x04 }, | ||
72 | { 0x08, 0xe0 }, { 0x10, 0x23 }, { 0x13, 0x05 }, { 0x14, 0x30 }, | ||
73 | { 0x15, 0x00 }, { 0x17, 0x70 }, { 0x18, 0xf2 }, { 0x19, 0x1e }, | ||
74 | { 0x1a, 0x18 }, { 0x1b, 0x0d }, { 0x1c, 0x08 }, { 0x50, 0x60 }, | ||
75 | { 0x51, 0x0f }, | ||
76 | }; | ||
77 | |||
78 | static const struct phy_reg exynos4_sataphy_comlane[] = { | ||
79 | { 0x01, 0x20 }, { 0x03, 0x40 }, { 0x04, 0x3c }, { 0x05, 0x7d }, | ||
80 | { 0x06, 0x1d }, { 0x07, 0xcf }, { 0x08, 0x05 }, { 0x09, 0x63 }, | ||
81 | { 0x0a, 0x29 }, { 0x0b, 0xc4 }, { 0x0c, 0x01 }, { 0x0d, 0x03 }, | ||
82 | { 0x0e, 0x28 }, { 0x0f, 0x98 }, { 0x10, 0x19 }, { 0x13, 0x80 }, | ||
83 | { 0x14, 0xf0 }, { 0x15, 0xd0 }, { 0x39, 0xa0 }, { 0x3a, 0xa0 }, | ||
84 | { 0x3b, 0xa0 }, { 0x3c, 0xa0 }, { 0x3d, 0xa0 }, { 0x3e, 0xa0 }, | ||
85 | { 0x3f, 0xa0 }, { 0x40, 0x42 }, { 0x42, 0x80 }, { 0x43, 0x58 }, | ||
86 | { 0x45, 0x44 }, { 0x46, 0x5c }, { 0x47, 0x86 }, { 0x48, 0x8d }, | ||
87 | { 0x49, 0xd0 }, { 0x4a, 0x09 }, { 0x4b, 0x90 }, { 0x4c, 0x07 }, | ||
88 | { 0x4d, 0x40 }, { 0x51, 0x20 }, { 0x52, 0x32 }, { 0x7f, 0xd8 }, | ||
89 | { 0x80, 0x1a }, { 0x81, 0xff }, { 0x82, 0x11 }, { 0x83, 0x00 }, | ||
90 | { 0x87, 0xf0 }, { 0x87, 0xff }, { 0x87, 0xff }, { 0x87, 0xff }, | ||
91 | { 0x87, 0xff }, { 0x8c, 0x1c }, { 0x8d, 0xc2 }, { 0x8e, 0xc3 }, | ||
92 | { 0x8f, 0x3f }, { 0x90, 0x0a }, { 0x96, 0xf8 }, | ||
93 | }; | ||
94 | |||
95 | static int wait_for_phy_ready(void __iomem *reg, unsigned long bit) | ||
96 | { | ||
97 | unsigned long timeout; | ||
98 | |||
99 | /* wait for maximum of 3 sec */ | ||
100 | timeout = jiffies + msecs_to_jiffies(3000); | ||
101 | while (!(__raw_readl(reg) & bit)) { | ||
102 | if (time_after(jiffies, timeout)) | ||
103 | return -1; | ||
104 | cpu_relax(); | ||
105 | } | ||
106 | return 0; | ||
107 | } | ||
108 | |||
109 | static int ahci_phy_init(void __iomem *mmio) | ||
110 | { | ||
111 | int i, ctrl0; | ||
112 | |||
113 | for (i = 0; i < ARRAY_SIZE(exynos4_sataphy_cmu); i++) | ||
114 | __raw_writeb(exynos4_sataphy_cmu[i].val, | ||
115 | phy_base + (exynos4_sataphy_cmu[i].reg * 4)); | ||
116 | |||
117 | for (i = 0; i < ARRAY_SIZE(exynos4_sataphy_lane); i++) | ||
118 | __raw_writeb(exynos4_sataphy_lane[i].val, | ||
119 | phy_base + (LANE0 + exynos4_sataphy_lane[i].reg) * 4); | ||
120 | |||
121 | for (i = 0; i < ARRAY_SIZE(exynos4_sataphy_comlane); i++) | ||
122 | __raw_writeb(exynos4_sataphy_comlane[i].val, | ||
123 | phy_base + (COM_LANE + exynos4_sataphy_comlane[i].reg) * 4); | ||
124 | |||
125 | __raw_writeb(0x07, phy_base); | ||
126 | |||
127 | ctrl0 = __raw_readl(phy_ctrl + SATA_CTRL0); | ||
128 | ctrl0 |= SATA_CTRL0_PHY_CMU_RST_N; | ||
129 | __raw_writel(ctrl0, phy_ctrl + SATA_CTRL0); | ||
130 | |||
131 | if (wait_for_phy_ready(phy_ctrl + SATA_PHY_STATUS, | ||
132 | SATA_PHY_STATUS_CMU_OK) < 0) { | ||
133 | printk(KERN_ERR "PHY CMU not ready\n"); | ||
134 | return -EBUSY; | ||
135 | } | ||
136 | |||
137 | __raw_writeb(0x03, phy_base + (COM_LANE * 4)); | ||
138 | |||
139 | ctrl0 = __raw_readl(phy_ctrl + SATA_CTRL0); | ||
140 | ctrl0 |= SATA_CTRL0_M_PHY_LN_RST_N; | ||
141 | __raw_writel(ctrl0, phy_ctrl + SATA_CTRL0); | ||
142 | |||
143 | if (wait_for_phy_ready(phy_ctrl + SATA_PHY_STATUS, | ||
144 | SATA_PHY_STATUS_LANE_OK) < 0) { | ||
145 | printk(KERN_ERR "PHY LANE not ready\n"); | ||
146 | return -EBUSY; | ||
147 | } | ||
148 | |||
149 | ctrl0 = __raw_readl(phy_ctrl + SATA_CTRL0); | ||
150 | ctrl0 |= SATA_CTRL0_M_PHY_CAL; | ||
151 | __raw_writel(ctrl0, phy_ctrl + SATA_CTRL0); | ||
152 | |||
153 | return 0; | ||
154 | } | ||
155 | |||
156 | static int exynos4_ahci_init(struct device *dev, void __iomem *mmio) | ||
157 | { | ||
158 | struct clk *clk_sata, *clk_sataphy, *clk_sclk_sata; | ||
159 | int val, ret; | ||
160 | |||
161 | phy_base = ioremap(EXYNOS4_PA_SATAPHY, SZ_64K); | ||
162 | if (!phy_base) { | ||
163 | dev_err(dev, "failed to allocate memory for SATA PHY\n"); | ||
164 | return -ENOMEM; | ||
165 | } | ||
166 | |||
167 | phy_ctrl = ioremap(EXYNOS4_PA_SATAPHY_CTRL, SZ_16); | ||
168 | if (!phy_ctrl) { | ||
169 | dev_err(dev, "failed to allocate memory for SATA PHY CTRL\n"); | ||
170 | ret = -ENOMEM; | ||
171 | goto err1; | ||
172 | } | ||
173 | |||
174 | clk_sata = clk_get(dev, "sata"); | ||
175 | if (IS_ERR(clk_sata)) { | ||
176 | dev_err(dev, "failed to get sata clock\n"); | ||
177 | ret = PTR_ERR(clk_sata); | ||
178 | clk_sata = NULL; | ||
179 | goto err2; | ||
180 | |||
181 | } | ||
182 | clk_enable(clk_sata); | ||
183 | |||
184 | clk_sataphy = clk_get(dev, "sataphy"); | ||
185 | if (IS_ERR(clk_sataphy)) { | ||
186 | dev_err(dev, "failed to get sataphy clock\n"); | ||
187 | ret = PTR_ERR(clk_sataphy); | ||
188 | clk_sataphy = NULL; | ||
189 | goto err3; | ||
190 | } | ||
191 | clk_enable(clk_sataphy); | ||
192 | |||
193 | clk_sclk_sata = clk_get(dev, "sclk_sata"); | ||
194 | if (IS_ERR(clk_sclk_sata)) { | ||
195 | dev_err(dev, "failed to get sclk_sata\n"); | ||
196 | ret = PTR_ERR(clk_sclk_sata); | ||
197 | clk_sclk_sata = NULL; | ||
198 | goto err4; | ||
199 | } | ||
200 | clk_enable(clk_sclk_sata); | ||
201 | clk_set_rate(clk_sclk_sata, SCLK_SATA_FREQ); | ||
202 | |||
203 | __raw_writel(S5P_PMU_SATA_PHY_CONTROL_EN, S5P_PMU_SATA_PHY_CONTROL); | ||
204 | |||
205 | /* Enable PHY link control */ | ||
206 | val = SATA_CTRL1_RST_PMALIVE_N | SATA_CTRL1_RST_RXOOB_N | | ||
207 | SATA_CTRL1_RST_RX_N | SATA_CTRL1_RST_TX_N; | ||
208 | __raw_writel(val, phy_ctrl + SATA_CTRL1); | ||
209 | |||
210 | /* Set communication speed as 3Gbps and enable PHY power */ | ||
211 | val = SATA_CTRL0_RX_DATA_VALID(3) | SATA_CTRL0_SPEED_MODE | | ||
212 | SATA_CTRL0_PHY_POR_N; | ||
213 | __raw_writel(val, phy_ctrl + SATA_CTRL0); | ||
214 | |||
215 | /* Port0 is available */ | ||
216 | __raw_writel(0x1, mmio + HOST_PORTS_IMPL); | ||
217 | |||
218 | return ahci_phy_init(mmio); | ||
219 | |||
220 | err4: | ||
221 | clk_disable(clk_sataphy); | ||
222 | clk_put(clk_sataphy); | ||
223 | err3: | ||
224 | clk_disable(clk_sata); | ||
225 | clk_put(clk_sata); | ||
226 | err2: | ||
227 | iounmap(phy_ctrl); | ||
228 | err1: | ||
229 | iounmap(phy_base); | ||
230 | |||
231 | return ret; | ||
232 | } | ||
233 | |||
234 | static struct ahci_platform_data exynos4_ahci_pdata = { | ||
235 | .init = exynos4_ahci_init, | ||
236 | }; | ||
237 | |||
238 | static struct resource exynos4_ahci_resource[] = { | ||
239 | [0] = { | ||
240 | .start = EXYNOS4_PA_SATA, | ||
241 | .end = EXYNOS4_PA_SATA + SZ_64K - 1, | ||
242 | .flags = IORESOURCE_MEM, | ||
243 | }, | ||
244 | [1] = { | ||
245 | .start = IRQ_SATA, | ||
246 | .end = IRQ_SATA, | ||
247 | .flags = IORESOURCE_IRQ, | ||
248 | }, | ||
249 | }; | ||
250 | |||
251 | static u64 exynos4_ahci_dmamask = DMA_BIT_MASK(32); | ||
252 | |||
253 | struct platform_device exynos4_device_ahci = { | ||
254 | .name = "ahci", | ||
255 | .id = -1, | ||
256 | .resource = exynos4_ahci_resource, | ||
257 | .num_resources = ARRAY_SIZE(exynos4_ahci_resource), | ||
258 | .dev = { | ||
259 | .platform_data = &exynos4_ahci_pdata, | ||
260 | .dma_mask = &exynos4_ahci_dmamask, | ||
261 | .coherent_dma_mask = DMA_BIT_MASK(32), | ||
262 | }, | ||
263 | }; | ||
diff --git a/arch/arm/mach-s5pv310/dev-audio.c b/arch/arm/mach-exynos4/dev-audio.c index a1964242f0fa..1eed5f9f7bd3 100644 --- a/arch/arm/mach-s5pv310/dev-audio.c +++ b/arch/arm/mach-exynos4/dev-audio.c | |||
@@ -1,4 +1,7 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/dev-audio.c | 1 | /* linux/arch/arm/mach-exynos4/dev-audio.c |
2 | * | ||
3 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
2 | * | 5 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co. Ltd | 6 | * Copyright (c) 2010 Samsung Electronics Co. Ltd |
4 | * Jaswinder Singh <jassi.brar@samsung.com> | 7 | * Jaswinder Singh <jassi.brar@samsung.com> |
@@ -24,18 +27,18 @@ static const char *rclksrc[] = { | |||
24 | [1] = "i2sclk", | 27 | [1] = "i2sclk", |
25 | }; | 28 | }; |
26 | 29 | ||
27 | static int s5pv310_cfg_i2s(struct platform_device *pdev) | 30 | static int exynos4_cfg_i2s(struct platform_device *pdev) |
28 | { | 31 | { |
29 | /* configure GPIO for i2s port */ | 32 | /* configure GPIO for i2s port */ |
30 | switch (pdev->id) { | 33 | switch (pdev->id) { |
31 | case 0: | 34 | case 0: |
32 | s3c_gpio_cfgpin_range(S5PV310_GPZ(0), 7, S3C_GPIO_SFN(2)); | 35 | s3c_gpio_cfgpin_range(EXYNOS4_GPZ(0), 7, S3C_GPIO_SFN(2)); |
33 | break; | 36 | break; |
34 | case 1: | 37 | case 1: |
35 | s3c_gpio_cfgpin_range(S5PV310_GPC0(0), 5, S3C_GPIO_SFN(2)); | 38 | s3c_gpio_cfgpin_range(EXYNOS4_GPC0(0), 5, S3C_GPIO_SFN(2)); |
36 | break; | 39 | break; |
37 | case 2: | 40 | case 2: |
38 | s3c_gpio_cfgpin_range(S5PV310_GPC1(0), 5, S3C_GPIO_SFN(4)); | 41 | s3c_gpio_cfgpin_range(EXYNOS4_GPC1(0), 5, S3C_GPIO_SFN(4)); |
39 | break; | 42 | break; |
40 | default: | 43 | default: |
41 | printk(KERN_ERR "Invalid Device %d\n", pdev->id); | 44 | printk(KERN_ERR "Invalid Device %d\n", pdev->id); |
@@ -46,7 +49,7 @@ static int s5pv310_cfg_i2s(struct platform_device *pdev) | |||
46 | } | 49 | } |
47 | 50 | ||
48 | static struct s3c_audio_pdata i2sv5_pdata = { | 51 | static struct s3c_audio_pdata i2sv5_pdata = { |
49 | .cfg_gpio = s5pv310_cfg_i2s, | 52 | .cfg_gpio = exynos4_cfg_i2s, |
50 | .type = { | 53 | .type = { |
51 | .i2s = { | 54 | .i2s = { |
52 | .quirks = QUIRK_PRI_6CHAN | QUIRK_SEC_DAI | 55 | .quirks = QUIRK_PRI_6CHAN | QUIRK_SEC_DAI |
@@ -56,10 +59,10 @@ static struct s3c_audio_pdata i2sv5_pdata = { | |||
56 | }, | 59 | }, |
57 | }; | 60 | }; |
58 | 61 | ||
59 | static struct resource s5pv310_i2s0_resource[] = { | 62 | static struct resource exynos4_i2s0_resource[] = { |
60 | [0] = { | 63 | [0] = { |
61 | .start = S5PV310_PA_I2S0, | 64 | .start = EXYNOS4_PA_I2S0, |
62 | .end = S5PV310_PA_I2S0 + 0x100 - 1, | 65 | .end = EXYNOS4_PA_I2S0 + 0x100 - 1, |
63 | .flags = IORESOURCE_MEM, | 66 | .flags = IORESOURCE_MEM, |
64 | }, | 67 | }, |
65 | [1] = { | 68 | [1] = { |
@@ -79,11 +82,11 @@ static struct resource s5pv310_i2s0_resource[] = { | |||
79 | }, | 82 | }, |
80 | }; | 83 | }; |
81 | 84 | ||
82 | struct platform_device s5pv310_device_i2s0 = { | 85 | struct platform_device exynos4_device_i2s0 = { |
83 | .name = "samsung-i2s", | 86 | .name = "samsung-i2s", |
84 | .id = 0, | 87 | .id = 0, |
85 | .num_resources = ARRAY_SIZE(s5pv310_i2s0_resource), | 88 | .num_resources = ARRAY_SIZE(exynos4_i2s0_resource), |
86 | .resource = s5pv310_i2s0_resource, | 89 | .resource = exynos4_i2s0_resource, |
87 | .dev = { | 90 | .dev = { |
88 | .platform_data = &i2sv5_pdata, | 91 | .platform_data = &i2sv5_pdata, |
89 | }, | 92 | }, |
@@ -95,7 +98,7 @@ static const char *rclksrc_v3[] = { | |||
95 | }; | 98 | }; |
96 | 99 | ||
97 | static struct s3c_audio_pdata i2sv3_pdata = { | 100 | static struct s3c_audio_pdata i2sv3_pdata = { |
98 | .cfg_gpio = s5pv310_cfg_i2s, | 101 | .cfg_gpio = exynos4_cfg_i2s, |
99 | .type = { | 102 | .type = { |
100 | .i2s = { | 103 | .i2s = { |
101 | .quirks = QUIRK_NO_MUXPSR, | 104 | .quirks = QUIRK_NO_MUXPSR, |
@@ -104,10 +107,10 @@ static struct s3c_audio_pdata i2sv3_pdata = { | |||
104 | }, | 107 | }, |
105 | }; | 108 | }; |
106 | 109 | ||
107 | static struct resource s5pv310_i2s1_resource[] = { | 110 | static struct resource exynos4_i2s1_resource[] = { |
108 | [0] = { | 111 | [0] = { |
109 | .start = S5PV310_PA_I2S1, | 112 | .start = EXYNOS4_PA_I2S1, |
110 | .end = S5PV310_PA_I2S1 + 0x100 - 1, | 113 | .end = EXYNOS4_PA_I2S1 + 0x100 - 1, |
111 | .flags = IORESOURCE_MEM, | 114 | .flags = IORESOURCE_MEM, |
112 | }, | 115 | }, |
113 | [1] = { | 116 | [1] = { |
@@ -122,20 +125,20 @@ static struct resource s5pv310_i2s1_resource[] = { | |||
122 | }, | 125 | }, |
123 | }; | 126 | }; |
124 | 127 | ||
125 | struct platform_device s5pv310_device_i2s1 = { | 128 | struct platform_device exynos4_device_i2s1 = { |
126 | .name = "samsung-i2s", | 129 | .name = "samsung-i2s", |
127 | .id = 1, | 130 | .id = 1, |
128 | .num_resources = ARRAY_SIZE(s5pv310_i2s1_resource), | 131 | .num_resources = ARRAY_SIZE(exynos4_i2s1_resource), |
129 | .resource = s5pv310_i2s1_resource, | 132 | .resource = exynos4_i2s1_resource, |
130 | .dev = { | 133 | .dev = { |
131 | .platform_data = &i2sv3_pdata, | 134 | .platform_data = &i2sv3_pdata, |
132 | }, | 135 | }, |
133 | }; | 136 | }; |
134 | 137 | ||
135 | static struct resource s5pv310_i2s2_resource[] = { | 138 | static struct resource exynos4_i2s2_resource[] = { |
136 | [0] = { | 139 | [0] = { |
137 | .start = S5PV310_PA_I2S2, | 140 | .start = EXYNOS4_PA_I2S2, |
138 | .end = S5PV310_PA_I2S2 + 0x100 - 1, | 141 | .end = EXYNOS4_PA_I2S2 + 0x100 - 1, |
139 | .flags = IORESOURCE_MEM, | 142 | .flags = IORESOURCE_MEM, |
140 | }, | 143 | }, |
141 | [1] = { | 144 | [1] = { |
@@ -150,11 +153,11 @@ static struct resource s5pv310_i2s2_resource[] = { | |||
150 | }, | 153 | }, |
151 | }; | 154 | }; |
152 | 155 | ||
153 | struct platform_device s5pv310_device_i2s2 = { | 156 | struct platform_device exynos4_device_i2s2 = { |
154 | .name = "samsung-i2s", | 157 | .name = "samsung-i2s", |
155 | .id = 2, | 158 | .id = 2, |
156 | .num_resources = ARRAY_SIZE(s5pv310_i2s2_resource), | 159 | .num_resources = ARRAY_SIZE(exynos4_i2s2_resource), |
157 | .resource = s5pv310_i2s2_resource, | 160 | .resource = exynos4_i2s2_resource, |
158 | .dev = { | 161 | .dev = { |
159 | .platform_data = &i2sv3_pdata, | 162 | .platform_data = &i2sv3_pdata, |
160 | }, | 163 | }, |
@@ -162,17 +165,17 @@ struct platform_device s5pv310_device_i2s2 = { | |||
162 | 165 | ||
163 | /* PCM Controller platform_devices */ | 166 | /* PCM Controller platform_devices */ |
164 | 167 | ||
165 | static int s5pv310_pcm_cfg_gpio(struct platform_device *pdev) | 168 | static int exynos4_pcm_cfg_gpio(struct platform_device *pdev) |
166 | { | 169 | { |
167 | switch (pdev->id) { | 170 | switch (pdev->id) { |
168 | case 0: | 171 | case 0: |
169 | s3c_gpio_cfgpin_range(S5PV310_GPZ(0), 5, S3C_GPIO_SFN(3)); | 172 | s3c_gpio_cfgpin_range(EXYNOS4_GPZ(0), 5, S3C_GPIO_SFN(3)); |
170 | break; | 173 | break; |
171 | case 1: | 174 | case 1: |
172 | s3c_gpio_cfgpin_range(S5PV310_GPC0(0), 5, S3C_GPIO_SFN(3)); | 175 | s3c_gpio_cfgpin_range(EXYNOS4_GPC0(0), 5, S3C_GPIO_SFN(3)); |
173 | break; | 176 | break; |
174 | case 2: | 177 | case 2: |
175 | s3c_gpio_cfgpin_range(S5PV310_GPC1(0), 5, S3C_GPIO_SFN(3)); | 178 | s3c_gpio_cfgpin_range(EXYNOS4_GPC1(0), 5, S3C_GPIO_SFN(3)); |
176 | break; | 179 | break; |
177 | default: | 180 | default: |
178 | printk(KERN_DEBUG "Invalid PCM Controller number!"); | 181 | printk(KERN_DEBUG "Invalid PCM Controller number!"); |
@@ -183,13 +186,13 @@ static int s5pv310_pcm_cfg_gpio(struct platform_device *pdev) | |||
183 | } | 186 | } |
184 | 187 | ||
185 | static struct s3c_audio_pdata s3c_pcm_pdata = { | 188 | static struct s3c_audio_pdata s3c_pcm_pdata = { |
186 | .cfg_gpio = s5pv310_pcm_cfg_gpio, | 189 | .cfg_gpio = exynos4_pcm_cfg_gpio, |
187 | }; | 190 | }; |
188 | 191 | ||
189 | static struct resource s5pv310_pcm0_resource[] = { | 192 | static struct resource exynos4_pcm0_resource[] = { |
190 | [0] = { | 193 | [0] = { |
191 | .start = S5PV310_PA_PCM0, | 194 | .start = EXYNOS4_PA_PCM0, |
192 | .end = S5PV310_PA_PCM0 + 0x100 - 1, | 195 | .end = EXYNOS4_PA_PCM0 + 0x100 - 1, |
193 | .flags = IORESOURCE_MEM, | 196 | .flags = IORESOURCE_MEM, |
194 | }, | 197 | }, |
195 | [1] = { | 198 | [1] = { |
@@ -204,20 +207,20 @@ static struct resource s5pv310_pcm0_resource[] = { | |||
204 | }, | 207 | }, |
205 | }; | 208 | }; |
206 | 209 | ||
207 | struct platform_device s5pv310_device_pcm0 = { | 210 | struct platform_device exynos4_device_pcm0 = { |
208 | .name = "samsung-pcm", | 211 | .name = "samsung-pcm", |
209 | .id = 0, | 212 | .id = 0, |
210 | .num_resources = ARRAY_SIZE(s5pv310_pcm0_resource), | 213 | .num_resources = ARRAY_SIZE(exynos4_pcm0_resource), |
211 | .resource = s5pv310_pcm0_resource, | 214 | .resource = exynos4_pcm0_resource, |
212 | .dev = { | 215 | .dev = { |
213 | .platform_data = &s3c_pcm_pdata, | 216 | .platform_data = &s3c_pcm_pdata, |
214 | }, | 217 | }, |
215 | }; | 218 | }; |
216 | 219 | ||
217 | static struct resource s5pv310_pcm1_resource[] = { | 220 | static struct resource exynos4_pcm1_resource[] = { |
218 | [0] = { | 221 | [0] = { |
219 | .start = S5PV310_PA_PCM1, | 222 | .start = EXYNOS4_PA_PCM1, |
220 | .end = S5PV310_PA_PCM1 + 0x100 - 1, | 223 | .end = EXYNOS4_PA_PCM1 + 0x100 - 1, |
221 | .flags = IORESOURCE_MEM, | 224 | .flags = IORESOURCE_MEM, |
222 | }, | 225 | }, |
223 | [1] = { | 226 | [1] = { |
@@ -232,20 +235,20 @@ static struct resource s5pv310_pcm1_resource[] = { | |||
232 | }, | 235 | }, |
233 | }; | 236 | }; |
234 | 237 | ||
235 | struct platform_device s5pv310_device_pcm1 = { | 238 | struct platform_device exynos4_device_pcm1 = { |
236 | .name = "samsung-pcm", | 239 | .name = "samsung-pcm", |
237 | .id = 1, | 240 | .id = 1, |
238 | .num_resources = ARRAY_SIZE(s5pv310_pcm1_resource), | 241 | .num_resources = ARRAY_SIZE(exynos4_pcm1_resource), |
239 | .resource = s5pv310_pcm1_resource, | 242 | .resource = exynos4_pcm1_resource, |
240 | .dev = { | 243 | .dev = { |
241 | .platform_data = &s3c_pcm_pdata, | 244 | .platform_data = &s3c_pcm_pdata, |
242 | }, | 245 | }, |
243 | }; | 246 | }; |
244 | 247 | ||
245 | static struct resource s5pv310_pcm2_resource[] = { | 248 | static struct resource exynos4_pcm2_resource[] = { |
246 | [0] = { | 249 | [0] = { |
247 | .start = S5PV310_PA_PCM2, | 250 | .start = EXYNOS4_PA_PCM2, |
248 | .end = S5PV310_PA_PCM2 + 0x100 - 1, | 251 | .end = EXYNOS4_PA_PCM2 + 0x100 - 1, |
249 | .flags = IORESOURCE_MEM, | 252 | .flags = IORESOURCE_MEM, |
250 | }, | 253 | }, |
251 | [1] = { | 254 | [1] = { |
@@ -260,11 +263,11 @@ static struct resource s5pv310_pcm2_resource[] = { | |||
260 | }, | 263 | }, |
261 | }; | 264 | }; |
262 | 265 | ||
263 | struct platform_device s5pv310_device_pcm2 = { | 266 | struct platform_device exynos4_device_pcm2 = { |
264 | .name = "samsung-pcm", | 267 | .name = "samsung-pcm", |
265 | .id = 2, | 268 | .id = 2, |
266 | .num_resources = ARRAY_SIZE(s5pv310_pcm2_resource), | 269 | .num_resources = ARRAY_SIZE(exynos4_pcm2_resource), |
267 | .resource = s5pv310_pcm2_resource, | 270 | .resource = exynos4_pcm2_resource, |
268 | .dev = { | 271 | .dev = { |
269 | .platform_data = &s3c_pcm_pdata, | 272 | .platform_data = &s3c_pcm_pdata, |
270 | }, | 273 | }, |
@@ -272,15 +275,15 @@ struct platform_device s5pv310_device_pcm2 = { | |||
272 | 275 | ||
273 | /* AC97 Controller platform devices */ | 276 | /* AC97 Controller platform devices */ |
274 | 277 | ||
275 | static int s5pv310_ac97_cfg_gpio(struct platform_device *pdev) | 278 | static int exynos4_ac97_cfg_gpio(struct platform_device *pdev) |
276 | { | 279 | { |
277 | return s3c_gpio_cfgpin_range(S5PV310_GPC0(0), 5, S3C_GPIO_SFN(4)); | 280 | return s3c_gpio_cfgpin_range(EXYNOS4_GPC0(0), 5, S3C_GPIO_SFN(4)); |
278 | } | 281 | } |
279 | 282 | ||
280 | static struct resource s5pv310_ac97_resource[] = { | 283 | static struct resource exynos4_ac97_resource[] = { |
281 | [0] = { | 284 | [0] = { |
282 | .start = S5PV310_PA_AC97, | 285 | .start = EXYNOS4_PA_AC97, |
283 | .end = S5PV310_PA_AC97 + 0x100 - 1, | 286 | .end = EXYNOS4_PA_AC97 + 0x100 - 1, |
284 | .flags = IORESOURCE_MEM, | 287 | .flags = IORESOURCE_MEM, |
285 | }, | 288 | }, |
286 | [1] = { | 289 | [1] = { |
@@ -306,36 +309,36 @@ static struct resource s5pv310_ac97_resource[] = { | |||
306 | }; | 309 | }; |
307 | 310 | ||
308 | static struct s3c_audio_pdata s3c_ac97_pdata = { | 311 | static struct s3c_audio_pdata s3c_ac97_pdata = { |
309 | .cfg_gpio = s5pv310_ac97_cfg_gpio, | 312 | .cfg_gpio = exynos4_ac97_cfg_gpio, |
310 | }; | 313 | }; |
311 | 314 | ||
312 | static u64 s5pv310_ac97_dmamask = DMA_BIT_MASK(32); | 315 | static u64 exynos4_ac97_dmamask = DMA_BIT_MASK(32); |
313 | 316 | ||
314 | struct platform_device s5pv310_device_ac97 = { | 317 | struct platform_device exynos4_device_ac97 = { |
315 | .name = "samsung-ac97", | 318 | .name = "samsung-ac97", |
316 | .id = -1, | 319 | .id = -1, |
317 | .num_resources = ARRAY_SIZE(s5pv310_ac97_resource), | 320 | .num_resources = ARRAY_SIZE(exynos4_ac97_resource), |
318 | .resource = s5pv310_ac97_resource, | 321 | .resource = exynos4_ac97_resource, |
319 | .dev = { | 322 | .dev = { |
320 | .platform_data = &s3c_ac97_pdata, | 323 | .platform_data = &s3c_ac97_pdata, |
321 | .dma_mask = &s5pv310_ac97_dmamask, | 324 | .dma_mask = &exynos4_ac97_dmamask, |
322 | .coherent_dma_mask = DMA_BIT_MASK(32), | 325 | .coherent_dma_mask = DMA_BIT_MASK(32), |
323 | }, | 326 | }, |
324 | }; | 327 | }; |
325 | 328 | ||
326 | /* S/PDIF Controller platform_device */ | 329 | /* S/PDIF Controller platform_device */ |
327 | 330 | ||
328 | static int s5pv310_spdif_cfg_gpio(struct platform_device *pdev) | 331 | static int exynos4_spdif_cfg_gpio(struct platform_device *pdev) |
329 | { | 332 | { |
330 | s3c_gpio_cfgpin_range(S5PV310_GPC1(0), 2, S3C_GPIO_SFN(3)); | 333 | s3c_gpio_cfgpin_range(EXYNOS4_GPC1(0), 2, S3C_GPIO_SFN(3)); |
331 | 334 | ||
332 | return 0; | 335 | return 0; |
333 | } | 336 | } |
334 | 337 | ||
335 | static struct resource s5pv310_spdif_resource[] = { | 338 | static struct resource exynos4_spdif_resource[] = { |
336 | [0] = { | 339 | [0] = { |
337 | .start = S5PV310_PA_SPDIF, | 340 | .start = EXYNOS4_PA_SPDIF, |
338 | .end = S5PV310_PA_SPDIF + 0x100 - 1, | 341 | .end = EXYNOS4_PA_SPDIF + 0x100 - 1, |
339 | .flags = IORESOURCE_MEM, | 342 | .flags = IORESOURCE_MEM, |
340 | }, | 343 | }, |
341 | [1] = { | 344 | [1] = { |
@@ -346,19 +349,19 @@ static struct resource s5pv310_spdif_resource[] = { | |||
346 | }; | 349 | }; |
347 | 350 | ||
348 | static struct s3c_audio_pdata samsung_spdif_pdata = { | 351 | static struct s3c_audio_pdata samsung_spdif_pdata = { |
349 | .cfg_gpio = s5pv310_spdif_cfg_gpio, | 352 | .cfg_gpio = exynos4_spdif_cfg_gpio, |
350 | }; | 353 | }; |
351 | 354 | ||
352 | static u64 s5pv310_spdif_dmamask = DMA_BIT_MASK(32); | 355 | static u64 exynos4_spdif_dmamask = DMA_BIT_MASK(32); |
353 | 356 | ||
354 | struct platform_device s5pv310_device_spdif = { | 357 | struct platform_device exynos4_device_spdif = { |
355 | .name = "samsung-spdif", | 358 | .name = "samsung-spdif", |
356 | .id = -1, | 359 | .id = -1, |
357 | .num_resources = ARRAY_SIZE(s5pv310_spdif_resource), | 360 | .num_resources = ARRAY_SIZE(exynos4_spdif_resource), |
358 | .resource = s5pv310_spdif_resource, | 361 | .resource = exynos4_spdif_resource, |
359 | .dev = { | 362 | .dev = { |
360 | .platform_data = &samsung_spdif_pdata, | 363 | .platform_data = &samsung_spdif_pdata, |
361 | .dma_mask = &s5pv310_spdif_dmamask, | 364 | .dma_mask = &exynos4_spdif_dmamask, |
362 | .coherent_dma_mask = DMA_BIT_MASK(32), | 365 | .coherent_dma_mask = DMA_BIT_MASK(32), |
363 | }, | 366 | }, |
364 | }; | 367 | }; |
diff --git a/arch/arm/mach-s5pv310/dev-pd.c b/arch/arm/mach-exynos4/dev-pd.c index 58a50c2d0b67..3273f25d6a75 100644 --- a/arch/arm/mach-s5pv310/dev-pd.c +++ b/arch/arm/mach-exynos4/dev-pd.c | |||
@@ -1,9 +1,9 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/dev-pd.c | 1 | /* linux/arch/arm/mach-exynos4/dev-pd.c |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * S5PV310 - Power Domain support | 6 | * EXYNOS4 - Power Domain support |
7 | * | 7 | * |
8 | * This program is free software; you can redistribute it and/or modify | 8 | * This program is free software; you can redistribute it and/or modify |
9 | * it under the terms of the GNU General Public License version 2 as | 9 | * it under the terms of the GNU General Public License version 2 as |
@@ -19,7 +19,7 @@ | |||
19 | 19 | ||
20 | #include <plat/pd.h> | 20 | #include <plat/pd.h> |
21 | 21 | ||
22 | static int s5pv310_pd_enable(struct device *dev) | 22 | static int exynos4_pd_enable(struct device *dev) |
23 | { | 23 | { |
24 | struct samsung_pd_info *pdata = dev->platform_data; | 24 | struct samsung_pd_info *pdata = dev->platform_data; |
25 | u32 timeout; | 25 | u32 timeout; |
@@ -42,7 +42,7 @@ static int s5pv310_pd_enable(struct device *dev) | |||
42 | return 0; | 42 | return 0; |
43 | } | 43 | } |
44 | 44 | ||
45 | static int s5pv310_pd_disable(struct device *dev) | 45 | static int exynos4_pd_disable(struct device *dev) |
46 | { | 46 | { |
47 | struct samsung_pd_info *pdata = dev->platform_data; | 47 | struct samsung_pd_info *pdata = dev->platform_data; |
48 | u32 timeout; | 48 | u32 timeout; |
@@ -64,14 +64,14 @@ static int s5pv310_pd_disable(struct device *dev) | |||
64 | return 0; | 64 | return 0; |
65 | } | 65 | } |
66 | 66 | ||
67 | struct platform_device s5pv310_device_pd[] = { | 67 | struct platform_device exynos4_device_pd[] = { |
68 | { | 68 | { |
69 | .name = "samsung-pd", | 69 | .name = "samsung-pd", |
70 | .id = 0, | 70 | .id = 0, |
71 | .dev = { | 71 | .dev = { |
72 | .platform_data = &(struct samsung_pd_info) { | 72 | .platform_data = &(struct samsung_pd_info) { |
73 | .enable = s5pv310_pd_enable, | 73 | .enable = exynos4_pd_enable, |
74 | .disable = s5pv310_pd_disable, | 74 | .disable = exynos4_pd_disable, |
75 | .base = S5P_PMU_MFC_CONF, | 75 | .base = S5P_PMU_MFC_CONF, |
76 | }, | 76 | }, |
77 | }, | 77 | }, |
@@ -80,8 +80,8 @@ struct platform_device s5pv310_device_pd[] = { | |||
80 | .id = 1, | 80 | .id = 1, |
81 | .dev = { | 81 | .dev = { |
82 | .platform_data = &(struct samsung_pd_info) { | 82 | .platform_data = &(struct samsung_pd_info) { |
83 | .enable = s5pv310_pd_enable, | 83 | .enable = exynos4_pd_enable, |
84 | .disable = s5pv310_pd_disable, | 84 | .disable = exynos4_pd_disable, |
85 | .base = S5P_PMU_G3D_CONF, | 85 | .base = S5P_PMU_G3D_CONF, |
86 | }, | 86 | }, |
87 | }, | 87 | }, |
@@ -90,8 +90,8 @@ struct platform_device s5pv310_device_pd[] = { | |||
90 | .id = 2, | 90 | .id = 2, |
91 | .dev = { | 91 | .dev = { |
92 | .platform_data = &(struct samsung_pd_info) { | 92 | .platform_data = &(struct samsung_pd_info) { |
93 | .enable = s5pv310_pd_enable, | 93 | .enable = exynos4_pd_enable, |
94 | .disable = s5pv310_pd_disable, | 94 | .disable = exynos4_pd_disable, |
95 | .base = S5P_PMU_LCD0_CONF, | 95 | .base = S5P_PMU_LCD0_CONF, |
96 | }, | 96 | }, |
97 | }, | 97 | }, |
@@ -100,8 +100,8 @@ struct platform_device s5pv310_device_pd[] = { | |||
100 | .id = 3, | 100 | .id = 3, |
101 | .dev = { | 101 | .dev = { |
102 | .platform_data = &(struct samsung_pd_info) { | 102 | .platform_data = &(struct samsung_pd_info) { |
103 | .enable = s5pv310_pd_enable, | 103 | .enable = exynos4_pd_enable, |
104 | .disable = s5pv310_pd_disable, | 104 | .disable = exynos4_pd_disable, |
105 | .base = S5P_PMU_LCD1_CONF, | 105 | .base = S5P_PMU_LCD1_CONF, |
106 | }, | 106 | }, |
107 | }, | 107 | }, |
@@ -110,8 +110,8 @@ struct platform_device s5pv310_device_pd[] = { | |||
110 | .id = 4, | 110 | .id = 4, |
111 | .dev = { | 111 | .dev = { |
112 | .platform_data = &(struct samsung_pd_info) { | 112 | .platform_data = &(struct samsung_pd_info) { |
113 | .enable = s5pv310_pd_enable, | 113 | .enable = exynos4_pd_enable, |
114 | .disable = s5pv310_pd_disable, | 114 | .disable = exynos4_pd_disable, |
115 | .base = S5P_PMU_TV_CONF, | 115 | .base = S5P_PMU_TV_CONF, |
116 | }, | 116 | }, |
117 | }, | 117 | }, |
@@ -120,8 +120,8 @@ struct platform_device s5pv310_device_pd[] = { | |||
120 | .id = 5, | 120 | .id = 5, |
121 | .dev = { | 121 | .dev = { |
122 | .platform_data = &(struct samsung_pd_info) { | 122 | .platform_data = &(struct samsung_pd_info) { |
123 | .enable = s5pv310_pd_enable, | 123 | .enable = exynos4_pd_enable, |
124 | .disable = s5pv310_pd_disable, | 124 | .disable = exynos4_pd_disable, |
125 | .base = S5P_PMU_CAM_CONF, | 125 | .base = S5P_PMU_CAM_CONF, |
126 | }, | 126 | }, |
127 | }, | 127 | }, |
@@ -130,8 +130,8 @@ struct platform_device s5pv310_device_pd[] = { | |||
130 | .id = 6, | 130 | .id = 6, |
131 | .dev = { | 131 | .dev = { |
132 | .platform_data = &(struct samsung_pd_info) { | 132 | .platform_data = &(struct samsung_pd_info) { |
133 | .enable = s5pv310_pd_enable, | 133 | .enable = exynos4_pd_enable, |
134 | .disable = s5pv310_pd_disable, | 134 | .disable = exynos4_pd_disable, |
135 | .base = S5P_PMU_GPS_CONF, | 135 | .base = S5P_PMU_GPS_CONF, |
136 | }, | 136 | }, |
137 | }, | 137 | }, |
diff --git a/arch/arm/mach-s5pv310/dev-sysmmu.c b/arch/arm/mach-exynos4/dev-sysmmu.c index e1bb200ac0f0..3b7cae0fe23e 100644 --- a/arch/arm/mach-s5pv310/dev-sysmmu.c +++ b/arch/arm/mach-exynos4/dev-sysmmu.c | |||
@@ -1,8 +1,10 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/dev-sysmmu.c | 1 | /* linux/arch/arm/mach-exynos4/dev-sysmmu.c |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * EXYNOS4 - System MMU support | ||
7 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | 8 | * This program is free software; you can redistribute it and/or modify |
7 | * it under the terms of the GNU General Public License version 2 as | 9 | * it under the terms of the GNU General Public License version 2 as |
8 | * published by the Free Software Foundation. | 10 | * published by the Free Software Foundation. |
@@ -13,11 +15,33 @@ | |||
13 | 15 | ||
14 | #include <mach/map.h> | 16 | #include <mach/map.h> |
15 | #include <mach/irqs.h> | 17 | #include <mach/irqs.h> |
18 | #include <mach/sysmmu.h> | ||
19 | #include <plat/s5p-clock.h> | ||
20 | |||
21 | /* These names must be equal to the clock names in mach-exynos4/clock.c */ | ||
22 | const char *sysmmu_ips_name[EXYNOS4_SYSMMU_TOTAL_IPNUM] = { | ||
23 | "SYSMMU_MDMA" , | ||
24 | "SYSMMU_SSS" , | ||
25 | "SYSMMU_FIMC0" , | ||
26 | "SYSMMU_FIMC1" , | ||
27 | "SYSMMU_FIMC2" , | ||
28 | "SYSMMU_FIMC3" , | ||
29 | "SYSMMU_JPEG" , | ||
30 | "SYSMMU_FIMD0" , | ||
31 | "SYSMMU_FIMD1" , | ||
32 | "SYSMMU_PCIe" , | ||
33 | "SYSMMU_G2D" , | ||
34 | "SYSMMU_ROTATOR", | ||
35 | "SYSMMU_MDMA2" , | ||
36 | "SYSMMU_TV" , | ||
37 | "SYSMMU_MFC_L" , | ||
38 | "SYSMMU_MFC_R" , | ||
39 | }; | ||
16 | 40 | ||
17 | static struct resource s5pv310_sysmmu_resource[] = { | 41 | static struct resource exynos4_sysmmu_resource[] = { |
18 | [0] = { | 42 | [0] = { |
19 | .start = S5PV310_PA_SYSMMU_MDMA, | 43 | .start = EXYNOS4_PA_SYSMMU_MDMA, |
20 | .end = S5PV310_PA_SYSMMU_MDMA + SZ_64K - 1, | 44 | .end = EXYNOS4_PA_SYSMMU_MDMA + SZ_64K - 1, |
21 | .flags = IORESOURCE_MEM, | 45 | .flags = IORESOURCE_MEM, |
22 | }, | 46 | }, |
23 | [1] = { | 47 | [1] = { |
@@ -26,8 +50,8 @@ static struct resource s5pv310_sysmmu_resource[] = { | |||
26 | .flags = IORESOURCE_IRQ, | 50 | .flags = IORESOURCE_IRQ, |
27 | }, | 51 | }, |
28 | [2] = { | 52 | [2] = { |
29 | .start = S5PV310_PA_SYSMMU_SSS, | 53 | .start = EXYNOS4_PA_SYSMMU_SSS, |
30 | .end = S5PV310_PA_SYSMMU_SSS + SZ_64K - 1, | 54 | .end = EXYNOS4_PA_SYSMMU_SSS + SZ_64K - 1, |
31 | .flags = IORESOURCE_MEM, | 55 | .flags = IORESOURCE_MEM, |
32 | }, | 56 | }, |
33 | [3] = { | 57 | [3] = { |
@@ -36,8 +60,8 @@ static struct resource s5pv310_sysmmu_resource[] = { | |||
36 | .flags = IORESOURCE_IRQ, | 60 | .flags = IORESOURCE_IRQ, |
37 | }, | 61 | }, |
38 | [4] = { | 62 | [4] = { |
39 | .start = S5PV310_PA_SYSMMU_FIMC0, | 63 | .start = EXYNOS4_PA_SYSMMU_FIMC0, |
40 | .end = S5PV310_PA_SYSMMU_FIMC0 + SZ_64K - 1, | 64 | .end = EXYNOS4_PA_SYSMMU_FIMC0 + SZ_64K - 1, |
41 | .flags = IORESOURCE_MEM, | 65 | .flags = IORESOURCE_MEM, |
42 | }, | 66 | }, |
43 | [5] = { | 67 | [5] = { |
@@ -46,8 +70,8 @@ static struct resource s5pv310_sysmmu_resource[] = { | |||
46 | .flags = IORESOURCE_IRQ, | 70 | .flags = IORESOURCE_IRQ, |
47 | }, | 71 | }, |
48 | [6] = { | 72 | [6] = { |
49 | .start = S5PV310_PA_SYSMMU_FIMC1, | 73 | .start = EXYNOS4_PA_SYSMMU_FIMC1, |
50 | .end = S5PV310_PA_SYSMMU_FIMC1 + SZ_64K - 1, | 74 | .end = EXYNOS4_PA_SYSMMU_FIMC1 + SZ_64K - 1, |
51 | .flags = IORESOURCE_MEM, | 75 | .flags = IORESOURCE_MEM, |
52 | }, | 76 | }, |
53 | [7] = { | 77 | [7] = { |
@@ -56,8 +80,8 @@ static struct resource s5pv310_sysmmu_resource[] = { | |||
56 | .flags = IORESOURCE_IRQ, | 80 | .flags = IORESOURCE_IRQ, |
57 | }, | 81 | }, |
58 | [8] = { | 82 | [8] = { |
59 | .start = S5PV310_PA_SYSMMU_FIMC2, | 83 | .start = EXYNOS4_PA_SYSMMU_FIMC2, |
60 | .end = S5PV310_PA_SYSMMU_FIMC2 + SZ_64K - 1, | 84 | .end = EXYNOS4_PA_SYSMMU_FIMC2 + SZ_64K - 1, |
61 | .flags = IORESOURCE_MEM, | 85 | .flags = IORESOURCE_MEM, |
62 | }, | 86 | }, |
63 | [9] = { | 87 | [9] = { |
@@ -66,8 +90,8 @@ static struct resource s5pv310_sysmmu_resource[] = { | |||
66 | .flags = IORESOURCE_IRQ, | 90 | .flags = IORESOURCE_IRQ, |
67 | }, | 91 | }, |
68 | [10] = { | 92 | [10] = { |
69 | .start = S5PV310_PA_SYSMMU_FIMC3, | 93 | .start = EXYNOS4_PA_SYSMMU_FIMC3, |
70 | .end = S5PV310_PA_SYSMMU_FIMC3 + SZ_64K - 1, | 94 | .end = EXYNOS4_PA_SYSMMU_FIMC3 + SZ_64K - 1, |
71 | .flags = IORESOURCE_MEM, | 95 | .flags = IORESOURCE_MEM, |
72 | }, | 96 | }, |
73 | [11] = { | 97 | [11] = { |
@@ -76,8 +100,8 @@ static struct resource s5pv310_sysmmu_resource[] = { | |||
76 | .flags = IORESOURCE_IRQ, | 100 | .flags = IORESOURCE_IRQ, |
77 | }, | 101 | }, |
78 | [12] = { | 102 | [12] = { |
79 | .start = S5PV310_PA_SYSMMU_JPEG, | 103 | .start = EXYNOS4_PA_SYSMMU_JPEG, |
80 | .end = S5PV310_PA_SYSMMU_JPEG + SZ_64K - 1, | 104 | .end = EXYNOS4_PA_SYSMMU_JPEG + SZ_64K - 1, |
81 | .flags = IORESOURCE_MEM, | 105 | .flags = IORESOURCE_MEM, |
82 | }, | 106 | }, |
83 | [13] = { | 107 | [13] = { |
@@ -86,8 +110,8 @@ static struct resource s5pv310_sysmmu_resource[] = { | |||
86 | .flags = IORESOURCE_IRQ, | 110 | .flags = IORESOURCE_IRQ, |
87 | }, | 111 | }, |
88 | [14] = { | 112 | [14] = { |
89 | .start = S5PV310_PA_SYSMMU_FIMD0, | 113 | .start = EXYNOS4_PA_SYSMMU_FIMD0, |
90 | .end = S5PV310_PA_SYSMMU_FIMD0 + SZ_64K - 1, | 114 | .end = EXYNOS4_PA_SYSMMU_FIMD0 + SZ_64K - 1, |
91 | .flags = IORESOURCE_MEM, | 115 | .flags = IORESOURCE_MEM, |
92 | }, | 116 | }, |
93 | [15] = { | 117 | [15] = { |
@@ -96,8 +120,8 @@ static struct resource s5pv310_sysmmu_resource[] = { | |||
96 | .flags = IORESOURCE_IRQ, | 120 | .flags = IORESOURCE_IRQ, |
97 | }, | 121 | }, |
98 | [16] = { | 122 | [16] = { |
99 | .start = S5PV310_PA_SYSMMU_FIMD1, | 123 | .start = EXYNOS4_PA_SYSMMU_FIMD1, |
100 | .end = S5PV310_PA_SYSMMU_FIMD1 + SZ_64K - 1, | 124 | .end = EXYNOS4_PA_SYSMMU_FIMD1 + SZ_64K - 1, |
101 | .flags = IORESOURCE_MEM, | 125 | .flags = IORESOURCE_MEM, |
102 | }, | 126 | }, |
103 | [17] = { | 127 | [17] = { |
@@ -106,8 +130,8 @@ static struct resource s5pv310_sysmmu_resource[] = { | |||
106 | .flags = IORESOURCE_IRQ, | 130 | .flags = IORESOURCE_IRQ, |
107 | }, | 131 | }, |
108 | [18] = { | 132 | [18] = { |
109 | .start = S5PV310_PA_SYSMMU_PCIe, | 133 | .start = EXYNOS4_PA_SYSMMU_PCIe, |
110 | .end = S5PV310_PA_SYSMMU_PCIe + SZ_64K - 1, | 134 | .end = EXYNOS4_PA_SYSMMU_PCIe + SZ_64K - 1, |
111 | .flags = IORESOURCE_MEM, | 135 | .flags = IORESOURCE_MEM, |
112 | }, | 136 | }, |
113 | [19] = { | 137 | [19] = { |
@@ -116,8 +140,8 @@ static struct resource s5pv310_sysmmu_resource[] = { | |||
116 | .flags = IORESOURCE_IRQ, | 140 | .flags = IORESOURCE_IRQ, |
117 | }, | 141 | }, |
118 | [20] = { | 142 | [20] = { |
119 | .start = S5PV310_PA_SYSMMU_G2D, | 143 | .start = EXYNOS4_PA_SYSMMU_G2D, |
120 | .end = S5PV310_PA_SYSMMU_G2D + SZ_64K - 1, | 144 | .end = EXYNOS4_PA_SYSMMU_G2D + SZ_64K - 1, |
121 | .flags = IORESOURCE_MEM, | 145 | .flags = IORESOURCE_MEM, |
122 | }, | 146 | }, |
123 | [21] = { | 147 | [21] = { |
@@ -126,8 +150,8 @@ static struct resource s5pv310_sysmmu_resource[] = { | |||
126 | .flags = IORESOURCE_IRQ, | 150 | .flags = IORESOURCE_IRQ, |
127 | }, | 151 | }, |
128 | [22] = { | 152 | [22] = { |
129 | .start = S5PV310_PA_SYSMMU_ROTATOR, | 153 | .start = EXYNOS4_PA_SYSMMU_ROTATOR, |
130 | .end = S5PV310_PA_SYSMMU_ROTATOR + SZ_64K - 1, | 154 | .end = EXYNOS4_PA_SYSMMU_ROTATOR + SZ_64K - 1, |
131 | .flags = IORESOURCE_MEM, | 155 | .flags = IORESOURCE_MEM, |
132 | }, | 156 | }, |
133 | [23] = { | 157 | [23] = { |
@@ -136,8 +160,8 @@ static struct resource s5pv310_sysmmu_resource[] = { | |||
136 | .flags = IORESOURCE_IRQ, | 160 | .flags = IORESOURCE_IRQ, |
137 | }, | 161 | }, |
138 | [24] = { | 162 | [24] = { |
139 | .start = S5PV310_PA_SYSMMU_MDMA2, | 163 | .start = EXYNOS4_PA_SYSMMU_MDMA2, |
140 | .end = S5PV310_PA_SYSMMU_MDMA2 + SZ_64K - 1, | 164 | .end = EXYNOS4_PA_SYSMMU_MDMA2 + SZ_64K - 1, |
141 | .flags = IORESOURCE_MEM, | 165 | .flags = IORESOURCE_MEM, |
142 | }, | 166 | }, |
143 | [25] = { | 167 | [25] = { |
@@ -146,8 +170,8 @@ static struct resource s5pv310_sysmmu_resource[] = { | |||
146 | .flags = IORESOURCE_IRQ, | 170 | .flags = IORESOURCE_IRQ, |
147 | }, | 171 | }, |
148 | [26] = { | 172 | [26] = { |
149 | .start = S5PV310_PA_SYSMMU_TV, | 173 | .start = EXYNOS4_PA_SYSMMU_TV, |
150 | .end = S5PV310_PA_SYSMMU_TV + SZ_64K - 1, | 174 | .end = EXYNOS4_PA_SYSMMU_TV + SZ_64K - 1, |
151 | .flags = IORESOURCE_MEM, | 175 | .flags = IORESOURCE_MEM, |
152 | }, | 176 | }, |
153 | [27] = { | 177 | [27] = { |
@@ -156,8 +180,8 @@ static struct resource s5pv310_sysmmu_resource[] = { | |||
156 | .flags = IORESOURCE_IRQ, | 180 | .flags = IORESOURCE_IRQ, |
157 | }, | 181 | }, |
158 | [28] = { | 182 | [28] = { |
159 | .start = S5PV310_PA_SYSMMU_MFC_L, | 183 | .start = EXYNOS4_PA_SYSMMU_MFC_L, |
160 | .end = S5PV310_PA_SYSMMU_MFC_L + SZ_64K - 1, | 184 | .end = EXYNOS4_PA_SYSMMU_MFC_L + SZ_64K - 1, |
161 | .flags = IORESOURCE_MEM, | 185 | .flags = IORESOURCE_MEM, |
162 | }, | 186 | }, |
163 | [29] = { | 187 | [29] = { |
@@ -166,8 +190,8 @@ static struct resource s5pv310_sysmmu_resource[] = { | |||
166 | .flags = IORESOURCE_IRQ, | 190 | .flags = IORESOURCE_IRQ, |
167 | }, | 191 | }, |
168 | [30] = { | 192 | [30] = { |
169 | .start = S5PV310_PA_SYSMMU_MFC_R, | 193 | .start = EXYNOS4_PA_SYSMMU_MFC_R, |
170 | .end = S5PV310_PA_SYSMMU_MFC_R + SZ_64K - 1, | 194 | .end = EXYNOS4_PA_SYSMMU_MFC_R + SZ_64K - 1, |
171 | .flags = IORESOURCE_MEM, | 195 | .flags = IORESOURCE_MEM, |
172 | }, | 196 | }, |
173 | [31] = { | 197 | [31] = { |
@@ -177,11 +201,32 @@ static struct resource s5pv310_sysmmu_resource[] = { | |||
177 | }, | 201 | }, |
178 | }; | 202 | }; |
179 | 203 | ||
180 | struct platform_device s5pv310_device_sysmmu = { | 204 | struct platform_device exynos4_device_sysmmu = { |
181 | .name = "s5p-sysmmu", | 205 | .name = "s5p-sysmmu", |
182 | .id = 32, | 206 | .id = 32, |
183 | .num_resources = ARRAY_SIZE(s5pv310_sysmmu_resource), | 207 | .num_resources = ARRAY_SIZE(exynos4_sysmmu_resource), |
184 | .resource = s5pv310_sysmmu_resource, | 208 | .resource = exynos4_sysmmu_resource, |
185 | }; | 209 | }; |
210 | EXPORT_SYMBOL(exynos4_device_sysmmu); | ||
211 | |||
212 | static struct clk *sysmmu_clk[S5P_SYSMMU_TOTAL_IPNUM]; | ||
213 | void sysmmu_clk_init(struct device *dev, sysmmu_ips ips) | ||
214 | { | ||
215 | sysmmu_clk[ips] = clk_get(dev, sysmmu_ips_name[ips]); | ||
216 | if (IS_ERR(sysmmu_clk[ips])) | ||
217 | sysmmu_clk[ips] = NULL; | ||
218 | else | ||
219 | clk_put(sysmmu_clk[ips]); | ||
220 | } | ||
221 | |||
222 | void sysmmu_clk_enable(sysmmu_ips ips) | ||
223 | { | ||
224 | if (sysmmu_clk[ips]) | ||
225 | clk_enable(sysmmu_clk[ips]); | ||
226 | } | ||
186 | 227 | ||
187 | EXPORT_SYMBOL(s5pv310_device_sysmmu); | 228 | void sysmmu_clk_disable(sysmmu_ips ips) |
229 | { | ||
230 | if (sysmmu_clk[ips]) | ||
231 | clk_disable(sysmmu_clk[ips]); | ||
232 | } | ||
diff --git a/arch/arm/mach-s5pv310/dma.c b/arch/arm/mach-exynos4/dma.c index 20066c7c9e56..564bb530f332 100644 --- a/arch/arm/mach-s5pv310/dma.c +++ b/arch/arm/mach-exynos4/dma.c | |||
@@ -1,4 +1,8 @@ | |||
1 | /* | 1 | /* linux/arch/arm/mach-exynos4/dma.c |
2 | * | ||
3 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
2 | * Copyright (C) 2010 Samsung Electronics Co. Ltd. | 6 | * Copyright (C) 2010 Samsung Electronics Co. Ltd. |
3 | * Jaswinder Singh <jassi.brar@samsung.com> | 7 | * Jaswinder Singh <jassi.brar@samsung.com> |
4 | * | 8 | * |
@@ -30,10 +34,10 @@ | |||
30 | 34 | ||
31 | static u64 dma_dmamask = DMA_BIT_MASK(32); | 35 | static u64 dma_dmamask = DMA_BIT_MASK(32); |
32 | 36 | ||
33 | static struct resource s5pv310_pdma0_resource[] = { | 37 | static struct resource exynos4_pdma0_resource[] = { |
34 | [0] = { | 38 | [0] = { |
35 | .start = S5PV310_PA_PDMA0, | 39 | .start = EXYNOS4_PA_PDMA0, |
36 | .end = S5PV310_PA_PDMA0 + SZ_4K, | 40 | .end = EXYNOS4_PA_PDMA0 + SZ_4K, |
37 | .flags = IORESOURCE_MEM, | 41 | .flags = IORESOURCE_MEM, |
38 | }, | 42 | }, |
39 | [1] = { | 43 | [1] = { |
@@ -43,7 +47,7 @@ static struct resource s5pv310_pdma0_resource[] = { | |||
43 | }, | 47 | }, |
44 | }; | 48 | }; |
45 | 49 | ||
46 | static struct s3c_pl330_platdata s5pv310_pdma0_pdata = { | 50 | static struct s3c_pl330_platdata exynos4_pdma0_pdata = { |
47 | .peri = { | 51 | .peri = { |
48 | [0] = DMACH_PCM0_RX, | 52 | [0] = DMACH_PCM0_RX, |
49 | [1] = DMACH_PCM0_TX, | 53 | [1] = DMACH_PCM0_TX, |
@@ -80,22 +84,22 @@ static struct s3c_pl330_platdata s5pv310_pdma0_pdata = { | |||
80 | }, | 84 | }, |
81 | }; | 85 | }; |
82 | 86 | ||
83 | static struct platform_device s5pv310_device_pdma0 = { | 87 | static struct platform_device exynos4_device_pdma0 = { |
84 | .name = "s3c-pl330", | 88 | .name = "s3c-pl330", |
85 | .id = 0, | 89 | .id = 0, |
86 | .num_resources = ARRAY_SIZE(s5pv310_pdma0_resource), | 90 | .num_resources = ARRAY_SIZE(exynos4_pdma0_resource), |
87 | .resource = s5pv310_pdma0_resource, | 91 | .resource = exynos4_pdma0_resource, |
88 | .dev = { | 92 | .dev = { |
89 | .dma_mask = &dma_dmamask, | 93 | .dma_mask = &dma_dmamask, |
90 | .coherent_dma_mask = DMA_BIT_MASK(32), | 94 | .coherent_dma_mask = DMA_BIT_MASK(32), |
91 | .platform_data = &s5pv310_pdma0_pdata, | 95 | .platform_data = &exynos4_pdma0_pdata, |
92 | }, | 96 | }, |
93 | }; | 97 | }; |
94 | 98 | ||
95 | static struct resource s5pv310_pdma1_resource[] = { | 99 | static struct resource exynos4_pdma1_resource[] = { |
96 | [0] = { | 100 | [0] = { |
97 | .start = S5PV310_PA_PDMA1, | 101 | .start = EXYNOS4_PA_PDMA1, |
98 | .end = S5PV310_PA_PDMA1 + SZ_4K, | 102 | .end = EXYNOS4_PA_PDMA1 + SZ_4K, |
99 | .flags = IORESOURCE_MEM, | 103 | .flags = IORESOURCE_MEM, |
100 | }, | 104 | }, |
101 | [1] = { | 105 | [1] = { |
@@ -105,7 +109,7 @@ static struct resource s5pv310_pdma1_resource[] = { | |||
105 | }, | 109 | }, |
106 | }; | 110 | }; |
107 | 111 | ||
108 | static struct s3c_pl330_platdata s5pv310_pdma1_pdata = { | 112 | static struct s3c_pl330_platdata exynos4_pdma1_pdata = { |
109 | .peri = { | 113 | .peri = { |
110 | [0] = DMACH_PCM0_RX, | 114 | [0] = DMACH_PCM0_RX, |
111 | [1] = DMACH_PCM0_TX, | 115 | [1] = DMACH_PCM0_TX, |
@@ -142,27 +146,27 @@ static struct s3c_pl330_platdata s5pv310_pdma1_pdata = { | |||
142 | }, | 146 | }, |
143 | }; | 147 | }; |
144 | 148 | ||
145 | static struct platform_device s5pv310_device_pdma1 = { | 149 | static struct platform_device exynos4_device_pdma1 = { |
146 | .name = "s3c-pl330", | 150 | .name = "s3c-pl330", |
147 | .id = 1, | 151 | .id = 1, |
148 | .num_resources = ARRAY_SIZE(s5pv310_pdma1_resource), | 152 | .num_resources = ARRAY_SIZE(exynos4_pdma1_resource), |
149 | .resource = s5pv310_pdma1_resource, | 153 | .resource = exynos4_pdma1_resource, |
150 | .dev = { | 154 | .dev = { |
151 | .dma_mask = &dma_dmamask, | 155 | .dma_mask = &dma_dmamask, |
152 | .coherent_dma_mask = DMA_BIT_MASK(32), | 156 | .coherent_dma_mask = DMA_BIT_MASK(32), |
153 | .platform_data = &s5pv310_pdma1_pdata, | 157 | .platform_data = &exynos4_pdma1_pdata, |
154 | }, | 158 | }, |
155 | }; | 159 | }; |
156 | 160 | ||
157 | static struct platform_device *s5pv310_dmacs[] __initdata = { | 161 | static struct platform_device *exynos4_dmacs[] __initdata = { |
158 | &s5pv310_device_pdma0, | 162 | &exynos4_device_pdma0, |
159 | &s5pv310_device_pdma1, | 163 | &exynos4_device_pdma1, |
160 | }; | 164 | }; |
161 | 165 | ||
162 | static int __init s5pv310_dma_init(void) | 166 | static int __init exynos4_dma_init(void) |
163 | { | 167 | { |
164 | platform_add_devices(s5pv310_dmacs, ARRAY_SIZE(s5pv310_dmacs)); | 168 | platform_add_devices(exynos4_dmacs, ARRAY_SIZE(exynos4_dmacs)); |
165 | 169 | ||
166 | return 0; | 170 | return 0; |
167 | } | 171 | } |
168 | arch_initcall(s5pv310_dma_init); | 172 | arch_initcall(exynos4_dma_init); |
diff --git a/arch/arm/mach-exynos4/gpiolib.c b/arch/arm/mach-exynos4/gpiolib.c new file mode 100644 index 000000000000..d54ca6adb660 --- /dev/null +++ b/arch/arm/mach-exynos4/gpiolib.c | |||
@@ -0,0 +1,365 @@ | |||
1 | /* linux/arch/arm/mach-exynos4/gpiolib.c | ||
2 | * | ||
3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * EXYNOS4 - GPIOlib support | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #include <linux/kernel.h> | ||
14 | #include <linux/irq.h> | ||
15 | #include <linux/io.h> | ||
16 | #include <linux/gpio.h> | ||
17 | |||
18 | #include <mach/map.h> | ||
19 | |||
20 | #include <plat/gpio-core.h> | ||
21 | #include <plat/gpio-cfg.h> | ||
22 | #include <plat/gpio-cfg-helpers.h> | ||
23 | |||
24 | static struct s3c_gpio_cfg gpio_cfg = { | ||
25 | .set_config = s3c_gpio_setcfg_s3c64xx_4bit, | ||
26 | .set_pull = s3c_gpio_setpull_updown, | ||
27 | .get_pull = s3c_gpio_getpull_updown, | ||
28 | }; | ||
29 | |||
30 | static struct s3c_gpio_cfg gpio_cfg_noint = { | ||
31 | .set_config = s3c_gpio_setcfg_s3c64xx_4bit, | ||
32 | .set_pull = s3c_gpio_setpull_updown, | ||
33 | .get_pull = s3c_gpio_getpull_updown, | ||
34 | }; | ||
35 | |||
36 | /* | ||
37 | * Following are the gpio banks in v310. | ||
38 | * | ||
39 | * The 'config' member when left to NULL, is initialized to the default | ||
40 | * structure gpio_cfg in the init function below. | ||
41 | * | ||
42 | * The 'base' member is also initialized in the init function below. | ||
43 | * Note: The initialization of 'base' member of s3c_gpio_chip structure | ||
44 | * uses the above macro and depends on the banks being listed in order here. | ||
45 | */ | ||
46 | static struct s3c_gpio_chip exynos4_gpio_part1_4bit[] = { | ||
47 | { | ||
48 | .chip = { | ||
49 | .base = EXYNOS4_GPA0(0), | ||
50 | .ngpio = EXYNOS4_GPIO_A0_NR, | ||
51 | .label = "GPA0", | ||
52 | }, | ||
53 | }, { | ||
54 | .chip = { | ||
55 | .base = EXYNOS4_GPA1(0), | ||
56 | .ngpio = EXYNOS4_GPIO_A1_NR, | ||
57 | .label = "GPA1", | ||
58 | }, | ||
59 | }, { | ||
60 | .chip = { | ||
61 | .base = EXYNOS4_GPB(0), | ||
62 | .ngpio = EXYNOS4_GPIO_B_NR, | ||
63 | .label = "GPB", | ||
64 | }, | ||
65 | }, { | ||
66 | .chip = { | ||
67 | .base = EXYNOS4_GPC0(0), | ||
68 | .ngpio = EXYNOS4_GPIO_C0_NR, | ||
69 | .label = "GPC0", | ||
70 | }, | ||
71 | }, { | ||
72 | .chip = { | ||
73 | .base = EXYNOS4_GPC1(0), | ||
74 | .ngpio = EXYNOS4_GPIO_C1_NR, | ||
75 | .label = "GPC1", | ||
76 | }, | ||
77 | }, { | ||
78 | .chip = { | ||
79 | .base = EXYNOS4_GPD0(0), | ||
80 | .ngpio = EXYNOS4_GPIO_D0_NR, | ||
81 | .label = "GPD0", | ||
82 | }, | ||
83 | }, { | ||
84 | .chip = { | ||
85 | .base = EXYNOS4_GPD1(0), | ||
86 | .ngpio = EXYNOS4_GPIO_D1_NR, | ||
87 | .label = "GPD1", | ||
88 | }, | ||
89 | }, { | ||
90 | .chip = { | ||
91 | .base = EXYNOS4_GPE0(0), | ||
92 | .ngpio = EXYNOS4_GPIO_E0_NR, | ||
93 | .label = "GPE0", | ||
94 | }, | ||
95 | }, { | ||
96 | .chip = { | ||
97 | .base = EXYNOS4_GPE1(0), | ||
98 | .ngpio = EXYNOS4_GPIO_E1_NR, | ||
99 | .label = "GPE1", | ||
100 | }, | ||
101 | }, { | ||
102 | .chip = { | ||
103 | .base = EXYNOS4_GPE2(0), | ||
104 | .ngpio = EXYNOS4_GPIO_E2_NR, | ||
105 | .label = "GPE2", | ||
106 | }, | ||
107 | }, { | ||
108 | .chip = { | ||
109 | .base = EXYNOS4_GPE3(0), | ||
110 | .ngpio = EXYNOS4_GPIO_E3_NR, | ||
111 | .label = "GPE3", | ||
112 | }, | ||
113 | }, { | ||
114 | .chip = { | ||
115 | .base = EXYNOS4_GPE4(0), | ||
116 | .ngpio = EXYNOS4_GPIO_E4_NR, | ||
117 | .label = "GPE4", | ||
118 | }, | ||
119 | }, { | ||
120 | .chip = { | ||
121 | .base = EXYNOS4_GPF0(0), | ||
122 | .ngpio = EXYNOS4_GPIO_F0_NR, | ||
123 | .label = "GPF0", | ||
124 | }, | ||
125 | }, { | ||
126 | .chip = { | ||
127 | .base = EXYNOS4_GPF1(0), | ||
128 | .ngpio = EXYNOS4_GPIO_F1_NR, | ||
129 | .label = "GPF1", | ||
130 | }, | ||
131 | }, { | ||
132 | .chip = { | ||
133 | .base = EXYNOS4_GPF2(0), | ||
134 | .ngpio = EXYNOS4_GPIO_F2_NR, | ||
135 | .label = "GPF2", | ||
136 | }, | ||
137 | }, { | ||
138 | .chip = { | ||
139 | .base = EXYNOS4_GPF3(0), | ||
140 | .ngpio = EXYNOS4_GPIO_F3_NR, | ||
141 | .label = "GPF3", | ||
142 | }, | ||
143 | }, | ||
144 | }; | ||
145 | |||
146 | static struct s3c_gpio_chip exynos4_gpio_part2_4bit[] = { | ||
147 | { | ||
148 | .chip = { | ||
149 | .base = EXYNOS4_GPJ0(0), | ||
150 | .ngpio = EXYNOS4_GPIO_J0_NR, | ||
151 | .label = "GPJ0", | ||
152 | }, | ||
153 | }, { | ||
154 | .chip = { | ||
155 | .base = EXYNOS4_GPJ1(0), | ||
156 | .ngpio = EXYNOS4_GPIO_J1_NR, | ||
157 | .label = "GPJ1", | ||
158 | }, | ||
159 | }, { | ||
160 | .chip = { | ||
161 | .base = EXYNOS4_GPK0(0), | ||
162 | .ngpio = EXYNOS4_GPIO_K0_NR, | ||
163 | .label = "GPK0", | ||
164 | }, | ||
165 | }, { | ||
166 | .chip = { | ||
167 | .base = EXYNOS4_GPK1(0), | ||
168 | .ngpio = EXYNOS4_GPIO_K1_NR, | ||
169 | .label = "GPK1", | ||
170 | }, | ||
171 | }, { | ||
172 | .chip = { | ||
173 | .base = EXYNOS4_GPK2(0), | ||
174 | .ngpio = EXYNOS4_GPIO_K2_NR, | ||
175 | .label = "GPK2", | ||
176 | }, | ||
177 | }, { | ||
178 | .chip = { | ||
179 | .base = EXYNOS4_GPK3(0), | ||
180 | .ngpio = EXYNOS4_GPIO_K3_NR, | ||
181 | .label = "GPK3", | ||
182 | }, | ||
183 | }, { | ||
184 | .chip = { | ||
185 | .base = EXYNOS4_GPL0(0), | ||
186 | .ngpio = EXYNOS4_GPIO_L0_NR, | ||
187 | .label = "GPL0", | ||
188 | }, | ||
189 | }, { | ||
190 | .chip = { | ||
191 | .base = EXYNOS4_GPL1(0), | ||
192 | .ngpio = EXYNOS4_GPIO_L1_NR, | ||
193 | .label = "GPL1", | ||
194 | }, | ||
195 | }, { | ||
196 | .chip = { | ||
197 | .base = EXYNOS4_GPL2(0), | ||
198 | .ngpio = EXYNOS4_GPIO_L2_NR, | ||
199 | .label = "GPL2", | ||
200 | }, | ||
201 | }, { | ||
202 | .config = &gpio_cfg_noint, | ||
203 | .chip = { | ||
204 | .base = EXYNOS4_GPY0(0), | ||
205 | .ngpio = EXYNOS4_GPIO_Y0_NR, | ||
206 | .label = "GPY0", | ||
207 | }, | ||
208 | }, { | ||
209 | .config = &gpio_cfg_noint, | ||
210 | .chip = { | ||
211 | .base = EXYNOS4_GPY1(0), | ||
212 | .ngpio = EXYNOS4_GPIO_Y1_NR, | ||
213 | .label = "GPY1", | ||
214 | }, | ||
215 | }, { | ||
216 | .config = &gpio_cfg_noint, | ||
217 | .chip = { | ||
218 | .base = EXYNOS4_GPY2(0), | ||
219 | .ngpio = EXYNOS4_GPIO_Y2_NR, | ||
220 | .label = "GPY2", | ||
221 | }, | ||
222 | }, { | ||
223 | .config = &gpio_cfg_noint, | ||
224 | .chip = { | ||
225 | .base = EXYNOS4_GPY3(0), | ||
226 | .ngpio = EXYNOS4_GPIO_Y3_NR, | ||
227 | .label = "GPY3", | ||
228 | }, | ||
229 | }, { | ||
230 | .config = &gpio_cfg_noint, | ||
231 | .chip = { | ||
232 | .base = EXYNOS4_GPY4(0), | ||
233 | .ngpio = EXYNOS4_GPIO_Y4_NR, | ||
234 | .label = "GPY4", | ||
235 | }, | ||
236 | }, { | ||
237 | .config = &gpio_cfg_noint, | ||
238 | .chip = { | ||
239 | .base = EXYNOS4_GPY5(0), | ||
240 | .ngpio = EXYNOS4_GPIO_Y5_NR, | ||
241 | .label = "GPY5", | ||
242 | }, | ||
243 | }, { | ||
244 | .config = &gpio_cfg_noint, | ||
245 | .chip = { | ||
246 | .base = EXYNOS4_GPY6(0), | ||
247 | .ngpio = EXYNOS4_GPIO_Y6_NR, | ||
248 | .label = "GPY6", | ||
249 | }, | ||
250 | }, { | ||
251 | .base = (S5P_VA_GPIO2 + 0xC00), | ||
252 | .config = &gpio_cfg_noint, | ||
253 | .irq_base = IRQ_EINT(0), | ||
254 | .chip = { | ||
255 | .base = EXYNOS4_GPX0(0), | ||
256 | .ngpio = EXYNOS4_GPIO_X0_NR, | ||
257 | .label = "GPX0", | ||
258 | .to_irq = samsung_gpiolib_to_irq, | ||
259 | }, | ||
260 | }, { | ||
261 | .base = (S5P_VA_GPIO2 + 0xC20), | ||
262 | .config = &gpio_cfg_noint, | ||
263 | .irq_base = IRQ_EINT(8), | ||
264 | .chip = { | ||
265 | .base = EXYNOS4_GPX1(0), | ||
266 | .ngpio = EXYNOS4_GPIO_X1_NR, | ||
267 | .label = "GPX1", | ||
268 | .to_irq = samsung_gpiolib_to_irq, | ||
269 | }, | ||
270 | }, { | ||
271 | .base = (S5P_VA_GPIO2 + 0xC40), | ||
272 | .config = &gpio_cfg_noint, | ||
273 | .irq_base = IRQ_EINT(16), | ||
274 | .chip = { | ||
275 | .base = EXYNOS4_GPX2(0), | ||
276 | .ngpio = EXYNOS4_GPIO_X2_NR, | ||
277 | .label = "GPX2", | ||
278 | .to_irq = samsung_gpiolib_to_irq, | ||
279 | }, | ||
280 | }, { | ||
281 | .base = (S5P_VA_GPIO2 + 0xC60), | ||
282 | .config = &gpio_cfg_noint, | ||
283 | .irq_base = IRQ_EINT(24), | ||
284 | .chip = { | ||
285 | .base = EXYNOS4_GPX3(0), | ||
286 | .ngpio = EXYNOS4_GPIO_X3_NR, | ||
287 | .label = "GPX3", | ||
288 | .to_irq = samsung_gpiolib_to_irq, | ||
289 | }, | ||
290 | }, | ||
291 | }; | ||
292 | |||
293 | static struct s3c_gpio_chip exynos4_gpio_part3_4bit[] = { | ||
294 | { | ||
295 | .chip = { | ||
296 | .base = EXYNOS4_GPZ(0), | ||
297 | .ngpio = EXYNOS4_GPIO_Z_NR, | ||
298 | .label = "GPZ", | ||
299 | }, | ||
300 | }, | ||
301 | }; | ||
302 | |||
303 | static __init int exynos4_gpiolib_init(void) | ||
304 | { | ||
305 | struct s3c_gpio_chip *chip; | ||
306 | int i; | ||
307 | int group = 0; | ||
308 | int nr_chips; | ||
309 | |||
310 | /* GPIO part 1 */ | ||
311 | |||
312 | chip = exynos4_gpio_part1_4bit; | ||
313 | nr_chips = ARRAY_SIZE(exynos4_gpio_part1_4bit); | ||
314 | |||
315 | for (i = 0; i < nr_chips; i++, chip++) { | ||
316 | if (chip->config == NULL) { | ||
317 | chip->config = &gpio_cfg; | ||
318 | /* Assign the GPIO interrupt group */ | ||
319 | chip->group = group++; | ||
320 | } | ||
321 | if (chip->base == NULL) | ||
322 | chip->base = S5P_VA_GPIO1 + (i) * 0x20; | ||
323 | } | ||
324 | |||
325 | samsung_gpiolib_add_4bit_chips(exynos4_gpio_part1_4bit, nr_chips); | ||
326 | |||
327 | /* GPIO part 2 */ | ||
328 | |||
329 | chip = exynos4_gpio_part2_4bit; | ||
330 | nr_chips = ARRAY_SIZE(exynos4_gpio_part2_4bit); | ||
331 | |||
332 | for (i = 0; i < nr_chips; i++, chip++) { | ||
333 | if (chip->config == NULL) { | ||
334 | chip->config = &gpio_cfg; | ||
335 | /* Assign the GPIO interrupt group */ | ||
336 | chip->group = group++; | ||
337 | } | ||
338 | if (chip->base == NULL) | ||
339 | chip->base = S5P_VA_GPIO2 + (i) * 0x20; | ||
340 | } | ||
341 | |||
342 | samsung_gpiolib_add_4bit_chips(exynos4_gpio_part2_4bit, nr_chips); | ||
343 | |||
344 | /* GPIO part 3 */ | ||
345 | |||
346 | chip = exynos4_gpio_part3_4bit; | ||
347 | nr_chips = ARRAY_SIZE(exynos4_gpio_part3_4bit); | ||
348 | |||
349 | for (i = 0; i < nr_chips; i++, chip++) { | ||
350 | if (chip->config == NULL) { | ||
351 | chip->config = &gpio_cfg; | ||
352 | /* Assign the GPIO interrupt group */ | ||
353 | chip->group = group++; | ||
354 | } | ||
355 | if (chip->base == NULL) | ||
356 | chip->base = S5P_VA_GPIO3 + (i) * 0x20; | ||
357 | } | ||
358 | |||
359 | samsung_gpiolib_add_4bit_chips(exynos4_gpio_part3_4bit, nr_chips); | ||
360 | s5p_register_gpioint_bank(IRQ_GPIO_XA, 0, IRQ_GPIO1_NR_GROUPS); | ||
361 | s5p_register_gpioint_bank(IRQ_GPIO_XB, IRQ_GPIO1_NR_GROUPS, IRQ_GPIO2_NR_GROUPS); | ||
362 | |||
363 | return 0; | ||
364 | } | ||
365 | core_initcall(exynos4_gpiolib_init); | ||
diff --git a/arch/arm/mach-s5pv310/headsmp.S b/arch/arm/mach-exynos4/headsmp.S index 164b7b045713..6c6cfc50c46b 100644 --- a/arch/arm/mach-s5pv310/headsmp.S +++ b/arch/arm/mach-exynos4/headsmp.S | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * linux/arch/arm/mach-s5pv310/headsmp.S | 2 | * linux/arch/arm/mach-exynos4/headsmp.S |
3 | * | 3 | * |
4 | * Cloned from linux/arch/arm/mach-realview/headsmp.S | 4 | * Cloned from linux/arch/arm/mach-realview/headsmp.S |
5 | * | 5 | * |
@@ -16,11 +16,11 @@ | |||
16 | __INIT | 16 | __INIT |
17 | 17 | ||
18 | /* | 18 | /* |
19 | * s5pv310 specific entry point for secondary CPUs. This provides | 19 | * exynos4 specific entry point for secondary CPUs. This provides |
20 | * a "holding pen" into which all secondary cores are held until we're | 20 | * a "holding pen" into which all secondary cores are held until we're |
21 | * ready for them to initialise. | 21 | * ready for them to initialise. |
22 | */ | 22 | */ |
23 | ENTRY(s5pv310_secondary_startup) | 23 | ENTRY(exynos4_secondary_startup) |
24 | mrc p15, 0, r0, c0, c0, 5 | 24 | mrc p15, 0, r0, c0, c0, 5 |
25 | and r0, r0, #15 | 25 | and r0, r0, #15 |
26 | adr r4, 1f | 26 | adr r4, 1f |
diff --git a/arch/arm/mach-s5pv310/hotplug.c b/arch/arm/mach-exynos4/hotplug.c index c24235c89eed..2b5909e2ccd3 100644 --- a/arch/arm/mach-s5pv310/hotplug.c +++ b/arch/arm/mach-exynos4/hotplug.c | |||
@@ -1,4 +1,4 @@ | |||
1 | /* linux arch/arm/mach-s5pv310/hotplug.c | 1 | /* linux arch/arm/mach-exynos4/hotplug.c |
2 | * | 2 | * |
3 | * Cloned from linux/arch/arm/mach-realview/hotplug.c | 3 | * Cloned from linux/arch/arm/mach-realview/hotplug.c |
4 | * | 4 | * |
@@ -30,13 +30,13 @@ static inline void cpu_enter_lowpower(void) | |||
30 | * Turn off coherency | 30 | * Turn off coherency |
31 | */ | 31 | */ |
32 | " mrc p15, 0, %0, c1, c0, 1\n" | 32 | " mrc p15, 0, %0, c1, c0, 1\n" |
33 | " bic %0, %0, #0x20\n" | 33 | " bic %0, %0, %3\n" |
34 | " mcr p15, 0, %0, c1, c0, 1\n" | 34 | " mcr p15, 0, %0, c1, c0, 1\n" |
35 | " mrc p15, 0, %0, c1, c0, 0\n" | 35 | " mrc p15, 0, %0, c1, c0, 0\n" |
36 | " bic %0, %0, %2\n" | 36 | " bic %0, %0, %2\n" |
37 | " mcr p15, 0, %0, c1, c0, 0\n" | 37 | " mcr p15, 0, %0, c1, c0, 0\n" |
38 | : "=&r" (v) | 38 | : "=&r" (v) |
39 | : "r" (0), "Ir" (CR_C) | 39 | : "r" (0), "Ir" (CR_C), "Ir" (0x40) |
40 | : "cc"); | 40 | : "cc"); |
41 | } | 41 | } |
42 | 42 | ||
@@ -49,10 +49,10 @@ static inline void cpu_leave_lowpower(void) | |||
49 | " orr %0, %0, %1\n" | 49 | " orr %0, %0, %1\n" |
50 | " mcr p15, 0, %0, c1, c0, 0\n" | 50 | " mcr p15, 0, %0, c1, c0, 0\n" |
51 | " mrc p15, 0, %0, c1, c0, 1\n" | 51 | " mrc p15, 0, %0, c1, c0, 1\n" |
52 | " orr %0, %0, #0x20\n" | 52 | " orr %0, %0, %2\n" |
53 | " mcr p15, 0, %0, c1, c0, 1\n" | 53 | " mcr p15, 0, %0, c1, c0, 1\n" |
54 | : "=&r" (v) | 54 | : "=&r" (v) |
55 | : "Ir" (CR_C) | 55 | : "Ir" (CR_C), "Ir" (0x40) |
56 | : "cc"); | 56 | : "cc"); |
57 | } | 57 | } |
58 | 58 | ||
diff --git a/arch/arm/mach-s5pv310/include/mach/debug-macro.S b/arch/arm/mach-exynos4/include/mach/debug-macro.S index b0d920c474d3..58bbd049a6c4 100644 --- a/arch/arm/mach-s5pv310/include/mach/debug-macro.S +++ b/arch/arm/mach-exynos4/include/mach/debug-macro.S | |||
@@ -1,7 +1,7 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/debug-macro.S | 1 | /* linux/arch/arm/mach-exynos4/include/mach/debug-macro.S |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * Based on arch/arm/mach-s3c6400/include/mach/debug-macro.S | 6 | * Based on arch/arm/mach-s3c6400/include/mach/debug-macro.S |
7 | * | 7 | * |
diff --git a/arch/arm/mach-s5pv310/include/mach/dma.h b/arch/arm/mach-exynos4/include/mach/dma.h index 81209eb1409b..81209eb1409b 100644 --- a/arch/arm/mach-s5pv310/include/mach/dma.h +++ b/arch/arm/mach-exynos4/include/mach/dma.h | |||
diff --git a/arch/arm/mach-s5pv310/include/mach/entry-macro.S b/arch/arm/mach-exynos4/include/mach/entry-macro.S index e600e1d522df..d8f38c2e5654 100644 --- a/arch/arm/mach-s5pv310/include/mach/entry-macro.S +++ b/arch/arm/mach-exynos4/include/mach/entry-macro.S | |||
@@ -1,8 +1,8 @@ | |||
1 | /* arch/arm/mach-s5pv310/include/mach/entry-macro.S | 1 | /* arch/arm/mach-exynos4/include/mach/entry-macro.S |
2 | * | 2 | * |
3 | * Cloned from arch/arm/mach-realview/include/mach/entry-macro.S | 3 | * Cloned from arch/arm/mach-realview/include/mach/entry-macro.S |
4 | * | 4 | * |
5 | * Low-level IRQ helper macros for S5PV310 platforms | 5 | * Low-level IRQ helper macros for EXYNOS4 platforms |
6 | * | 6 | * |
7 | * This file is licensed under the terms of the GNU General Public | 7 | * This file is licensed under the terms of the GNU General Public |
8 | * License version 2. This program is licensed "as is" without any | 8 | * License version 2. This program is licensed "as is" without any |
diff --git a/arch/arm/mach-exynos4/include/mach/gpio.h b/arch/arm/mach-exynos4/include/mach/gpio.h new file mode 100644 index 000000000000..939728b38d48 --- /dev/null +++ b/arch/arm/mach-exynos4/include/mach/gpio.h | |||
@@ -0,0 +1,156 @@ | |||
1 | /* linux/arch/arm/mach-exynos4/include/mach/gpio.h | ||
2 | * | ||
3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * EXYNOS4 - GPIO lib support | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __ASM_ARCH_GPIO_H | ||
14 | #define __ASM_ARCH_GPIO_H __FILE__ | ||
15 | |||
16 | #define gpio_get_value __gpio_get_value | ||
17 | #define gpio_set_value __gpio_set_value | ||
18 | #define gpio_cansleep __gpio_cansleep | ||
19 | #define gpio_to_irq __gpio_to_irq | ||
20 | |||
21 | /* Practically, GPIO banks upto GPZ are the configurable gpio banks */ | ||
22 | |||
23 | /* GPIO bank sizes */ | ||
24 | #define EXYNOS4_GPIO_A0_NR (8) | ||
25 | #define EXYNOS4_GPIO_A1_NR (6) | ||
26 | #define EXYNOS4_GPIO_B_NR (8) | ||
27 | #define EXYNOS4_GPIO_C0_NR (5) | ||
28 | #define EXYNOS4_GPIO_C1_NR (5) | ||
29 | #define EXYNOS4_GPIO_D0_NR (4) | ||
30 | #define EXYNOS4_GPIO_D1_NR (4) | ||
31 | #define EXYNOS4_GPIO_E0_NR (5) | ||
32 | #define EXYNOS4_GPIO_E1_NR (8) | ||
33 | #define EXYNOS4_GPIO_E2_NR (6) | ||
34 | #define EXYNOS4_GPIO_E3_NR (8) | ||
35 | #define EXYNOS4_GPIO_E4_NR (8) | ||
36 | #define EXYNOS4_GPIO_F0_NR (8) | ||
37 | #define EXYNOS4_GPIO_F1_NR (8) | ||
38 | #define EXYNOS4_GPIO_F2_NR (8) | ||
39 | #define EXYNOS4_GPIO_F3_NR (6) | ||
40 | #define EXYNOS4_GPIO_J0_NR (8) | ||
41 | #define EXYNOS4_GPIO_J1_NR (5) | ||
42 | #define EXYNOS4_GPIO_K0_NR (7) | ||
43 | #define EXYNOS4_GPIO_K1_NR (7) | ||
44 | #define EXYNOS4_GPIO_K2_NR (7) | ||
45 | #define EXYNOS4_GPIO_K3_NR (7) | ||
46 | #define EXYNOS4_GPIO_L0_NR (8) | ||
47 | #define EXYNOS4_GPIO_L1_NR (3) | ||
48 | #define EXYNOS4_GPIO_L2_NR (8) | ||
49 | #define EXYNOS4_GPIO_X0_NR (8) | ||
50 | #define EXYNOS4_GPIO_X1_NR (8) | ||
51 | #define EXYNOS4_GPIO_X2_NR (8) | ||
52 | #define EXYNOS4_GPIO_X3_NR (8) | ||
53 | #define EXYNOS4_GPIO_Y0_NR (6) | ||
54 | #define EXYNOS4_GPIO_Y1_NR (4) | ||
55 | #define EXYNOS4_GPIO_Y2_NR (6) | ||
56 | #define EXYNOS4_GPIO_Y3_NR (8) | ||
57 | #define EXYNOS4_GPIO_Y4_NR (8) | ||
58 | #define EXYNOS4_GPIO_Y5_NR (8) | ||
59 | #define EXYNOS4_GPIO_Y6_NR (8) | ||
60 | #define EXYNOS4_GPIO_Z_NR (7) | ||
61 | |||
62 | /* GPIO bank numbers */ | ||
63 | |||
64 | #define EXYNOS4_GPIO_NEXT(__gpio) \ | ||
65 | ((__gpio##_START) + (__gpio##_NR) + CONFIG_S3C_GPIO_SPACE + 1) | ||
66 | |||
67 | enum s5p_gpio_number { | ||
68 | EXYNOS4_GPIO_A0_START = 0, | ||
69 | EXYNOS4_GPIO_A1_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_A0), | ||
70 | EXYNOS4_GPIO_B_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_A1), | ||
71 | EXYNOS4_GPIO_C0_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_B), | ||
72 | EXYNOS4_GPIO_C1_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_C0), | ||
73 | EXYNOS4_GPIO_D0_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_C1), | ||
74 | EXYNOS4_GPIO_D1_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_D0), | ||
75 | EXYNOS4_GPIO_E0_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_D1), | ||
76 | EXYNOS4_GPIO_E1_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_E0), | ||
77 | EXYNOS4_GPIO_E2_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_E1), | ||
78 | EXYNOS4_GPIO_E3_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_E2), | ||
79 | EXYNOS4_GPIO_E4_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_E3), | ||
80 | EXYNOS4_GPIO_F0_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_E4), | ||
81 | EXYNOS4_GPIO_F1_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_F0), | ||
82 | EXYNOS4_GPIO_F2_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_F1), | ||
83 | EXYNOS4_GPIO_F3_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_F2), | ||
84 | EXYNOS4_GPIO_J0_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_F3), | ||
85 | EXYNOS4_GPIO_J1_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_J0), | ||
86 | EXYNOS4_GPIO_K0_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_J1), | ||
87 | EXYNOS4_GPIO_K1_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_K0), | ||
88 | EXYNOS4_GPIO_K2_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_K1), | ||
89 | EXYNOS4_GPIO_K3_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_K2), | ||
90 | EXYNOS4_GPIO_L0_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_K3), | ||
91 | EXYNOS4_GPIO_L1_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_L0), | ||
92 | EXYNOS4_GPIO_L2_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_L1), | ||
93 | EXYNOS4_GPIO_X0_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_L2), | ||
94 | EXYNOS4_GPIO_X1_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_X0), | ||
95 | EXYNOS4_GPIO_X2_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_X1), | ||
96 | EXYNOS4_GPIO_X3_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_X2), | ||
97 | EXYNOS4_GPIO_Y0_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_X3), | ||
98 | EXYNOS4_GPIO_Y1_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_Y0), | ||
99 | EXYNOS4_GPIO_Y2_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_Y1), | ||
100 | EXYNOS4_GPIO_Y3_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_Y2), | ||
101 | EXYNOS4_GPIO_Y4_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_Y3), | ||
102 | EXYNOS4_GPIO_Y5_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_Y4), | ||
103 | EXYNOS4_GPIO_Y6_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_Y5), | ||
104 | EXYNOS4_GPIO_Z_START = EXYNOS4_GPIO_NEXT(EXYNOS4_GPIO_Y6), | ||
105 | }; | ||
106 | |||
107 | /* EXYNOS4 GPIO number definitions */ | ||
108 | #define EXYNOS4_GPA0(_nr) (EXYNOS4_GPIO_A0_START + (_nr)) | ||
109 | #define EXYNOS4_GPA1(_nr) (EXYNOS4_GPIO_A1_START + (_nr)) | ||
110 | #define EXYNOS4_GPB(_nr) (EXYNOS4_GPIO_B_START + (_nr)) | ||
111 | #define EXYNOS4_GPC0(_nr) (EXYNOS4_GPIO_C0_START + (_nr)) | ||
112 | #define EXYNOS4_GPC1(_nr) (EXYNOS4_GPIO_C1_START + (_nr)) | ||
113 | #define EXYNOS4_GPD0(_nr) (EXYNOS4_GPIO_D0_START + (_nr)) | ||
114 | #define EXYNOS4_GPD1(_nr) (EXYNOS4_GPIO_D1_START + (_nr)) | ||
115 | #define EXYNOS4_GPE0(_nr) (EXYNOS4_GPIO_E0_START + (_nr)) | ||
116 | #define EXYNOS4_GPE1(_nr) (EXYNOS4_GPIO_E1_START + (_nr)) | ||
117 | #define EXYNOS4_GPE2(_nr) (EXYNOS4_GPIO_E2_START + (_nr)) | ||
118 | #define EXYNOS4_GPE3(_nr) (EXYNOS4_GPIO_E3_START + (_nr)) | ||
119 | #define EXYNOS4_GPE4(_nr) (EXYNOS4_GPIO_E4_START + (_nr)) | ||
120 | #define EXYNOS4_GPF0(_nr) (EXYNOS4_GPIO_F0_START + (_nr)) | ||
121 | #define EXYNOS4_GPF1(_nr) (EXYNOS4_GPIO_F1_START + (_nr)) | ||
122 | #define EXYNOS4_GPF2(_nr) (EXYNOS4_GPIO_F2_START + (_nr)) | ||
123 | #define EXYNOS4_GPF3(_nr) (EXYNOS4_GPIO_F3_START + (_nr)) | ||
124 | #define EXYNOS4_GPJ0(_nr) (EXYNOS4_GPIO_J0_START + (_nr)) | ||
125 | #define EXYNOS4_GPJ1(_nr) (EXYNOS4_GPIO_J1_START + (_nr)) | ||
126 | #define EXYNOS4_GPK0(_nr) (EXYNOS4_GPIO_K0_START + (_nr)) | ||
127 | #define EXYNOS4_GPK1(_nr) (EXYNOS4_GPIO_K1_START + (_nr)) | ||
128 | #define EXYNOS4_GPK2(_nr) (EXYNOS4_GPIO_K2_START + (_nr)) | ||
129 | #define EXYNOS4_GPK3(_nr) (EXYNOS4_GPIO_K3_START + (_nr)) | ||
130 | #define EXYNOS4_GPL0(_nr) (EXYNOS4_GPIO_L0_START + (_nr)) | ||
131 | #define EXYNOS4_GPL1(_nr) (EXYNOS4_GPIO_L1_START + (_nr)) | ||
132 | #define EXYNOS4_GPL2(_nr) (EXYNOS4_GPIO_L2_START + (_nr)) | ||
133 | #define EXYNOS4_GPX0(_nr) (EXYNOS4_GPIO_X0_START + (_nr)) | ||
134 | #define EXYNOS4_GPX1(_nr) (EXYNOS4_GPIO_X1_START + (_nr)) | ||
135 | #define EXYNOS4_GPX2(_nr) (EXYNOS4_GPIO_X2_START + (_nr)) | ||
136 | #define EXYNOS4_GPX3(_nr) (EXYNOS4_GPIO_X3_START + (_nr)) | ||
137 | #define EXYNOS4_GPY0(_nr) (EXYNOS4_GPIO_Y0_START + (_nr)) | ||
138 | #define EXYNOS4_GPY1(_nr) (EXYNOS4_GPIO_Y1_START + (_nr)) | ||
139 | #define EXYNOS4_GPY2(_nr) (EXYNOS4_GPIO_Y2_START + (_nr)) | ||
140 | #define EXYNOS4_GPY3(_nr) (EXYNOS4_GPIO_Y3_START + (_nr)) | ||
141 | #define EXYNOS4_GPY4(_nr) (EXYNOS4_GPIO_Y4_START + (_nr)) | ||
142 | #define EXYNOS4_GPY5(_nr) (EXYNOS4_GPIO_Y5_START + (_nr)) | ||
143 | #define EXYNOS4_GPY6(_nr) (EXYNOS4_GPIO_Y6_START + (_nr)) | ||
144 | #define EXYNOS4_GPZ(_nr) (EXYNOS4_GPIO_Z_START + (_nr)) | ||
145 | |||
146 | /* the end of the EXYNOS4 specific gpios */ | ||
147 | #define EXYNOS4_GPIO_END (EXYNOS4_GPZ(EXYNOS4_GPIO_Z_NR) + 1) | ||
148 | #define S3C_GPIO_END EXYNOS4_GPIO_END | ||
149 | |||
150 | /* define the number of gpios we need to the one after the GPZ() range */ | ||
151 | #define ARCH_NR_GPIOS (EXYNOS4_GPZ(EXYNOS4_GPIO_Z_NR) + \ | ||
152 | CONFIG_SAMSUNG_GPIO_EXTRA + 1) | ||
153 | |||
154 | #include <asm-generic/gpio.h> | ||
155 | |||
156 | #endif /* __ASM_ARCH_GPIO_H */ | ||
diff --git a/arch/arm/mach-s5pv310/include/mach/hardware.h b/arch/arm/mach-exynos4/include/mach/hardware.h index 28ff9881f1a6..5109eb232f23 100644 --- a/arch/arm/mach-s5pv310/include/mach/hardware.h +++ b/arch/arm/mach-exynos4/include/mach/hardware.h | |||
@@ -1,9 +1,9 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/hardware.h | 1 | /* linux/arch/arm/mach-exynos4/include/mach/hardware.h |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * S5PV310 - Hardware support | 6 | * EXYNOS4 - Hardware support |
7 | * | 7 | * |
8 | * This program is free software; you can redistribute it and/or modify | 8 | * This program is free software; you can redistribute it and/or modify |
9 | * it under the terms of the GNU General Public License version 2 as | 9 | * it under the terms of the GNU General Public License version 2 as |
diff --git a/arch/arm/mach-s5pv310/include/mach/io.h b/arch/arm/mach-exynos4/include/mach/io.h index 8a7f9128391f..d5478d247535 100644 --- a/arch/arm/mach-s5pv310/include/mach/io.h +++ b/arch/arm/mach-exynos4/include/mach/io.h | |||
@@ -1,13 +1,13 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/io.h | 1 | /* linux/arch/arm/mach-exynos4/include/mach/io.h |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * Copyright 2008-2010 Ben Dooks <ben-linux@fluff.org> | 6 | * Copyright 2008-2010 Ben Dooks <ben-linux@fluff.org> |
7 | * | 7 | * |
8 | * Based on arch/arm/mach-s5p6442/include/mach/io.h | 8 | * Based on arch/arm/mach-s5p6442/include/mach/io.h |
9 | * | 9 | * |
10 | * Default IO routines for S5PV310 | 10 | * Default IO routines for EXYNOS4 |
11 | * | 11 | * |
12 | * This program is free software; you can redistribute it and/or modify | 12 | * This program is free software; you can redistribute it and/or modify |
13 | * it under the terms of the GNU General Public License version 2 as | 13 | * it under the terms of the GNU General Public License version 2 as |
diff --git a/arch/arm/mach-s5pv310/include/mach/irqs.h b/arch/arm/mach-exynos4/include/mach/irqs.h index 536b0b59fc83..5d037301d21a 100644 --- a/arch/arm/mach-s5pv310/include/mach/irqs.h +++ b/arch/arm/mach-exynos4/include/mach/irqs.h | |||
@@ -1,9 +1,9 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/irqs.h | 1 | /* linux/arch/arm/mach-exynos4/include/mach/irqs.h |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * S5PV310 - IRQ definitions | 6 | * EXYNOS4 - IRQ definitions |
7 | * | 7 | * |
8 | * This program is free software; you can redistribute it and/or modify | 8 | * This program is free software; you can redistribute it and/or modify |
9 | * it under the terms of the GNU General Public License version 2 as | 9 | * it under the terms of the GNU General Public License version 2 as |
@@ -85,6 +85,9 @@ | |||
85 | #define IRQ_RTC_ALARM COMBINER_IRQ(23, 0) | 85 | #define IRQ_RTC_ALARM COMBINER_IRQ(23, 0) |
86 | #define IRQ_RTC_TIC COMBINER_IRQ(23, 1) | 86 | #define IRQ_RTC_TIC COMBINER_IRQ(23, 1) |
87 | 87 | ||
88 | #define IRQ_GPIO_XB COMBINER_IRQ(24, 0) | ||
89 | #define IRQ_GPIO_XA COMBINER_IRQ(24, 1) | ||
90 | |||
88 | #define IRQ_UART0 COMBINER_IRQ(26, 0) | 91 | #define IRQ_UART0 COMBINER_IRQ(26, 0) |
89 | #define IRQ_UART1 COMBINER_IRQ(26, 1) | 92 | #define IRQ_UART1 COMBINER_IRQ(26, 1) |
90 | #define IRQ_UART2 COMBINER_IRQ(26, 2) | 93 | #define IRQ_UART2 COMBINER_IRQ(26, 2) |
@@ -108,6 +111,11 @@ | |||
108 | #define IRQ_MIPI_CSIS0 COMBINER_IRQ(30, 0) | 111 | #define IRQ_MIPI_CSIS0 COMBINER_IRQ(30, 0) |
109 | #define IRQ_MIPI_CSIS1 COMBINER_IRQ(30, 1) | 112 | #define IRQ_MIPI_CSIS1 COMBINER_IRQ(30, 1) |
110 | 113 | ||
114 | #define IRQ_FIMC0 COMBINER_IRQ(32, 0) | ||
115 | #define IRQ_FIMC1 COMBINER_IRQ(32, 1) | ||
116 | #define IRQ_FIMC2 COMBINER_IRQ(33, 0) | ||
117 | #define IRQ_FIMC3 COMBINER_IRQ(33, 1) | ||
118 | |||
111 | #define IRQ_ONENAND_AUDI COMBINER_IRQ(34, 0) | 119 | #define IRQ_ONENAND_AUDI COMBINER_IRQ(34, 0) |
112 | 120 | ||
113 | #define IRQ_MCT_L1 COMBINER_IRQ(35, 3) | 121 | #define IRQ_MCT_L1 COMBINER_IRQ(35, 3) |
@@ -131,6 +139,7 @@ | |||
131 | #define IRQ_MCT_L0 COMBINER_IRQ(51, 0) | 139 | #define IRQ_MCT_L0 COMBINER_IRQ(51, 0) |
132 | 140 | ||
133 | #define IRQ_WDT COMBINER_IRQ(53, 0) | 141 | #define IRQ_WDT COMBINER_IRQ(53, 0) |
142 | #define IRQ_MCT_G0 COMBINER_IRQ(53, 4) | ||
134 | 143 | ||
135 | #define MAX_COMBINER_NR 54 | 144 | #define MAX_COMBINER_NR 54 |
136 | 145 | ||
@@ -139,8 +148,13 @@ | |||
139 | #define S5P_EINT_BASE1 (S5P_IRQ_EINT_BASE + 0) | 148 | #define S5P_EINT_BASE1 (S5P_IRQ_EINT_BASE + 0) |
140 | #define S5P_EINT_BASE2 (S5P_IRQ_EINT_BASE + 16) | 149 | #define S5P_EINT_BASE2 (S5P_IRQ_EINT_BASE + 16) |
141 | 150 | ||
142 | /* Set the default NR_IRQS */ | 151 | /* optional GPIO interrupts */ |
152 | #define S5P_GPIOINT_BASE (S5P_IRQ_EINT_BASE + 32) | ||
153 | #define IRQ_GPIO1_NR_GROUPS 16 | ||
154 | #define IRQ_GPIO2_NR_GROUPS 9 | ||
155 | #define IRQ_GPIO_END (S5P_GPIOINT_BASE + S5P_GPIOINT_COUNT) | ||
143 | 156 | ||
144 | #define NR_IRQS (S5P_IRQ_EINT_BASE + 32) | 157 | /* Set the default NR_IRQS */ |
158 | #define NR_IRQS (IRQ_GPIO_END) | ||
145 | 159 | ||
146 | #endif /* __ASM_ARCH_IRQS_H */ | 160 | #endif /* __ASM_ARCH_IRQS_H */ |
diff --git a/arch/arm/mach-exynos4/include/mach/map.h b/arch/arm/mach-exynos4/include/mach/map.h new file mode 100644 index 000000000000..6330b73b9ea7 --- /dev/null +++ b/arch/arm/mach-exynos4/include/mach/map.h | |||
@@ -0,0 +1,162 @@ | |||
1 | /* linux/arch/arm/mach-exynos4/include/mach/map.h | ||
2 | * | ||
3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com/ | ||
5 | * | ||
6 | * EXYNOS4 - Memory map definitions | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __ASM_ARCH_MAP_H | ||
14 | #define __ASM_ARCH_MAP_H __FILE__ | ||
15 | |||
16 | #include <plat/map-base.h> | ||
17 | |||
18 | /* | ||
19 | * EXYNOS4 UART offset is 0x10000 but the older S5P SoCs are 0x400. | ||
20 | * So need to define it, and here is to avoid redefinition warning. | ||
21 | */ | ||
22 | #define S3C_UART_OFFSET (0x10000) | ||
23 | |||
24 | #include <plat/map-s5p.h> | ||
25 | |||
26 | #define EXYNOS4_PA_SYSRAM 0x02020000 | ||
27 | |||
28 | #define EXYNOS4_PA_FIMC0 0x11800000 | ||
29 | #define EXYNOS4_PA_FIMC1 0x11810000 | ||
30 | #define EXYNOS4_PA_FIMC2 0x11820000 | ||
31 | #define EXYNOS4_PA_FIMC3 0x11830000 | ||
32 | |||
33 | #define EXYNOS4_PA_I2S0 0x03830000 | ||
34 | #define EXYNOS4_PA_I2S1 0xE3100000 | ||
35 | #define EXYNOS4_PA_I2S2 0xE2A00000 | ||
36 | |||
37 | #define EXYNOS4_PA_PCM0 0x03840000 | ||
38 | #define EXYNOS4_PA_PCM1 0x13980000 | ||
39 | #define EXYNOS4_PA_PCM2 0x13990000 | ||
40 | |||
41 | #define EXYNOS4_PA_SROM_BANK(x) (0x04000000 + ((x) * 0x01000000)) | ||
42 | |||
43 | #define EXYNOS4_PA_ONENAND 0x0C000000 | ||
44 | #define EXYNOS4_PA_ONENAND_DMA 0x0C600000 | ||
45 | |||
46 | #define EXYNOS4_PA_CHIPID 0x10000000 | ||
47 | |||
48 | #define EXYNOS4_PA_SYSCON 0x10010000 | ||
49 | #define EXYNOS4_PA_PMU 0x10020000 | ||
50 | #define EXYNOS4_PA_CMU 0x10030000 | ||
51 | |||
52 | #define EXYNOS4_PA_SYSTIMER 0x10050000 | ||
53 | #define EXYNOS4_PA_WATCHDOG 0x10060000 | ||
54 | #define EXYNOS4_PA_RTC 0x10070000 | ||
55 | |||
56 | #define EXYNOS4_PA_KEYPAD 0x100A0000 | ||
57 | |||
58 | #define EXYNOS4_PA_DMC0 0x10400000 | ||
59 | |||
60 | #define EXYNOS4_PA_COMBINER 0x10448000 | ||
61 | |||
62 | #define EXYNOS4_PA_COREPERI 0x10500000 | ||
63 | #define EXYNOS4_PA_GIC_CPU 0x10500100 | ||
64 | #define EXYNOS4_PA_TWD 0x10500600 | ||
65 | #define EXYNOS4_PA_GIC_DIST 0x10501000 | ||
66 | #define EXYNOS4_PA_L2CC 0x10502000 | ||
67 | |||
68 | #define EXYNOS4_PA_MDMA 0x10810000 | ||
69 | #define EXYNOS4_PA_PDMA0 0x12680000 | ||
70 | #define EXYNOS4_PA_PDMA1 0x12690000 | ||
71 | |||
72 | #define EXYNOS4_PA_SYSMMU_MDMA 0x10A40000 | ||
73 | #define EXYNOS4_PA_SYSMMU_SSS 0x10A50000 | ||
74 | #define EXYNOS4_PA_SYSMMU_FIMC0 0x11A20000 | ||
75 | #define EXYNOS4_PA_SYSMMU_FIMC1 0x11A30000 | ||
76 | #define EXYNOS4_PA_SYSMMU_FIMC2 0x11A40000 | ||
77 | #define EXYNOS4_PA_SYSMMU_FIMC3 0x11A50000 | ||
78 | #define EXYNOS4_PA_SYSMMU_JPEG 0x11A60000 | ||
79 | #define EXYNOS4_PA_SYSMMU_FIMD0 0x11E20000 | ||
80 | #define EXYNOS4_PA_SYSMMU_FIMD1 0x12220000 | ||
81 | #define EXYNOS4_PA_SYSMMU_PCIe 0x12620000 | ||
82 | #define EXYNOS4_PA_SYSMMU_G2D 0x12A20000 | ||
83 | #define EXYNOS4_PA_SYSMMU_ROTATOR 0x12A30000 | ||
84 | #define EXYNOS4_PA_SYSMMU_MDMA2 0x12A40000 | ||
85 | #define EXYNOS4_PA_SYSMMU_TV 0x12E20000 | ||
86 | #define EXYNOS4_PA_SYSMMU_MFC_L 0x13620000 | ||
87 | #define EXYNOS4_PA_SYSMMU_MFC_R 0x13630000 | ||
88 | |||
89 | #define EXYNOS4_PA_GPIO1 0x11400000 | ||
90 | #define EXYNOS4_PA_GPIO2 0x11000000 | ||
91 | #define EXYNOS4_PA_GPIO3 0x03860000 | ||
92 | |||
93 | #define EXYNOS4_PA_MIPI_CSIS0 0x11880000 | ||
94 | #define EXYNOS4_PA_MIPI_CSIS1 0x11890000 | ||
95 | |||
96 | #define EXYNOS4_PA_HSMMC(x) (0x12510000 + ((x) * 0x10000)) | ||
97 | |||
98 | #define EXYNOS4_PA_SATA 0x12560000 | ||
99 | #define EXYNOS4_PA_SATAPHY 0x125D0000 | ||
100 | #define EXYNOS4_PA_SATAPHY_CTRL 0x126B0000 | ||
101 | |||
102 | #define EXYNOS4_PA_SROMC 0x12570000 | ||
103 | |||
104 | #define EXYNOS4_PA_UART 0x13800000 | ||
105 | |||
106 | #define EXYNOS4_PA_IIC(x) (0x13860000 + ((x) * 0x10000)) | ||
107 | |||
108 | #define EXYNOS4_PA_AC97 0x139A0000 | ||
109 | |||
110 | #define EXYNOS4_PA_SPDIF 0x139B0000 | ||
111 | |||
112 | #define EXYNOS4_PA_TIMER 0x139D0000 | ||
113 | |||
114 | #define EXYNOS4_PA_SDRAM 0x40000000 | ||
115 | |||
116 | /* Compatibiltiy Defines */ | ||
117 | |||
118 | #define S3C_PA_HSMMC0 EXYNOS4_PA_HSMMC(0) | ||
119 | #define S3C_PA_HSMMC1 EXYNOS4_PA_HSMMC(1) | ||
120 | #define S3C_PA_HSMMC2 EXYNOS4_PA_HSMMC(2) | ||
121 | #define S3C_PA_HSMMC3 EXYNOS4_PA_HSMMC(3) | ||
122 | #define S3C_PA_IIC EXYNOS4_PA_IIC(0) | ||
123 | #define S3C_PA_IIC1 EXYNOS4_PA_IIC(1) | ||
124 | #define S3C_PA_IIC2 EXYNOS4_PA_IIC(2) | ||
125 | #define S3C_PA_IIC3 EXYNOS4_PA_IIC(3) | ||
126 | #define S3C_PA_IIC4 EXYNOS4_PA_IIC(4) | ||
127 | #define S3C_PA_IIC5 EXYNOS4_PA_IIC(5) | ||
128 | #define S3C_PA_IIC6 EXYNOS4_PA_IIC(6) | ||
129 | #define S3C_PA_IIC7 EXYNOS4_PA_IIC(7) | ||
130 | #define S3C_PA_RTC EXYNOS4_PA_RTC | ||
131 | #define S3C_PA_WDT EXYNOS4_PA_WATCHDOG | ||
132 | |||
133 | #define S5P_PA_CHIPID EXYNOS4_PA_CHIPID | ||
134 | #define S5P_PA_FIMC0 EXYNOS4_PA_FIMC0 | ||
135 | #define S5P_PA_FIMC1 EXYNOS4_PA_FIMC1 | ||
136 | #define S5P_PA_FIMC2 EXYNOS4_PA_FIMC2 | ||
137 | #define S5P_PA_FIMC3 EXYNOS4_PA_FIMC3 | ||
138 | #define S5P_PA_MIPI_CSIS0 EXYNOS4_PA_MIPI_CSIS0 | ||
139 | #define S5P_PA_MIPI_CSIS1 EXYNOS4_PA_MIPI_CSIS1 | ||
140 | #define S5P_PA_ONENAND EXYNOS4_PA_ONENAND | ||
141 | #define S5P_PA_ONENAND_DMA EXYNOS4_PA_ONENAND_DMA | ||
142 | #define S5P_PA_SDRAM EXYNOS4_PA_SDRAM | ||
143 | #define S5P_PA_SROMC EXYNOS4_PA_SROMC | ||
144 | #define S5P_PA_SYSCON EXYNOS4_PA_SYSCON | ||
145 | #define S5P_PA_TIMER EXYNOS4_PA_TIMER | ||
146 | |||
147 | #define SAMSUNG_PA_KEYPAD EXYNOS4_PA_KEYPAD | ||
148 | |||
149 | /* UART */ | ||
150 | |||
151 | #define S3C_PA_UART EXYNOS4_PA_UART | ||
152 | |||
153 | #define S5P_PA_UART(x) (S3C_PA_UART + ((x) * S3C_UART_OFFSET)) | ||
154 | #define S5P_PA_UART0 S5P_PA_UART(0) | ||
155 | #define S5P_PA_UART1 S5P_PA_UART(1) | ||
156 | #define S5P_PA_UART2 S5P_PA_UART(2) | ||
157 | #define S5P_PA_UART3 S5P_PA_UART(3) | ||
158 | #define S5P_PA_UART4 S5P_PA_UART(4) | ||
159 | |||
160 | #define S5P_SZ_UART SZ_256 | ||
161 | |||
162 | #endif /* __ASM_ARCH_MAP_H */ | ||
diff --git a/arch/arm/mach-s5pv310/include/mach/memory.h b/arch/arm/mach-exynos4/include/mach/memory.h index 1dffb4823245..39b47d06f9bb 100644 --- a/arch/arm/mach-s5pv310/include/mach/memory.h +++ b/arch/arm/mach-exynos4/include/mach/memory.h | |||
@@ -1,9 +1,9 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/memory.h | 1 | /* linux/arch/arm/mach-exynos4/include/mach/memory.h |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * S5PV310 - Memory definitions | 6 | * EXYNOS4 - Memory definitions |
7 | * | 7 | * |
8 | * This program is free software; you can redistribute it and/or modify | 8 | * This program is free software; you can redistribute it and/or modify |
9 | * it under the terms of the GNU General Public License version 2 as | 9 | * it under the terms of the GNU General Public License version 2 as |
diff --git a/arch/arm/mach-exynos4/include/mach/pm-core.h b/arch/arm/mach-exynos4/include/mach/pm-core.h new file mode 100644 index 000000000000..f26e46bc06ca --- /dev/null +++ b/arch/arm/mach-exynos4/include/mach/pm-core.h | |||
@@ -0,0 +1,49 @@ | |||
1 | /* linux/arch/arm/mach-exynos4/include/mach/pm-core.h | ||
2 | * | ||
3 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * Based on arch/arm/mach-s3c2410/include/mach/pm-core.h, | ||
7 | * Copyright 2008 Simtec Electronics | ||
8 | * Ben Dooks <ben@simtec.co.uk> | ||
9 | * http://armlinux.simtec.co.uk/ | ||
10 | * | ||
11 | * EXYNOS4210 - PM core support for arch/arm/plat-s5p/pm.c | ||
12 | * | ||
13 | * This program is free software; you can redistribute it and/or modify | ||
14 | * it under the terms of the GNU General Public License version 2 as | ||
15 | * published by the Free Software Foundation. | ||
16 | */ | ||
17 | #include <mach/regs-pmu.h> | ||
18 | |||
19 | static inline void s3c_pm_debug_init_uart(void) | ||
20 | { | ||
21 | /* nothing here yet */ | ||
22 | } | ||
23 | |||
24 | static inline void s3c_pm_arch_prepare_irqs(void) | ||
25 | { | ||
26 | unsigned int tmp; | ||
27 | tmp = __raw_readl(S5P_WAKEUP_MASK); | ||
28 | tmp &= ~(1 << 31); | ||
29 | __raw_writel(tmp, S5P_WAKEUP_MASK); | ||
30 | |||
31 | __raw_writel(s3c_irqwake_intmask, S5P_WAKEUP_MASK); | ||
32 | __raw_writel(s3c_irqwake_eintmask, S5P_EINT_WAKEUP_MASK); | ||
33 | } | ||
34 | |||
35 | static inline void s3c_pm_arch_stop_clocks(void) | ||
36 | { | ||
37 | /* nothing here yet */ | ||
38 | } | ||
39 | |||
40 | static inline void s3c_pm_arch_show_resume_irqs(void) | ||
41 | { | ||
42 | /* nothing here yet */ | ||
43 | } | ||
44 | |||
45 | static inline void s3c_pm_arch_update_uart(void __iomem *regs, | ||
46 | struct pm_uart_save *save) | ||
47 | { | ||
48 | /* nothing here yet */ | ||
49 | } | ||
diff --git a/arch/arm/mach-s5pv310/include/mach/pwm-clock.h b/arch/arm/mach-exynos4/include/mach/pwm-clock.h index 7e6da2701088..8e12090287bb 100644 --- a/arch/arm/mach-s5pv310/include/mach/pwm-clock.h +++ b/arch/arm/mach-exynos4/include/mach/pwm-clock.h | |||
@@ -1,7 +1,7 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/pwm-clock.h | 1 | /* linux/arch/arm/mach-exynos4/include/mach/pwm-clock.h |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * Copyright 2008 Openmoko, Inc. | 6 | * Copyright 2008 Openmoko, Inc. |
7 | * Copyright 2008 Simtec Electronics | 7 | * Copyright 2008 Simtec Electronics |
@@ -10,7 +10,7 @@ | |||
10 | * | 10 | * |
11 | * Based on arch/arm/mach-s3c64xx/include/mach/pwm-clock.h | 11 | * Based on arch/arm/mach-s3c64xx/include/mach/pwm-clock.h |
12 | * | 12 | * |
13 | * S5PV310 - pwm clock and timer support | 13 | * EXYNOS4 - pwm clock and timer support |
14 | * | 14 | * |
15 | * This program is free software; you can redistribute it and/or modify | 15 | * This program is free software; you can redistribute it and/or modify |
16 | * it under the terms of the GNU General Public License version 2 as | 16 | * it under the terms of the GNU General Public License version 2 as |
diff --git a/arch/arm/mach-s5pv310/include/mach/regs-clock.h b/arch/arm/mach-exynos4/include/mach/regs-clock.h index b5c4ada1cff5..6e311c1157f5 100644 --- a/arch/arm/mach-s5pv310/include/mach/regs-clock.h +++ b/arch/arm/mach-exynos4/include/mach/regs-clock.h | |||
@@ -1,9 +1,9 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/regs-clock.h | 1 | /* linux/arch/arm/mach-exynos4/include/mach/regs-clock.h |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * S5PV310 - Clock register definitions | 6 | * EXYNOS4 - Clock register definitions |
7 | * | 7 | * |
8 | * This program is free software; you can redistribute it and/or modify | 8 | * This program is free software; you can redistribute it and/or modify |
9 | * it under the terms of the GNU General Public License version 2 as | 9 | * it under the terms of the GNU General Public License version 2 as |
@@ -17,13 +17,13 @@ | |||
17 | 17 | ||
18 | #define S5P_CLKREG(x) (S5P_VA_CMU + (x)) | 18 | #define S5P_CLKREG(x) (S5P_VA_CMU + (x)) |
19 | 19 | ||
20 | #define S5P_INFORM0 S5P_CLKREG(0x800) | ||
21 | |||
22 | #define S5P_CLKDIV_LEFTBUS S5P_CLKREG(0x04500) | 20 | #define S5P_CLKDIV_LEFTBUS S5P_CLKREG(0x04500) |
23 | #define S5P_CLKDIV_STAT_LEFTBUS S5P_CLKREG(0x04600) | 21 | #define S5P_CLKDIV_STAT_LEFTBUS S5P_CLKREG(0x04600) |
22 | #define S5P_CLKGATE_IP_LEFTBUS S5P_CLKREG(0x04800) | ||
24 | 23 | ||
25 | #define S5P_CLKDIV_RIGHTBUS S5P_CLKREG(0x08500) | 24 | #define S5P_CLKDIV_RIGHTBUS S5P_CLKREG(0x08500) |
26 | #define S5P_CLKDIV_STAT_RIGHTBUS S5P_CLKREG(0x08600) | 25 | #define S5P_CLKDIV_STAT_RIGHTBUS S5P_CLKREG(0x08600) |
26 | #define S5P_CLKGATE_IP_RIGHTBUS S5P_CLKREG(0x08800) | ||
27 | 27 | ||
28 | #define S5P_EPLL_CON0 S5P_CLKREG(0x0C110) | 28 | #define S5P_EPLL_CON0 S5P_CLKREG(0x0C110) |
29 | #define S5P_EPLL_CON1 S5P_CLKREG(0x0C114) | 29 | #define S5P_EPLL_CON1 S5P_CLKREG(0x0C114) |
@@ -33,18 +33,24 @@ | |||
33 | #define S5P_CLKSRC_TOP0 S5P_CLKREG(0x0C210) | 33 | #define S5P_CLKSRC_TOP0 S5P_CLKREG(0x0C210) |
34 | #define S5P_CLKSRC_TOP1 S5P_CLKREG(0x0C214) | 34 | #define S5P_CLKSRC_TOP1 S5P_CLKREG(0x0C214) |
35 | #define S5P_CLKSRC_CAM S5P_CLKREG(0x0C220) | 35 | #define S5P_CLKSRC_CAM S5P_CLKREG(0x0C220) |
36 | #define S5P_CLKSRC_MFC S5P_CLKREG(0x0C228) | ||
36 | #define S5P_CLKSRC_IMAGE S5P_CLKREG(0x0C230) | 37 | #define S5P_CLKSRC_IMAGE S5P_CLKREG(0x0C230) |
37 | #define S5P_CLKSRC_LCD0 S5P_CLKREG(0x0C234) | 38 | #define S5P_CLKSRC_LCD0 S5P_CLKREG(0x0C234) |
38 | #define S5P_CLKSRC_LCD1 S5P_CLKREG(0x0C238) | 39 | #define S5P_CLKSRC_LCD1 S5P_CLKREG(0x0C238) |
40 | #define S5P_CLKSRC_MAUDIO S5P_CLKREG(0x0C23C) | ||
39 | #define S5P_CLKSRC_FSYS S5P_CLKREG(0x0C240) | 41 | #define S5P_CLKSRC_FSYS S5P_CLKREG(0x0C240) |
40 | #define S5P_CLKSRC_PERIL0 S5P_CLKREG(0x0C250) | 42 | #define S5P_CLKSRC_PERIL0 S5P_CLKREG(0x0C250) |
41 | #define S5P_CLKSRC_PERIL1 S5P_CLKREG(0x0C254) | 43 | #define S5P_CLKSRC_PERIL1 S5P_CLKREG(0x0C254) |
42 | 44 | ||
43 | #define S5P_CLKDIV_TOP S5P_CLKREG(0x0C510) | 45 | #define S5P_CLKDIV_TOP S5P_CLKREG(0x0C510) |
44 | #define S5P_CLKDIV_CAM S5P_CLKREG(0x0C520) | 46 | #define S5P_CLKDIV_CAM S5P_CLKREG(0x0C520) |
47 | #define S5P_CLKDIV_TV S5P_CLKREG(0x0C524) | ||
48 | #define S5P_CLKDIV_MFC S5P_CLKREG(0x0C528) | ||
49 | #define S5P_CLKDIV_G3D S5P_CLKREG(0x0C52C) | ||
45 | #define S5P_CLKDIV_IMAGE S5P_CLKREG(0x0C530) | 50 | #define S5P_CLKDIV_IMAGE S5P_CLKREG(0x0C530) |
46 | #define S5P_CLKDIV_LCD0 S5P_CLKREG(0x0C534) | 51 | #define S5P_CLKDIV_LCD0 S5P_CLKREG(0x0C534) |
47 | #define S5P_CLKDIV_LCD1 S5P_CLKREG(0x0C538) | 52 | #define S5P_CLKDIV_LCD1 S5P_CLKREG(0x0C538) |
53 | #define S5P_CLKDIV_MAUDIO S5P_CLKREG(0x0C53C) | ||
48 | #define S5P_CLKDIV_FSYS0 S5P_CLKREG(0x0C540) | 54 | #define S5P_CLKDIV_FSYS0 S5P_CLKREG(0x0C540) |
49 | #define S5P_CLKDIV_FSYS1 S5P_CLKREG(0x0C544) | 55 | #define S5P_CLKDIV_FSYS1 S5P_CLKREG(0x0C544) |
50 | #define S5P_CLKDIV_FSYS2 S5P_CLKREG(0x0C548) | 56 | #define S5P_CLKDIV_FSYS2 S5P_CLKREG(0x0C548) |
@@ -58,25 +64,36 @@ | |||
58 | 64 | ||
59 | #define S5P_CLKSRC_MASK_TOP S5P_CLKREG(0x0C310) | 65 | #define S5P_CLKSRC_MASK_TOP S5P_CLKREG(0x0C310) |
60 | #define S5P_CLKSRC_MASK_CAM S5P_CLKREG(0x0C320) | 66 | #define S5P_CLKSRC_MASK_CAM S5P_CLKREG(0x0C320) |
67 | #define S5P_CLKSRC_MASK_TV S5P_CLKREG(0x0C324) | ||
61 | #define S5P_CLKSRC_MASK_LCD0 S5P_CLKREG(0x0C334) | 68 | #define S5P_CLKSRC_MASK_LCD0 S5P_CLKREG(0x0C334) |
62 | #define S5P_CLKSRC_MASK_LCD1 S5P_CLKREG(0x0C338) | 69 | #define S5P_CLKSRC_MASK_LCD1 S5P_CLKREG(0x0C338) |
70 | #define S5P_CLKSRC_MASK_MAUDIO S5P_CLKREG(0x0C33C) | ||
63 | #define S5P_CLKSRC_MASK_FSYS S5P_CLKREG(0x0C340) | 71 | #define S5P_CLKSRC_MASK_FSYS S5P_CLKREG(0x0C340) |
64 | #define S5P_CLKSRC_MASK_PERIL0 S5P_CLKREG(0x0C350) | 72 | #define S5P_CLKSRC_MASK_PERIL0 S5P_CLKREG(0x0C350) |
65 | #define S5P_CLKSRC_MASK_PERIL1 S5P_CLKREG(0x0C354) | 73 | #define S5P_CLKSRC_MASK_PERIL1 S5P_CLKREG(0x0C354) |
66 | 74 | ||
67 | #define S5P_CLKDIV_STAT_TOP S5P_CLKREG(0x0C610) | 75 | #define S5P_CLKDIV_STAT_TOP S5P_CLKREG(0x0C610) |
68 | 76 | ||
77 | #define S5P_CLKGATE_SCLKCAM S5P_CLKREG(0x0C820) | ||
69 | #define S5P_CLKGATE_IP_CAM S5P_CLKREG(0x0C920) | 78 | #define S5P_CLKGATE_IP_CAM S5P_CLKREG(0x0C920) |
79 | #define S5P_CLKGATE_IP_TV S5P_CLKREG(0x0C924) | ||
80 | #define S5P_CLKGATE_IP_MFC S5P_CLKREG(0x0C928) | ||
81 | #define S5P_CLKGATE_IP_G3D S5P_CLKREG(0x0C92C) | ||
70 | #define S5P_CLKGATE_IP_IMAGE S5P_CLKREG(0x0C930) | 82 | #define S5P_CLKGATE_IP_IMAGE S5P_CLKREG(0x0C930) |
71 | #define S5P_CLKGATE_IP_LCD0 S5P_CLKREG(0x0C934) | 83 | #define S5P_CLKGATE_IP_LCD0 S5P_CLKREG(0x0C934) |
72 | #define S5P_CLKGATE_IP_LCD1 S5P_CLKREG(0x0C938) | 84 | #define S5P_CLKGATE_IP_LCD1 S5P_CLKREG(0x0C938) |
73 | #define S5P_CLKGATE_IP_FSYS S5P_CLKREG(0x0C940) | 85 | #define S5P_CLKGATE_IP_FSYS S5P_CLKREG(0x0C940) |
86 | #define S5P_CLKGATE_IP_GPS S5P_CLKREG(0x0C94C) | ||
74 | #define S5P_CLKGATE_IP_PERIL S5P_CLKREG(0x0C950) | 87 | #define S5P_CLKGATE_IP_PERIL S5P_CLKREG(0x0C950) |
75 | #define S5P_CLKGATE_IP_PERIR S5P_CLKREG(0x0C960) | 88 | #define S5P_CLKGATE_IP_PERIR S5P_CLKREG(0x0C960) |
89 | #define S5P_CLKGATE_BLOCK S5P_CLKREG(0x0C970) | ||
76 | 90 | ||
91 | #define S5P_CLKSRC_MASK_DMC S5P_CLKREG(0x10300) | ||
77 | #define S5P_CLKSRC_DMC S5P_CLKREG(0x10200) | 92 | #define S5P_CLKSRC_DMC S5P_CLKREG(0x10200) |
78 | #define S5P_CLKDIV_DMC0 S5P_CLKREG(0x10500) | 93 | #define S5P_CLKDIV_DMC0 S5P_CLKREG(0x10500) |
94 | #define S5P_CLKDIV_DMC1 S5P_CLKREG(0x10504) | ||
79 | #define S5P_CLKDIV_STAT_DMC0 S5P_CLKREG(0x10600) | 95 | #define S5P_CLKDIV_STAT_DMC0 S5P_CLKREG(0x10600) |
96 | #define S5P_CLKGATE_IP_DMC S5P_CLKREG(0x10900) | ||
80 | 97 | ||
81 | #define S5P_APLL_LOCK S5P_CLKREG(0x14000) | 98 | #define S5P_APLL_LOCK S5P_CLKREG(0x14000) |
82 | #define S5P_MPLL_LOCK S5P_CLKREG(0x14004) | 99 | #define S5P_MPLL_LOCK S5P_CLKREG(0x14004) |
@@ -94,21 +111,18 @@ | |||
94 | #define S5P_CLKDIV_STATCPU1 S5P_CLKREG(0x14604) | 111 | #define S5P_CLKDIV_STATCPU1 S5P_CLKREG(0x14604) |
95 | 112 | ||
96 | #define S5P_CLKGATE_SCLKCPU S5P_CLKREG(0x14800) | 113 | #define S5P_CLKGATE_SCLKCPU S5P_CLKREG(0x14800) |
114 | #define S5P_CLKGATE_IP_CPU S5P_CLKREG(0x14900) | ||
97 | 115 | ||
98 | /* APLL_LOCK */ | ||
99 | #define S5P_APLL_LOCKTIME (0x1C20) /* 300us */ | 116 | #define S5P_APLL_LOCKTIME (0x1C20) /* 300us */ |
100 | 117 | ||
101 | /* APLL_CON0 */ | ||
102 | #define S5P_APLLCON0_ENABLE_SHIFT (31) | 118 | #define S5P_APLLCON0_ENABLE_SHIFT (31) |
103 | #define S5P_APLLCON0_LOCKED_SHIFT (29) | 119 | #define S5P_APLLCON0_LOCKED_SHIFT (29) |
104 | #define S5P_APLL_VAL_1000 ((250 << 16) | (6 << 8) | 1) | 120 | #define S5P_APLL_VAL_1000 ((250 << 16) | (6 << 8) | 1) |
105 | #define S5P_APLL_VAL_800 ((200 << 16) | (6 << 8) | 1) | 121 | #define S5P_APLL_VAL_800 ((200 << 16) | (6 << 8) | 1) |
106 | 122 | ||
107 | /* CLK_SRC_CPU */ | ||
108 | #define S5P_CLKSRC_CPU_MUXCORE_SHIFT (16) | 123 | #define S5P_CLKSRC_CPU_MUXCORE_SHIFT (16) |
109 | #define S5P_CLKMUX_STATCPU_MUXCORE_MASK (0x7 << S5P_CLKSRC_CPU_MUXCORE_SHIFT) | 124 | #define S5P_CLKMUX_STATCPU_MUXCORE_MASK (0x7 << S5P_CLKSRC_CPU_MUXCORE_SHIFT) |
110 | 125 | ||
111 | /* CLKDIV_CPU0 */ | ||
112 | #define S5P_CLKDIV_CPU0_CORE_SHIFT (0) | 126 | #define S5P_CLKDIV_CPU0_CORE_SHIFT (0) |
113 | #define S5P_CLKDIV_CPU0_CORE_MASK (0x7 << S5P_CLKDIV_CPU0_CORE_SHIFT) | 127 | #define S5P_CLKDIV_CPU0_CORE_MASK (0x7 << S5P_CLKDIV_CPU0_CORE_SHIFT) |
114 | #define S5P_CLKDIV_CPU0_COREM0_SHIFT (4) | 128 | #define S5P_CLKDIV_CPU0_COREM0_SHIFT (4) |
@@ -124,7 +138,6 @@ | |||
124 | #define S5P_CLKDIV_CPU0_APLL_SHIFT (24) | 138 | #define S5P_CLKDIV_CPU0_APLL_SHIFT (24) |
125 | #define S5P_CLKDIV_CPU0_APLL_MASK (0x7 << S5P_CLKDIV_CPU0_APLL_SHIFT) | 139 | #define S5P_CLKDIV_CPU0_APLL_MASK (0x7 << S5P_CLKDIV_CPU0_APLL_SHIFT) |
126 | 140 | ||
127 | /* CLKDIV_DMC0 */ | ||
128 | #define S5P_CLKDIV_DMC0_ACP_SHIFT (0) | 141 | #define S5P_CLKDIV_DMC0_ACP_SHIFT (0) |
129 | #define S5P_CLKDIV_DMC0_ACP_MASK (0x7 << S5P_CLKDIV_DMC0_ACP_SHIFT) | 142 | #define S5P_CLKDIV_DMC0_ACP_MASK (0x7 << S5P_CLKDIV_DMC0_ACP_SHIFT) |
130 | #define S5P_CLKDIV_DMC0_ACPPCLK_SHIFT (4) | 143 | #define S5P_CLKDIV_DMC0_ACPPCLK_SHIFT (4) |
@@ -142,7 +155,6 @@ | |||
142 | #define S5P_CLKDIV_DMC0_CORETI_SHIFT (28) | 155 | #define S5P_CLKDIV_DMC0_CORETI_SHIFT (28) |
143 | #define S5P_CLKDIV_DMC0_CORETI_MASK (0x7 << S5P_CLKDIV_DMC0_CORETI_SHIFT) | 156 | #define S5P_CLKDIV_DMC0_CORETI_MASK (0x7 << S5P_CLKDIV_DMC0_CORETI_SHIFT) |
144 | 157 | ||
145 | /* CLKDIV_TOP */ | ||
146 | #define S5P_CLKDIV_TOP_ACLK200_SHIFT (0) | 158 | #define S5P_CLKDIV_TOP_ACLK200_SHIFT (0) |
147 | #define S5P_CLKDIV_TOP_ACLK200_MASK (0x7 << S5P_CLKDIV_TOP_ACLK200_SHIFT) | 159 | #define S5P_CLKDIV_TOP_ACLK200_MASK (0x7 << S5P_CLKDIV_TOP_ACLK200_SHIFT) |
148 | #define S5P_CLKDIV_TOP_ACLK100_SHIFT (4) | 160 | #define S5P_CLKDIV_TOP_ACLK100_SHIFT (4) |
@@ -154,13 +166,14 @@ | |||
154 | #define S5P_CLKDIV_TOP_ONENAND_SHIFT (16) | 166 | #define S5P_CLKDIV_TOP_ONENAND_SHIFT (16) |
155 | #define S5P_CLKDIV_TOP_ONENAND_MASK (0x7 << S5P_CLKDIV_TOP_ONENAND_SHIFT) | 167 | #define S5P_CLKDIV_TOP_ONENAND_MASK (0x7 << S5P_CLKDIV_TOP_ONENAND_SHIFT) |
156 | 168 | ||
157 | /* CLKDIV_LEFTBUS / CLKDIV_RIGHTBUS*/ | ||
158 | #define S5P_CLKDIV_BUS_GDLR_SHIFT (0) | 169 | #define S5P_CLKDIV_BUS_GDLR_SHIFT (0) |
159 | #define S5P_CLKDIV_BUS_GDLR_MASK (0x7 << S5P_CLKDIV_BUS_GDLR_SHIFT) | 170 | #define S5P_CLKDIV_BUS_GDLR_MASK (0x7 << S5P_CLKDIV_BUS_GDLR_SHIFT) |
160 | #define S5P_CLKDIV_BUS_GPLR_SHIFT (4) | 171 | #define S5P_CLKDIV_BUS_GPLR_SHIFT (4) |
161 | #define S5P_CLKDIV_BUS_GPLR_MASK (0x7 << S5P_CLKDIV_BUS_GPLR_SHIFT) | 172 | #define S5P_CLKDIV_BUS_GPLR_MASK (0x7 << S5P_CLKDIV_BUS_GPLR_SHIFT) |
162 | 173 | ||
163 | /* Compatibility defines */ | 174 | /* Compatibility defines and inclusion */ |
175 | |||
176 | #include <mach/regs-pmu.h> | ||
164 | 177 | ||
165 | #define S5P_EPLL_CON S5P_EPLL_CON0 | 178 | #define S5P_EPLL_CON S5P_EPLL_CON0 |
166 | 179 | ||
diff --git a/arch/arm/mach-exynos4/include/mach/regs-gpio.h b/arch/arm/mach-exynos4/include/mach/regs-gpio.h new file mode 100644 index 000000000000..1401b21663a5 --- /dev/null +++ b/arch/arm/mach-exynos4/include/mach/regs-gpio.h | |||
@@ -0,0 +1,42 @@ | |||
1 | /* linux/arch/arm/mach-exynos4/include/mach/regs-gpio.h | ||
2 | * | ||
3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * EXYNOS4 - GPIO (including EINT) register definitions | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __ASM_ARCH_REGS_GPIO_H | ||
14 | #define __ASM_ARCH_REGS_GPIO_H __FILE__ | ||
15 | |||
16 | #include <mach/map.h> | ||
17 | #include <mach/irqs.h> | ||
18 | |||
19 | #define EXYNOS4_EINT40CON (S5P_VA_GPIO2 + 0xE00) | ||
20 | #define S5P_EINT_CON(x) (EXYNOS4_EINT40CON + ((x) * 0x4)) | ||
21 | |||
22 | #define EXYNOS4_EINT40FLTCON0 (S5P_VA_GPIO2 + 0xE80) | ||
23 | #define S5P_EINT_FLTCON(x) (EXYNOS4_EINT40FLTCON0 + ((x) * 0x4)) | ||
24 | |||
25 | #define EXYNOS4_EINT40MASK (S5P_VA_GPIO2 + 0xF00) | ||
26 | #define S5P_EINT_MASK(x) (EXYNOS4_EINT40MASK + ((x) * 0x4)) | ||
27 | |||
28 | #define EXYNOS4_EINT40PEND (S5P_VA_GPIO2 + 0xF40) | ||
29 | #define S5P_EINT_PEND(x) (EXYNOS4_EINT40PEND + ((x) * 0x4)) | ||
30 | |||
31 | #define EINT_REG_NR(x) (EINT_OFFSET(x) >> 3) | ||
32 | |||
33 | #define eint_irq_to_bit(irq) (1 << (EINT_OFFSET(irq) & 0x7)) | ||
34 | |||
35 | #define EINT_MODE S3C_GPIO_SFN(0xf) | ||
36 | |||
37 | #define EINT_GPIO_0(x) EXYNOS4_GPX0(x) | ||
38 | #define EINT_GPIO_1(x) EXYNOS4_GPX1(x) | ||
39 | #define EINT_GPIO_2(x) EXYNOS4_GPX2(x) | ||
40 | #define EINT_GPIO_3(x) EXYNOS4_GPX3(x) | ||
41 | |||
42 | #endif /* __ASM_ARCH_REGS_GPIO_H */ | ||
diff --git a/arch/arm/mach-s5pv310/include/mach/regs-irq.h b/arch/arm/mach-exynos4/include/mach/regs-irq.h index c6e09c7f9161..9c7b4bfd546f 100644 --- a/arch/arm/mach-s5pv310/include/mach/regs-irq.h +++ b/arch/arm/mach-exynos4/include/mach/regs-irq.h | |||
@@ -1,9 +1,9 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/regs-irq.h | 1 | /* linux/arch/arm/mach-exynos4/include/mach/regs-irq.h |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * S5PV310 - IRQ register definitions | 6 | * EXYNOS4 - IRQ register definitions |
7 | * | 7 | * |
8 | * This program is free software; you can redistribute it and/or modify | 8 | * This program is free software; you can redistribute it and/or modify |
9 | * it under the terms of the GNU General Public License version 2 as | 9 | * it under the terms of the GNU General Public License version 2 as |
diff --git a/arch/arm/mach-exynos4/include/mach/regs-mct.h b/arch/arm/mach-exynos4/include/mach/regs-mct.h new file mode 100644 index 000000000000..ca9c8434b023 --- /dev/null +++ b/arch/arm/mach-exynos4/include/mach/regs-mct.h | |||
@@ -0,0 +1,52 @@ | |||
1 | /* arch/arm/mach-exynos4/include/mach/regs-mct.h | ||
2 | * | ||
3 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * EXYNOS4 MCT configutation | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __ASM_ARCH_REGS_MCT_H | ||
14 | #define __ASM_ARCH_REGS_MCT_H __FILE__ | ||
15 | |||
16 | #include <mach/map.h> | ||
17 | |||
18 | #define EXYNOS4_MCTREG(x) (S5P_VA_SYSTIMER + (x)) | ||
19 | |||
20 | #define EXYNOS4_MCT_G_CNT_L EXYNOS4_MCTREG(0x100) | ||
21 | #define EXYNOS4_MCT_G_CNT_U EXYNOS4_MCTREG(0x104) | ||
22 | #define EXYNOS4_MCT_G_CNT_WSTAT EXYNOS4_MCTREG(0x110) | ||
23 | |||
24 | #define EXYNOS4_MCT_G_COMP0_L EXYNOS4_MCTREG(0x200) | ||
25 | #define EXYNOS4_MCT_G_COMP0_U EXYNOS4_MCTREG(0x204) | ||
26 | #define EXYNOS4_MCT_G_COMP0_ADD_INCR EXYNOS4_MCTREG(0x208) | ||
27 | |||
28 | #define EXYNOS4_MCT_G_TCON EXYNOS4_MCTREG(0x240) | ||
29 | |||
30 | #define EXYNOS4_MCT_G_INT_CSTAT EXYNOS4_MCTREG(0x244) | ||
31 | #define EXYNOS4_MCT_G_INT_ENB EXYNOS4_MCTREG(0x248) | ||
32 | #define EXYNOS4_MCT_G_WSTAT EXYNOS4_MCTREG(0x24C) | ||
33 | |||
34 | #define EXYNOS4_MCT_L0_BASE EXYNOS4_MCTREG(0x300) | ||
35 | #define EXYNOS4_MCT_L1_BASE EXYNOS4_MCTREG(0x400) | ||
36 | |||
37 | #define MCT_L_TCNTB_OFFSET (0x00) | ||
38 | #define MCT_L_ICNTB_OFFSET (0x08) | ||
39 | #define MCT_L_TCON_OFFSET (0x20) | ||
40 | #define MCT_L_INT_CSTAT_OFFSET (0x30) | ||
41 | #define MCT_L_INT_ENB_OFFSET (0x34) | ||
42 | #define MCT_L_WSTAT_OFFSET (0x40) | ||
43 | |||
44 | #define MCT_G_TCON_START (1 << 8) | ||
45 | #define MCT_G_TCON_COMP0_AUTO_INC (1 << 1) | ||
46 | #define MCT_G_TCON_COMP0_ENABLE (1 << 0) | ||
47 | |||
48 | #define MCT_L_TCON_INTERVAL_MODE (1 << 2) | ||
49 | #define MCT_L_TCON_INT_START (1 << 1) | ||
50 | #define MCT_L_TCON_TIMER_START (1 << 0) | ||
51 | |||
52 | #endif /* __ASM_ARCH_REGS_MCT_H */ | ||
diff --git a/arch/arm/mach-s5pv310/include/mach/regs-mem.h b/arch/arm/mach-exynos4/include/mach/regs-mem.h index 834227140eaa..0368b5a27252 100644 --- a/arch/arm/mach-s5pv310/include/mach/regs-mem.h +++ b/arch/arm/mach-exynos4/include/mach/regs-mem.h | |||
@@ -1,9 +1,9 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/regs-mem.h | 1 | /* linux/arch/arm/mach-exynos4/include/mach/regs-mem.h |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * S5PV310 - SROMC and DMC register definitions | 6 | * EXYNOS4 - SROMC and DMC register definitions |
7 | * | 7 | * |
8 | * This program is free software; you can redistribute it and/or modify | 8 | * This program is free software; you can redistribute it and/or modify |
9 | * it under the terms of the GNU General Public License version 2 as | 9 | * it under the terms of the GNU General Public License version 2 as |
diff --git a/arch/arm/mach-exynos4/include/mach/regs-pmu.h b/arch/arm/mach-exynos4/include/mach/regs-pmu.h new file mode 100644 index 000000000000..62b0014d05e0 --- /dev/null +++ b/arch/arm/mach-exynos4/include/mach/regs-pmu.h | |||
@@ -0,0 +1,162 @@ | |||
1 | /* linux/arch/arm/mach-exynos4/include/mach/regs-pmu.h | ||
2 | * | ||
3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * EXYNOS4 - Power management unit definition | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __ASM_ARCH_REGS_PMU_H | ||
14 | #define __ASM_ARCH_REGS_PMU_H __FILE__ | ||
15 | |||
16 | #include <mach/map.h> | ||
17 | |||
18 | #define S5P_PMUREG(x) (S5P_VA_PMU + (x)) | ||
19 | |||
20 | #define S5P_CENTRAL_SEQ_CONFIGURATION S5P_PMUREG(0x0200) | ||
21 | |||
22 | #define S5P_CENTRAL_LOWPWR_CFG (1 << 16) | ||
23 | |||
24 | #define S5P_CENTRAL_SEQ_OPTION S5P_PMUREG(0x0208) | ||
25 | |||
26 | #define S5P_USE_STANDBY_WFI0 (1 << 16) | ||
27 | #define S5P_USE_STANDBY_WFI1 (1 << 17) | ||
28 | #define S5P_USE_STANDBY_WFE0 (1 << 24) | ||
29 | #define S5P_USE_STANDBY_WFE1 (1 << 25) | ||
30 | #define S5P_USE_MASK ((0x3 << 16) | (0x3 << 24)) | ||
31 | |||
32 | #define S5P_WAKEUP_STAT S5P_PMUREG(0x0600) | ||
33 | #define S5P_EINT_WAKEUP_MASK S5P_PMUREG(0x0604) | ||
34 | #define S5P_WAKEUP_MASK S5P_PMUREG(0x0608) | ||
35 | |||
36 | #define S5P_MIPI_DPHY_CONTROL(n) S5P_PMUREG(0x0710 + (n) * 4) | ||
37 | #define S5P_MIPI_DPHY_ENABLE (1 << 0) | ||
38 | #define S5P_MIPI_DPHY_SRESETN (1 << 1) | ||
39 | #define S5P_MIPI_DPHY_MRESETN (1 << 2) | ||
40 | |||
41 | #define S5P_PMU_SATA_PHY_CONTROL S5P_PMUREG(0x0720) | ||
42 | #define S5P_INFORM0 S5P_PMUREG(0x0800) | ||
43 | #define S5P_INFORM1 S5P_PMUREG(0x0804) | ||
44 | #define S5P_INFORM2 S5P_PMUREG(0x0808) | ||
45 | #define S5P_INFORM3 S5P_PMUREG(0x080C) | ||
46 | #define S5P_INFORM4 S5P_PMUREG(0x0810) | ||
47 | #define S5P_INFORM5 S5P_PMUREG(0x0814) | ||
48 | #define S5P_INFORM6 S5P_PMUREG(0x0818) | ||
49 | #define S5P_INFORM7 S5P_PMUREG(0x081C) | ||
50 | |||
51 | #define S5P_ARM_CORE0_LOWPWR S5P_PMUREG(0x1000) | ||
52 | #define S5P_DIS_IRQ_CORE0 S5P_PMUREG(0x1004) | ||
53 | #define S5P_DIS_IRQ_CENTRAL0 S5P_PMUREG(0x1008) | ||
54 | #define S5P_ARM_CORE1_LOWPWR S5P_PMUREG(0x1010) | ||
55 | #define S5P_DIS_IRQ_CORE1 S5P_PMUREG(0x1014) | ||
56 | #define S5P_DIS_IRQ_CENTRAL1 S5P_PMUREG(0x1018) | ||
57 | #define S5P_ARM_COMMON_LOWPWR S5P_PMUREG(0x1080) | ||
58 | #define S5P_L2_0_LOWPWR S5P_PMUREG(0x10C0) | ||
59 | #define S5P_L2_1_LOWPWR S5P_PMUREG(0x10C4) | ||
60 | #define S5P_CMU_ACLKSTOP_LOWPWR S5P_PMUREG(0x1100) | ||
61 | #define S5P_CMU_SCLKSTOP_LOWPWR S5P_PMUREG(0x1104) | ||
62 | #define S5P_CMU_RESET_LOWPWR S5P_PMUREG(0x110C) | ||
63 | #define S5P_APLL_SYSCLK_LOWPWR S5P_PMUREG(0x1120) | ||
64 | #define S5P_MPLL_SYSCLK_LOWPWR S5P_PMUREG(0x1124) | ||
65 | #define S5P_VPLL_SYSCLK_LOWPWR S5P_PMUREG(0x1128) | ||
66 | #define S5P_EPLL_SYSCLK_LOWPWR S5P_PMUREG(0x112C) | ||
67 | #define S5P_CMU_CLKSTOP_GPS_ALIVE_LOWPWR S5P_PMUREG(0x1138) | ||
68 | #define S5P_CMU_RESET_GPSALIVE_LOWPWR S5P_PMUREG(0x113C) | ||
69 | #define S5P_CMU_CLKSTOP_CAM_LOWPWR S5P_PMUREG(0x1140) | ||
70 | #define S5P_CMU_CLKSTOP_TV_LOWPWR S5P_PMUREG(0x1144) | ||
71 | #define S5P_CMU_CLKSTOP_MFC_LOWPWR S5P_PMUREG(0x1148) | ||
72 | #define S5P_CMU_CLKSTOP_G3D_LOWPWR S5P_PMUREG(0x114C) | ||
73 | #define S5P_CMU_CLKSTOP_LCD0_LOWPWR S5P_PMUREG(0x1150) | ||
74 | #define S5P_CMU_CLKSTOP_LCD1_LOWPWR S5P_PMUREG(0x1154) | ||
75 | #define S5P_CMU_CLKSTOP_MAUDIO_LOWPWR S5P_PMUREG(0x1158) | ||
76 | #define S5P_CMU_CLKSTOP_GPS_LOWPWR S5P_PMUREG(0x115C) | ||
77 | #define S5P_CMU_RESET_CAM_LOWPWR S5P_PMUREG(0x1160) | ||
78 | #define S5P_CMU_RESET_TV_LOWPWR S5P_PMUREG(0x1164) | ||
79 | #define S5P_CMU_RESET_MFC_LOWPWR S5P_PMUREG(0x1168) | ||
80 | #define S5P_CMU_RESET_G3D_LOWPWR S5P_PMUREG(0x116C) | ||
81 | #define S5P_CMU_RESET_LCD0_LOWPWR S5P_PMUREG(0x1170) | ||
82 | #define S5P_CMU_RESET_LCD1_LOWPWR S5P_PMUREG(0x1174) | ||
83 | #define S5P_CMU_RESET_MAUDIO_LOWPWR S5P_PMUREG(0x1178) | ||
84 | #define S5P_CMU_RESET_GPS_LOWPWR S5P_PMUREG(0x117C) | ||
85 | #define S5P_TOP_BUS_LOWPWR S5P_PMUREG(0x1180) | ||
86 | #define S5P_TOP_RETENTION_LOWPWR S5P_PMUREG(0x1184) | ||
87 | #define S5P_TOP_PWR_LOWPWR S5P_PMUREG(0x1188) | ||
88 | #define S5P_LOGIC_RESET_LOWPWR S5P_PMUREG(0x11A0) | ||
89 | #define S5P_ONENAND_MEM_LOWPWR S5P_PMUREG(0x11C0) | ||
90 | #define S5P_MODIMIF_MEM_LOWPWR S5P_PMUREG(0x11C4) | ||
91 | #define S5P_G2D_ACP_MEM_LOWPWR S5P_PMUREG(0x11C8) | ||
92 | #define S5P_USBOTG_MEM_LOWPWR S5P_PMUREG(0x11CC) | ||
93 | #define S5P_HSMMC_MEM_LOWPWR S5P_PMUREG(0x11D0) | ||
94 | #define S5P_CSSYS_MEM_LOWPWR S5P_PMUREG(0x11D4) | ||
95 | #define S5P_SECSS_MEM_LOWPWR S5P_PMUREG(0x11D8) | ||
96 | #define S5P_PCIE_MEM_LOWPWR S5P_PMUREG(0x11E0) | ||
97 | #define S5P_SATA_MEM_LOWPWR S5P_PMUREG(0x11E4) | ||
98 | #define S5P_PAD_RETENTION_DRAM_LOWPWR S5P_PMUREG(0x1200) | ||
99 | #define S5P_PAD_RETENTION_MAUDIO_LOWPWR S5P_PMUREG(0x1204) | ||
100 | #define S5P_PAD_RETENTION_GPIO_LOWPWR S5P_PMUREG(0x1220) | ||
101 | #define S5P_PAD_RETENTION_UART_LOWPWR S5P_PMUREG(0x1224) | ||
102 | #define S5P_PAD_RETENTION_MMCA_LOWPWR S5P_PMUREG(0x1228) | ||
103 | #define S5P_PAD_RETENTION_MMCB_LOWPWR S5P_PMUREG(0x122C) | ||
104 | #define S5P_PAD_RETENTION_EBIA_LOWPWR S5P_PMUREG(0x1230) | ||
105 | #define S5P_PAD_RETENTION_EBIB_LOWPWR S5P_PMUREG(0x1234) | ||
106 | #define S5P_PAD_RETENTION_ISOLATION_LOWPWR S5P_PMUREG(0x1240) | ||
107 | #define S5P_PAD_RETENTION_ALV_SEL_LOWPWR S5P_PMUREG(0x1260) | ||
108 | #define S5P_XUSBXTI_LOWPWR S5P_PMUREG(0x1280) | ||
109 | #define S5P_XXTI_LOWPWR S5P_PMUREG(0x1284) | ||
110 | #define S5P_EXT_REGULATOR_LOWPWR S5P_PMUREG(0x12C0) | ||
111 | #define S5P_GPIO_MODE_LOWPWR S5P_PMUREG(0x1300) | ||
112 | #define S5P_GPIO_MODE_MAUDIO_LOWPWR S5P_PMUREG(0x1340) | ||
113 | #define S5P_CAM_LOWPWR S5P_PMUREG(0x1380) | ||
114 | #define S5P_TV_LOWPWR S5P_PMUREG(0x1384) | ||
115 | #define S5P_MFC_LOWPWR S5P_PMUREG(0x1388) | ||
116 | #define S5P_G3D_LOWPWR S5P_PMUREG(0x138C) | ||
117 | #define S5P_LCD0_LOWPWR S5P_PMUREG(0x1390) | ||
118 | #define S5P_LCD1_LOWPWR S5P_PMUREG(0x1394) | ||
119 | #define S5P_MAUDIO_LOWPWR S5P_PMUREG(0x1398) | ||
120 | #define S5P_GPS_LOWPWR S5P_PMUREG(0x139C) | ||
121 | #define S5P_GPS_ALIVE_LOWPWR S5P_PMUREG(0x13A0) | ||
122 | |||
123 | #define S5P_ARM_CORE0_CONFIGURATION S5P_PMUREG(0x2000) | ||
124 | #define S5P_ARM_CORE0_OPTION S5P_PMUREG(0x2008) | ||
125 | #define S5P_ARM_CORE1_CONFIGURATION S5P_PMUREG(0x2080) | ||
126 | #define S5P_ARM_CORE1_STATUS S5P_PMUREG(0x2084) | ||
127 | #define S5P_ARM_CORE1_OPTION S5P_PMUREG(0x2088) | ||
128 | |||
129 | #define S5P_ARM_COMMON_OPTION S5P_PMUREG(0x2408) | ||
130 | #define S5P_TOP_PWR_OPTION S5P_PMUREG(0x2C48) | ||
131 | #define S5P_CAM_OPTION S5P_PMUREG(0x3C08) | ||
132 | #define S5P_TV_OPTION S5P_PMUREG(0x3C28) | ||
133 | #define S5P_MFC_OPTION S5P_PMUREG(0x3C48) | ||
134 | #define S5P_G3D_OPTION S5P_PMUREG(0x3C68) | ||
135 | #define S5P_LCD0_OPTION S5P_PMUREG(0x3C88) | ||
136 | #define S5P_LCD1_OPTION S5P_PMUREG(0x3CA8) | ||
137 | #define S5P_MAUDIO_OPTION S5P_PMUREG(0x3CC8) | ||
138 | #define S5P_GPS_OPTION S5P_PMUREG(0x3CE8) | ||
139 | #define S5P_GPS_ALIVE_OPTION S5P_PMUREG(0x3D08) | ||
140 | |||
141 | #define S5P_PAD_RET_MAUDIO_OPTION S5P_PMUREG(0x3028) | ||
142 | #define S5P_PAD_RET_GPIO_OPTION S5P_PMUREG(0x3108) | ||
143 | #define S5P_PAD_RET_UART_OPTION S5P_PMUREG(0x3128) | ||
144 | #define S5P_PAD_RET_MMCA_OPTION S5P_PMUREG(0x3148) | ||
145 | #define S5P_PAD_RET_MMCB_OPTION S5P_PMUREG(0x3168) | ||
146 | #define S5P_PAD_RET_EBIA_OPTION S5P_PMUREG(0x3188) | ||
147 | #define S5P_PAD_RET_EBIB_OPTION S5P_PMUREG(0x31A8) | ||
148 | |||
149 | #define S5P_PMU_CAM_CONF S5P_PMUREG(0x3C00) | ||
150 | #define S5P_PMU_TV_CONF S5P_PMUREG(0x3C20) | ||
151 | #define S5P_PMU_MFC_CONF S5P_PMUREG(0x3C40) | ||
152 | #define S5P_PMU_G3D_CONF S5P_PMUREG(0x3C60) | ||
153 | #define S5P_PMU_LCD0_CONF S5P_PMUREG(0x3C80) | ||
154 | #define S5P_PMU_LCD1_CONF S5P_PMUREG(0x3CA0) | ||
155 | #define S5P_PMU_GPS_CONF S5P_PMUREG(0x3CE0) | ||
156 | |||
157 | #define S5P_PMU_SATA_PHY_CONTROL_EN 0x1 | ||
158 | #define S5P_INT_LOCAL_PWR_EN 0x7 | ||
159 | |||
160 | #define S5P_CHECK_SLEEP 0x00000BAD | ||
161 | |||
162 | #endif /* __ASM_ARCH_REGS_PMU_H */ | ||
diff --git a/arch/arm/mach-s5pv310/include/mach/regs-sysmmu.h b/arch/arm/mach-exynos4/include/mach/regs-sysmmu.h index 0b28e81a16f7..68ff6ad08a2b 100644 --- a/arch/arm/mach-s5pv310/include/mach/regs-sysmmu.h +++ b/arch/arm/mach-exynos4/include/mach/regs-sysmmu.h | |||
@@ -1,9 +1,9 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/regs-sysmmu.h | 1 | /* linux/arch/arm/mach-exynos4/include/mach/regs-sysmmu.h |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * S5PV310 - System MMU register | 6 | * EXYNOS4 - System MMU register |
7 | * | 7 | * |
8 | * This program is free software; you can redistribute it and/or modify | 8 | * This program is free software; you can redistribute it and/or modify |
9 | * it under the terms of the GNU General Public License version 2 as | 9 | * it under the terms of the GNU General Public License version 2 as |
@@ -19,6 +19,10 @@ | |||
19 | #define S5P_MMU_FLUSH 0x00C | 19 | #define S5P_MMU_FLUSH 0x00C |
20 | #define S5P_PT_BASE_ADDR 0x014 | 20 | #define S5P_PT_BASE_ADDR 0x014 |
21 | #define S5P_INT_STATUS 0x018 | 21 | #define S5P_INT_STATUS 0x018 |
22 | #define S5P_INT_CLEAR 0x01C | ||
22 | #define S5P_PAGE_FAULT_ADDR 0x024 | 23 | #define S5P_PAGE_FAULT_ADDR 0x024 |
24 | #define S5P_AW_FAULT_ADDR 0x028 | ||
25 | #define S5P_AR_FAULT_ADDR 0x02C | ||
26 | #define S5P_DEFAULT_SLAVE_ADDR 0x030 | ||
23 | 27 | ||
24 | #endif /* __ASM_ARCH_REGS_SYSMMU_H */ | 28 | #endif /* __ASM_ARCH_REGS_SYSMMU_H */ |
diff --git a/arch/arm/mach-s5pv310/include/mach/smp.h b/arch/arm/mach-exynos4/include/mach/smp.h index 393ccbd52c4a..a463dcebcfd3 100644 --- a/arch/arm/mach-s5pv310/include/mach/smp.h +++ b/arch/arm/mach-exynos4/include/mach/smp.h | |||
@@ -1,4 +1,4 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/smp.h | 1 | /* linux/arch/arm/mach-exynos4/include/mach/smp.h |
2 | * | 2 | * |
3 | * Cloned from arch/arm/mach-realview/include/mach/smp.h | 3 | * Cloned from arch/arm/mach-realview/include/mach/smp.h |
4 | */ | 4 | */ |
diff --git a/arch/arm/mach-exynos4/include/mach/sysmmu.h b/arch/arm/mach-exynos4/include/mach/sysmmu.h new file mode 100644 index 000000000000..6a5fbb534e82 --- /dev/null +++ b/arch/arm/mach-exynos4/include/mach/sysmmu.h | |||
@@ -0,0 +1,46 @@ | |||
1 | /* linux/arch/arm/mach-exynos4/include/mach/sysmmu.h | ||
2 | * | ||
3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * Samsung sysmmu driver for EXYNOS4 | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __ASM_ARM_ARCH_SYSMMU_H | ||
14 | #define __ASM_ARM_ARCH_SYSMMU_H __FILE__ | ||
15 | |||
16 | enum exynos4_sysmmu_ips { | ||
17 | SYSMMU_MDMA, | ||
18 | SYSMMU_SSS, | ||
19 | SYSMMU_FIMC0, | ||
20 | SYSMMU_FIMC1, | ||
21 | SYSMMU_FIMC2, | ||
22 | SYSMMU_FIMC3, | ||
23 | SYSMMU_JPEG, | ||
24 | SYSMMU_FIMD0, | ||
25 | SYSMMU_FIMD1, | ||
26 | SYSMMU_PCIe, | ||
27 | SYSMMU_G2D, | ||
28 | SYSMMU_ROTATOR, | ||
29 | SYSMMU_MDMA2, | ||
30 | SYSMMU_TV, | ||
31 | SYSMMU_MFC_L, | ||
32 | SYSMMU_MFC_R, | ||
33 | EXYNOS4_SYSMMU_TOTAL_IPNUM, | ||
34 | }; | ||
35 | |||
36 | #define S5P_SYSMMU_TOTAL_IPNUM EXYNOS4_SYSMMU_TOTAL_IPNUM | ||
37 | |||
38 | extern const char *sysmmu_ips_name[EXYNOS4_SYSMMU_TOTAL_IPNUM]; | ||
39 | |||
40 | typedef enum exynos4_sysmmu_ips sysmmu_ips; | ||
41 | |||
42 | void sysmmu_clk_init(struct device *dev, sysmmu_ips ips); | ||
43 | void sysmmu_clk_enable(sysmmu_ips ips); | ||
44 | void sysmmu_clk_disable(sysmmu_ips ips); | ||
45 | |||
46 | #endif /* __ASM_ARM_ARCH_SYSMMU_H */ | ||
diff --git a/arch/arm/mach-s5pv310/include/mach/system.h b/arch/arm/mach-exynos4/include/mach/system.h index d10c009cf0f1..5e3220c18fc7 100644 --- a/arch/arm/mach-s5pv310/include/mach/system.h +++ b/arch/arm/mach-exynos4/include/mach/system.h | |||
@@ -1,9 +1,9 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/system.h | 1 | /* linux/arch/arm/mach-exynos4/include/mach/system.h |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * S5PV310 - system support header | 6 | * EXYNOS4 - system support header |
7 | * | 7 | * |
8 | * This program is free software; you can redistribute it and/or modify | 8 | * This program is free software; you can redistribute it and/or modify |
9 | * it under the terms of the GNU General Public License version 2 as | 9 | * it under the terms of the GNU General Public License version 2 as |
diff --git a/arch/arm/mach-s5pv310/include/mach/timex.h b/arch/arm/mach-exynos4/include/mach/timex.h index bd2359b952b4..6d138750a708 100644 --- a/arch/arm/mach-s5pv310/include/mach/timex.h +++ b/arch/arm/mach-exynos4/include/mach/timex.h | |||
@@ -1,14 +1,14 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/timex.h | 1 | /* linux/arch/arm/mach-exynos4/include/mach/timex.h |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * Copyright (c) 2003-2010 Simtec Electronics | 6 | * Copyright (c) 2003-2010 Simtec Electronics |
7 | * Ben Dooks <ben@simtec.co.uk> | 7 | * Ben Dooks <ben@simtec.co.uk> |
8 | * | 8 | * |
9 | * Based on arch/arm/mach-s5p6442/include/mach/timex.h | 9 | * Based on arch/arm/mach-s5p6442/include/mach/timex.h |
10 | * | 10 | * |
11 | * S5PV310 - time parameters | 11 | * EXYNOS4 - time parameters |
12 | * | 12 | * |
13 | * This program is free software; you can redistribute it and/or modify | 13 | * This program is free software; you can redistribute it and/or modify |
14 | * it under the terms of the GNU General Public License version 2 as | 14 | * it under the terms of the GNU General Public License version 2 as |
diff --git a/arch/arm/mach-s5pv310/include/mach/uncompress.h b/arch/arm/mach-exynos4/include/mach/uncompress.h index 59593c1e2416..21d97bcd9acb 100644 --- a/arch/arm/mach-s5pv310/include/mach/uncompress.h +++ b/arch/arm/mach-exynos4/include/mach/uncompress.h | |||
@@ -1,9 +1,9 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/uncompress.h | 1 | /* linux/arch/arm/mach-exynos4/include/mach/uncompress.h |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * S5PV310 - uncompress code | 6 | * EXYNOS4 - uncompress code |
7 | * | 7 | * |
8 | * This program is free software; you can redistribute it and/or modify | 8 | * This program is free software; you can redistribute it and/or modify |
9 | * it under the terms of the GNU General Public License version 2 as | 9 | * it under the terms of the GNU General Public License version 2 as |
diff --git a/arch/arm/mach-s5pv310/include/mach/vmalloc.h b/arch/arm/mach-exynos4/include/mach/vmalloc.h index 65759fb97581..284330e571d2 100644 --- a/arch/arm/mach-s5pv310/include/mach/vmalloc.h +++ b/arch/arm/mach-exynos4/include/mach/vmalloc.h | |||
@@ -1,7 +1,7 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/vmalloc.h | 1 | /* linux/arch/arm/mach-exynos4/include/mach/vmalloc.h |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * Copyright 2010 Ben Dooks <ben-linux@fluff.org> | 6 | * Copyright 2010 Ben Dooks <ben-linux@fluff.org> |
7 | * | 7 | * |
@@ -11,7 +11,7 @@ | |||
11 | * it under the terms of the GNU General Public License version 2 as | 11 | * it under the terms of the GNU General Public License version 2 as |
12 | * published by the Free Software Foundation. | 12 | * published by the Free Software Foundation. |
13 | * | 13 | * |
14 | * S5PV310 vmalloc definition | 14 | * EXYNOS4 vmalloc definition |
15 | */ | 15 | */ |
16 | 16 | ||
17 | #ifndef __ASM_ARCH_VMALLOC_H | 17 | #ifndef __ASM_ARCH_VMALLOC_H |
diff --git a/arch/arm/mach-s5pv310/init.c b/arch/arm/mach-exynos4/init.c index 182dcf42cfb4..cf91f50e43ab 100644 --- a/arch/arm/mach-s5pv310/init.c +++ b/arch/arm/mach-exynos4/init.c | |||
@@ -1,4 +1,4 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/init.c | 1 | /* linux/arch/arm/mach-exynos4/init.c |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com/ |
@@ -14,7 +14,7 @@ | |||
14 | #include <plat/devs.h> | 14 | #include <plat/devs.h> |
15 | #include <plat/regs-serial.h> | 15 | #include <plat/regs-serial.h> |
16 | 16 | ||
17 | static struct s3c24xx_uart_clksrc s5pv310_serial_clocks[] = { | 17 | static struct s3c24xx_uart_clksrc exynos4_serial_clocks[] = { |
18 | [0] = { | 18 | [0] = { |
19 | .name = "uclk1", | 19 | .name = "uclk1", |
20 | .divisor = 1, | 20 | .divisor = 1, |
@@ -24,7 +24,7 @@ static struct s3c24xx_uart_clksrc s5pv310_serial_clocks[] = { | |||
24 | }; | 24 | }; |
25 | 25 | ||
26 | /* uart registration process */ | 26 | /* uart registration process */ |
27 | void __init s5pv310_common_init_uarts(struct s3c2410_uartcfg *cfg, int no) | 27 | void __init exynos4_common_init_uarts(struct s3c2410_uartcfg *cfg, int no) |
28 | { | 28 | { |
29 | struct s3c2410_uartcfg *tcfg = cfg; | 29 | struct s3c2410_uartcfg *tcfg = cfg; |
30 | u32 ucnt; | 30 | u32 ucnt; |
@@ -32,8 +32,8 @@ void __init s5pv310_common_init_uarts(struct s3c2410_uartcfg *cfg, int no) | |||
32 | for (ucnt = 0; ucnt < no; ucnt++, tcfg++) { | 32 | for (ucnt = 0; ucnt < no; ucnt++, tcfg++) { |
33 | if (!tcfg->clocks) { | 33 | if (!tcfg->clocks) { |
34 | tcfg->has_fracval = 1; | 34 | tcfg->has_fracval = 1; |
35 | tcfg->clocks = s5pv310_serial_clocks; | 35 | tcfg->clocks = exynos4_serial_clocks; |
36 | tcfg->clocks_size = ARRAY_SIZE(s5pv310_serial_clocks); | 36 | tcfg->clocks_size = ARRAY_SIZE(exynos4_serial_clocks); |
37 | } | 37 | } |
38 | } | 38 | } |
39 | 39 | ||
diff --git a/arch/arm/mach-s5pv310/irq-combiner.c b/arch/arm/mach-exynos4/irq-combiner.c index 1ea4a9e83bbe..31618d91ce15 100644 --- a/arch/arm/mach-s5pv310/irq-combiner.c +++ b/arch/arm/mach-exynos4/irq-combiner.c | |||
@@ -1,6 +1,6 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/irq-combiner.c | 1 | /* linux/arch/arm/mach-exynos4/irq-combiner.c |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * Based on arch/arm/common/gic.c | 6 | * Based on arch/arm/common/gic.c |
diff --git a/arch/arm/mach-s5pv310/irq-eint.c b/arch/arm/mach-exynos4/irq-eint.c index 477bd9e97f0f..4f7ad4a796e4 100644 --- a/arch/arm/mach-s5pv310/irq-eint.c +++ b/arch/arm/mach-exynos4/irq-eint.c | |||
@@ -1,9 +1,9 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/irq-eint.c | 1 | /* linux/arch/arm/mach-exynos4/irq-eint.c |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * S5PV310 - IRQ EINT support | 6 | * EXYNOS4 - IRQ EINT support |
7 | * | 7 | * |
8 | * This program is free software; you can redistribute it and/or modify | 8 | * This program is free software; you can redistribute it and/or modify |
9 | * it under the terms of the GNU General Public License version 2 as | 9 | * it under the terms of the GNU General Public License version 2 as |
@@ -27,7 +27,7 @@ static DEFINE_SPINLOCK(eint_lock); | |||
27 | 27 | ||
28 | static unsigned int eint0_15_data[16]; | 28 | static unsigned int eint0_15_data[16]; |
29 | 29 | ||
30 | static unsigned int s5pv310_get_irq_nr(unsigned int number) | 30 | static unsigned int exynos4_get_irq_nr(unsigned int number) |
31 | { | 31 | { |
32 | u32 ret = 0; | 32 | u32 ret = 0; |
33 | 33 | ||
@@ -48,7 +48,7 @@ static unsigned int s5pv310_get_irq_nr(unsigned int number) | |||
48 | return ret; | 48 | return ret; |
49 | } | 49 | } |
50 | 50 | ||
51 | static inline void s5pv310_irq_eint_mask(struct irq_data *data) | 51 | static inline void exynos4_irq_eint_mask(struct irq_data *data) |
52 | { | 52 | { |
53 | u32 mask; | 53 | u32 mask; |
54 | 54 | ||
@@ -59,7 +59,7 @@ static inline void s5pv310_irq_eint_mask(struct irq_data *data) | |||
59 | spin_unlock(&eint_lock); | 59 | spin_unlock(&eint_lock); |
60 | } | 60 | } |
61 | 61 | ||
62 | static void s5pv310_irq_eint_unmask(struct irq_data *data) | 62 | static void exynos4_irq_eint_unmask(struct irq_data *data) |
63 | { | 63 | { |
64 | u32 mask; | 64 | u32 mask; |
65 | 65 | ||
@@ -70,19 +70,19 @@ static void s5pv310_irq_eint_unmask(struct irq_data *data) | |||
70 | spin_unlock(&eint_lock); | 70 | spin_unlock(&eint_lock); |
71 | } | 71 | } |
72 | 72 | ||
73 | static inline void s5pv310_irq_eint_ack(struct irq_data *data) | 73 | static inline void exynos4_irq_eint_ack(struct irq_data *data) |
74 | { | 74 | { |
75 | __raw_writel(eint_irq_to_bit(data->irq), | 75 | __raw_writel(eint_irq_to_bit(data->irq), |
76 | S5P_EINT_PEND(EINT_REG_NR(data->irq))); | 76 | S5P_EINT_PEND(EINT_REG_NR(data->irq))); |
77 | } | 77 | } |
78 | 78 | ||
79 | static void s5pv310_irq_eint_maskack(struct irq_data *data) | 79 | static void exynos4_irq_eint_maskack(struct irq_data *data) |
80 | { | 80 | { |
81 | s5pv310_irq_eint_mask(data); | 81 | exynos4_irq_eint_mask(data); |
82 | s5pv310_irq_eint_ack(data); | 82 | exynos4_irq_eint_ack(data); |
83 | } | 83 | } |
84 | 84 | ||
85 | static int s5pv310_irq_eint_set_type(struct irq_data *data, unsigned int type) | 85 | static int exynos4_irq_eint_set_type(struct irq_data *data, unsigned int type) |
86 | { | 86 | { |
87 | int offs = EINT_OFFSET(data->irq); | 87 | int offs = EINT_OFFSET(data->irq); |
88 | int shift; | 88 | int shift; |
@@ -145,19 +145,19 @@ static int s5pv310_irq_eint_set_type(struct irq_data *data, unsigned int type) | |||
145 | return 0; | 145 | return 0; |
146 | } | 146 | } |
147 | 147 | ||
148 | static struct irq_chip s5pv310_irq_eint = { | 148 | static struct irq_chip exynos4_irq_eint = { |
149 | .name = "s5pv310-eint", | 149 | .name = "exynos4-eint", |
150 | .irq_mask = s5pv310_irq_eint_mask, | 150 | .irq_mask = exynos4_irq_eint_mask, |
151 | .irq_unmask = s5pv310_irq_eint_unmask, | 151 | .irq_unmask = exynos4_irq_eint_unmask, |
152 | .irq_mask_ack = s5pv310_irq_eint_maskack, | 152 | .irq_mask_ack = exynos4_irq_eint_maskack, |
153 | .irq_ack = s5pv310_irq_eint_ack, | 153 | .irq_ack = exynos4_irq_eint_ack, |
154 | .irq_set_type = s5pv310_irq_eint_set_type, | 154 | .irq_set_type = exynos4_irq_eint_set_type, |
155 | #ifdef CONFIG_PM | 155 | #ifdef CONFIG_PM |
156 | .irq_set_wake = s3c_irqext_wake, | 156 | .irq_set_wake = s3c_irqext_wake, |
157 | #endif | 157 | #endif |
158 | }; | 158 | }; |
159 | 159 | ||
160 | /* s5pv310_irq_demux_eint | 160 | /* exynos4_irq_demux_eint |
161 | * | 161 | * |
162 | * This function demuxes the IRQ from from EINTs 16 to 31. | 162 | * This function demuxes the IRQ from from EINTs 16 to 31. |
163 | * It is designed to be inlined into the specific handler | 163 | * It is designed to be inlined into the specific handler |
@@ -165,7 +165,7 @@ static struct irq_chip s5pv310_irq_eint = { | |||
165 | * | 165 | * |
166 | * Each EINT pend/mask registers handle eight of them. | 166 | * Each EINT pend/mask registers handle eight of them. |
167 | */ | 167 | */ |
168 | static inline void s5pv310_irq_demux_eint(unsigned int start) | 168 | static inline void exynos4_irq_demux_eint(unsigned int start) |
169 | { | 169 | { |
170 | unsigned int irq; | 170 | unsigned int irq; |
171 | 171 | ||
@@ -182,13 +182,13 @@ static inline void s5pv310_irq_demux_eint(unsigned int start) | |||
182 | } | 182 | } |
183 | } | 183 | } |
184 | 184 | ||
185 | static void s5pv310_irq_demux_eint16_31(unsigned int irq, struct irq_desc *desc) | 185 | static void exynos4_irq_demux_eint16_31(unsigned int irq, struct irq_desc *desc) |
186 | { | 186 | { |
187 | s5pv310_irq_demux_eint(IRQ_EINT(16)); | 187 | exynos4_irq_demux_eint(IRQ_EINT(16)); |
188 | s5pv310_irq_demux_eint(IRQ_EINT(24)); | 188 | exynos4_irq_demux_eint(IRQ_EINT(24)); |
189 | } | 189 | } |
190 | 190 | ||
191 | static void s5pv310_irq_eint0_15(unsigned int irq, struct irq_desc *desc) | 191 | static void exynos4_irq_eint0_15(unsigned int irq, struct irq_desc *desc) |
192 | { | 192 | { |
193 | u32 *irq_data = get_irq_data(irq); | 193 | u32 *irq_data = get_irq_data(irq); |
194 | struct irq_chip *chip = get_irq_chip(irq); | 194 | struct irq_chip *chip = get_irq_chip(irq); |
@@ -203,27 +203,27 @@ static void s5pv310_irq_eint0_15(unsigned int irq, struct irq_desc *desc) | |||
203 | chip->irq_unmask(&desc->irq_data); | 203 | chip->irq_unmask(&desc->irq_data); |
204 | } | 204 | } |
205 | 205 | ||
206 | int __init s5pv310_init_irq_eint(void) | 206 | int __init exynos4_init_irq_eint(void) |
207 | { | 207 | { |
208 | int irq; | 208 | int irq; |
209 | 209 | ||
210 | for (irq = 0 ; irq <= 31 ; irq++) { | 210 | for (irq = 0 ; irq <= 31 ; irq++) { |
211 | set_irq_chip(IRQ_EINT(irq), &s5pv310_irq_eint); | 211 | set_irq_chip(IRQ_EINT(irq), &exynos4_irq_eint); |
212 | set_irq_handler(IRQ_EINT(irq), handle_level_irq); | 212 | set_irq_handler(IRQ_EINT(irq), handle_level_irq); |
213 | set_irq_flags(IRQ_EINT(irq), IRQF_VALID); | 213 | set_irq_flags(IRQ_EINT(irq), IRQF_VALID); |
214 | } | 214 | } |
215 | 215 | ||
216 | set_irq_chained_handler(IRQ_EINT16_31, s5pv310_irq_demux_eint16_31); | 216 | set_irq_chained_handler(IRQ_EINT16_31, exynos4_irq_demux_eint16_31); |
217 | 217 | ||
218 | for (irq = 0 ; irq <= 15 ; irq++) { | 218 | for (irq = 0 ; irq <= 15 ; irq++) { |
219 | eint0_15_data[irq] = IRQ_EINT(irq); | 219 | eint0_15_data[irq] = IRQ_EINT(irq); |
220 | 220 | ||
221 | set_irq_data(s5pv310_get_irq_nr(irq), &eint0_15_data[irq]); | 221 | set_irq_data(exynos4_get_irq_nr(irq), &eint0_15_data[irq]); |
222 | set_irq_chained_handler(s5pv310_get_irq_nr(irq), | 222 | set_irq_chained_handler(exynos4_get_irq_nr(irq), |
223 | s5pv310_irq_eint0_15); | 223 | exynos4_irq_eint0_15); |
224 | } | 224 | } |
225 | 225 | ||
226 | return 0; | 226 | return 0; |
227 | } | 227 | } |
228 | 228 | ||
229 | arch_initcall(s5pv310_init_irq_eint); | 229 | arch_initcall(exynos4_init_irq_eint); |
diff --git a/arch/arm/mach-s5pv310/localtimer.c b/arch/arm/mach-exynos4/localtimer.c index 2784036cd8b1..2a2993ae8d86 100644 --- a/arch/arm/mach-s5pv310/localtimer.c +++ b/arch/arm/mach-exynos4/localtimer.c | |||
@@ -1,4 +1,4 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/localtimer.c | 1 | /* linux/arch/arm/mach-exynos4/localtimer.c |
2 | * | 2 | * |
3 | * Cloned from linux/arch/arm/mach-realview/localtimer.c | 3 | * Cloned from linux/arch/arm/mach-realview/localtimer.c |
4 | * | 4 | * |
diff --git a/arch/arm/mach-exynos4/mach-armlex4210.c b/arch/arm/mach-exynos4/mach-armlex4210.c new file mode 100644 index 000000000000..b482c6285fc4 --- /dev/null +++ b/arch/arm/mach-exynos4/mach-armlex4210.c | |||
@@ -0,0 +1,215 @@ | |||
1 | /* linux/arch/arm/mach-exynos4/mach-armlex4210.c | ||
2 | * | ||
3 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | |||
11 | #include <linux/gpio.h> | ||
12 | #include <linux/io.h> | ||
13 | #include <linux/mmc/host.h> | ||
14 | #include <linux/platform_device.h> | ||
15 | #include <linux/serial_core.h> | ||
16 | #include <linux/smsc911x.h> | ||
17 | |||
18 | #include <asm/mach/arch.h> | ||
19 | #include <asm/mach-types.h> | ||
20 | |||
21 | #include <plat/cpu.h> | ||
22 | #include <plat/devs.h> | ||
23 | #include <plat/exynos4.h> | ||
24 | #include <plat/gpio-cfg.h> | ||
25 | #include <plat/regs-serial.h> | ||
26 | #include <plat/regs-srom.h> | ||
27 | #include <plat/sdhci.h> | ||
28 | |||
29 | #include <mach/map.h> | ||
30 | |||
31 | /* Following are default values for UCON, ULCON and UFCON UART registers */ | ||
32 | #define ARMLEX4210_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ | ||
33 | S3C2410_UCON_RXILEVEL | \ | ||
34 | S3C2410_UCON_TXIRQMODE | \ | ||
35 | S3C2410_UCON_RXIRQMODE | \ | ||
36 | S3C2410_UCON_RXFIFO_TOI | \ | ||
37 | S3C2443_UCON_RXERR_IRQEN) | ||
38 | |||
39 | #define ARMLEX4210_ULCON_DEFAULT S3C2410_LCON_CS8 | ||
40 | |||
41 | #define ARMLEX4210_UFCON_DEFAULT (S3C2410_UFCON_FIFOMODE | \ | ||
42 | S5PV210_UFCON_TXTRIG4 | \ | ||
43 | S5PV210_UFCON_RXTRIG4) | ||
44 | |||
45 | static struct s3c2410_uartcfg armlex4210_uartcfgs[] __initdata = { | ||
46 | [0] = { | ||
47 | .hwport = 0, | ||
48 | .flags = 0, | ||
49 | .ucon = ARMLEX4210_UCON_DEFAULT, | ||
50 | .ulcon = ARMLEX4210_ULCON_DEFAULT, | ||
51 | .ufcon = ARMLEX4210_UFCON_DEFAULT, | ||
52 | }, | ||
53 | [1] = { | ||
54 | .hwport = 1, | ||
55 | .flags = 0, | ||
56 | .ucon = ARMLEX4210_UCON_DEFAULT, | ||
57 | .ulcon = ARMLEX4210_ULCON_DEFAULT, | ||
58 | .ufcon = ARMLEX4210_UFCON_DEFAULT, | ||
59 | }, | ||
60 | [2] = { | ||
61 | .hwport = 2, | ||
62 | .flags = 0, | ||
63 | .ucon = ARMLEX4210_UCON_DEFAULT, | ||
64 | .ulcon = ARMLEX4210_ULCON_DEFAULT, | ||
65 | .ufcon = ARMLEX4210_UFCON_DEFAULT, | ||
66 | }, | ||
67 | [3] = { | ||
68 | .hwport = 3, | ||
69 | .flags = 0, | ||
70 | .ucon = ARMLEX4210_UCON_DEFAULT, | ||
71 | .ulcon = ARMLEX4210_ULCON_DEFAULT, | ||
72 | .ufcon = ARMLEX4210_UFCON_DEFAULT, | ||
73 | }, | ||
74 | }; | ||
75 | |||
76 | static struct s3c_sdhci_platdata armlex4210_hsmmc0_pdata __initdata = { | ||
77 | .cd_type = S3C_SDHCI_CD_PERMANENT, | ||
78 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | ||
79 | #ifdef CONFIG_EXYNOS4_SDHCI_CH0_8BIT | ||
80 | .max_width = 8, | ||
81 | .host_caps = MMC_CAP_8_BIT_DATA, | ||
82 | #endif | ||
83 | }; | ||
84 | |||
85 | static struct s3c_sdhci_platdata armlex4210_hsmmc2_pdata __initdata = { | ||
86 | .cd_type = S3C_SDHCI_CD_GPIO, | ||
87 | .ext_cd_gpio = EXYNOS4_GPX2(5), | ||
88 | .ext_cd_gpio_invert = 1, | ||
89 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | ||
90 | .max_width = 4, | ||
91 | }; | ||
92 | |||
93 | static struct s3c_sdhci_platdata armlex4210_hsmmc3_pdata __initdata = { | ||
94 | .cd_type = S3C_SDHCI_CD_PERMANENT, | ||
95 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | ||
96 | .max_width = 4, | ||
97 | }; | ||
98 | |||
99 | static void __init armlex4210_sdhci_init(void) | ||
100 | { | ||
101 | s3c_sdhci0_set_platdata(&armlex4210_hsmmc0_pdata); | ||
102 | s3c_sdhci2_set_platdata(&armlex4210_hsmmc2_pdata); | ||
103 | s3c_sdhci3_set_platdata(&armlex4210_hsmmc3_pdata); | ||
104 | } | ||
105 | |||
106 | static void __init armlex4210_wlan_init(void) | ||
107 | { | ||
108 | /* enable */ | ||
109 | s3c_gpio_cfgpin(EXYNOS4_GPX2(0), S3C_GPIO_SFN(0xf)); | ||
110 | s3c_gpio_setpull(EXYNOS4_GPX2(0), S3C_GPIO_PULL_UP); | ||
111 | |||
112 | /* reset */ | ||
113 | s3c_gpio_cfgpin(EXYNOS4_GPX1(6), S3C_GPIO_SFN(0xf)); | ||
114 | s3c_gpio_setpull(EXYNOS4_GPX1(6), S3C_GPIO_PULL_UP); | ||
115 | |||
116 | /* wakeup */ | ||
117 | s3c_gpio_cfgpin(EXYNOS4_GPX1(5), S3C_GPIO_SFN(0xf)); | ||
118 | s3c_gpio_setpull(EXYNOS4_GPX1(5), S3C_GPIO_PULL_UP); | ||
119 | } | ||
120 | |||
121 | static struct resource armlex4210_smsc911x_resources[] = { | ||
122 | [0] = { | ||
123 | .start = EXYNOS4_PA_SROM_BANK(3), | ||
124 | .end = EXYNOS4_PA_SROM_BANK(3) + SZ_64K - 1, | ||
125 | .flags = IORESOURCE_MEM, | ||
126 | }, | ||
127 | [1] = { | ||
128 | .start = IRQ_EINT(27), | ||
129 | .end = IRQ_EINT(27), | ||
130 | .flags = IORESOURCE_IRQ | IRQF_TRIGGER_HIGH, | ||
131 | }, | ||
132 | }; | ||
133 | |||
134 | static struct smsc911x_platform_config smsc9215_config = { | ||
135 | .irq_polarity = SMSC911X_IRQ_POLARITY_ACTIVE_HIGH, | ||
136 | .irq_type = SMSC911X_IRQ_TYPE_PUSH_PULL, | ||
137 | .flags = SMSC911X_USE_16BIT | SMSC911X_FORCE_INTERNAL_PHY, | ||
138 | .phy_interface = PHY_INTERFACE_MODE_MII, | ||
139 | .mac = {0x00, 0x80, 0x00, 0x23, 0x45, 0x67}, | ||
140 | }; | ||
141 | |||
142 | static struct platform_device armlex4210_smsc911x = { | ||
143 | .name = "smsc911x", | ||
144 | .id = -1, | ||
145 | .num_resources = ARRAY_SIZE(armlex4210_smsc911x_resources), | ||
146 | .resource = armlex4210_smsc911x_resources, | ||
147 | .dev = { | ||
148 | .platform_data = &smsc9215_config, | ||
149 | }, | ||
150 | }; | ||
151 | |||
152 | static struct platform_device *armlex4210_devices[] __initdata = { | ||
153 | &s3c_device_hsmmc0, | ||
154 | &s3c_device_hsmmc2, | ||
155 | &s3c_device_hsmmc3, | ||
156 | &s3c_device_rtc, | ||
157 | &s3c_device_wdt, | ||
158 | &exynos4_device_sysmmu, | ||
159 | &samsung_asoc_dma, | ||
160 | &armlex4210_smsc911x, | ||
161 | &exynos4_device_ahci, | ||
162 | }; | ||
163 | |||
164 | static void __init armlex4210_smsc911x_init(void) | ||
165 | { | ||
166 | u32 cs1; | ||
167 | |||
168 | /* configure nCS1 width to 16 bits */ | ||
169 | cs1 = __raw_readl(S5P_SROM_BW) & | ||
170 | ~(S5P_SROM_BW__CS_MASK << S5P_SROM_BW__NCS1__SHIFT); | ||
171 | cs1 |= ((1 << S5P_SROM_BW__DATAWIDTH__SHIFT) | | ||
172 | (0 << S5P_SROM_BW__WAITENABLE__SHIFT) | | ||
173 | (1 << S5P_SROM_BW__ADDRMODE__SHIFT) | | ||
174 | (1 << S5P_SROM_BW__BYTEENABLE__SHIFT)) << | ||
175 | S5P_SROM_BW__NCS1__SHIFT; | ||
176 | __raw_writel(cs1, S5P_SROM_BW); | ||
177 | |||
178 | /* set timing for nCS1 suitable for ethernet chip */ | ||
179 | __raw_writel((0x1 << S5P_SROM_BCX__PMC__SHIFT) | | ||
180 | (0x9 << S5P_SROM_BCX__TACP__SHIFT) | | ||
181 | (0xc << S5P_SROM_BCX__TCAH__SHIFT) | | ||
182 | (0x1 << S5P_SROM_BCX__TCOH__SHIFT) | | ||
183 | (0x6 << S5P_SROM_BCX__TACC__SHIFT) | | ||
184 | (0x1 << S5P_SROM_BCX__TCOS__SHIFT) | | ||
185 | (0x1 << S5P_SROM_BCX__TACS__SHIFT), S5P_SROM_BC1); | ||
186 | } | ||
187 | |||
188 | static void __init armlex4210_map_io(void) | ||
189 | { | ||
190 | s5p_init_io(NULL, 0, S5P_VA_CHIPID); | ||
191 | s3c24xx_init_clocks(24000000); | ||
192 | s3c24xx_init_uarts(armlex4210_uartcfgs, | ||
193 | ARRAY_SIZE(armlex4210_uartcfgs)); | ||
194 | } | ||
195 | |||
196 | static void __init armlex4210_machine_init(void) | ||
197 | { | ||
198 | armlex4210_smsc911x_init(); | ||
199 | |||
200 | armlex4210_sdhci_init(); | ||
201 | |||
202 | armlex4210_wlan_init(); | ||
203 | |||
204 | platform_add_devices(armlex4210_devices, | ||
205 | ARRAY_SIZE(armlex4210_devices)); | ||
206 | } | ||
207 | |||
208 | MACHINE_START(ARMLEX4210, "ARMLEX4210") | ||
209 | /* Maintainer: Alim Akhtar <alim.akhtar@samsung.com> */ | ||
210 | .boot_params = S5P_PA_SDRAM + 0x100, | ||
211 | .init_irq = exynos4_init_irq, | ||
212 | .map_io = armlex4210_map_io, | ||
213 | .init_machine = armlex4210_machine_init, | ||
214 | .timer = &exynos4_timer, | ||
215 | MACHINE_END | ||
diff --git a/arch/arm/mach-exynos4/mach-nuri.c b/arch/arm/mach-exynos4/mach-nuri.c new file mode 100644 index 000000000000..b79ad010d194 --- /dev/null +++ b/arch/arm/mach-exynos4/mach-nuri.c | |||
@@ -0,0 +1,305 @@ | |||
1 | /* | ||
2 | * linux/arch/arm/mach-exynos4/mach-nuri.c | ||
3 | * | ||
4 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | |||
11 | #include <linux/platform_device.h> | ||
12 | #include <linux/serial_core.h> | ||
13 | #include <linux/input.h> | ||
14 | #include <linux/i2c.h> | ||
15 | #include <linux/gpio_keys.h> | ||
16 | #include <linux/gpio.h> | ||
17 | #include <linux/regulator/machine.h> | ||
18 | #include <linux/regulator/fixed.h> | ||
19 | #include <linux/mmc/host.h> | ||
20 | #include <linux/fb.h> | ||
21 | #include <linux/pwm_backlight.h> | ||
22 | |||
23 | #include <video/platform_lcd.h> | ||
24 | |||
25 | #include <asm/mach/arch.h> | ||
26 | #include <asm/mach-types.h> | ||
27 | |||
28 | #include <plat/regs-serial.h> | ||
29 | #include <plat/exynos4.h> | ||
30 | #include <plat/cpu.h> | ||
31 | #include <plat/devs.h> | ||
32 | #include <plat/sdhci.h> | ||
33 | |||
34 | #include <mach/map.h> | ||
35 | |||
36 | /* Following are default values for UCON, ULCON and UFCON UART registers */ | ||
37 | #define NURI_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ | ||
38 | S3C2410_UCON_RXILEVEL | \ | ||
39 | S3C2410_UCON_TXIRQMODE | \ | ||
40 | S3C2410_UCON_RXIRQMODE | \ | ||
41 | S3C2410_UCON_RXFIFO_TOI | \ | ||
42 | S3C2443_UCON_RXERR_IRQEN) | ||
43 | |||
44 | #define NURI_ULCON_DEFAULT S3C2410_LCON_CS8 | ||
45 | |||
46 | #define NURI_UFCON_DEFAULT (S3C2410_UFCON_FIFOMODE | \ | ||
47 | S5PV210_UFCON_TXTRIG256 | \ | ||
48 | S5PV210_UFCON_RXTRIG256) | ||
49 | |||
50 | enum fixed_regulator_id { | ||
51 | FIXED_REG_ID_MMC = 0, | ||
52 | }; | ||
53 | |||
54 | static struct s3c2410_uartcfg nuri_uartcfgs[] __initdata = { | ||
55 | { | ||
56 | .hwport = 0, | ||
57 | .ucon = NURI_UCON_DEFAULT, | ||
58 | .ulcon = NURI_ULCON_DEFAULT, | ||
59 | .ufcon = NURI_UFCON_DEFAULT, | ||
60 | }, | ||
61 | { | ||
62 | .hwport = 1, | ||
63 | .ucon = NURI_UCON_DEFAULT, | ||
64 | .ulcon = NURI_ULCON_DEFAULT, | ||
65 | .ufcon = NURI_UFCON_DEFAULT, | ||
66 | }, | ||
67 | { | ||
68 | .hwport = 2, | ||
69 | .ucon = NURI_UCON_DEFAULT, | ||
70 | .ulcon = NURI_ULCON_DEFAULT, | ||
71 | .ufcon = NURI_UFCON_DEFAULT, | ||
72 | }, | ||
73 | { | ||
74 | .hwport = 3, | ||
75 | .ucon = NURI_UCON_DEFAULT, | ||
76 | .ulcon = NURI_ULCON_DEFAULT, | ||
77 | .ufcon = NURI_UFCON_DEFAULT, | ||
78 | }, | ||
79 | }; | ||
80 | |||
81 | /* eMMC */ | ||
82 | static struct s3c_sdhci_platdata nuri_hsmmc0_data __initdata = { | ||
83 | .max_width = 8, | ||
84 | .host_caps = (MMC_CAP_8_BIT_DATA | MMC_CAP_4_BIT_DATA | | ||
85 | MMC_CAP_MMC_HIGHSPEED | MMC_CAP_SD_HIGHSPEED | | ||
86 | MMC_CAP_DISABLE | MMC_CAP_ERASE), | ||
87 | .cd_type = S3C_SDHCI_CD_PERMANENT, | ||
88 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | ||
89 | }; | ||
90 | |||
91 | static struct regulator_consumer_supply emmc_supplies[] = { | ||
92 | REGULATOR_SUPPLY("vmmc", "s3c-sdhci.0"), | ||
93 | REGULATOR_SUPPLY("vmmc", "dw_mmc"), | ||
94 | }; | ||
95 | |||
96 | static struct regulator_init_data emmc_fixed_voltage_init_data = { | ||
97 | .constraints = { | ||
98 | .name = "VMEM_VDD_2.8V", | ||
99 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
100 | }, | ||
101 | .num_consumer_supplies = ARRAY_SIZE(emmc_supplies), | ||
102 | .consumer_supplies = emmc_supplies, | ||
103 | }; | ||
104 | |||
105 | static struct fixed_voltage_config emmc_fixed_voltage_config = { | ||
106 | .supply_name = "MASSMEMORY_EN (inverted)", | ||
107 | .microvolts = 2800000, | ||
108 | .gpio = EXYNOS4_GPL1(1), | ||
109 | .enable_high = false, | ||
110 | .init_data = &emmc_fixed_voltage_init_data, | ||
111 | }; | ||
112 | |||
113 | static struct platform_device emmc_fixed_voltage = { | ||
114 | .name = "reg-fixed-voltage", | ||
115 | .id = FIXED_REG_ID_MMC, | ||
116 | .dev = { | ||
117 | .platform_data = &emmc_fixed_voltage_config, | ||
118 | }, | ||
119 | }; | ||
120 | |||
121 | /* SD */ | ||
122 | static struct s3c_sdhci_platdata nuri_hsmmc2_data __initdata = { | ||
123 | .max_width = 4, | ||
124 | .host_caps = MMC_CAP_4_BIT_DATA | | ||
125 | MMC_CAP_MMC_HIGHSPEED | MMC_CAP_SD_HIGHSPEED | | ||
126 | MMC_CAP_DISABLE, | ||
127 | .ext_cd_gpio = EXYNOS4_GPX3(3), /* XEINT_27 */ | ||
128 | .ext_cd_gpio_invert = 1, | ||
129 | .cd_type = S3C_SDHCI_CD_GPIO, | ||
130 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | ||
131 | }; | ||
132 | |||
133 | /* WLAN */ | ||
134 | static struct s3c_sdhci_platdata nuri_hsmmc3_data __initdata = { | ||
135 | .max_width = 4, | ||
136 | .host_caps = MMC_CAP_4_BIT_DATA | | ||
137 | MMC_CAP_MMC_HIGHSPEED | MMC_CAP_SD_HIGHSPEED, | ||
138 | .cd_type = S3C_SDHCI_CD_EXTERNAL, | ||
139 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | ||
140 | }; | ||
141 | |||
142 | static void __init nuri_sdhci_init(void) | ||
143 | { | ||
144 | s3c_sdhci0_set_platdata(&nuri_hsmmc0_data); | ||
145 | s3c_sdhci2_set_platdata(&nuri_hsmmc2_data); | ||
146 | s3c_sdhci3_set_platdata(&nuri_hsmmc3_data); | ||
147 | } | ||
148 | |||
149 | /* GPIO KEYS */ | ||
150 | static struct gpio_keys_button nuri_gpio_keys_tables[] = { | ||
151 | { | ||
152 | .code = KEY_VOLUMEUP, | ||
153 | .gpio = EXYNOS4_GPX2(0), /* XEINT16 */ | ||
154 | .desc = "gpio-keys: KEY_VOLUMEUP", | ||
155 | .type = EV_KEY, | ||
156 | .active_low = 1, | ||
157 | .debounce_interval = 1, | ||
158 | }, { | ||
159 | .code = KEY_VOLUMEDOWN, | ||
160 | .gpio = EXYNOS4_GPX2(1), /* XEINT17 */ | ||
161 | .desc = "gpio-keys: KEY_VOLUMEDOWN", | ||
162 | .type = EV_KEY, | ||
163 | .active_low = 1, | ||
164 | .debounce_interval = 1, | ||
165 | }, { | ||
166 | .code = KEY_POWER, | ||
167 | .gpio = EXYNOS4_GPX2(7), /* XEINT23 */ | ||
168 | .desc = "gpio-keys: KEY_POWER", | ||
169 | .type = EV_KEY, | ||
170 | .active_low = 1, | ||
171 | .wakeup = 1, | ||
172 | .debounce_interval = 1, | ||
173 | }, | ||
174 | }; | ||
175 | |||
176 | static struct gpio_keys_platform_data nuri_gpio_keys_data = { | ||
177 | .buttons = nuri_gpio_keys_tables, | ||
178 | .nbuttons = ARRAY_SIZE(nuri_gpio_keys_tables), | ||
179 | }; | ||
180 | |||
181 | static struct platform_device nuri_gpio_keys = { | ||
182 | .name = "gpio-keys", | ||
183 | .dev = { | ||
184 | .platform_data = &nuri_gpio_keys_data, | ||
185 | }, | ||
186 | }; | ||
187 | |||
188 | static void nuri_lcd_power_on(struct plat_lcd_data *pd, unsigned int power) | ||
189 | { | ||
190 | int gpio = EXYNOS4_GPE1(5); | ||
191 | |||
192 | gpio_request(gpio, "LVDS_nSHDN"); | ||
193 | gpio_direction_output(gpio, power); | ||
194 | gpio_free(gpio); | ||
195 | } | ||
196 | |||
197 | static int nuri_bl_init(struct device *dev) | ||
198 | { | ||
199 | int ret, gpio = EXYNOS4_GPE2(3); | ||
200 | |||
201 | ret = gpio_request(gpio, "LCD_LDO_EN"); | ||
202 | if (!ret) | ||
203 | gpio_direction_output(gpio, 0); | ||
204 | |||
205 | return ret; | ||
206 | } | ||
207 | |||
208 | static int nuri_bl_notify(struct device *dev, int brightness) | ||
209 | { | ||
210 | if (brightness < 1) | ||
211 | brightness = 0; | ||
212 | |||
213 | gpio_set_value(EXYNOS4_GPE2(3), 1); | ||
214 | |||
215 | return brightness; | ||
216 | } | ||
217 | |||
218 | static void nuri_bl_exit(struct device *dev) | ||
219 | { | ||
220 | gpio_free(EXYNOS4_GPE2(3)); | ||
221 | } | ||
222 | |||
223 | /* nuri pwm backlight */ | ||
224 | static struct platform_pwm_backlight_data nuri_backlight_data = { | ||
225 | .pwm_id = 0, | ||
226 | .pwm_period_ns = 30000, | ||
227 | .max_brightness = 100, | ||
228 | .dft_brightness = 50, | ||
229 | .init = nuri_bl_init, | ||
230 | .notify = nuri_bl_notify, | ||
231 | .exit = nuri_bl_exit, | ||
232 | }; | ||
233 | |||
234 | static struct platform_device nuri_backlight_device = { | ||
235 | .name = "pwm-backlight", | ||
236 | .id = -1, | ||
237 | .dev = { | ||
238 | .parent = &s3c_device_timer[0].dev, | ||
239 | .platform_data = &nuri_backlight_data, | ||
240 | }, | ||
241 | }; | ||
242 | |||
243 | static struct plat_lcd_data nuri_lcd_platform_data = { | ||
244 | .set_power = nuri_lcd_power_on, | ||
245 | }; | ||
246 | |||
247 | static struct platform_device nuri_lcd_device = { | ||
248 | .name = "platform-lcd", | ||
249 | .id = -1, | ||
250 | .dev = { | ||
251 | .platform_data = &nuri_lcd_platform_data, | ||
252 | }, | ||
253 | }; | ||
254 | |||
255 | /* I2C1 */ | ||
256 | static struct i2c_board_info i2c1_devs[] __initdata = { | ||
257 | /* Gyro, To be updated */ | ||
258 | }; | ||
259 | |||
260 | /* GPIO I2C 5 (PMIC) */ | ||
261 | static struct i2c_board_info i2c5_devs[] __initdata = { | ||
262 | /* max8997, To be updated */ | ||
263 | }; | ||
264 | |||
265 | static struct platform_device *nuri_devices[] __initdata = { | ||
266 | /* Samsung Platform Devices */ | ||
267 | &emmc_fixed_voltage, | ||
268 | &s3c_device_hsmmc0, | ||
269 | &s3c_device_hsmmc2, | ||
270 | &s3c_device_hsmmc3, | ||
271 | &s3c_device_wdt, | ||
272 | &s3c_device_timer[0], | ||
273 | |||
274 | /* NURI Devices */ | ||
275 | &nuri_gpio_keys, | ||
276 | &nuri_lcd_device, | ||
277 | &nuri_backlight_device, | ||
278 | }; | ||
279 | |||
280 | static void __init nuri_map_io(void) | ||
281 | { | ||
282 | s5p_init_io(NULL, 0, S5P_VA_CHIPID); | ||
283 | s3c24xx_init_clocks(24000000); | ||
284 | s3c24xx_init_uarts(nuri_uartcfgs, ARRAY_SIZE(nuri_uartcfgs)); | ||
285 | } | ||
286 | |||
287 | static void __init nuri_machine_init(void) | ||
288 | { | ||
289 | nuri_sdhci_init(); | ||
290 | |||
291 | i2c_register_board_info(1, i2c1_devs, ARRAY_SIZE(i2c1_devs)); | ||
292 | i2c_register_board_info(5, i2c5_devs, ARRAY_SIZE(i2c5_devs)); | ||
293 | |||
294 | /* Last */ | ||
295 | platform_add_devices(nuri_devices, ARRAY_SIZE(nuri_devices)); | ||
296 | } | ||
297 | |||
298 | MACHINE_START(NURI, "NURI") | ||
299 | /* Maintainer: Kyungmin Park <kyungmin.park@samsung.com> */ | ||
300 | .boot_params = S5P_PA_SDRAM + 0x100, | ||
301 | .init_irq = exynos4_init_irq, | ||
302 | .map_io = nuri_map_io, | ||
303 | .init_machine = nuri_machine_init, | ||
304 | .timer = &exynos4_timer, | ||
305 | MACHINE_END | ||
diff --git a/arch/arm/mach-s5pv310/mach-smdkc210.c b/arch/arm/mach-exynos4/mach-smdkc210.c index d9cab02e23ca..25a256818122 100644 --- a/arch/arm/mach-s5pv310/mach-smdkc210.c +++ b/arch/arm/mach-exynos4/mach-smdkc210.c | |||
@@ -1,7 +1,7 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/mach-smdkc210.c | 1 | /* linux/arch/arm/mach-exynos4/mach-smdkc210.c |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * This program is free software; you can redistribute it and/or modify | 6 | * This program is free software; you can redistribute it and/or modify |
7 | * it under the terms of the GNU General Public License version 2 as | 7 | * it under the terms of the GNU General Public License version 2 as |
@@ -21,7 +21,7 @@ | |||
21 | 21 | ||
22 | #include <plat/regs-serial.h> | 22 | #include <plat/regs-serial.h> |
23 | #include <plat/regs-srom.h> | 23 | #include <plat/regs-srom.h> |
24 | #include <plat/s5pv310.h> | 24 | #include <plat/exynos4.h> |
25 | #include <plat/cpu.h> | 25 | #include <plat/cpu.h> |
26 | #include <plat/devs.h> | 26 | #include <plat/devs.h> |
27 | #include <plat/sdhci.h> | 27 | #include <plat/sdhci.h> |
@@ -77,10 +77,10 @@ static struct s3c2410_uartcfg smdkc210_uartcfgs[] __initdata = { | |||
77 | 77 | ||
78 | static struct s3c_sdhci_platdata smdkc210_hsmmc0_pdata __initdata = { | 78 | static struct s3c_sdhci_platdata smdkc210_hsmmc0_pdata __initdata = { |
79 | .cd_type = S3C_SDHCI_CD_GPIO, | 79 | .cd_type = S3C_SDHCI_CD_GPIO, |
80 | .ext_cd_gpio = S5PV310_GPK0(2), | 80 | .ext_cd_gpio = EXYNOS4_GPK0(2), |
81 | .ext_cd_gpio_invert = 1, | 81 | .ext_cd_gpio_invert = 1, |
82 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | 82 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, |
83 | #ifdef CONFIG_S5PV310_SDHCI_CH0_8BIT | 83 | #ifdef CONFIG_EXYNOS4_SDHCI_CH0_8BIT |
84 | .max_width = 8, | 84 | .max_width = 8, |
85 | .host_caps = MMC_CAP_8_BIT_DATA, | 85 | .host_caps = MMC_CAP_8_BIT_DATA, |
86 | #endif | 86 | #endif |
@@ -88,17 +88,17 @@ static struct s3c_sdhci_platdata smdkc210_hsmmc0_pdata __initdata = { | |||
88 | 88 | ||
89 | static struct s3c_sdhci_platdata smdkc210_hsmmc1_pdata __initdata = { | 89 | static struct s3c_sdhci_platdata smdkc210_hsmmc1_pdata __initdata = { |
90 | .cd_type = S3C_SDHCI_CD_GPIO, | 90 | .cd_type = S3C_SDHCI_CD_GPIO, |
91 | .ext_cd_gpio = S5PV310_GPK0(2), | 91 | .ext_cd_gpio = EXYNOS4_GPK0(2), |
92 | .ext_cd_gpio_invert = 1, | 92 | .ext_cd_gpio_invert = 1, |
93 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | 93 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, |
94 | }; | 94 | }; |
95 | 95 | ||
96 | static struct s3c_sdhci_platdata smdkc210_hsmmc2_pdata __initdata = { | 96 | static struct s3c_sdhci_platdata smdkc210_hsmmc2_pdata __initdata = { |
97 | .cd_type = S3C_SDHCI_CD_GPIO, | 97 | .cd_type = S3C_SDHCI_CD_GPIO, |
98 | .ext_cd_gpio = S5PV310_GPK2(2), | 98 | .ext_cd_gpio = EXYNOS4_GPK2(2), |
99 | .ext_cd_gpio_invert = 1, | 99 | .ext_cd_gpio_invert = 1, |
100 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | 100 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, |
101 | #ifdef CONFIG_S5PV310_SDHCI_CH2_8BIT | 101 | #ifdef CONFIG_EXYNOS4_SDHCI_CH2_8BIT |
102 | .max_width = 8, | 102 | .max_width = 8, |
103 | .host_caps = MMC_CAP_8_BIT_DATA, | 103 | .host_caps = MMC_CAP_8_BIT_DATA, |
104 | #endif | 104 | #endif |
@@ -106,15 +106,15 @@ static struct s3c_sdhci_platdata smdkc210_hsmmc2_pdata __initdata = { | |||
106 | 106 | ||
107 | static struct s3c_sdhci_platdata smdkc210_hsmmc3_pdata __initdata = { | 107 | static struct s3c_sdhci_platdata smdkc210_hsmmc3_pdata __initdata = { |
108 | .cd_type = S3C_SDHCI_CD_GPIO, | 108 | .cd_type = S3C_SDHCI_CD_GPIO, |
109 | .ext_cd_gpio = S5PV310_GPK2(2), | 109 | .ext_cd_gpio = EXYNOS4_GPK2(2), |
110 | .ext_cd_gpio_invert = 1, | 110 | .ext_cd_gpio_invert = 1, |
111 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | 111 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, |
112 | }; | 112 | }; |
113 | 113 | ||
114 | static struct resource smdkc210_smsc911x_resources[] = { | 114 | static struct resource smdkc210_smsc911x_resources[] = { |
115 | [0] = { | 115 | [0] = { |
116 | .start = S5PV310_PA_SROM_BANK(1), | 116 | .start = EXYNOS4_PA_SROM_BANK(1), |
117 | .end = S5PV310_PA_SROM_BANK(1) + SZ_64K - 1, | 117 | .end = EXYNOS4_PA_SROM_BANK(1) + SZ_64K - 1, |
118 | .flags = IORESOURCE_MEM, | 118 | .flags = IORESOURCE_MEM, |
119 | }, | 119 | }, |
120 | [1] = { | 120 | [1] = { |
@@ -154,16 +154,16 @@ static struct platform_device *smdkc210_devices[] __initdata = { | |||
154 | &s3c_device_i2c1, | 154 | &s3c_device_i2c1, |
155 | &s3c_device_rtc, | 155 | &s3c_device_rtc, |
156 | &s3c_device_wdt, | 156 | &s3c_device_wdt, |
157 | &s5pv310_device_ac97, | 157 | &exynos4_device_ac97, |
158 | &s5pv310_device_i2s0, | 158 | &exynos4_device_i2s0, |
159 | &s5pv310_device_pd[PD_MFC], | 159 | &exynos4_device_pd[PD_MFC], |
160 | &s5pv310_device_pd[PD_G3D], | 160 | &exynos4_device_pd[PD_G3D], |
161 | &s5pv310_device_pd[PD_LCD0], | 161 | &exynos4_device_pd[PD_LCD0], |
162 | &s5pv310_device_pd[PD_LCD1], | 162 | &exynos4_device_pd[PD_LCD1], |
163 | &s5pv310_device_pd[PD_CAM], | 163 | &exynos4_device_pd[PD_CAM], |
164 | &s5pv310_device_pd[PD_TV], | 164 | &exynos4_device_pd[PD_TV], |
165 | &s5pv310_device_pd[PD_GPS], | 165 | &exynos4_device_pd[PD_GPS], |
166 | &s5pv310_device_sysmmu, | 166 | &exynos4_device_sysmmu, |
167 | &samsung_asoc_dma, | 167 | &samsung_asoc_dma, |
168 | &smdkc210_smsc911x, | 168 | &smdkc210_smsc911x, |
169 | }; | 169 | }; |
@@ -216,8 +216,8 @@ static void __init smdkc210_machine_init(void) | |||
216 | MACHINE_START(SMDKC210, "SMDKC210") | 216 | MACHINE_START(SMDKC210, "SMDKC210") |
217 | /* Maintainer: Kukjin Kim <kgene.kim@samsung.com> */ | 217 | /* Maintainer: Kukjin Kim <kgene.kim@samsung.com> */ |
218 | .boot_params = S5P_PA_SDRAM + 0x100, | 218 | .boot_params = S5P_PA_SDRAM + 0x100, |
219 | .init_irq = s5pv310_init_irq, | 219 | .init_irq = exynos4_init_irq, |
220 | .map_io = smdkc210_map_io, | 220 | .map_io = smdkc210_map_io, |
221 | .init_machine = smdkc210_machine_init, | 221 | .init_machine = smdkc210_machine_init, |
222 | .timer = &s5pv310_timer, | 222 | .timer = &exynos4_timer, |
223 | MACHINE_END | 223 | MACHINE_END |
diff --git a/arch/arm/mach-s5pv310/mach-smdkv310.c b/arch/arm/mach-exynos4/mach-smdkv310.c index b1cddbf3c616..88e0275143be 100644 --- a/arch/arm/mach-s5pv310/mach-smdkv310.c +++ b/arch/arm/mach-exynos4/mach-smdkv310.c | |||
@@ -1,7 +1,7 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/mach-smdkv310.c | 1 | /* linux/arch/arm/mach-exynos4/mach-smdkv310.c |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * This program is free software; you can redistribute it and/or modify | 6 | * This program is free software; you can redistribute it and/or modify |
7 | * it under the terms of the GNU General Public License version 2 as | 7 | * it under the terms of the GNU General Public License version 2 as |
@@ -15,15 +15,17 @@ | |||
15 | #include <linux/smsc911x.h> | 15 | #include <linux/smsc911x.h> |
16 | #include <linux/io.h> | 16 | #include <linux/io.h> |
17 | #include <linux/i2c.h> | 17 | #include <linux/i2c.h> |
18 | #include <linux/input.h> | ||
18 | 19 | ||
19 | #include <asm/mach/arch.h> | 20 | #include <asm/mach/arch.h> |
20 | #include <asm/mach-types.h> | 21 | #include <asm/mach-types.h> |
21 | 22 | ||
22 | #include <plat/regs-serial.h> | 23 | #include <plat/regs-serial.h> |
23 | #include <plat/regs-srom.h> | 24 | #include <plat/regs-srom.h> |
24 | #include <plat/s5pv310.h> | 25 | #include <plat/exynos4.h> |
25 | #include <plat/cpu.h> | 26 | #include <plat/cpu.h> |
26 | #include <plat/devs.h> | 27 | #include <plat/devs.h> |
28 | #include <plat/keypad.h> | ||
27 | #include <plat/sdhci.h> | 29 | #include <plat/sdhci.h> |
28 | #include <plat/iic.h> | 30 | #include <plat/iic.h> |
29 | #include <plat/pd.h> | 31 | #include <plat/pd.h> |
@@ -77,10 +79,10 @@ static struct s3c2410_uartcfg smdkv310_uartcfgs[] __initdata = { | |||
77 | 79 | ||
78 | static struct s3c_sdhci_platdata smdkv310_hsmmc0_pdata __initdata = { | 80 | static struct s3c_sdhci_platdata smdkv310_hsmmc0_pdata __initdata = { |
79 | .cd_type = S3C_SDHCI_CD_GPIO, | 81 | .cd_type = S3C_SDHCI_CD_GPIO, |
80 | .ext_cd_gpio = S5PV310_GPK0(2), | 82 | .ext_cd_gpio = EXYNOS4_GPK0(2), |
81 | .ext_cd_gpio_invert = 1, | 83 | .ext_cd_gpio_invert = 1, |
82 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | 84 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, |
83 | #ifdef CONFIG_S5PV310_SDHCI_CH0_8BIT | 85 | #ifdef CONFIG_EXYNOS4_SDHCI_CH0_8BIT |
84 | .max_width = 8, | 86 | .max_width = 8, |
85 | .host_caps = MMC_CAP_8_BIT_DATA, | 87 | .host_caps = MMC_CAP_8_BIT_DATA, |
86 | #endif | 88 | #endif |
@@ -88,17 +90,17 @@ static struct s3c_sdhci_platdata smdkv310_hsmmc0_pdata __initdata = { | |||
88 | 90 | ||
89 | static struct s3c_sdhci_platdata smdkv310_hsmmc1_pdata __initdata = { | 91 | static struct s3c_sdhci_platdata smdkv310_hsmmc1_pdata __initdata = { |
90 | .cd_type = S3C_SDHCI_CD_GPIO, | 92 | .cd_type = S3C_SDHCI_CD_GPIO, |
91 | .ext_cd_gpio = S5PV310_GPK0(2), | 93 | .ext_cd_gpio = EXYNOS4_GPK0(2), |
92 | .ext_cd_gpio_invert = 1, | 94 | .ext_cd_gpio_invert = 1, |
93 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | 95 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, |
94 | }; | 96 | }; |
95 | 97 | ||
96 | static struct s3c_sdhci_platdata smdkv310_hsmmc2_pdata __initdata = { | 98 | static struct s3c_sdhci_platdata smdkv310_hsmmc2_pdata __initdata = { |
97 | .cd_type = S3C_SDHCI_CD_GPIO, | 99 | .cd_type = S3C_SDHCI_CD_GPIO, |
98 | .ext_cd_gpio = S5PV310_GPK2(2), | 100 | .ext_cd_gpio = EXYNOS4_GPK2(2), |
99 | .ext_cd_gpio_invert = 1, | 101 | .ext_cd_gpio_invert = 1, |
100 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | 102 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, |
101 | #ifdef CONFIG_S5PV310_SDHCI_CH2_8BIT | 103 | #ifdef CONFIG_EXYNOS4_SDHCI_CH2_8BIT |
102 | .max_width = 8, | 104 | .max_width = 8, |
103 | .host_caps = MMC_CAP_8_BIT_DATA, | 105 | .host_caps = MMC_CAP_8_BIT_DATA, |
104 | #endif | 106 | #endif |
@@ -106,15 +108,15 @@ static struct s3c_sdhci_platdata smdkv310_hsmmc2_pdata __initdata = { | |||
106 | 108 | ||
107 | static struct s3c_sdhci_platdata smdkv310_hsmmc3_pdata __initdata = { | 109 | static struct s3c_sdhci_platdata smdkv310_hsmmc3_pdata __initdata = { |
108 | .cd_type = S3C_SDHCI_CD_GPIO, | 110 | .cd_type = S3C_SDHCI_CD_GPIO, |
109 | .ext_cd_gpio = S5PV310_GPK2(2), | 111 | .ext_cd_gpio = EXYNOS4_GPK2(2), |
110 | .ext_cd_gpio_invert = 1, | 112 | .ext_cd_gpio_invert = 1, |
111 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | 113 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, |
112 | }; | 114 | }; |
113 | 115 | ||
114 | static struct resource smdkv310_smsc911x_resources[] = { | 116 | static struct resource smdkv310_smsc911x_resources[] = { |
115 | [0] = { | 117 | [0] = { |
116 | .start = S5PV310_PA_SROM_BANK(1), | 118 | .start = EXYNOS4_PA_SROM_BANK(1), |
117 | .end = S5PV310_PA_SROM_BANK(1) + SZ_64K - 1, | 119 | .end = EXYNOS4_PA_SROM_BANK(1) + SZ_64K - 1, |
118 | .flags = IORESOURCE_MEM, | 120 | .flags = IORESOURCE_MEM, |
119 | }, | 121 | }, |
120 | [1] = { | 122 | [1] = { |
@@ -142,6 +144,25 @@ static struct platform_device smdkv310_smsc911x = { | |||
142 | }, | 144 | }, |
143 | }; | 145 | }; |
144 | 146 | ||
147 | static uint32_t smdkv310_keymap[] __initdata = { | ||
148 | /* KEY(row, col, keycode) */ | ||
149 | KEY(0, 3, KEY_1), KEY(0, 4, KEY_2), KEY(0, 5, KEY_3), | ||
150 | KEY(0, 6, KEY_4), KEY(0, 7, KEY_5), | ||
151 | KEY(1, 3, KEY_A), KEY(1, 4, KEY_B), KEY(1, 5, KEY_C), | ||
152 | KEY(1, 6, KEY_D), KEY(1, 7, KEY_E) | ||
153 | }; | ||
154 | |||
155 | static struct matrix_keymap_data smdkv310_keymap_data __initdata = { | ||
156 | .keymap = smdkv310_keymap, | ||
157 | .keymap_size = ARRAY_SIZE(smdkv310_keymap), | ||
158 | }; | ||
159 | |||
160 | static struct samsung_keypad_platdata smdkv310_keypad_data __initdata = { | ||
161 | .keymap_data = &smdkv310_keymap_data, | ||
162 | .rows = 2, | ||
163 | .cols = 8, | ||
164 | }; | ||
165 | |||
145 | static struct i2c_board_info i2c_devs1[] __initdata = { | 166 | static struct i2c_board_info i2c_devs1[] __initdata = { |
146 | {I2C_BOARD_INFO("wm8994", 0x1a),}, | 167 | {I2C_BOARD_INFO("wm8994", 0x1a),}, |
147 | }; | 168 | }; |
@@ -154,16 +175,17 @@ static struct platform_device *smdkv310_devices[] __initdata = { | |||
154 | &s3c_device_i2c1, | 175 | &s3c_device_i2c1, |
155 | &s3c_device_rtc, | 176 | &s3c_device_rtc, |
156 | &s3c_device_wdt, | 177 | &s3c_device_wdt, |
157 | &s5pv310_device_ac97, | 178 | &exynos4_device_ac97, |
158 | &s5pv310_device_i2s0, | 179 | &exynos4_device_i2s0, |
159 | &s5pv310_device_pd[PD_MFC], | 180 | &samsung_device_keypad, |
160 | &s5pv310_device_pd[PD_G3D], | 181 | &exynos4_device_pd[PD_MFC], |
161 | &s5pv310_device_pd[PD_LCD0], | 182 | &exynos4_device_pd[PD_G3D], |
162 | &s5pv310_device_pd[PD_LCD1], | 183 | &exynos4_device_pd[PD_LCD0], |
163 | &s5pv310_device_pd[PD_CAM], | 184 | &exynos4_device_pd[PD_LCD1], |
164 | &s5pv310_device_pd[PD_TV], | 185 | &exynos4_device_pd[PD_CAM], |
165 | &s5pv310_device_pd[PD_GPS], | 186 | &exynos4_device_pd[PD_TV], |
166 | &s5pv310_device_sysmmu, | 187 | &exynos4_device_pd[PD_GPS], |
188 | &exynos4_device_sysmmu, | ||
167 | &samsung_asoc_dma, | 189 | &samsung_asoc_dma, |
168 | &smdkv310_smsc911x, | 190 | &smdkv310_smsc911x, |
169 | }; | 191 | }; |
@@ -210,6 +232,8 @@ static void __init smdkv310_machine_init(void) | |||
210 | s3c_sdhci2_set_platdata(&smdkv310_hsmmc2_pdata); | 232 | s3c_sdhci2_set_platdata(&smdkv310_hsmmc2_pdata); |
211 | s3c_sdhci3_set_platdata(&smdkv310_hsmmc3_pdata); | 233 | s3c_sdhci3_set_platdata(&smdkv310_hsmmc3_pdata); |
212 | 234 | ||
235 | samsung_keypad_set_platdata(&smdkv310_keypad_data); | ||
236 | |||
213 | platform_add_devices(smdkv310_devices, ARRAY_SIZE(smdkv310_devices)); | 237 | platform_add_devices(smdkv310_devices, ARRAY_SIZE(smdkv310_devices)); |
214 | } | 238 | } |
215 | 239 | ||
@@ -217,8 +241,8 @@ MACHINE_START(SMDKV310, "SMDKV310") | |||
217 | /* Maintainer: Kukjin Kim <kgene.kim@samsung.com> */ | 241 | /* Maintainer: Kukjin Kim <kgene.kim@samsung.com> */ |
218 | /* Maintainer: Changhwan Youn <chaos.youn@samsung.com> */ | 242 | /* Maintainer: Changhwan Youn <chaos.youn@samsung.com> */ |
219 | .boot_params = S5P_PA_SDRAM + 0x100, | 243 | .boot_params = S5P_PA_SDRAM + 0x100, |
220 | .init_irq = s5pv310_init_irq, | 244 | .init_irq = exynos4_init_irq, |
221 | .map_io = smdkv310_map_io, | 245 | .map_io = smdkv310_map_io, |
222 | .init_machine = smdkv310_machine_init, | 246 | .init_machine = smdkv310_machine_init, |
223 | .timer = &s5pv310_timer, | 247 | .timer = &exynos4_timer, |
224 | MACHINE_END | 248 | MACHINE_END |
diff --git a/arch/arm/mach-exynos4/mach-universal_c210.c b/arch/arm/mach-exynos4/mach-universal_c210.c new file mode 100644 index 000000000000..97d329fff2cf --- /dev/null +++ b/arch/arm/mach-exynos4/mach-universal_c210.c | |||
@@ -0,0 +1,650 @@ | |||
1 | /* linux/arch/arm/mach-exynos4/mach-universal_c210.c | ||
2 | * | ||
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | ||
4 | * | ||
5 | * This program is free software; you can redistribute it and/or modify | ||
6 | * it under the terms of the GNU General Public License version 2 as | ||
7 | * published by the Free Software Foundation. | ||
8 | */ | ||
9 | |||
10 | #include <linux/platform_device.h> | ||
11 | #include <linux/serial_core.h> | ||
12 | #include <linux/input.h> | ||
13 | #include <linux/i2c.h> | ||
14 | #include <linux/gpio_keys.h> | ||
15 | #include <linux/gpio.h> | ||
16 | #include <linux/mfd/max8998.h> | ||
17 | #include <linux/regulator/machine.h> | ||
18 | #include <linux/regulator/fixed.h> | ||
19 | #include <linux/regulator/max8952.h> | ||
20 | #include <linux/mmc/host.h> | ||
21 | |||
22 | #include <asm/mach/arch.h> | ||
23 | #include <asm/mach-types.h> | ||
24 | |||
25 | #include <plat/regs-serial.h> | ||
26 | #include <plat/exynos4.h> | ||
27 | #include <plat/cpu.h> | ||
28 | #include <plat/devs.h> | ||
29 | #include <plat/iic.h> | ||
30 | #include <plat/sdhci.h> | ||
31 | |||
32 | #include <mach/map.h> | ||
33 | |||
34 | /* Following are default values for UCON, ULCON and UFCON UART registers */ | ||
35 | #define UNIVERSAL_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ | ||
36 | S3C2410_UCON_RXILEVEL | \ | ||
37 | S3C2410_UCON_TXIRQMODE | \ | ||
38 | S3C2410_UCON_RXIRQMODE | \ | ||
39 | S3C2410_UCON_RXFIFO_TOI | \ | ||
40 | S3C2443_UCON_RXERR_IRQEN) | ||
41 | |||
42 | #define UNIVERSAL_ULCON_DEFAULT S3C2410_LCON_CS8 | ||
43 | |||
44 | #define UNIVERSAL_UFCON_DEFAULT (S3C2410_UFCON_FIFOMODE | \ | ||
45 | S5PV210_UFCON_TXTRIG256 | \ | ||
46 | S5PV210_UFCON_RXTRIG256) | ||
47 | |||
48 | static struct s3c2410_uartcfg universal_uartcfgs[] __initdata = { | ||
49 | [0] = { | ||
50 | .hwport = 0, | ||
51 | .ucon = UNIVERSAL_UCON_DEFAULT, | ||
52 | .ulcon = UNIVERSAL_ULCON_DEFAULT, | ||
53 | .ufcon = UNIVERSAL_UFCON_DEFAULT, | ||
54 | }, | ||
55 | [1] = { | ||
56 | .hwport = 1, | ||
57 | .ucon = UNIVERSAL_UCON_DEFAULT, | ||
58 | .ulcon = UNIVERSAL_ULCON_DEFAULT, | ||
59 | .ufcon = UNIVERSAL_UFCON_DEFAULT, | ||
60 | }, | ||
61 | [2] = { | ||
62 | .hwport = 2, | ||
63 | .ucon = UNIVERSAL_UCON_DEFAULT, | ||
64 | .ulcon = UNIVERSAL_ULCON_DEFAULT, | ||
65 | .ufcon = UNIVERSAL_UFCON_DEFAULT, | ||
66 | }, | ||
67 | [3] = { | ||
68 | .hwport = 3, | ||
69 | .ucon = UNIVERSAL_UCON_DEFAULT, | ||
70 | .ulcon = UNIVERSAL_ULCON_DEFAULT, | ||
71 | .ufcon = UNIVERSAL_UFCON_DEFAULT, | ||
72 | }, | ||
73 | }; | ||
74 | |||
75 | static struct regulator_consumer_supply max8952_consumer = | ||
76 | REGULATOR_SUPPLY("vddarm", NULL); | ||
77 | |||
78 | static struct max8952_platform_data universal_max8952_pdata __initdata = { | ||
79 | .gpio_vid0 = EXYNOS4_GPX0(3), | ||
80 | .gpio_vid1 = EXYNOS4_GPX0(4), | ||
81 | .gpio_en = -1, /* Not controllable, set "Always High" */ | ||
82 | .default_mode = 0, /* vid0 = 0, vid1 = 0 */ | ||
83 | .dvs_mode = { 48, 32, 28, 18 }, /* 1.25, 1.20, 1.05, 0.95V */ | ||
84 | .sync_freq = 0, /* default: fastest */ | ||
85 | .ramp_speed = 0, /* default: fastest */ | ||
86 | |||
87 | .reg_data = { | ||
88 | .constraints = { | ||
89 | .name = "VARM_1.2V", | ||
90 | .min_uV = 770000, | ||
91 | .max_uV = 1400000, | ||
92 | .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE, | ||
93 | .always_on = 1, | ||
94 | .boot_on = 1, | ||
95 | }, | ||
96 | .num_consumer_supplies = 1, | ||
97 | .consumer_supplies = &max8952_consumer, | ||
98 | }, | ||
99 | }; | ||
100 | |||
101 | static struct regulator_consumer_supply lp3974_buck1_consumer = | ||
102 | REGULATOR_SUPPLY("vddint", NULL); | ||
103 | |||
104 | static struct regulator_consumer_supply lp3974_buck2_consumer = | ||
105 | REGULATOR_SUPPLY("vddg3d", NULL); | ||
106 | |||
107 | static struct regulator_init_data lp3974_buck1_data = { | ||
108 | .constraints = { | ||
109 | .name = "VINT_1.1V", | ||
110 | .min_uV = 750000, | ||
111 | .max_uV = 1500000, | ||
112 | .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE | | ||
113 | REGULATOR_CHANGE_STATUS, | ||
114 | .boot_on = 1, | ||
115 | .state_mem = { | ||
116 | .disabled = 1, | ||
117 | }, | ||
118 | }, | ||
119 | .num_consumer_supplies = 1, | ||
120 | .consumer_supplies = &lp3974_buck1_consumer, | ||
121 | }; | ||
122 | |||
123 | static struct regulator_init_data lp3974_buck2_data = { | ||
124 | .constraints = { | ||
125 | .name = "VG3D_1.1V", | ||
126 | .min_uV = 750000, | ||
127 | .max_uV = 1500000, | ||
128 | .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE | | ||
129 | REGULATOR_CHANGE_STATUS, | ||
130 | .boot_on = 1, | ||
131 | .state_mem = { | ||
132 | .disabled = 1, | ||
133 | }, | ||
134 | }, | ||
135 | .num_consumer_supplies = 1, | ||
136 | .consumer_supplies = &lp3974_buck2_consumer, | ||
137 | }; | ||
138 | |||
139 | static struct regulator_init_data lp3974_buck3_data = { | ||
140 | .constraints = { | ||
141 | .name = "VCC_1.8V", | ||
142 | .min_uV = 1800000, | ||
143 | .max_uV = 1800000, | ||
144 | .apply_uV = 1, | ||
145 | .always_on = 1, | ||
146 | .state_mem = { | ||
147 | .enabled = 1, | ||
148 | }, | ||
149 | }, | ||
150 | }; | ||
151 | |||
152 | static struct regulator_init_data lp3974_buck4_data = { | ||
153 | .constraints = { | ||
154 | .name = "VMEM_1.2V", | ||
155 | .min_uV = 1200000, | ||
156 | .max_uV = 1200000, | ||
157 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
158 | .apply_uV = 1, | ||
159 | .state_mem = { | ||
160 | .disabled = 1, | ||
161 | }, | ||
162 | }, | ||
163 | }; | ||
164 | |||
165 | static struct regulator_init_data lp3974_ldo2_data = { | ||
166 | .constraints = { | ||
167 | .name = "VALIVE_1.2V", | ||
168 | .min_uV = 1200000, | ||
169 | .max_uV = 1200000, | ||
170 | .apply_uV = 1, | ||
171 | .always_on = 1, | ||
172 | .state_mem = { | ||
173 | .enabled = 1, | ||
174 | }, | ||
175 | }, | ||
176 | }; | ||
177 | |||
178 | static struct regulator_init_data lp3974_ldo3_data = { | ||
179 | .constraints = { | ||
180 | .name = "VUSB+MIPI_1.1V", | ||
181 | .min_uV = 1100000, | ||
182 | .max_uV = 1100000, | ||
183 | .apply_uV = 1, | ||
184 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
185 | .state_mem = { | ||
186 | .disabled = 1, | ||
187 | }, | ||
188 | }, | ||
189 | }; | ||
190 | |||
191 | static struct regulator_init_data lp3974_ldo4_data = { | ||
192 | .constraints = { | ||
193 | .name = "VADC_3.3V", | ||
194 | .min_uV = 3300000, | ||
195 | .max_uV = 3300000, | ||
196 | .apply_uV = 1, | ||
197 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
198 | .state_mem = { | ||
199 | .disabled = 1, | ||
200 | }, | ||
201 | }, | ||
202 | }; | ||
203 | |||
204 | static struct regulator_init_data lp3974_ldo5_data = { | ||
205 | .constraints = { | ||
206 | .name = "VTF_2.8V", | ||
207 | .min_uV = 2800000, | ||
208 | .max_uV = 2800000, | ||
209 | .apply_uV = 1, | ||
210 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
211 | .state_mem = { | ||
212 | .disabled = 1, | ||
213 | }, | ||
214 | }, | ||
215 | }; | ||
216 | |||
217 | static struct regulator_init_data lp3974_ldo6_data = { | ||
218 | .constraints = { | ||
219 | .name = "LDO6", | ||
220 | .min_uV = 2000000, | ||
221 | .max_uV = 2000000, | ||
222 | .apply_uV = 1, | ||
223 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
224 | .state_mem = { | ||
225 | .disabled = 1, | ||
226 | }, | ||
227 | }, | ||
228 | }; | ||
229 | |||
230 | static struct regulator_init_data lp3974_ldo7_data = { | ||
231 | .constraints = { | ||
232 | .name = "VLCD+VMIPI_1.8V", | ||
233 | .min_uV = 1800000, | ||
234 | .max_uV = 1800000, | ||
235 | .apply_uV = 1, | ||
236 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
237 | .state_mem = { | ||
238 | .disabled = 1, | ||
239 | }, | ||
240 | }, | ||
241 | }; | ||
242 | |||
243 | static struct regulator_init_data lp3974_ldo8_data = { | ||
244 | .constraints = { | ||
245 | .name = "VUSB+VDAC_3.3V", | ||
246 | .min_uV = 3300000, | ||
247 | .max_uV = 3300000, | ||
248 | .apply_uV = 1, | ||
249 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
250 | .state_mem = { | ||
251 | .disabled = 1, | ||
252 | }, | ||
253 | }, | ||
254 | }; | ||
255 | |||
256 | static struct regulator_init_data lp3974_ldo9_data = { | ||
257 | .constraints = { | ||
258 | .name = "VCC_2.8V", | ||
259 | .min_uV = 2800000, | ||
260 | .max_uV = 2800000, | ||
261 | .apply_uV = 1, | ||
262 | .always_on = 1, | ||
263 | .state_mem = { | ||
264 | .enabled = 1, | ||
265 | }, | ||
266 | }, | ||
267 | }; | ||
268 | |||
269 | static struct regulator_init_data lp3974_ldo10_data = { | ||
270 | .constraints = { | ||
271 | .name = "VPLL_1.1V", | ||
272 | .min_uV = 1100000, | ||
273 | .max_uV = 1100000, | ||
274 | .boot_on = 1, | ||
275 | .apply_uV = 1, | ||
276 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
277 | .state_mem = { | ||
278 | .disabled = 1, | ||
279 | }, | ||
280 | }, | ||
281 | }; | ||
282 | |||
283 | static struct regulator_init_data lp3974_ldo11_data = { | ||
284 | .constraints = { | ||
285 | .name = "CAM_AF_3.3V", | ||
286 | .min_uV = 3300000, | ||
287 | .max_uV = 3300000, | ||
288 | .apply_uV = 1, | ||
289 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
290 | .state_mem = { | ||
291 | .disabled = 1, | ||
292 | }, | ||
293 | }, | ||
294 | }; | ||
295 | |||
296 | static struct regulator_init_data lp3974_ldo12_data = { | ||
297 | .constraints = { | ||
298 | .name = "PS_2.8V", | ||
299 | .min_uV = 2800000, | ||
300 | .max_uV = 2800000, | ||
301 | .apply_uV = 1, | ||
302 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
303 | .state_mem = { | ||
304 | .disabled = 1, | ||
305 | }, | ||
306 | }, | ||
307 | }; | ||
308 | |||
309 | static struct regulator_init_data lp3974_ldo13_data = { | ||
310 | .constraints = { | ||
311 | .name = "VHIC_1.2V", | ||
312 | .min_uV = 1200000, | ||
313 | .max_uV = 1200000, | ||
314 | .apply_uV = 1, | ||
315 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
316 | .state_mem = { | ||
317 | .disabled = 1, | ||
318 | }, | ||
319 | }, | ||
320 | }; | ||
321 | |||
322 | static struct regulator_init_data lp3974_ldo14_data = { | ||
323 | .constraints = { | ||
324 | .name = "CAM_I_HOST_1.8V", | ||
325 | .min_uV = 1800000, | ||
326 | .max_uV = 1800000, | ||
327 | .apply_uV = 1, | ||
328 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
329 | .state_mem = { | ||
330 | .disabled = 1, | ||
331 | }, | ||
332 | }, | ||
333 | }; | ||
334 | |||
335 | static struct regulator_init_data lp3974_ldo15_data = { | ||
336 | .constraints = { | ||
337 | .name = "CAM_S_DIG+FM33_CORE_1.2V", | ||
338 | .min_uV = 1200000, | ||
339 | .max_uV = 1200000, | ||
340 | .apply_uV = 1, | ||
341 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
342 | .state_mem = { | ||
343 | .disabled = 1, | ||
344 | }, | ||
345 | }, | ||
346 | }; | ||
347 | |||
348 | static struct regulator_init_data lp3974_ldo16_data = { | ||
349 | .constraints = { | ||
350 | .name = "CAM_S_ANA_2.8V", | ||
351 | .min_uV = 2800000, | ||
352 | .max_uV = 2800000, | ||
353 | .apply_uV = 1, | ||
354 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
355 | .state_mem = { | ||
356 | .disabled = 1, | ||
357 | }, | ||
358 | }, | ||
359 | }; | ||
360 | |||
361 | static struct regulator_init_data lp3974_ldo17_data = { | ||
362 | .constraints = { | ||
363 | .name = "VCC_3.0V_LCD", | ||
364 | .min_uV = 3000000, | ||
365 | .max_uV = 3000000, | ||
366 | .apply_uV = 1, | ||
367 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
368 | .boot_on = 1, | ||
369 | .state_mem = { | ||
370 | .disabled = 1, | ||
371 | }, | ||
372 | }, | ||
373 | }; | ||
374 | |||
375 | static struct regulator_init_data lp3974_32khz_ap_data = { | ||
376 | .constraints = { | ||
377 | .name = "32KHz AP", | ||
378 | .always_on = 1, | ||
379 | .state_mem = { | ||
380 | .enabled = 1, | ||
381 | }, | ||
382 | }, | ||
383 | }; | ||
384 | |||
385 | static struct regulator_init_data lp3974_32khz_cp_data = { | ||
386 | .constraints = { | ||
387 | .name = "32KHz CP", | ||
388 | .state_mem = { | ||
389 | .disabled = 1, | ||
390 | }, | ||
391 | }, | ||
392 | }; | ||
393 | |||
394 | static struct regulator_init_data lp3974_vichg_data = { | ||
395 | .constraints = { | ||
396 | .name = "VICHG", | ||
397 | .state_mem = { | ||
398 | .disabled = 1, | ||
399 | }, | ||
400 | }, | ||
401 | }; | ||
402 | |||
403 | static struct regulator_init_data lp3974_esafeout1_data = { | ||
404 | .constraints = { | ||
405 | .name = "SAFEOUT1", | ||
406 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
407 | .state_mem = { | ||
408 | .enabled = 1, | ||
409 | }, | ||
410 | }, | ||
411 | }; | ||
412 | |||
413 | static struct regulator_init_data lp3974_esafeout2_data = { | ||
414 | .constraints = { | ||
415 | .name = "SAFEOUT2", | ||
416 | .boot_on = 1, | ||
417 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
418 | .state_mem = { | ||
419 | .enabled = 1, | ||
420 | }, | ||
421 | }, | ||
422 | }; | ||
423 | |||
424 | static struct max8998_regulator_data lp3974_regulators[] = { | ||
425 | { MAX8998_LDO2, &lp3974_ldo2_data }, | ||
426 | { MAX8998_LDO3, &lp3974_ldo3_data }, | ||
427 | { MAX8998_LDO4, &lp3974_ldo4_data }, | ||
428 | { MAX8998_LDO5, &lp3974_ldo5_data }, | ||
429 | { MAX8998_LDO6, &lp3974_ldo6_data }, | ||
430 | { MAX8998_LDO7, &lp3974_ldo7_data }, | ||
431 | { MAX8998_LDO8, &lp3974_ldo8_data }, | ||
432 | { MAX8998_LDO9, &lp3974_ldo9_data }, | ||
433 | { MAX8998_LDO10, &lp3974_ldo10_data }, | ||
434 | { MAX8998_LDO11, &lp3974_ldo11_data }, | ||
435 | { MAX8998_LDO12, &lp3974_ldo12_data }, | ||
436 | { MAX8998_LDO13, &lp3974_ldo13_data }, | ||
437 | { MAX8998_LDO14, &lp3974_ldo14_data }, | ||
438 | { MAX8998_LDO15, &lp3974_ldo15_data }, | ||
439 | { MAX8998_LDO16, &lp3974_ldo16_data }, | ||
440 | { MAX8998_LDO17, &lp3974_ldo17_data }, | ||
441 | { MAX8998_BUCK1, &lp3974_buck1_data }, | ||
442 | { MAX8998_BUCK2, &lp3974_buck2_data }, | ||
443 | { MAX8998_BUCK3, &lp3974_buck3_data }, | ||
444 | { MAX8998_BUCK4, &lp3974_buck4_data }, | ||
445 | { MAX8998_EN32KHZ_AP, &lp3974_32khz_ap_data }, | ||
446 | { MAX8998_EN32KHZ_CP, &lp3974_32khz_cp_data }, | ||
447 | { MAX8998_ENVICHG, &lp3974_vichg_data }, | ||
448 | { MAX8998_ESAFEOUT1, &lp3974_esafeout1_data }, | ||
449 | { MAX8998_ESAFEOUT2, &lp3974_esafeout2_data }, | ||
450 | }; | ||
451 | |||
452 | static struct max8998_platform_data universal_lp3974_pdata = { | ||
453 | .num_regulators = ARRAY_SIZE(lp3974_regulators), | ||
454 | .regulators = lp3974_regulators, | ||
455 | .buck1_voltage1 = 1100000, /* INT */ | ||
456 | .buck1_voltage2 = 1000000, | ||
457 | .buck1_voltage3 = 1100000, | ||
458 | .buck1_voltage4 = 1000000, | ||
459 | .buck1_set1 = EXYNOS4_GPX0(5), | ||
460 | .buck1_set2 = EXYNOS4_GPX0(6), | ||
461 | .buck2_voltage1 = 1200000, /* G3D */ | ||
462 | .buck2_voltage2 = 1100000, | ||
463 | .buck1_default_idx = 0, | ||
464 | .buck2_set3 = EXYNOS4_GPE2(0), | ||
465 | .buck2_default_idx = 0, | ||
466 | .wakeup = true, | ||
467 | }; | ||
468 | |||
469 | /* GPIO I2C 5 (PMIC) */ | ||
470 | static struct i2c_board_info i2c5_devs[] __initdata = { | ||
471 | { | ||
472 | I2C_BOARD_INFO("max8952", 0xC0 >> 1), | ||
473 | .platform_data = &universal_max8952_pdata, | ||
474 | }, { | ||
475 | I2C_BOARD_INFO("lp3974", 0xCC >> 1), | ||
476 | .platform_data = &universal_lp3974_pdata, | ||
477 | }, | ||
478 | }; | ||
479 | |||
480 | /* GPIO KEYS */ | ||
481 | static struct gpio_keys_button universal_gpio_keys_tables[] = { | ||
482 | { | ||
483 | .code = KEY_VOLUMEUP, | ||
484 | .gpio = EXYNOS4_GPX2(0), /* XEINT16 */ | ||
485 | .desc = "gpio-keys: KEY_VOLUMEUP", | ||
486 | .type = EV_KEY, | ||
487 | .active_low = 1, | ||
488 | .debounce_interval = 1, | ||
489 | }, { | ||
490 | .code = KEY_VOLUMEDOWN, | ||
491 | .gpio = EXYNOS4_GPX2(1), /* XEINT17 */ | ||
492 | .desc = "gpio-keys: KEY_VOLUMEDOWN", | ||
493 | .type = EV_KEY, | ||
494 | .active_low = 1, | ||
495 | .debounce_interval = 1, | ||
496 | }, { | ||
497 | .code = KEY_CONFIG, | ||
498 | .gpio = EXYNOS4_GPX2(2), /* XEINT18 */ | ||
499 | .desc = "gpio-keys: KEY_CONFIG", | ||
500 | .type = EV_KEY, | ||
501 | .active_low = 1, | ||
502 | .debounce_interval = 1, | ||
503 | }, { | ||
504 | .code = KEY_CAMERA, | ||
505 | .gpio = EXYNOS4_GPX2(3), /* XEINT19 */ | ||
506 | .desc = "gpio-keys: KEY_CAMERA", | ||
507 | .type = EV_KEY, | ||
508 | .active_low = 1, | ||
509 | .debounce_interval = 1, | ||
510 | }, { | ||
511 | .code = KEY_OK, | ||
512 | .gpio = EXYNOS4_GPX3(5), /* XEINT29 */ | ||
513 | .desc = "gpio-keys: KEY_OK", | ||
514 | .type = EV_KEY, | ||
515 | .active_low = 1, | ||
516 | .debounce_interval = 1, | ||
517 | }, | ||
518 | }; | ||
519 | |||
520 | static struct gpio_keys_platform_data universal_gpio_keys_data = { | ||
521 | .buttons = universal_gpio_keys_tables, | ||
522 | .nbuttons = ARRAY_SIZE(universal_gpio_keys_tables), | ||
523 | }; | ||
524 | |||
525 | static struct platform_device universal_gpio_keys = { | ||
526 | .name = "gpio-keys", | ||
527 | .dev = { | ||
528 | .platform_data = &universal_gpio_keys_data, | ||
529 | }, | ||
530 | }; | ||
531 | |||
532 | /* eMMC */ | ||
533 | static struct s3c_sdhci_platdata universal_hsmmc0_data __initdata = { | ||
534 | .max_width = 8, | ||
535 | .host_caps = (MMC_CAP_8_BIT_DATA | MMC_CAP_4_BIT_DATA | | ||
536 | MMC_CAP_MMC_HIGHSPEED | MMC_CAP_SD_HIGHSPEED | | ||
537 | MMC_CAP_DISABLE), | ||
538 | .cd_type = S3C_SDHCI_CD_PERMANENT, | ||
539 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | ||
540 | }; | ||
541 | |||
542 | static struct regulator_consumer_supply mmc0_supplies[] = { | ||
543 | REGULATOR_SUPPLY("vmmc", "s3c-sdhci.0"), | ||
544 | }; | ||
545 | |||
546 | static struct regulator_init_data mmc0_fixed_voltage_init_data = { | ||
547 | .constraints = { | ||
548 | .name = "VMEM_VDD_2.8V", | ||
549 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
550 | }, | ||
551 | .num_consumer_supplies = ARRAY_SIZE(mmc0_supplies), | ||
552 | .consumer_supplies = mmc0_supplies, | ||
553 | }; | ||
554 | |||
555 | static struct fixed_voltage_config mmc0_fixed_voltage_config = { | ||
556 | .supply_name = "MASSMEMORY_EN", | ||
557 | .microvolts = 2800000, | ||
558 | .gpio = EXYNOS4_GPE1(3), | ||
559 | .enable_high = true, | ||
560 | .init_data = &mmc0_fixed_voltage_init_data, | ||
561 | }; | ||
562 | |||
563 | static struct platform_device mmc0_fixed_voltage = { | ||
564 | .name = "reg-fixed-voltage", | ||
565 | .id = 0, | ||
566 | .dev = { | ||
567 | .platform_data = &mmc0_fixed_voltage_config, | ||
568 | }, | ||
569 | }; | ||
570 | |||
571 | /* SD */ | ||
572 | static struct s3c_sdhci_platdata universal_hsmmc2_data __initdata = { | ||
573 | .max_width = 4, | ||
574 | .host_caps = MMC_CAP_4_BIT_DATA | | ||
575 | MMC_CAP_MMC_HIGHSPEED | MMC_CAP_SD_HIGHSPEED | | ||
576 | MMC_CAP_DISABLE, | ||
577 | .ext_cd_gpio = EXYNOS4_GPX3(4), /* XEINT_28 */ | ||
578 | .ext_cd_gpio_invert = 1, | ||
579 | .cd_type = S3C_SDHCI_CD_GPIO, | ||
580 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | ||
581 | }; | ||
582 | |||
583 | /* WiFi */ | ||
584 | static struct s3c_sdhci_platdata universal_hsmmc3_data __initdata = { | ||
585 | .max_width = 4, | ||
586 | .host_caps = MMC_CAP_4_BIT_DATA | | ||
587 | MMC_CAP_MMC_HIGHSPEED | MMC_CAP_SD_HIGHSPEED | | ||
588 | MMC_CAP_DISABLE, | ||
589 | .cd_type = S3C_SDHCI_CD_EXTERNAL, | ||
590 | }; | ||
591 | |||
592 | static void __init universal_sdhci_init(void) | ||
593 | { | ||
594 | s3c_sdhci0_set_platdata(&universal_hsmmc0_data); | ||
595 | s3c_sdhci2_set_platdata(&universal_hsmmc2_data); | ||
596 | s3c_sdhci3_set_platdata(&universal_hsmmc3_data); | ||
597 | } | ||
598 | |||
599 | /* I2C0 */ | ||
600 | static struct i2c_board_info i2c0_devs[] __initdata = { | ||
601 | /* Camera, To be updated */ | ||
602 | }; | ||
603 | |||
604 | /* I2C1 */ | ||
605 | static struct i2c_board_info i2c1_devs[] __initdata = { | ||
606 | /* Gyro, To be updated */ | ||
607 | }; | ||
608 | |||
609 | static struct platform_device *universal_devices[] __initdata = { | ||
610 | /* Samsung Platform Devices */ | ||
611 | &mmc0_fixed_voltage, | ||
612 | &s3c_device_hsmmc0, | ||
613 | &s3c_device_hsmmc2, | ||
614 | &s3c_device_hsmmc3, | ||
615 | &s3c_device_i2c5, | ||
616 | |||
617 | /* Universal Devices */ | ||
618 | &universal_gpio_keys, | ||
619 | &s5p_device_onenand, | ||
620 | }; | ||
621 | |||
622 | static void __init universal_map_io(void) | ||
623 | { | ||
624 | s5p_init_io(NULL, 0, S5P_VA_CHIPID); | ||
625 | s3c24xx_init_clocks(24000000); | ||
626 | s3c24xx_init_uarts(universal_uartcfgs, ARRAY_SIZE(universal_uartcfgs)); | ||
627 | } | ||
628 | |||
629 | static void __init universal_machine_init(void) | ||
630 | { | ||
631 | universal_sdhci_init(); | ||
632 | |||
633 | i2c_register_board_info(0, i2c0_devs, ARRAY_SIZE(i2c0_devs)); | ||
634 | i2c_register_board_info(1, i2c1_devs, ARRAY_SIZE(i2c1_devs)); | ||
635 | |||
636 | s3c_i2c5_set_platdata(NULL); | ||
637 | i2c_register_board_info(5, i2c5_devs, ARRAY_SIZE(i2c5_devs)); | ||
638 | |||
639 | /* Last */ | ||
640 | platform_add_devices(universal_devices, ARRAY_SIZE(universal_devices)); | ||
641 | } | ||
642 | |||
643 | MACHINE_START(UNIVERSAL_C210, "UNIVERSAL_C210") | ||
644 | /* Maintainer: Kyungmin Park <kyungmin.park@samsung.com> */ | ||
645 | .boot_params = S5P_PA_SDRAM + 0x100, | ||
646 | .init_irq = exynos4_init_irq, | ||
647 | .map_io = universal_map_io, | ||
648 | .init_machine = universal_machine_init, | ||
649 | .timer = &exynos4_timer, | ||
650 | MACHINE_END | ||
diff --git a/arch/arm/mach-exynos4/mct.c b/arch/arm/mach-exynos4/mct.c new file mode 100644 index 000000000000..af82a8fbb68b --- /dev/null +++ b/arch/arm/mach-exynos4/mct.c | |||
@@ -0,0 +1,421 @@ | |||
1 | /* linux/arch/arm/mach-exynos4/mct.c | ||
2 | * | ||
3 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * EXYNOS4 MCT(Multi-Core Timer) support | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #include <linux/sched.h> | ||
14 | #include <linux/interrupt.h> | ||
15 | #include <linux/irq.h> | ||
16 | #include <linux/err.h> | ||
17 | #include <linux/clk.h> | ||
18 | #include <linux/clockchips.h> | ||
19 | #include <linux/platform_device.h> | ||
20 | #include <linux/delay.h> | ||
21 | #include <linux/percpu.h> | ||
22 | |||
23 | #include <mach/map.h> | ||
24 | #include <mach/regs-mct.h> | ||
25 | #include <asm/mach/time.h> | ||
26 | |||
27 | static unsigned long clk_cnt_per_tick; | ||
28 | static unsigned long clk_rate; | ||
29 | |||
30 | struct mct_clock_event_device { | ||
31 | struct clock_event_device *evt; | ||
32 | void __iomem *base; | ||
33 | }; | ||
34 | |||
35 | struct mct_clock_event_device mct_tick[2]; | ||
36 | |||
37 | static void exynos4_mct_write(unsigned int value, void *addr) | ||
38 | { | ||
39 | void __iomem *stat_addr; | ||
40 | u32 mask; | ||
41 | u32 i; | ||
42 | |||
43 | __raw_writel(value, addr); | ||
44 | |||
45 | switch ((u32) addr) { | ||
46 | case (u32) EXYNOS4_MCT_G_TCON: | ||
47 | stat_addr = EXYNOS4_MCT_G_WSTAT; | ||
48 | mask = 1 << 16; /* G_TCON write status */ | ||
49 | break; | ||
50 | case (u32) EXYNOS4_MCT_G_COMP0_L: | ||
51 | stat_addr = EXYNOS4_MCT_G_WSTAT; | ||
52 | mask = 1 << 0; /* G_COMP0_L write status */ | ||
53 | break; | ||
54 | case (u32) EXYNOS4_MCT_G_COMP0_U: | ||
55 | stat_addr = EXYNOS4_MCT_G_WSTAT; | ||
56 | mask = 1 << 1; /* G_COMP0_U write status */ | ||
57 | break; | ||
58 | case (u32) EXYNOS4_MCT_G_COMP0_ADD_INCR: | ||
59 | stat_addr = EXYNOS4_MCT_G_WSTAT; | ||
60 | mask = 1 << 2; /* G_COMP0_ADD_INCR write status */ | ||
61 | break; | ||
62 | case (u32) EXYNOS4_MCT_G_CNT_L: | ||
63 | stat_addr = EXYNOS4_MCT_G_CNT_WSTAT; | ||
64 | mask = 1 << 0; /* G_CNT_L write status */ | ||
65 | break; | ||
66 | case (u32) EXYNOS4_MCT_G_CNT_U: | ||
67 | stat_addr = EXYNOS4_MCT_G_CNT_WSTAT; | ||
68 | mask = 1 << 1; /* G_CNT_U write status */ | ||
69 | break; | ||
70 | case (u32)(EXYNOS4_MCT_L0_BASE + MCT_L_TCON_OFFSET): | ||
71 | stat_addr = EXYNOS4_MCT_L0_BASE + MCT_L_WSTAT_OFFSET; | ||
72 | mask = 1 << 3; /* L0_TCON write status */ | ||
73 | break; | ||
74 | case (u32)(EXYNOS4_MCT_L1_BASE + MCT_L_TCON_OFFSET): | ||
75 | stat_addr = EXYNOS4_MCT_L1_BASE + MCT_L_WSTAT_OFFSET; | ||
76 | mask = 1 << 3; /* L1_TCON write status */ | ||
77 | break; | ||
78 | case (u32)(EXYNOS4_MCT_L0_BASE + MCT_L_TCNTB_OFFSET): | ||
79 | stat_addr = EXYNOS4_MCT_L0_BASE + MCT_L_WSTAT_OFFSET; | ||
80 | mask = 1 << 0; /* L0_TCNTB write status */ | ||
81 | break; | ||
82 | case (u32)(EXYNOS4_MCT_L1_BASE + MCT_L_TCNTB_OFFSET): | ||
83 | stat_addr = EXYNOS4_MCT_L1_BASE + MCT_L_WSTAT_OFFSET; | ||
84 | mask = 1 << 0; /* L1_TCNTB write status */ | ||
85 | break; | ||
86 | case (u32)(EXYNOS4_MCT_L0_BASE + MCT_L_ICNTB_OFFSET): | ||
87 | stat_addr = EXYNOS4_MCT_L0_BASE + MCT_L_WSTAT_OFFSET; | ||
88 | mask = 1 << 1; /* L0_ICNTB write status */ | ||
89 | break; | ||
90 | case (u32)(EXYNOS4_MCT_L1_BASE + MCT_L_ICNTB_OFFSET): | ||
91 | stat_addr = EXYNOS4_MCT_L1_BASE + MCT_L_WSTAT_OFFSET; | ||
92 | mask = 1 << 1; /* L1_ICNTB write status */ | ||
93 | break; | ||
94 | default: | ||
95 | return; | ||
96 | } | ||
97 | |||
98 | /* Wait maximum 1 ms until written values are applied */ | ||
99 | for (i = 0; i < loops_per_jiffy / 1000 * HZ; i++) | ||
100 | if (__raw_readl(stat_addr) & mask) { | ||
101 | __raw_writel(mask, stat_addr); | ||
102 | return; | ||
103 | } | ||
104 | |||
105 | panic("MCT hangs after writing %d (addr:0x%08x)\n", value, (u32)addr); | ||
106 | } | ||
107 | |||
108 | /* Clocksource handling */ | ||
109 | static void exynos4_mct_frc_start(u32 hi, u32 lo) | ||
110 | { | ||
111 | u32 reg; | ||
112 | |||
113 | exynos4_mct_write(lo, EXYNOS4_MCT_G_CNT_L); | ||
114 | exynos4_mct_write(hi, EXYNOS4_MCT_G_CNT_U); | ||
115 | |||
116 | reg = __raw_readl(EXYNOS4_MCT_G_TCON); | ||
117 | reg |= MCT_G_TCON_START; | ||
118 | exynos4_mct_write(reg, EXYNOS4_MCT_G_TCON); | ||
119 | } | ||
120 | |||
121 | static cycle_t exynos4_frc_read(struct clocksource *cs) | ||
122 | { | ||
123 | unsigned int lo, hi; | ||
124 | u32 hi2 = __raw_readl(EXYNOS4_MCT_G_CNT_U); | ||
125 | |||
126 | do { | ||
127 | hi = hi2; | ||
128 | lo = __raw_readl(EXYNOS4_MCT_G_CNT_L); | ||
129 | hi2 = __raw_readl(EXYNOS4_MCT_G_CNT_U); | ||
130 | } while (hi != hi2); | ||
131 | |||
132 | return ((cycle_t)hi << 32) | lo; | ||
133 | } | ||
134 | |||
135 | struct clocksource mct_frc = { | ||
136 | .name = "mct-frc", | ||
137 | .rating = 400, | ||
138 | .read = exynos4_frc_read, | ||
139 | .mask = CLOCKSOURCE_MASK(64), | ||
140 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, | ||
141 | }; | ||
142 | |||
143 | static void __init exynos4_clocksource_init(void) | ||
144 | { | ||
145 | exynos4_mct_frc_start(0, 0); | ||
146 | |||
147 | if (clocksource_register_hz(&mct_frc, clk_rate)) | ||
148 | panic("%s: can't register clocksource\n", mct_frc.name); | ||
149 | } | ||
150 | |||
151 | static void exynos4_mct_comp0_stop(void) | ||
152 | { | ||
153 | unsigned int tcon; | ||
154 | |||
155 | tcon = __raw_readl(EXYNOS4_MCT_G_TCON); | ||
156 | tcon &= ~(MCT_G_TCON_COMP0_ENABLE | MCT_G_TCON_COMP0_AUTO_INC); | ||
157 | |||
158 | exynos4_mct_write(tcon, EXYNOS4_MCT_G_TCON); | ||
159 | exynos4_mct_write(0, EXYNOS4_MCT_G_INT_ENB); | ||
160 | } | ||
161 | |||
162 | static void exynos4_mct_comp0_start(enum clock_event_mode mode, | ||
163 | unsigned long cycles) | ||
164 | { | ||
165 | unsigned int tcon; | ||
166 | cycle_t comp_cycle; | ||
167 | |||
168 | tcon = __raw_readl(EXYNOS4_MCT_G_TCON); | ||
169 | |||
170 | if (mode == CLOCK_EVT_MODE_PERIODIC) { | ||
171 | tcon |= MCT_G_TCON_COMP0_AUTO_INC; | ||
172 | exynos4_mct_write(cycles, EXYNOS4_MCT_G_COMP0_ADD_INCR); | ||
173 | } | ||
174 | |||
175 | comp_cycle = exynos4_frc_read(&mct_frc) + cycles; | ||
176 | exynos4_mct_write((u32)comp_cycle, EXYNOS4_MCT_G_COMP0_L); | ||
177 | exynos4_mct_write((u32)(comp_cycle >> 32), EXYNOS4_MCT_G_COMP0_U); | ||
178 | |||
179 | exynos4_mct_write(0x1, EXYNOS4_MCT_G_INT_ENB); | ||
180 | |||
181 | tcon |= MCT_G_TCON_COMP0_ENABLE; | ||
182 | exynos4_mct_write(tcon , EXYNOS4_MCT_G_TCON); | ||
183 | } | ||
184 | |||
185 | static int exynos4_comp_set_next_event(unsigned long cycles, | ||
186 | struct clock_event_device *evt) | ||
187 | { | ||
188 | exynos4_mct_comp0_start(evt->mode, cycles); | ||
189 | |||
190 | return 0; | ||
191 | } | ||
192 | |||
193 | static void exynos4_comp_set_mode(enum clock_event_mode mode, | ||
194 | struct clock_event_device *evt) | ||
195 | { | ||
196 | exynos4_mct_comp0_stop(); | ||
197 | |||
198 | switch (mode) { | ||
199 | case CLOCK_EVT_MODE_PERIODIC: | ||
200 | exynos4_mct_comp0_start(mode, clk_cnt_per_tick); | ||
201 | break; | ||
202 | |||
203 | case CLOCK_EVT_MODE_ONESHOT: | ||
204 | case CLOCK_EVT_MODE_UNUSED: | ||
205 | case CLOCK_EVT_MODE_SHUTDOWN: | ||
206 | case CLOCK_EVT_MODE_RESUME: | ||
207 | break; | ||
208 | } | ||
209 | } | ||
210 | |||
211 | static struct clock_event_device mct_comp_device = { | ||
212 | .name = "mct-comp", | ||
213 | .features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT, | ||
214 | .rating = 250, | ||
215 | .set_next_event = exynos4_comp_set_next_event, | ||
216 | .set_mode = exynos4_comp_set_mode, | ||
217 | }; | ||
218 | |||
219 | static irqreturn_t exynos4_mct_comp_isr(int irq, void *dev_id) | ||
220 | { | ||
221 | struct clock_event_device *evt = dev_id; | ||
222 | |||
223 | exynos4_mct_write(0x1, EXYNOS4_MCT_G_INT_CSTAT); | ||
224 | |||
225 | evt->event_handler(evt); | ||
226 | |||
227 | return IRQ_HANDLED; | ||
228 | } | ||
229 | |||
230 | static struct irqaction mct_comp_event_irq = { | ||
231 | .name = "mct_comp_irq", | ||
232 | .flags = IRQF_TIMER | IRQF_IRQPOLL, | ||
233 | .handler = exynos4_mct_comp_isr, | ||
234 | .dev_id = &mct_comp_device, | ||
235 | }; | ||
236 | |||
237 | static void exynos4_clockevent_init(void) | ||
238 | { | ||
239 | clk_cnt_per_tick = clk_rate / 2 / HZ; | ||
240 | |||
241 | clockevents_calc_mult_shift(&mct_comp_device, clk_rate / 2, 5); | ||
242 | mct_comp_device.max_delta_ns = | ||
243 | clockevent_delta2ns(0xffffffff, &mct_comp_device); | ||
244 | mct_comp_device.min_delta_ns = | ||
245 | clockevent_delta2ns(0xf, &mct_comp_device); | ||
246 | mct_comp_device.cpumask = cpumask_of(0); | ||
247 | clockevents_register_device(&mct_comp_device); | ||
248 | |||
249 | setup_irq(IRQ_MCT_G0, &mct_comp_event_irq); | ||
250 | } | ||
251 | |||
252 | #ifdef CONFIG_LOCAL_TIMERS | ||
253 | /* Clock event handling */ | ||
254 | static void exynos4_mct_tick_stop(struct mct_clock_event_device *mevt) | ||
255 | { | ||
256 | unsigned long tmp; | ||
257 | unsigned long mask = MCT_L_TCON_INT_START | MCT_L_TCON_TIMER_START; | ||
258 | void __iomem *addr = mevt->base + MCT_L_TCON_OFFSET; | ||
259 | |||
260 | tmp = __raw_readl(addr); | ||
261 | if (tmp & mask) { | ||
262 | tmp &= ~mask; | ||
263 | exynos4_mct_write(tmp, addr); | ||
264 | } | ||
265 | } | ||
266 | |||
267 | static void exynos4_mct_tick_start(unsigned long cycles, | ||
268 | struct mct_clock_event_device *mevt) | ||
269 | { | ||
270 | unsigned long tmp; | ||
271 | |||
272 | exynos4_mct_tick_stop(mevt); | ||
273 | |||
274 | tmp = (1 << 31) | cycles; /* MCT_L_UPDATE_ICNTB */ | ||
275 | |||
276 | /* update interrupt count buffer */ | ||
277 | exynos4_mct_write(tmp, mevt->base + MCT_L_ICNTB_OFFSET); | ||
278 | |||
279 | /* enable MCT tick interupt */ | ||
280 | exynos4_mct_write(0x1, mevt->base + MCT_L_INT_ENB_OFFSET); | ||
281 | |||
282 | tmp = __raw_readl(mevt->base + MCT_L_TCON_OFFSET); | ||
283 | tmp |= MCT_L_TCON_INT_START | MCT_L_TCON_TIMER_START | | ||
284 | MCT_L_TCON_INTERVAL_MODE; | ||
285 | exynos4_mct_write(tmp, mevt->base + MCT_L_TCON_OFFSET); | ||
286 | } | ||
287 | |||
288 | static int exynos4_tick_set_next_event(unsigned long cycles, | ||
289 | struct clock_event_device *evt) | ||
290 | { | ||
291 | struct mct_clock_event_device *mevt = &mct_tick[smp_processor_id()]; | ||
292 | |||
293 | exynos4_mct_tick_start(cycles, mevt); | ||
294 | |||
295 | return 0; | ||
296 | } | ||
297 | |||
298 | static inline void exynos4_tick_set_mode(enum clock_event_mode mode, | ||
299 | struct clock_event_device *evt) | ||
300 | { | ||
301 | struct mct_clock_event_device *mevt = &mct_tick[smp_processor_id()]; | ||
302 | |||
303 | exynos4_mct_tick_stop(mevt); | ||
304 | |||
305 | switch (mode) { | ||
306 | case CLOCK_EVT_MODE_PERIODIC: | ||
307 | exynos4_mct_tick_start(clk_cnt_per_tick, mevt); | ||
308 | break; | ||
309 | |||
310 | case CLOCK_EVT_MODE_ONESHOT: | ||
311 | case CLOCK_EVT_MODE_UNUSED: | ||
312 | case CLOCK_EVT_MODE_SHUTDOWN: | ||
313 | case CLOCK_EVT_MODE_RESUME: | ||
314 | break; | ||
315 | } | ||
316 | } | ||
317 | |||
318 | static irqreturn_t exynos4_mct_tick_isr(int irq, void *dev_id) | ||
319 | { | ||
320 | struct mct_clock_event_device *mevt = dev_id; | ||
321 | struct clock_event_device *evt = mevt->evt; | ||
322 | |||
323 | /* | ||
324 | * This is for supporting oneshot mode. | ||
325 | * Mct would generate interrupt periodically | ||
326 | * without explicit stopping. | ||
327 | */ | ||
328 | if (evt->mode != CLOCK_EVT_MODE_PERIODIC) | ||
329 | exynos4_mct_tick_stop(mevt); | ||
330 | |||
331 | /* Clear the MCT tick interrupt */ | ||
332 | exynos4_mct_write(0x1, mevt->base + MCT_L_INT_CSTAT_OFFSET); | ||
333 | |||
334 | evt->event_handler(evt); | ||
335 | |||
336 | return IRQ_HANDLED; | ||
337 | } | ||
338 | |||
339 | static struct irqaction mct_tick0_event_irq = { | ||
340 | .name = "mct_tick0_irq", | ||
341 | .flags = IRQF_TIMER | IRQF_NOBALANCING, | ||
342 | .handler = exynos4_mct_tick_isr, | ||
343 | }; | ||
344 | |||
345 | static struct irqaction mct_tick1_event_irq = { | ||
346 | .name = "mct_tick1_irq", | ||
347 | .flags = IRQF_TIMER | IRQF_NOBALANCING, | ||
348 | .handler = exynos4_mct_tick_isr, | ||
349 | }; | ||
350 | |||
351 | static void exynos4_mct_tick_init(struct clock_event_device *evt) | ||
352 | { | ||
353 | unsigned int cpu = smp_processor_id(); | ||
354 | |||
355 | mct_tick[cpu].evt = evt; | ||
356 | |||
357 | if (cpu == 0) { | ||
358 | mct_tick[cpu].base = EXYNOS4_MCT_L0_BASE; | ||
359 | evt->name = "mct_tick0"; | ||
360 | } else { | ||
361 | mct_tick[cpu].base = EXYNOS4_MCT_L1_BASE; | ||
362 | evt->name = "mct_tick1"; | ||
363 | } | ||
364 | |||
365 | evt->cpumask = cpumask_of(cpu); | ||
366 | evt->set_next_event = exynos4_tick_set_next_event; | ||
367 | evt->set_mode = exynos4_tick_set_mode; | ||
368 | evt->features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT; | ||
369 | evt->rating = 450; | ||
370 | |||
371 | clockevents_calc_mult_shift(evt, clk_rate / 2, 5); | ||
372 | evt->max_delta_ns = | ||
373 | clockevent_delta2ns(0x7fffffff, evt); | ||
374 | evt->min_delta_ns = | ||
375 | clockevent_delta2ns(0xf, evt); | ||
376 | |||
377 | clockevents_register_device(evt); | ||
378 | |||
379 | exynos4_mct_write(0x1, mct_tick[cpu].base + MCT_L_TCNTB_OFFSET); | ||
380 | |||
381 | if (cpu == 0) { | ||
382 | mct_tick0_event_irq.dev_id = &mct_tick[cpu]; | ||
383 | setup_irq(IRQ_MCT_L0, &mct_tick0_event_irq); | ||
384 | } else { | ||
385 | mct_tick1_event_irq.dev_id = &mct_tick[cpu]; | ||
386 | irq_set_affinity(IRQ_MCT1, cpumask_of(1)); | ||
387 | setup_irq(IRQ_MCT_L1, &mct_tick1_event_irq); | ||
388 | } | ||
389 | } | ||
390 | |||
391 | /* Setup the local clock events for a CPU */ | ||
392 | void __cpuinit local_timer_setup(struct clock_event_device *evt) | ||
393 | { | ||
394 | exynos4_mct_tick_init(evt); | ||
395 | } | ||
396 | |||
397 | int local_timer_ack(void) | ||
398 | { | ||
399 | return 0; | ||
400 | } | ||
401 | |||
402 | #endif /* CONFIG_LOCAL_TIMERS */ | ||
403 | |||
404 | static void __init exynos4_timer_resources(void) | ||
405 | { | ||
406 | struct clk *mct_clk; | ||
407 | mct_clk = clk_get(NULL, "xtal"); | ||
408 | |||
409 | clk_rate = clk_get_rate(mct_clk); | ||
410 | } | ||
411 | |||
412 | static void __init exynos4_timer_init(void) | ||
413 | { | ||
414 | exynos4_timer_resources(); | ||
415 | exynos4_clocksource_init(); | ||
416 | exynos4_clockevent_init(); | ||
417 | } | ||
418 | |||
419 | struct sys_timer exynos4_timer = { | ||
420 | .init = exynos4_timer_init, | ||
421 | }; | ||
diff --git a/arch/arm/mach-s5pv310/platsmp.c b/arch/arm/mach-exynos4/platsmp.c index 34093b069f67..6d35878ec1aa 100644 --- a/arch/arm/mach-s5pv310/platsmp.c +++ b/arch/arm/mach-exynos4/platsmp.c | |||
@@ -1,7 +1,7 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/platsmp.c | 1 | /* linux/arch/arm/mach-exynos4/platsmp.c |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * Cloned from linux/arch/arm/mach-vexpress/platsmp.c | 6 | * Cloned from linux/arch/arm/mach-vexpress/platsmp.c |
7 | * | 7 | * |
@@ -28,7 +28,7 @@ | |||
28 | #include <mach/hardware.h> | 28 | #include <mach/hardware.h> |
29 | #include <mach/regs-clock.h> | 29 | #include <mach/regs-clock.h> |
30 | 30 | ||
31 | extern void s5pv310_secondary_startup(void); | 31 | extern void exynos4_secondary_startup(void); |
32 | 32 | ||
33 | /* | 33 | /* |
34 | * control for which core is the next to come out of the secondary | 34 | * control for which core is the next to come out of the secondary |
@@ -139,7 +139,7 @@ void __init smp_init_cpus(void) | |||
139 | /* sanity check */ | 139 | /* sanity check */ |
140 | if (ncores > NR_CPUS) { | 140 | if (ncores > NR_CPUS) { |
141 | printk(KERN_WARNING | 141 | printk(KERN_WARNING |
142 | "S5PV310: no. of cores (%d) greater than configured " | 142 | "EXYNOS4: no. of cores (%d) greater than configured " |
143 | "maximum of %d - clipping\n", | 143 | "maximum of %d - clipping\n", |
144 | ncores, NR_CPUS); | 144 | ncores, NR_CPUS); |
145 | ncores = NR_CPUS; | 145 | ncores = NR_CPUS; |
@@ -168,5 +168,5 @@ void __init platform_smp_prepare_cpus(unsigned int max_cpus) | |||
168 | * until it receives a soft interrupt, and then the | 168 | * until it receives a soft interrupt, and then the |
169 | * secondary CPU branches to this address. | 169 | * secondary CPU branches to this address. |
170 | */ | 170 | */ |
171 | __raw_writel(BSYM(virt_to_phys(s5pv310_secondary_startup)), S5P_VA_SYSRAM); | 171 | __raw_writel(BSYM(virt_to_phys(exynos4_secondary_startup)), S5P_VA_SYSRAM); |
172 | } | 172 | } |
diff --git a/arch/arm/mach-exynos4/pm.c b/arch/arm/mach-exynos4/pm.c new file mode 100644 index 000000000000..10d917d9e3ad --- /dev/null +++ b/arch/arm/mach-exynos4/pm.c | |||
@@ -0,0 +1,420 @@ | |||
1 | /* linux/arch/arm/mach-exynos4/pm.c | ||
2 | * | ||
3 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * EXYNOS4210 - Power Management support | ||
7 | * | ||
8 | * Based on arch/arm/mach-s3c2410/pm.c | ||
9 | * Copyright (c) 2006 Simtec Electronics | ||
10 | * Ben Dooks <ben@simtec.co.uk> | ||
11 | * | ||
12 | * This program is free software; you can redistribute it and/or modify | ||
13 | * it under the terms of the GNU General Public License version 2 as | ||
14 | * published by the Free Software Foundation. | ||
15 | */ | ||
16 | |||
17 | #include <linux/init.h> | ||
18 | #include <linux/suspend.h> | ||
19 | #include <linux/io.h> | ||
20 | |||
21 | #include <asm/cacheflush.h> | ||
22 | #include <asm/hardware/cache-l2x0.h> | ||
23 | |||
24 | #include <plat/cpu.h> | ||
25 | #include <plat/pm.h> | ||
26 | |||
27 | #include <mach/regs-irq.h> | ||
28 | #include <mach/regs-gpio.h> | ||
29 | #include <mach/regs-clock.h> | ||
30 | #include <mach/regs-pmu.h> | ||
31 | #include <mach/pm-core.h> | ||
32 | |||
33 | static struct sleep_save exynos4_sleep[] = { | ||
34 | { .reg = S5P_ARM_CORE0_LOWPWR , .val = 0x2, }, | ||
35 | { .reg = S5P_DIS_IRQ_CORE0 , .val = 0x0, }, | ||
36 | { .reg = S5P_DIS_IRQ_CENTRAL0 , .val = 0x0, }, | ||
37 | { .reg = S5P_ARM_CORE1_LOWPWR , .val = 0x2, }, | ||
38 | { .reg = S5P_DIS_IRQ_CORE1 , .val = 0x0, }, | ||
39 | { .reg = S5P_DIS_IRQ_CENTRAL1 , .val = 0x0, }, | ||
40 | { .reg = S5P_ARM_COMMON_LOWPWR , .val = 0x2, }, | ||
41 | { .reg = S5P_L2_0_LOWPWR , .val = 0x3, }, | ||
42 | { .reg = S5P_L2_1_LOWPWR , .val = 0x3, }, | ||
43 | { .reg = S5P_CMU_ACLKSTOP_LOWPWR , .val = 0x0, }, | ||
44 | { .reg = S5P_CMU_SCLKSTOP_LOWPWR , .val = 0x0, }, | ||
45 | { .reg = S5P_CMU_RESET_LOWPWR , .val = 0x0, }, | ||
46 | { .reg = S5P_APLL_SYSCLK_LOWPWR , .val = 0x0, }, | ||
47 | { .reg = S5P_MPLL_SYSCLK_LOWPWR , .val = 0x0, }, | ||
48 | { .reg = S5P_VPLL_SYSCLK_LOWPWR , .val = 0x0, }, | ||
49 | { .reg = S5P_EPLL_SYSCLK_LOWPWR , .val = 0x0, }, | ||
50 | { .reg = S5P_CMU_CLKSTOP_GPS_ALIVE_LOWPWR , .val = 0x0, }, | ||
51 | { .reg = S5P_CMU_RESET_GPSALIVE_LOWPWR , .val = 0x0, }, | ||
52 | { .reg = S5P_CMU_CLKSTOP_CAM_LOWPWR , .val = 0x0, }, | ||
53 | { .reg = S5P_CMU_CLKSTOP_TV_LOWPWR , .val = 0x0, }, | ||
54 | { .reg = S5P_CMU_CLKSTOP_MFC_LOWPWR , .val = 0x0, }, | ||
55 | { .reg = S5P_CMU_CLKSTOP_G3D_LOWPWR , .val = 0x0, }, | ||
56 | { .reg = S5P_CMU_CLKSTOP_LCD0_LOWPWR , .val = 0x0, }, | ||
57 | { .reg = S5P_CMU_CLKSTOP_LCD1_LOWPWR , .val = 0x0, }, | ||
58 | { .reg = S5P_CMU_CLKSTOP_MAUDIO_LOWPWR , .val = 0x0, }, | ||
59 | { .reg = S5P_CMU_CLKSTOP_GPS_LOWPWR , .val = 0x0, }, | ||
60 | { .reg = S5P_CMU_RESET_CAM_LOWPWR , .val = 0x0, }, | ||
61 | { .reg = S5P_CMU_RESET_TV_LOWPWR , .val = 0x0, }, | ||
62 | { .reg = S5P_CMU_RESET_MFC_LOWPWR , .val = 0x0, }, | ||
63 | { .reg = S5P_CMU_RESET_G3D_LOWPWR , .val = 0x0, }, | ||
64 | { .reg = S5P_CMU_RESET_LCD0_LOWPWR , .val = 0x0, }, | ||
65 | { .reg = S5P_CMU_RESET_LCD1_LOWPWR , .val = 0x0, }, | ||
66 | { .reg = S5P_CMU_RESET_MAUDIO_LOWPWR , .val = 0x0, }, | ||
67 | { .reg = S5P_CMU_RESET_GPS_LOWPWR , .val = 0x0, }, | ||
68 | { .reg = S5P_TOP_BUS_LOWPWR , .val = 0x0, }, | ||
69 | { .reg = S5P_TOP_RETENTION_LOWPWR , .val = 0x1, }, | ||
70 | { .reg = S5P_TOP_PWR_LOWPWR , .val = 0x3, }, | ||
71 | { .reg = S5P_LOGIC_RESET_LOWPWR , .val = 0x0, }, | ||
72 | { .reg = S5P_ONENAND_MEM_LOWPWR , .val = 0x0, }, | ||
73 | { .reg = S5P_MODIMIF_MEM_LOWPWR , .val = 0x0, }, | ||
74 | { .reg = S5P_G2D_ACP_MEM_LOWPWR , .val = 0x0, }, | ||
75 | { .reg = S5P_USBOTG_MEM_LOWPWR , .val = 0x0, }, | ||
76 | { .reg = S5P_HSMMC_MEM_LOWPWR , .val = 0x0, }, | ||
77 | { .reg = S5P_CSSYS_MEM_LOWPWR , .val = 0x0, }, | ||
78 | { .reg = S5P_SECSS_MEM_LOWPWR , .val = 0x0, }, | ||
79 | { .reg = S5P_PCIE_MEM_LOWPWR , .val = 0x0, }, | ||
80 | { .reg = S5P_SATA_MEM_LOWPWR , .val = 0x0, }, | ||
81 | { .reg = S5P_PAD_RETENTION_DRAM_LOWPWR , .val = 0x0, }, | ||
82 | { .reg = S5P_PAD_RETENTION_MAUDIO_LOWPWR , .val = 0x0, }, | ||
83 | { .reg = S5P_PAD_RETENTION_GPIO_LOWPWR , .val = 0x0, }, | ||
84 | { .reg = S5P_PAD_RETENTION_UART_LOWPWR , .val = 0x0, }, | ||
85 | { .reg = S5P_PAD_RETENTION_MMCA_LOWPWR , .val = 0x0, }, | ||
86 | { .reg = S5P_PAD_RETENTION_MMCB_LOWPWR , .val = 0x0, }, | ||
87 | { .reg = S5P_PAD_RETENTION_EBIA_LOWPWR , .val = 0x0, }, | ||
88 | { .reg = S5P_PAD_RETENTION_EBIB_LOWPWR , .val = 0x0, }, | ||
89 | { .reg = S5P_PAD_RETENTION_ISOLATION_LOWPWR , .val = 0x0, }, | ||
90 | { .reg = S5P_PAD_RETENTION_ALV_SEL_LOWPWR , .val = 0x0, }, | ||
91 | { .reg = S5P_XUSBXTI_LOWPWR , .val = 0x0, }, | ||
92 | { .reg = S5P_XXTI_LOWPWR , .val = 0x0, }, | ||
93 | { .reg = S5P_EXT_REGULATOR_LOWPWR , .val = 0x0, }, | ||
94 | { .reg = S5P_GPIO_MODE_LOWPWR , .val = 0x0, }, | ||
95 | { .reg = S5P_GPIO_MODE_MAUDIO_LOWPWR , .val = 0x0, }, | ||
96 | { .reg = S5P_CAM_LOWPWR , .val = 0x0, }, | ||
97 | { .reg = S5P_TV_LOWPWR , .val = 0x0, }, | ||
98 | { .reg = S5P_MFC_LOWPWR , .val = 0x0, }, | ||
99 | { .reg = S5P_G3D_LOWPWR , .val = 0x0, }, | ||
100 | { .reg = S5P_LCD0_LOWPWR , .val = 0x0, }, | ||
101 | { .reg = S5P_LCD1_LOWPWR , .val = 0x0, }, | ||
102 | { .reg = S5P_MAUDIO_LOWPWR , .val = 0x0, }, | ||
103 | { .reg = S5P_GPS_LOWPWR , .val = 0x0, }, | ||
104 | { .reg = S5P_GPS_ALIVE_LOWPWR , .val = 0x0, }, | ||
105 | }; | ||
106 | |||
107 | static struct sleep_save exynos4_set_clksrc[] = { | ||
108 | { .reg = S5P_CLKSRC_MASK_TOP , .val = 0x00000001, }, | ||
109 | { .reg = S5P_CLKSRC_MASK_CAM , .val = 0x11111111, }, | ||
110 | { .reg = S5P_CLKSRC_MASK_TV , .val = 0x00000111, }, | ||
111 | { .reg = S5P_CLKSRC_MASK_LCD0 , .val = 0x00001111, }, | ||
112 | { .reg = S5P_CLKSRC_MASK_LCD1 , .val = 0x00001111, }, | ||
113 | { .reg = S5P_CLKSRC_MASK_MAUDIO , .val = 0x00000001, }, | ||
114 | { .reg = S5P_CLKSRC_MASK_FSYS , .val = 0x01011111, }, | ||
115 | { .reg = S5P_CLKSRC_MASK_PERIL0 , .val = 0x01111111, }, | ||
116 | { .reg = S5P_CLKSRC_MASK_PERIL1 , .val = 0x01110111, }, | ||
117 | { .reg = S5P_CLKSRC_MASK_DMC , .val = 0x00010000, }, | ||
118 | }; | ||
119 | |||
120 | static struct sleep_save exynos4_core_save[] = { | ||
121 | /* CMU side */ | ||
122 | SAVE_ITEM(S5P_CLKDIV_LEFTBUS), | ||
123 | SAVE_ITEM(S5P_CLKGATE_IP_LEFTBUS), | ||
124 | SAVE_ITEM(S5P_CLKDIV_RIGHTBUS), | ||
125 | SAVE_ITEM(S5P_CLKGATE_IP_RIGHTBUS), | ||
126 | SAVE_ITEM(S5P_EPLL_CON0), | ||
127 | SAVE_ITEM(S5P_EPLL_CON1), | ||
128 | SAVE_ITEM(S5P_VPLL_CON0), | ||
129 | SAVE_ITEM(S5P_VPLL_CON1), | ||
130 | SAVE_ITEM(S5P_CLKSRC_TOP0), | ||
131 | SAVE_ITEM(S5P_CLKSRC_TOP1), | ||
132 | SAVE_ITEM(S5P_CLKSRC_CAM), | ||
133 | SAVE_ITEM(S5P_CLKSRC_MFC), | ||
134 | SAVE_ITEM(S5P_CLKSRC_IMAGE), | ||
135 | SAVE_ITEM(S5P_CLKSRC_LCD0), | ||
136 | SAVE_ITEM(S5P_CLKSRC_LCD1), | ||
137 | SAVE_ITEM(S5P_CLKSRC_MAUDIO), | ||
138 | SAVE_ITEM(S5P_CLKSRC_FSYS), | ||
139 | SAVE_ITEM(S5P_CLKSRC_PERIL0), | ||
140 | SAVE_ITEM(S5P_CLKSRC_PERIL1), | ||
141 | SAVE_ITEM(S5P_CLKDIV_CAM), | ||
142 | SAVE_ITEM(S5P_CLKDIV_TV), | ||
143 | SAVE_ITEM(S5P_CLKDIV_MFC), | ||
144 | SAVE_ITEM(S5P_CLKDIV_G3D), | ||
145 | SAVE_ITEM(S5P_CLKDIV_IMAGE), | ||
146 | SAVE_ITEM(S5P_CLKDIV_LCD0), | ||
147 | SAVE_ITEM(S5P_CLKDIV_LCD1), | ||
148 | SAVE_ITEM(S5P_CLKDIV_MAUDIO), | ||
149 | SAVE_ITEM(S5P_CLKDIV_FSYS0), | ||
150 | SAVE_ITEM(S5P_CLKDIV_FSYS1), | ||
151 | SAVE_ITEM(S5P_CLKDIV_FSYS2), | ||
152 | SAVE_ITEM(S5P_CLKDIV_FSYS3), | ||
153 | SAVE_ITEM(S5P_CLKDIV_PERIL0), | ||
154 | SAVE_ITEM(S5P_CLKDIV_PERIL1), | ||
155 | SAVE_ITEM(S5P_CLKDIV_PERIL2), | ||
156 | SAVE_ITEM(S5P_CLKDIV_PERIL3), | ||
157 | SAVE_ITEM(S5P_CLKDIV_PERIL4), | ||
158 | SAVE_ITEM(S5P_CLKDIV_PERIL5), | ||
159 | SAVE_ITEM(S5P_CLKDIV_TOP), | ||
160 | SAVE_ITEM(S5P_CLKSRC_MASK_CAM), | ||
161 | SAVE_ITEM(S5P_CLKSRC_MASK_TV), | ||
162 | SAVE_ITEM(S5P_CLKSRC_MASK_LCD0), | ||
163 | SAVE_ITEM(S5P_CLKSRC_MASK_LCD1), | ||
164 | SAVE_ITEM(S5P_CLKSRC_MASK_MAUDIO), | ||
165 | SAVE_ITEM(S5P_CLKSRC_MASK_FSYS), | ||
166 | SAVE_ITEM(S5P_CLKSRC_MASK_PERIL0), | ||
167 | SAVE_ITEM(S5P_CLKSRC_MASK_PERIL1), | ||
168 | SAVE_ITEM(S5P_CLKGATE_SCLKCAM), | ||
169 | SAVE_ITEM(S5P_CLKGATE_IP_CAM), | ||
170 | SAVE_ITEM(S5P_CLKGATE_IP_TV), | ||
171 | SAVE_ITEM(S5P_CLKGATE_IP_MFC), | ||
172 | SAVE_ITEM(S5P_CLKGATE_IP_G3D), | ||
173 | SAVE_ITEM(S5P_CLKGATE_IP_IMAGE), | ||
174 | SAVE_ITEM(S5P_CLKGATE_IP_LCD0), | ||
175 | SAVE_ITEM(S5P_CLKGATE_IP_LCD1), | ||
176 | SAVE_ITEM(S5P_CLKGATE_IP_FSYS), | ||
177 | SAVE_ITEM(S5P_CLKGATE_IP_GPS), | ||
178 | SAVE_ITEM(S5P_CLKGATE_IP_PERIL), | ||
179 | SAVE_ITEM(S5P_CLKGATE_IP_PERIR), | ||
180 | SAVE_ITEM(S5P_CLKGATE_BLOCK), | ||
181 | SAVE_ITEM(S5P_CLKSRC_MASK_DMC), | ||
182 | SAVE_ITEM(S5P_CLKSRC_DMC), | ||
183 | SAVE_ITEM(S5P_CLKDIV_DMC0), | ||
184 | SAVE_ITEM(S5P_CLKDIV_DMC1), | ||
185 | SAVE_ITEM(S5P_CLKGATE_IP_DMC), | ||
186 | SAVE_ITEM(S5P_CLKSRC_CPU), | ||
187 | SAVE_ITEM(S5P_CLKDIV_CPU), | ||
188 | SAVE_ITEM(S5P_CLKGATE_SCLKCPU), | ||
189 | SAVE_ITEM(S5P_CLKGATE_IP_CPU), | ||
190 | /* GIC side */ | ||
191 | SAVE_ITEM(S5P_VA_GIC_CPU + 0x000), | ||
192 | SAVE_ITEM(S5P_VA_GIC_CPU + 0x004), | ||
193 | SAVE_ITEM(S5P_VA_GIC_CPU + 0x008), | ||
194 | SAVE_ITEM(S5P_VA_GIC_CPU + 0x00C), | ||
195 | SAVE_ITEM(S5P_VA_GIC_CPU + 0x014), | ||
196 | SAVE_ITEM(S5P_VA_GIC_CPU + 0x018), | ||
197 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x000), | ||
198 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x004), | ||
199 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x100), | ||
200 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x104), | ||
201 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x108), | ||
202 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x300), | ||
203 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x304), | ||
204 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x308), | ||
205 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x400), | ||
206 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x404), | ||
207 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x408), | ||
208 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x40C), | ||
209 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x410), | ||
210 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x414), | ||
211 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x418), | ||
212 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x41C), | ||
213 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x420), | ||
214 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x424), | ||
215 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x428), | ||
216 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x42C), | ||
217 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x430), | ||
218 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x434), | ||
219 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x438), | ||
220 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x43C), | ||
221 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x440), | ||
222 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x444), | ||
223 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x448), | ||
224 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x44C), | ||
225 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x450), | ||
226 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x454), | ||
227 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x458), | ||
228 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x45C), | ||
229 | |||
230 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x800), | ||
231 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x804), | ||
232 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x808), | ||
233 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x80C), | ||
234 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x810), | ||
235 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x814), | ||
236 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x818), | ||
237 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x81C), | ||
238 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x820), | ||
239 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x824), | ||
240 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x828), | ||
241 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x82C), | ||
242 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x830), | ||
243 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x834), | ||
244 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x838), | ||
245 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x83C), | ||
246 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x840), | ||
247 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x844), | ||
248 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x848), | ||
249 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x84C), | ||
250 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x850), | ||
251 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x854), | ||
252 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x858), | ||
253 | SAVE_ITEM(S5P_VA_GIC_DIST + 0x85C), | ||
254 | |||
255 | SAVE_ITEM(S5P_VA_GIC_DIST + 0xC00), | ||
256 | SAVE_ITEM(S5P_VA_GIC_DIST + 0xC04), | ||
257 | SAVE_ITEM(S5P_VA_GIC_DIST + 0xC08), | ||
258 | SAVE_ITEM(S5P_VA_GIC_DIST + 0xC0C), | ||
259 | SAVE_ITEM(S5P_VA_GIC_DIST + 0xC10), | ||
260 | SAVE_ITEM(S5P_VA_GIC_DIST + 0xC14), | ||
261 | |||
262 | SAVE_ITEM(S5P_VA_COMBINER_BASE + 0x000), | ||
263 | SAVE_ITEM(S5P_VA_COMBINER_BASE + 0x010), | ||
264 | SAVE_ITEM(S5P_VA_COMBINER_BASE + 0x020), | ||
265 | SAVE_ITEM(S5P_VA_COMBINER_BASE + 0x030), | ||
266 | SAVE_ITEM(S5P_VA_COMBINER_BASE + 0x040), | ||
267 | SAVE_ITEM(S5P_VA_COMBINER_BASE + 0x050), | ||
268 | SAVE_ITEM(S5P_VA_COMBINER_BASE + 0x060), | ||
269 | SAVE_ITEM(S5P_VA_COMBINER_BASE + 0x070), | ||
270 | SAVE_ITEM(S5P_VA_COMBINER_BASE + 0x080), | ||
271 | SAVE_ITEM(S5P_VA_COMBINER_BASE + 0x090), | ||
272 | }; | ||
273 | |||
274 | static struct sleep_save exynos4_l2cc_save[] = { | ||
275 | SAVE_ITEM(S5P_VA_L2CC + L2X0_TAG_LATENCY_CTRL), | ||
276 | SAVE_ITEM(S5P_VA_L2CC + L2X0_DATA_LATENCY_CTRL), | ||
277 | SAVE_ITEM(S5P_VA_L2CC + L2X0_PREFETCH_CTRL), | ||
278 | SAVE_ITEM(S5P_VA_L2CC + L2X0_POWER_CTRL), | ||
279 | SAVE_ITEM(S5P_VA_L2CC + L2X0_AUX_CTRL), | ||
280 | }; | ||
281 | |||
282 | void exynos4_cpu_suspend(void) | ||
283 | { | ||
284 | unsigned long tmp; | ||
285 | unsigned long mask = 0xFFFFFFFF; | ||
286 | |||
287 | /* Setting Central Sequence Register for power down mode */ | ||
288 | |||
289 | tmp = __raw_readl(S5P_CENTRAL_SEQ_CONFIGURATION); | ||
290 | tmp &= ~(S5P_CENTRAL_LOWPWR_CFG); | ||
291 | __raw_writel(tmp, S5P_CENTRAL_SEQ_CONFIGURATION); | ||
292 | |||
293 | /* Setting Central Sequence option Register */ | ||
294 | |||
295 | tmp = __raw_readl(S5P_CENTRAL_SEQ_OPTION); | ||
296 | tmp &= ~(S5P_USE_MASK); | ||
297 | tmp |= S5P_USE_STANDBY_WFI0; | ||
298 | __raw_writel(tmp, S5P_CENTRAL_SEQ_OPTION); | ||
299 | |||
300 | /* Clear all interrupt pending to avoid early wakeup */ | ||
301 | |||
302 | __raw_writel(mask, (S5P_VA_GIC_DIST + 0x280)); | ||
303 | __raw_writel(mask, (S5P_VA_GIC_DIST + 0x284)); | ||
304 | __raw_writel(mask, (S5P_VA_GIC_DIST + 0x288)); | ||
305 | |||
306 | /* Disable all interrupt */ | ||
307 | |||
308 | __raw_writel(0x0, (S5P_VA_GIC_CPU + 0x000)); | ||
309 | __raw_writel(0x0, (S5P_VA_GIC_DIST + 0x000)); | ||
310 | __raw_writel(mask, (S5P_VA_GIC_DIST + 0x184)); | ||
311 | __raw_writel(mask, (S5P_VA_GIC_DIST + 0x188)); | ||
312 | |||
313 | outer_flush_all(); | ||
314 | |||
315 | /* issue the standby signal into the pm unit. */ | ||
316 | cpu_do_idle(); | ||
317 | |||
318 | /* we should never get past here */ | ||
319 | panic("sleep resumed to originator?"); | ||
320 | } | ||
321 | |||
322 | static void exynos4_pm_prepare(void) | ||
323 | { | ||
324 | u32 tmp; | ||
325 | |||
326 | s3c_pm_do_save(exynos4_core_save, ARRAY_SIZE(exynos4_core_save)); | ||
327 | s3c_pm_do_save(exynos4_l2cc_save, ARRAY_SIZE(exynos4_l2cc_save)); | ||
328 | |||
329 | tmp = __raw_readl(S5P_INFORM1); | ||
330 | |||
331 | /* Set value of power down register for sleep mode */ | ||
332 | |||
333 | s3c_pm_do_restore_core(exynos4_sleep, ARRAY_SIZE(exynos4_sleep)); | ||
334 | __raw_writel(S5P_CHECK_SLEEP, S5P_INFORM1); | ||
335 | |||
336 | /* ensure at least INFORM0 has the resume address */ | ||
337 | |||
338 | __raw_writel(virt_to_phys(s3c_cpu_resume), S5P_INFORM0); | ||
339 | |||
340 | /* Before enter central sequence mode, clock src register have to set */ | ||
341 | |||
342 | s3c_pm_do_restore_core(exynos4_set_clksrc, ARRAY_SIZE(exynos4_set_clksrc)); | ||
343 | |||
344 | } | ||
345 | |||
346 | static int exynos4_pm_add(struct sys_device *sysdev) | ||
347 | { | ||
348 | pm_cpu_prep = exynos4_pm_prepare; | ||
349 | pm_cpu_sleep = exynos4_cpu_suspend; | ||
350 | |||
351 | return 0; | ||
352 | } | ||
353 | |||
354 | /* This function copy from linux/arch/arm/kernel/smp_scu.c */ | ||
355 | |||
356 | void exynos4_scu_enable(void __iomem *scu_base) | ||
357 | { | ||
358 | u32 scu_ctrl; | ||
359 | |||
360 | scu_ctrl = __raw_readl(scu_base); | ||
361 | /* already enabled? */ | ||
362 | if (scu_ctrl & 1) | ||
363 | return; | ||
364 | |||
365 | scu_ctrl |= 1; | ||
366 | __raw_writel(scu_ctrl, scu_base); | ||
367 | |||
368 | /* | ||
369 | * Ensure that the data accessed by CPU0 before the SCU was | ||
370 | * initialised is visible to the other CPUs. | ||
371 | */ | ||
372 | flush_cache_all(); | ||
373 | } | ||
374 | |||
375 | static int exynos4_pm_resume(struct sys_device *dev) | ||
376 | { | ||
377 | /* For release retention */ | ||
378 | |||
379 | __raw_writel((1 << 28), S5P_PAD_RET_MAUDIO_OPTION); | ||
380 | __raw_writel((1 << 28), S5P_PAD_RET_GPIO_OPTION); | ||
381 | __raw_writel((1 << 28), S5P_PAD_RET_UART_OPTION); | ||
382 | __raw_writel((1 << 28), S5P_PAD_RET_MMCA_OPTION); | ||
383 | __raw_writel((1 << 28), S5P_PAD_RET_MMCB_OPTION); | ||
384 | __raw_writel((1 << 28), S5P_PAD_RET_EBIA_OPTION); | ||
385 | __raw_writel((1 << 28), S5P_PAD_RET_EBIB_OPTION); | ||
386 | |||
387 | s3c_pm_do_restore_core(exynos4_core_save, ARRAY_SIZE(exynos4_core_save)); | ||
388 | |||
389 | exynos4_scu_enable(S5P_VA_SCU); | ||
390 | |||
391 | #ifdef CONFIG_CACHE_L2X0 | ||
392 | s3c_pm_do_restore_core(exynos4_l2cc_save, ARRAY_SIZE(exynos4_l2cc_save)); | ||
393 | outer_inv_all(); | ||
394 | /* enable L2X0*/ | ||
395 | writel_relaxed(1, S5P_VA_L2CC + L2X0_CTRL); | ||
396 | #endif | ||
397 | |||
398 | return 0; | ||
399 | } | ||
400 | |||
401 | static struct sysdev_driver exynos4_pm_driver = { | ||
402 | .add = exynos4_pm_add, | ||
403 | .resume = exynos4_pm_resume, | ||
404 | }; | ||
405 | |||
406 | static __init int exynos4_pm_drvinit(void) | ||
407 | { | ||
408 | unsigned int tmp; | ||
409 | |||
410 | s3c_pm_init(); | ||
411 | |||
412 | /* All wakeup disable */ | ||
413 | |||
414 | tmp = __raw_readl(S5P_WAKEUP_MASK); | ||
415 | tmp |= ((0xFF << 8) | (0x1F << 1)); | ||
416 | __raw_writel(tmp, S5P_WAKEUP_MASK); | ||
417 | |||
418 | return sysdev_driver_register(&exynos4_sysclass, &exynos4_pm_driver); | ||
419 | } | ||
420 | arch_initcall(exynos4_pm_drvinit); | ||
diff --git a/arch/arm/mach-exynos4/setup-fimc.c b/arch/arm/mach-exynos4/setup-fimc.c new file mode 100644 index 000000000000..6a45078d9d12 --- /dev/null +++ b/arch/arm/mach-exynos4/setup-fimc.c | |||
@@ -0,0 +1,44 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2011 Samsung Electronics Co., Ltd. | ||
3 | * | ||
4 | * Exynos4 camera interface GPIO configuration. | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | |||
11 | #include <linux/gpio.h> | ||
12 | #include <plat/gpio-cfg.h> | ||
13 | #include <plat/camport.h> | ||
14 | |||
15 | int exynos4_fimc_setup_gpio(enum s5p_camport_id id) | ||
16 | { | ||
17 | u32 gpio8, gpio5; | ||
18 | u32 sfn; | ||
19 | int ret; | ||
20 | |||
21 | switch (id) { | ||
22 | case S5P_CAMPORT_A: | ||
23 | gpio8 = EXYNOS4_GPJ0(0); /* PCLK, VSYNC, HREF, DATA[0:4] */ | ||
24 | gpio5 = EXYNOS4_GPJ1(0); /* DATA[5:7], CLKOUT, FIELD */ | ||
25 | sfn = S3C_GPIO_SFN(2); | ||
26 | break; | ||
27 | |||
28 | case S5P_CAMPORT_B: | ||
29 | gpio8 = EXYNOS4_GPE0(0); /* DATA[0:7] */ | ||
30 | gpio5 = EXYNOS4_GPE1(0); /* PCLK, VSYNC, HREF, CLKOUT, FIELD */ | ||
31 | sfn = S3C_GPIO_SFN(3); | ||
32 | break; | ||
33 | |||
34 | default: | ||
35 | WARN(1, "Wrong camport id: %d\n", id); | ||
36 | return -EINVAL; | ||
37 | } | ||
38 | |||
39 | ret = s3c_gpio_cfgall_range(gpio8, 8, sfn, S3C_GPIO_PULL_UP); | ||
40 | if (ret) | ||
41 | return ret; | ||
42 | |||
43 | return s3c_gpio_cfgall_range(gpio5, 5, sfn, S3C_GPIO_PULL_UP); | ||
44 | } | ||
diff --git a/arch/arm/mach-s5pv310/setup-i2c0.c b/arch/arm/mach-exynos4/setup-i2c0.c index f47f8f3152ec..d395bd17c38b 100644 --- a/arch/arm/mach-s5pv310/setup-i2c0.c +++ b/arch/arm/mach-exynos4/setup-i2c0.c | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * linux/arch/arm/mach-s5pv310/setup-i2c0.c | 2 | * linux/arch/arm/mach-exynos4/setup-i2c0.c |
3 | * | 3 | * |
4 | * Copyright (c) 2009-2010 Samsung Electronics Co., Ltd. | 4 | * Copyright (c) 2009-2010 Samsung Electronics Co., Ltd. |
5 | * http://www.samsung.com/ | 5 | * http://www.samsung.com/ |
@@ -21,6 +21,6 @@ struct platform_device; /* don't need the contents */ | |||
21 | 21 | ||
22 | void s3c_i2c0_cfg_gpio(struct platform_device *dev) | 22 | void s3c_i2c0_cfg_gpio(struct platform_device *dev) |
23 | { | 23 | { |
24 | s3c_gpio_cfgall_range(S5PV310_GPD1(0), 2, | 24 | s3c_gpio_cfgall_range(EXYNOS4_GPD1(0), 2, |
25 | S3C_GPIO_SFN(2), S3C_GPIO_PULL_UP); | 25 | S3C_GPIO_SFN(2), S3C_GPIO_PULL_UP); |
26 | } | 26 | } |
diff --git a/arch/arm/mach-s5pv310/setup-i2c1.c b/arch/arm/mach-exynos4/setup-i2c1.c index 9d07e4e2f14c..fd7235a43f6e 100644 --- a/arch/arm/mach-s5pv310/setup-i2c1.c +++ b/arch/arm/mach-exynos4/setup-i2c1.c | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * linux/arch/arm/mach-s5pv310/setup-i2c1.c | 2 | * linux/arch/arm/mach-exynos4/setup-i2c1.c |
3 | * | 3 | * |
4 | * Copyright (C) 2010 Samsung Electronics Co., Ltd. | 4 | * Copyright (C) 2010 Samsung Electronics Co., Ltd. |
5 | * | 5 | * |
@@ -18,6 +18,6 @@ struct platform_device; /* don't need the contents */ | |||
18 | 18 | ||
19 | void s3c_i2c1_cfg_gpio(struct platform_device *dev) | 19 | void s3c_i2c1_cfg_gpio(struct platform_device *dev) |
20 | { | 20 | { |
21 | s3c_gpio_cfgall_range(S5PV310_GPD1(2), 2, | 21 | s3c_gpio_cfgall_range(EXYNOS4_GPD1(2), 2, |
22 | S3C_GPIO_SFN(2), S3C_GPIO_PULL_UP); | 22 | S3C_GPIO_SFN(2), S3C_GPIO_PULL_UP); |
23 | } | 23 | } |
diff --git a/arch/arm/mach-s5pv310/setup-i2c2.c b/arch/arm/mach-exynos4/setup-i2c2.c index 4163b1233daf..2694b19e8b37 100644 --- a/arch/arm/mach-s5pv310/setup-i2c2.c +++ b/arch/arm/mach-exynos4/setup-i2c2.c | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * linux/arch/arm/mach-s5pv310/setup-i2c2.c | 2 | * linux/arch/arm/mach-exynos4/setup-i2c2.c |
3 | * | 3 | * |
4 | * Copyright (c) 2009-2010 Samsung Electronics Co., Ltd. | 4 | * Copyright (c) 2009-2010 Samsung Electronics Co., Ltd. |
5 | * | 5 | * |
@@ -18,6 +18,6 @@ struct platform_device; /* don't need the contents */ | |||
18 | 18 | ||
19 | void s3c_i2c2_cfg_gpio(struct platform_device *dev) | 19 | void s3c_i2c2_cfg_gpio(struct platform_device *dev) |
20 | { | 20 | { |
21 | s3c_gpio_cfgall_range(S5PV310_GPA0(6), 2, | 21 | s3c_gpio_cfgall_range(EXYNOS4_GPA0(6), 2, |
22 | S3C_GPIO_SFN(3), S3C_GPIO_PULL_UP); | 22 | S3C_GPIO_SFN(3), S3C_GPIO_PULL_UP); |
23 | } | 23 | } |
diff --git a/arch/arm/mach-s5pv310/setup-i2c3.c b/arch/arm/mach-exynos4/setup-i2c3.c index 180f153d2a20..379bd306993f 100644 --- a/arch/arm/mach-s5pv310/setup-i2c3.c +++ b/arch/arm/mach-exynos4/setup-i2c3.c | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * linux/arch/arm/mach-s5pv310/setup-i2c3.c | 2 | * linux/arch/arm/mach-exynos4/setup-i2c3.c |
3 | * | 3 | * |
4 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 4 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. |
5 | * | 5 | * |
@@ -18,6 +18,6 @@ struct platform_device; /* don't need the contents */ | |||
18 | 18 | ||
19 | void s3c_i2c3_cfg_gpio(struct platform_device *dev) | 19 | void s3c_i2c3_cfg_gpio(struct platform_device *dev) |
20 | { | 20 | { |
21 | s3c_gpio_cfgall_range(S5PV310_GPA1(2), 2, | 21 | s3c_gpio_cfgall_range(EXYNOS4_GPA1(2), 2, |
22 | S3C_GPIO_SFN(3), S3C_GPIO_PULL_UP); | 22 | S3C_GPIO_SFN(3), S3C_GPIO_PULL_UP); |
23 | } | 23 | } |
diff --git a/arch/arm/mach-s5pv310/setup-i2c4.c b/arch/arm/mach-exynos4/setup-i2c4.c index 909e8dfc5316..9f3c04855b76 100644 --- a/arch/arm/mach-s5pv310/setup-i2c4.c +++ b/arch/arm/mach-exynos4/setup-i2c4.c | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * linux/arch/arm/mach-s5pv310/setup-i2c4.c | 2 | * linux/arch/arm/mach-exynos4/setup-i2c4.c |
3 | * | 3 | * |
4 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 4 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. |
5 | * | 5 | * |
@@ -18,6 +18,6 @@ struct platform_device; /* don't need the contents */ | |||
18 | 18 | ||
19 | void s3c_i2c4_cfg_gpio(struct platform_device *dev) | 19 | void s3c_i2c4_cfg_gpio(struct platform_device *dev) |
20 | { | 20 | { |
21 | s3c_gpio_cfgall_range(S5PV310_GPB(2), 2, | 21 | s3c_gpio_cfgall_range(EXYNOS4_GPB(2), 2, |
22 | S3C_GPIO_SFN(3), S3C_GPIO_PULL_UP); | 22 | S3C_GPIO_SFN(3), S3C_GPIO_PULL_UP); |
23 | } | 23 | } |
diff --git a/arch/arm/mach-s5pv310/setup-i2c5.c b/arch/arm/mach-exynos4/setup-i2c5.c index 5d0fa4ac0283..77e1a1e57c76 100644 --- a/arch/arm/mach-s5pv310/setup-i2c5.c +++ b/arch/arm/mach-exynos4/setup-i2c5.c | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * linux/arch/arm/mach-s5pv310/setup-i2c5.c | 2 | * linux/arch/arm/mach-exynos4/setup-i2c5.c |
3 | * | 3 | * |
4 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 4 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. |
5 | * | 5 | * |
@@ -18,6 +18,6 @@ struct platform_device; /* don't need the contents */ | |||
18 | 18 | ||
19 | void s3c_i2c5_cfg_gpio(struct platform_device *dev) | 19 | void s3c_i2c5_cfg_gpio(struct platform_device *dev) |
20 | { | 20 | { |
21 | s3c_gpio_cfgall_range(S5PV310_GPB(6), 2, | 21 | s3c_gpio_cfgall_range(EXYNOS4_GPB(6), 2, |
22 | S3C_GPIO_SFN(3), S3C_GPIO_PULL_UP); | 22 | S3C_GPIO_SFN(3), S3C_GPIO_PULL_UP); |
23 | } | 23 | } |
diff --git a/arch/arm/mach-s5pv310/setup-i2c6.c b/arch/arm/mach-exynos4/setup-i2c6.c index 34aafab92ac4..284d12b7af0e 100644 --- a/arch/arm/mach-s5pv310/setup-i2c6.c +++ b/arch/arm/mach-exynos4/setup-i2c6.c | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * linux/arch/arm/mach-s5pv310/setup-i2c6.c | 2 | * linux/arch/arm/mach-exynos4/setup-i2c6.c |
3 | * | 3 | * |
4 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 4 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. |
5 | * | 5 | * |
@@ -18,6 +18,6 @@ struct platform_device; /* don't need the contents */ | |||
18 | 18 | ||
19 | void s3c_i2c6_cfg_gpio(struct platform_device *dev) | 19 | void s3c_i2c6_cfg_gpio(struct platform_device *dev) |
20 | { | 20 | { |
21 | s3c_gpio_cfgall_range(S5PV310_GPC1(3), 2, | 21 | s3c_gpio_cfgall_range(EXYNOS4_GPC1(3), 2, |
22 | S3C_GPIO_SFN(4), S3C_GPIO_PULL_UP); | 22 | S3C_GPIO_SFN(4), S3C_GPIO_PULL_UP); |
23 | } | 23 | } |
diff --git a/arch/arm/mach-s5pv310/setup-i2c7.c b/arch/arm/mach-exynos4/setup-i2c7.c index 9b25b8d18920..b7611ee359a2 100644 --- a/arch/arm/mach-s5pv310/setup-i2c7.c +++ b/arch/arm/mach-exynos4/setup-i2c7.c | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * linux/arch/arm/mach-s5pv310/setup-i2c7.c | 2 | * linux/arch/arm/mach-exynos4/setup-i2c7.c |
3 | * | 3 | * |
4 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 4 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. |
5 | * | 5 | * |
@@ -18,6 +18,6 @@ struct platform_device; /* don't need the contents */ | |||
18 | 18 | ||
19 | void s3c_i2c7_cfg_gpio(struct platform_device *dev) | 19 | void s3c_i2c7_cfg_gpio(struct platform_device *dev) |
20 | { | 20 | { |
21 | s3c_gpio_cfgall_range(S5PV310_GPD0(2), 2, | 21 | s3c_gpio_cfgall_range(EXYNOS4_GPD0(2), 2, |
22 | S3C_GPIO_SFN(3), S3C_GPIO_PULL_UP); | 22 | S3C_GPIO_SFN(3), S3C_GPIO_PULL_UP); |
23 | } | 23 | } |
diff --git a/arch/arm/mach-exynos4/setup-keypad.c b/arch/arm/mach-exynos4/setup-keypad.c new file mode 100644 index 000000000000..1ee0ebff111f --- /dev/null +++ b/arch/arm/mach-exynos4/setup-keypad.c | |||
@@ -0,0 +1,35 @@ | |||
1 | /* linux/arch/arm/mach-exynos4/setup-keypad.c | ||
2 | * | ||
3 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * GPIO configuration for Exynos4 KeyPad device | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #include <linux/gpio.h> | ||
14 | #include <plat/gpio-cfg.h> | ||
15 | |||
16 | void samsung_keypad_cfg_gpio(unsigned int rows, unsigned int cols) | ||
17 | { | ||
18 | /* Keypads can be of various combinations, Just making sure */ | ||
19 | |||
20 | if (rows > 8) { | ||
21 | /* Set all the necessary GPX2 pins: KP_ROW[0~7] */ | ||
22 | s3c_gpio_cfgrange_nopull(EXYNOS4_GPX2(0), 8, S3C_GPIO_SFN(3)); | ||
23 | |||
24 | /* Set all the necessary GPX3 pins: KP_ROW[8~] */ | ||
25 | s3c_gpio_cfgrange_nopull(EXYNOS4_GPX3(0), (rows - 8), | ||
26 | S3C_GPIO_SFN(3)); | ||
27 | } else { | ||
28 | /* Set all the necessary GPX2 pins: KP_ROW[x] */ | ||
29 | s3c_gpio_cfgrange_nopull(EXYNOS4_GPX2(0), rows, | ||
30 | S3C_GPIO_SFN(3)); | ||
31 | } | ||
32 | |||
33 | /* Set all the necessary GPX1 pins to special-function 3: KP_COL[x] */ | ||
34 | s3c_gpio_cfgrange_nopull(EXYNOS4_GPX1(0), cols, S3C_GPIO_SFN(3)); | ||
35 | } | ||
diff --git a/arch/arm/mach-s5pv310/setup-sdhci-gpio.c b/arch/arm/mach-exynos4/setup-sdhci-gpio.c index 86d38cc49135..1b3d3a2de95c 100644 --- a/arch/arm/mach-s5pv310/setup-sdhci-gpio.c +++ b/arch/arm/mach-exynos4/setup-sdhci-gpio.c | |||
@@ -1,9 +1,9 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/setup-sdhci-gpio.c | 1 | /* linux/arch/arm/mach-exynos4/setup-sdhci-gpio.c |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * S5PV310 - Helper functions for setting up SDHCI device(s) GPIO (HSMMC) | 6 | * EXYNOS4 - Helper functions for setting up SDHCI device(s) GPIO (HSMMC) |
7 | * | 7 | * |
8 | * This program is free software; you can redistribute it and/or modify | 8 | * This program is free software; you can redistribute it and/or modify |
9 | * it under the terms of the GNU General Public License version 2 as | 9 | * it under the terms of the GNU General Public License version 2 as |
@@ -23,13 +23,13 @@ | |||
23 | #include <plat/regs-sdhci.h> | 23 | #include <plat/regs-sdhci.h> |
24 | #include <plat/sdhci.h> | 24 | #include <plat/sdhci.h> |
25 | 25 | ||
26 | void s5pv310_setup_sdhci0_cfg_gpio(struct platform_device *dev, int width) | 26 | void exynos4_setup_sdhci0_cfg_gpio(struct platform_device *dev, int width) |
27 | { | 27 | { |
28 | struct s3c_sdhci_platdata *pdata = dev->dev.platform_data; | 28 | struct s3c_sdhci_platdata *pdata = dev->dev.platform_data; |
29 | unsigned int gpio; | 29 | unsigned int gpio; |
30 | 30 | ||
31 | /* Set all the necessary GPK0[0:1] pins to special-function 2 */ | 31 | /* Set all the necessary GPK0[0:1] pins to special-function 2 */ |
32 | for (gpio = S5PV310_GPK0(0); gpio < S5PV310_GPK0(2); gpio++) { | 32 | for (gpio = EXYNOS4_GPK0(0); gpio < EXYNOS4_GPK0(2); gpio++) { |
33 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(2)); | 33 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(2)); |
34 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_NONE); | 34 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_NONE); |
35 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); | 35 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); |
@@ -37,14 +37,14 @@ void s5pv310_setup_sdhci0_cfg_gpio(struct platform_device *dev, int width) | |||
37 | 37 | ||
38 | switch (width) { | 38 | switch (width) { |
39 | case 8: | 39 | case 8: |
40 | for (gpio = S5PV310_GPK1(3); gpio <= S5PV310_GPK1(6); gpio++) { | 40 | for (gpio = EXYNOS4_GPK1(3); gpio <= EXYNOS4_GPK1(6); gpio++) { |
41 | /* Data pin GPK1[3:6] to special-funtion 3 */ | 41 | /* Data pin GPK1[3:6] to special-funtion 3 */ |
42 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(3)); | 42 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(3)); |
43 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_UP); | 43 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_UP); |
44 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); | 44 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); |
45 | } | 45 | } |
46 | case 4: | 46 | case 4: |
47 | for (gpio = S5PV310_GPK0(3); gpio <= S5PV310_GPK0(6); gpio++) { | 47 | for (gpio = EXYNOS4_GPK0(3); gpio <= EXYNOS4_GPK0(6); gpio++) { |
48 | /* Data pin GPK0[3:6] to special-funtion 2 */ | 48 | /* Data pin GPK0[3:6] to special-funtion 2 */ |
49 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(2)); | 49 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(2)); |
50 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_UP); | 50 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_UP); |
@@ -55,25 +55,25 @@ void s5pv310_setup_sdhci0_cfg_gpio(struct platform_device *dev, int width) | |||
55 | } | 55 | } |
56 | 56 | ||
57 | if (pdata->cd_type == S3C_SDHCI_CD_INTERNAL) { | 57 | if (pdata->cd_type == S3C_SDHCI_CD_INTERNAL) { |
58 | s3c_gpio_cfgpin(S5PV310_GPK0(2), S3C_GPIO_SFN(2)); | 58 | s3c_gpio_cfgpin(EXYNOS4_GPK0(2), S3C_GPIO_SFN(2)); |
59 | s3c_gpio_setpull(S5PV310_GPK0(2), S3C_GPIO_PULL_UP); | 59 | s3c_gpio_setpull(EXYNOS4_GPK0(2), S3C_GPIO_PULL_UP); |
60 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); | 60 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); |
61 | } | 61 | } |
62 | } | 62 | } |
63 | 63 | ||
64 | void s5pv310_setup_sdhci1_cfg_gpio(struct platform_device *dev, int width) | 64 | void exynos4_setup_sdhci1_cfg_gpio(struct platform_device *dev, int width) |
65 | { | 65 | { |
66 | struct s3c_sdhci_platdata *pdata = dev->dev.platform_data; | 66 | struct s3c_sdhci_platdata *pdata = dev->dev.platform_data; |
67 | unsigned int gpio; | 67 | unsigned int gpio; |
68 | 68 | ||
69 | /* Set all the necessary GPK1[0:1] pins to special-function 2 */ | 69 | /* Set all the necessary GPK1[0:1] pins to special-function 2 */ |
70 | for (gpio = S5PV310_GPK1(0); gpio < S5PV310_GPK1(2); gpio++) { | 70 | for (gpio = EXYNOS4_GPK1(0); gpio < EXYNOS4_GPK1(2); gpio++) { |
71 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(2)); | 71 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(2)); |
72 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_NONE); | 72 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_NONE); |
73 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); | 73 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); |
74 | } | 74 | } |
75 | 75 | ||
76 | for (gpio = S5PV310_GPK1(3); gpio <= S5PV310_GPK1(6); gpio++) { | 76 | for (gpio = EXYNOS4_GPK1(3); gpio <= EXYNOS4_GPK1(6); gpio++) { |
77 | /* Data pin GPK1[3:6] to special-function 2 */ | 77 | /* Data pin GPK1[3:6] to special-function 2 */ |
78 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(2)); | 78 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(2)); |
79 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_UP); | 79 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_UP); |
@@ -81,19 +81,19 @@ void s5pv310_setup_sdhci1_cfg_gpio(struct platform_device *dev, int width) | |||
81 | } | 81 | } |
82 | 82 | ||
83 | if (pdata->cd_type == S3C_SDHCI_CD_INTERNAL) { | 83 | if (pdata->cd_type == S3C_SDHCI_CD_INTERNAL) { |
84 | s3c_gpio_cfgpin(S5PV310_GPK1(2), S3C_GPIO_SFN(2)); | 84 | s3c_gpio_cfgpin(EXYNOS4_GPK1(2), S3C_GPIO_SFN(2)); |
85 | s3c_gpio_setpull(S5PV310_GPK1(2), S3C_GPIO_PULL_UP); | 85 | s3c_gpio_setpull(EXYNOS4_GPK1(2), S3C_GPIO_PULL_UP); |
86 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); | 86 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); |
87 | } | 87 | } |
88 | } | 88 | } |
89 | 89 | ||
90 | void s5pv310_setup_sdhci2_cfg_gpio(struct platform_device *dev, int width) | 90 | void exynos4_setup_sdhci2_cfg_gpio(struct platform_device *dev, int width) |
91 | { | 91 | { |
92 | struct s3c_sdhci_platdata *pdata = dev->dev.platform_data; | 92 | struct s3c_sdhci_platdata *pdata = dev->dev.platform_data; |
93 | unsigned int gpio; | 93 | unsigned int gpio; |
94 | 94 | ||
95 | /* Set all the necessary GPK2[0:1] pins to special-function 2 */ | 95 | /* Set all the necessary GPK2[0:1] pins to special-function 2 */ |
96 | for (gpio = S5PV310_GPK2(0); gpio < S5PV310_GPK2(2); gpio++) { | 96 | for (gpio = EXYNOS4_GPK2(0); gpio < EXYNOS4_GPK2(2); gpio++) { |
97 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(2)); | 97 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(2)); |
98 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_NONE); | 98 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_NONE); |
99 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); | 99 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); |
@@ -101,14 +101,14 @@ void s5pv310_setup_sdhci2_cfg_gpio(struct platform_device *dev, int width) | |||
101 | 101 | ||
102 | switch (width) { | 102 | switch (width) { |
103 | case 8: | 103 | case 8: |
104 | for (gpio = S5PV310_GPK3(3); gpio <= S5PV310_GPK3(6); gpio++) { | 104 | for (gpio = EXYNOS4_GPK3(3); gpio <= EXYNOS4_GPK3(6); gpio++) { |
105 | /* Data pin GPK3[3:6] to special-function 3 */ | 105 | /* Data pin GPK3[3:6] to special-function 3 */ |
106 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(3)); | 106 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(3)); |
107 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_UP); | 107 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_UP); |
108 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); | 108 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); |
109 | } | 109 | } |
110 | case 4: | 110 | case 4: |
111 | for (gpio = S5PV310_GPK2(3); gpio <= S5PV310_GPK2(6); gpio++) { | 111 | for (gpio = EXYNOS4_GPK2(3); gpio <= EXYNOS4_GPK2(6); gpio++) { |
112 | /* Data pin GPK2[3:6] to special-function 2 */ | 112 | /* Data pin GPK2[3:6] to special-function 2 */ |
113 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(2)); | 113 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(2)); |
114 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_UP); | 114 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_UP); |
@@ -119,25 +119,25 @@ void s5pv310_setup_sdhci2_cfg_gpio(struct platform_device *dev, int width) | |||
119 | } | 119 | } |
120 | 120 | ||
121 | if (pdata->cd_type == S3C_SDHCI_CD_INTERNAL) { | 121 | if (pdata->cd_type == S3C_SDHCI_CD_INTERNAL) { |
122 | s3c_gpio_cfgpin(S5PV310_GPK2(2), S3C_GPIO_SFN(2)); | 122 | s3c_gpio_cfgpin(EXYNOS4_GPK2(2), S3C_GPIO_SFN(2)); |
123 | s3c_gpio_setpull(S5PV310_GPK2(2), S3C_GPIO_PULL_UP); | 123 | s3c_gpio_setpull(EXYNOS4_GPK2(2), S3C_GPIO_PULL_UP); |
124 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); | 124 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); |
125 | } | 125 | } |
126 | } | 126 | } |
127 | 127 | ||
128 | void s5pv310_setup_sdhci3_cfg_gpio(struct platform_device *dev, int width) | 128 | void exynos4_setup_sdhci3_cfg_gpio(struct platform_device *dev, int width) |
129 | { | 129 | { |
130 | struct s3c_sdhci_platdata *pdata = dev->dev.platform_data; | 130 | struct s3c_sdhci_platdata *pdata = dev->dev.platform_data; |
131 | unsigned int gpio; | 131 | unsigned int gpio; |
132 | 132 | ||
133 | /* Set all the necessary GPK3[0:1] pins to special-function 2 */ | 133 | /* Set all the necessary GPK3[0:1] pins to special-function 2 */ |
134 | for (gpio = S5PV310_GPK3(0); gpio < S5PV310_GPK3(2); gpio++) { | 134 | for (gpio = EXYNOS4_GPK3(0); gpio < EXYNOS4_GPK3(2); gpio++) { |
135 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(2)); | 135 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(2)); |
136 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_NONE); | 136 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_NONE); |
137 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); | 137 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); |
138 | } | 138 | } |
139 | 139 | ||
140 | for (gpio = S5PV310_GPK3(3); gpio <= S5PV310_GPK3(6); gpio++) { | 140 | for (gpio = EXYNOS4_GPK3(3); gpio <= EXYNOS4_GPK3(6); gpio++) { |
141 | /* Data pin GPK3[3:6] to special-function 2 */ | 141 | /* Data pin GPK3[3:6] to special-function 2 */ |
142 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(2)); | 142 | s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(2)); |
143 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_UP); | 143 | s3c_gpio_setpull(gpio, S3C_GPIO_PULL_UP); |
@@ -145,8 +145,8 @@ void s5pv310_setup_sdhci3_cfg_gpio(struct platform_device *dev, int width) | |||
145 | } | 145 | } |
146 | 146 | ||
147 | if (pdata->cd_type == S3C_SDHCI_CD_INTERNAL) { | 147 | if (pdata->cd_type == S3C_SDHCI_CD_INTERNAL) { |
148 | s3c_gpio_cfgpin(S5PV310_GPK3(2), S3C_GPIO_SFN(2)); | 148 | s3c_gpio_cfgpin(EXYNOS4_GPK3(2), S3C_GPIO_SFN(2)); |
149 | s3c_gpio_setpull(S5PV310_GPK3(2), S3C_GPIO_PULL_UP); | 149 | s3c_gpio_setpull(EXYNOS4_GPK3(2), S3C_GPIO_PULL_UP); |
150 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); | 150 | s5p_gpio_set_drvstr(gpio, S5P_GPIO_DRVSTR_LV4); |
151 | } | 151 | } |
152 | } | 152 | } |
diff --git a/arch/arm/mach-s5pv310/setup-sdhci.c b/arch/arm/mach-exynos4/setup-sdhci.c index db8358fc4662..85f9433d4836 100644 --- a/arch/arm/mach-s5pv310/setup-sdhci.c +++ b/arch/arm/mach-exynos4/setup-sdhci.c | |||
@@ -1,9 +1,9 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/setup-sdhci.c | 1 | /* linux/arch/arm/mach-exynos4/setup-sdhci.c |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * S5PV310 - Helper functions for settign up SDHCI device(s) (HSMMC) | 6 | * EXYNOS4 - Helper functions for settign up SDHCI device(s) (HSMMC) |
7 | * | 7 | * |
8 | * This program is free software; you can redistribute it and/or modify | 8 | * This program is free software; you can redistribute it and/or modify |
9 | * it under the terms of the GNU General Public License version 2 as | 9 | * it under the terms of the GNU General Public License version 2 as |
@@ -23,14 +23,14 @@ | |||
23 | 23 | ||
24 | /* clock sources for the mmc bus clock, order as for the ctrl2[5..4] */ | 24 | /* clock sources for the mmc bus clock, order as for the ctrl2[5..4] */ |
25 | 25 | ||
26 | char *s5pv310_hsmmc_clksrcs[4] = { | 26 | char *exynos4_hsmmc_clksrcs[4] = { |
27 | [0] = NULL, | 27 | [0] = NULL, |
28 | [1] = NULL, | 28 | [1] = NULL, |
29 | [2] = "sclk_mmc", /* mmc_bus */ | 29 | [2] = "sclk_mmc", /* mmc_bus */ |
30 | [3] = NULL, | 30 | [3] = NULL, |
31 | }; | 31 | }; |
32 | 32 | ||
33 | void s5pv310_setup_sdhci_cfg_card(struct platform_device *dev, void __iomem *r, | 33 | void exynos4_setup_sdhci_cfg_card(struct platform_device *dev, void __iomem *r, |
34 | struct mmc_ios *ios, struct mmc_card *card) | 34 | struct mmc_ios *ios, struct mmc_card *card) |
35 | { | 35 | { |
36 | u32 ctrl2, ctrl3; | 36 | u32 ctrl2, ctrl3; |
diff --git a/arch/arm/mach-exynos4/sleep.S b/arch/arm/mach-exynos4/sleep.S new file mode 100644 index 000000000000..6b62425417a6 --- /dev/null +++ b/arch/arm/mach-exynos4/sleep.S | |||
@@ -0,0 +1,76 @@ | |||
1 | /* linux/arch/arm/mach-exynos4/sleep.S | ||
2 | * | ||
3 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * EXYNOS4210 power Manager (Suspend-To-RAM) support | ||
7 | * Based on S3C2410 sleep code by: | ||
8 | * Ben Dooks, (c) 2004 Simtec Electronics | ||
9 | * | ||
10 | * Based on PXA/SA1100 sleep code by: | ||
11 | * Nicolas Pitre, (c) 2002 Monta Vista Software Inc | ||
12 | * Cliff Brake, (c) 2001 | ||
13 | * | ||
14 | * This program is free software; you can redistribute it and/or modify | ||
15 | * it under the terms of the GNU General Public License as published by | ||
16 | * the Free Software Foundation; either version 2 of the License, or | ||
17 | * (at your option) any later version. | ||
18 | * | ||
19 | * This program is distributed in the hope that it will be useful, | ||
20 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
21 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
22 | * GNU General Public License for more details. | ||
23 | * | ||
24 | * You should have received a copy of the GNU General Public License | ||
25 | * along with this program; if not, write to the Free Software | ||
26 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
27 | */ | ||
28 | |||
29 | #include <linux/linkage.h> | ||
30 | #include <asm/assembler.h> | ||
31 | #include <asm/memory.h> | ||
32 | |||
33 | .text | ||
34 | |||
35 | /* | ||
36 | * s3c_cpu_save | ||
37 | * | ||
38 | * entry: | ||
39 | * r1 = v:p offset | ||
40 | */ | ||
41 | |||
42 | ENTRY(s3c_cpu_save) | ||
43 | |||
44 | stmfd sp!, { r3 - r12, lr } | ||
45 | ldr r3, =resume_with_mmu | ||
46 | bl cpu_suspend | ||
47 | |||
48 | ldr r0, =pm_cpu_sleep | ||
49 | ldr r0, [ r0 ] | ||
50 | mov pc, r0 | ||
51 | |||
52 | resume_with_mmu: | ||
53 | ldmfd sp!, { r3 - r12, pc } | ||
54 | |||
55 | .ltorg | ||
56 | |||
57 | /* | ||
58 | * sleep magic, to allow the bootloader to check for an valid | ||
59 | * image to resume to. Must be the first word before the | ||
60 | * s3c_cpu_resume entry. | ||
61 | */ | ||
62 | |||
63 | .word 0x2bedf00d | ||
64 | |||
65 | /* | ||
66 | * s3c_cpu_resume | ||
67 | * | ||
68 | * resume code entry for bootloader to call | ||
69 | * | ||
70 | * we must put this code here in the data segment as we have no | ||
71 | * other way of restoring the stack pointer after sleep, and we | ||
72 | * must not write to the code segment (code is read-only) | ||
73 | */ | ||
74 | |||
75 | ENTRY(s3c_cpu_resume) | ||
76 | b cpu_resume | ||
diff --git a/arch/arm/mach-s5pv310/time.c b/arch/arm/mach-exynos4/time.c index b262d4615331..86b9fa0d3639 100644 --- a/arch/arm/mach-s5pv310/time.c +++ b/arch/arm/mach-exynos4/time.c | |||
@@ -1,9 +1,9 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/time.c | 1 | /* linux/arch/arm/mach-exynos4/time.c |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * S5PV310 (and compatible) HRT support | 6 | * EXYNOS4 (and compatible) HRT support |
7 | * PWM 2/4 is used for this feature | 7 | * PWM 2/4 is used for this feature |
8 | * | 8 | * |
9 | * This program is free software; you can redistribute it and/or modify | 9 | * This program is free software; you can redistribute it and/or modify |
@@ -33,7 +33,7 @@ static struct clk *tdiv2; | |||
33 | static struct clk *tdiv4; | 33 | static struct clk *tdiv4; |
34 | static struct clk *timerclk; | 34 | static struct clk *timerclk; |
35 | 35 | ||
36 | static void s5pv310_pwm_stop(unsigned int pwm_id) | 36 | static void exynos4_pwm_stop(unsigned int pwm_id) |
37 | { | 37 | { |
38 | unsigned long tcon; | 38 | unsigned long tcon; |
39 | 39 | ||
@@ -52,7 +52,7 @@ static void s5pv310_pwm_stop(unsigned int pwm_id) | |||
52 | __raw_writel(tcon, S3C2410_TCON); | 52 | __raw_writel(tcon, S3C2410_TCON); |
53 | } | 53 | } |
54 | 54 | ||
55 | static void s5pv310_pwm_init(unsigned int pwm_id, unsigned long tcnt) | 55 | static void exynos4_pwm_init(unsigned int pwm_id, unsigned long tcnt) |
56 | { | 56 | { |
57 | unsigned long tcon; | 57 | unsigned long tcon; |
58 | 58 | ||
@@ -86,7 +86,7 @@ static void s5pv310_pwm_init(unsigned int pwm_id, unsigned long tcnt) | |||
86 | } | 86 | } |
87 | } | 87 | } |
88 | 88 | ||
89 | static inline void s5pv310_pwm_start(unsigned int pwm_id, bool periodic) | 89 | static inline void exynos4_pwm_start(unsigned int pwm_id, bool periodic) |
90 | { | 90 | { |
91 | unsigned long tcon; | 91 | unsigned long tcon; |
92 | 92 | ||
@@ -117,23 +117,23 @@ static inline void s5pv310_pwm_start(unsigned int pwm_id, bool periodic) | |||
117 | __raw_writel(tcon, S3C2410_TCON); | 117 | __raw_writel(tcon, S3C2410_TCON); |
118 | } | 118 | } |
119 | 119 | ||
120 | static int s5pv310_pwm_set_next_event(unsigned long cycles, | 120 | static int exynos4_pwm_set_next_event(unsigned long cycles, |
121 | struct clock_event_device *evt) | 121 | struct clock_event_device *evt) |
122 | { | 122 | { |
123 | s5pv310_pwm_init(2, cycles); | 123 | exynos4_pwm_init(2, cycles); |
124 | s5pv310_pwm_start(2, 0); | 124 | exynos4_pwm_start(2, 0); |
125 | return 0; | 125 | return 0; |
126 | } | 126 | } |
127 | 127 | ||
128 | static void s5pv310_pwm_set_mode(enum clock_event_mode mode, | 128 | static void exynos4_pwm_set_mode(enum clock_event_mode mode, |
129 | struct clock_event_device *evt) | 129 | struct clock_event_device *evt) |
130 | { | 130 | { |
131 | s5pv310_pwm_stop(2); | 131 | exynos4_pwm_stop(2); |
132 | 132 | ||
133 | switch (mode) { | 133 | switch (mode) { |
134 | case CLOCK_EVT_MODE_PERIODIC: | 134 | case CLOCK_EVT_MODE_PERIODIC: |
135 | s5pv310_pwm_init(2, clock_count_per_tick); | 135 | exynos4_pwm_init(2, clock_count_per_tick); |
136 | s5pv310_pwm_start(2, 1); | 136 | exynos4_pwm_start(2, 1); |
137 | break; | 137 | break; |
138 | case CLOCK_EVT_MODE_ONESHOT: | 138 | case CLOCK_EVT_MODE_ONESHOT: |
139 | break; | 139 | break; |
@@ -149,11 +149,11 @@ static struct clock_event_device pwm_event_device = { | |||
149 | .features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT, | 149 | .features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT, |
150 | .rating = 200, | 150 | .rating = 200, |
151 | .shift = 32, | 151 | .shift = 32, |
152 | .set_next_event = s5pv310_pwm_set_next_event, | 152 | .set_next_event = exynos4_pwm_set_next_event, |
153 | .set_mode = s5pv310_pwm_set_mode, | 153 | .set_mode = exynos4_pwm_set_mode, |
154 | }; | 154 | }; |
155 | 155 | ||
156 | irqreturn_t s5pv310_clock_event_isr(int irq, void *dev_id) | 156 | irqreturn_t exynos4_clock_event_isr(int irq, void *dev_id) |
157 | { | 157 | { |
158 | struct clock_event_device *evt = &pwm_event_device; | 158 | struct clock_event_device *evt = &pwm_event_device; |
159 | 159 | ||
@@ -162,13 +162,13 @@ irqreturn_t s5pv310_clock_event_isr(int irq, void *dev_id) | |||
162 | return IRQ_HANDLED; | 162 | return IRQ_HANDLED; |
163 | } | 163 | } |
164 | 164 | ||
165 | static struct irqaction s5pv310_clock_event_irq = { | 165 | static struct irqaction exynos4_clock_event_irq = { |
166 | .name = "pwm_timer2_irq", | 166 | .name = "pwm_timer2_irq", |
167 | .flags = IRQF_DISABLED | IRQF_TIMER | IRQF_IRQPOLL, | 167 | .flags = IRQF_DISABLED | IRQF_TIMER | IRQF_IRQPOLL, |
168 | .handler = s5pv310_clock_event_isr, | 168 | .handler = exynos4_clock_event_isr, |
169 | }; | 169 | }; |
170 | 170 | ||
171 | static void __init s5pv310_clockevent_init(void) | 171 | static void __init exynos4_clockevent_init(void) |
172 | { | 172 | { |
173 | unsigned long pclk; | 173 | unsigned long pclk; |
174 | unsigned long clock_rate; | 174 | unsigned long clock_rate; |
@@ -198,23 +198,39 @@ static void __init s5pv310_clockevent_init(void) | |||
198 | pwm_event_device.cpumask = cpumask_of(0); | 198 | pwm_event_device.cpumask = cpumask_of(0); |
199 | clockevents_register_device(&pwm_event_device); | 199 | clockevents_register_device(&pwm_event_device); |
200 | 200 | ||
201 | setup_irq(IRQ_TIMER2, &s5pv310_clock_event_irq); | 201 | setup_irq(IRQ_TIMER2, &exynos4_clock_event_irq); |
202 | } | 202 | } |
203 | 203 | ||
204 | static cycle_t s5pv310_pwm4_read(struct clocksource *cs) | 204 | static cycle_t exynos4_pwm4_read(struct clocksource *cs) |
205 | { | 205 | { |
206 | return (cycle_t) ~__raw_readl(S3C_TIMERREG(0x40)); | 206 | return (cycle_t) ~__raw_readl(S3C_TIMERREG(0x40)); |
207 | } | 207 | } |
208 | 208 | ||
209 | static void exynos4_pwm4_resume(struct clocksource *cs) | ||
210 | { | ||
211 | unsigned long pclk; | ||
212 | |||
213 | pclk = clk_get_rate(timerclk); | ||
214 | |||
215 | clk_set_rate(tdiv4, pclk / 2); | ||
216 | clk_set_parent(tin4, tdiv4); | ||
217 | |||
218 | exynos4_pwm_init(4, ~0); | ||
219 | exynos4_pwm_start(4, 1); | ||
220 | } | ||
221 | |||
209 | struct clocksource pwm_clocksource = { | 222 | struct clocksource pwm_clocksource = { |
210 | .name = "pwm_timer4", | 223 | .name = "pwm_timer4", |
211 | .rating = 250, | 224 | .rating = 250, |
212 | .read = s5pv310_pwm4_read, | 225 | .read = exynos4_pwm4_read, |
213 | .mask = CLOCKSOURCE_MASK(32), | 226 | .mask = CLOCKSOURCE_MASK(32), |
214 | .flags = CLOCK_SOURCE_IS_CONTINUOUS , | 227 | .flags = CLOCK_SOURCE_IS_CONTINUOUS , |
228 | #ifdef CONFIG_PM | ||
229 | .resume = exynos4_pwm4_resume, | ||
230 | #endif | ||
215 | }; | 231 | }; |
216 | 232 | ||
217 | static void __init s5pv310_clocksource_init(void) | 233 | static void __init exynos4_clocksource_init(void) |
218 | { | 234 | { |
219 | unsigned long pclk; | 235 | unsigned long pclk; |
220 | unsigned long clock_rate; | 236 | unsigned long clock_rate; |
@@ -226,14 +242,14 @@ static void __init s5pv310_clocksource_init(void) | |||
226 | 242 | ||
227 | clock_rate = clk_get_rate(tin4); | 243 | clock_rate = clk_get_rate(tin4); |
228 | 244 | ||
229 | s5pv310_pwm_init(4, ~0); | 245 | exynos4_pwm_init(4, ~0); |
230 | s5pv310_pwm_start(4, 1); | 246 | exynos4_pwm_start(4, 1); |
231 | 247 | ||
232 | if (clocksource_register_hz(&pwm_clocksource, clock_rate)) | 248 | if (clocksource_register_hz(&pwm_clocksource, clock_rate)) |
233 | panic("%s: can't register clocksource\n", pwm_clocksource.name); | 249 | panic("%s: can't register clocksource\n", pwm_clocksource.name); |
234 | } | 250 | } |
235 | 251 | ||
236 | static void __init s5pv310_timer_resources(void) | 252 | static void __init exynos4_timer_resources(void) |
237 | { | 253 | { |
238 | struct platform_device tmpdev; | 254 | struct platform_device tmpdev; |
239 | 255 | ||
@@ -267,17 +283,17 @@ static void __init s5pv310_timer_resources(void) | |||
267 | clk_enable(tin4); | 283 | clk_enable(tin4); |
268 | } | 284 | } |
269 | 285 | ||
270 | static void __init s5pv310_timer_init(void) | 286 | static void __init exynos4_timer_init(void) |
271 | { | 287 | { |
272 | #ifdef CONFIG_LOCAL_TIMERS | 288 | #ifdef CONFIG_LOCAL_TIMERS |
273 | twd_base = S5P_VA_TWD; | 289 | twd_base = S5P_VA_TWD; |
274 | #endif | 290 | #endif |
275 | 291 | ||
276 | s5pv310_timer_resources(); | 292 | exynos4_timer_resources(); |
277 | s5pv310_clockevent_init(); | 293 | exynos4_clockevent_init(); |
278 | s5pv310_clocksource_init(); | 294 | exynos4_clocksource_init(); |
279 | } | 295 | } |
280 | 296 | ||
281 | struct sys_timer s5pv310_timer = { | 297 | struct sys_timer exynos4_timer = { |
282 | .init = s5pv310_timer_init, | 298 | .init = exynos4_timer_init, |
283 | }; | 299 | }; |
diff --git a/arch/arm/mach-s3c2440/mach-gta02.c b/arch/arm/mach-s3c2440/mach-gta02.c index 9f2c14ec7181..d217ef3cd86a 100644 --- a/arch/arm/mach-s3c2440/mach-gta02.c +++ b/arch/arm/mach-s3c2440/mach-gta02.c | |||
@@ -58,6 +58,9 @@ | |||
58 | #include <linux/mfd/pcf50633/pmic.h> | 58 | #include <linux/mfd/pcf50633/pmic.h> |
59 | #include <linux/mfd/pcf50633/backlight.h> | 59 | #include <linux/mfd/pcf50633/backlight.h> |
60 | 60 | ||
61 | #include <linux/input.h> | ||
62 | #include <linux/gpio_keys.h> | ||
63 | |||
61 | #include <asm/mach/arch.h> | 64 | #include <asm/mach/arch.h> |
62 | #include <asm/mach/map.h> | 65 | #include <asm/mach/map.h> |
63 | #include <asm/mach/irq.h> | 66 | #include <asm/mach/irq.h> |
@@ -86,6 +89,8 @@ | |||
86 | #include <plat/udc.h> | 89 | #include <plat/udc.h> |
87 | #include <plat/gpio-cfg.h> | 90 | #include <plat/gpio-cfg.h> |
88 | #include <plat/iic.h> | 91 | #include <plat/iic.h> |
92 | #include <plat/ts.h> | ||
93 | |||
89 | 94 | ||
90 | static struct pcf50633 *gta02_pcf; | 95 | static struct pcf50633 *gta02_pcf; |
91 | 96 | ||
@@ -280,9 +285,6 @@ struct pcf50633_platform_data gta02_pcf_pdata = { | |||
280 | .valid_modes_mask = REGULATOR_MODE_NORMAL, | 285 | .valid_modes_mask = REGULATOR_MODE_NORMAL, |
281 | .always_on = 1, | 286 | .always_on = 1, |
282 | .apply_uV = 1, | 287 | .apply_uV = 1, |
283 | .state_mem = { | ||
284 | .enabled = 1, | ||
285 | }, | ||
286 | }, | 288 | }, |
287 | }, | 289 | }, |
288 | [PCF50633_REGULATOR_DOWN1] = { | 290 | [PCF50633_REGULATOR_DOWN1] = { |
@@ -301,9 +303,6 @@ struct pcf50633_platform_data gta02_pcf_pdata = { | |||
301 | .valid_modes_mask = REGULATOR_MODE_NORMAL, | 303 | .valid_modes_mask = REGULATOR_MODE_NORMAL, |
302 | .apply_uV = 1, | 304 | .apply_uV = 1, |
303 | .always_on = 1, | 305 | .always_on = 1, |
304 | .state_mem = { | ||
305 | .enabled = 1, | ||
306 | }, | ||
307 | }, | 306 | }, |
308 | }, | 307 | }, |
309 | [PCF50633_REGULATOR_HCLDO] = { | 308 | [PCF50633_REGULATOR_HCLDO] = { |
@@ -311,8 +310,8 @@ struct pcf50633_platform_data gta02_pcf_pdata = { | |||
311 | .min_uV = 2000000, | 310 | .min_uV = 2000000, |
312 | .max_uV = 3300000, | 311 | .max_uV = 3300000, |
313 | .valid_modes_mask = REGULATOR_MODE_NORMAL, | 312 | .valid_modes_mask = REGULATOR_MODE_NORMAL, |
314 | .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE, | 313 | .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE | |
315 | .always_on = 1, | 314 | REGULATOR_CHANGE_STATUS, |
316 | }, | 315 | }, |
317 | }, | 316 | }, |
318 | [PCF50633_REGULATOR_LDO1] = { | 317 | [PCF50633_REGULATOR_LDO1] = { |
@@ -320,10 +319,8 @@ struct pcf50633_platform_data gta02_pcf_pdata = { | |||
320 | .min_uV = 3300000, | 319 | .min_uV = 3300000, |
321 | .max_uV = 3300000, | 320 | .max_uV = 3300000, |
322 | .valid_modes_mask = REGULATOR_MODE_NORMAL, | 321 | .valid_modes_mask = REGULATOR_MODE_NORMAL, |
322 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
323 | .apply_uV = 1, | 323 | .apply_uV = 1, |
324 | .state_mem = { | ||
325 | .enabled = 0, | ||
326 | }, | ||
327 | }, | 324 | }, |
328 | }, | 325 | }, |
329 | [PCF50633_REGULATOR_LDO2] = { | 326 | [PCF50633_REGULATOR_LDO2] = { |
@@ -347,6 +344,7 @@ struct pcf50633_platform_data gta02_pcf_pdata = { | |||
347 | .min_uV = 3200000, | 344 | .min_uV = 3200000, |
348 | .max_uV = 3200000, | 345 | .max_uV = 3200000, |
349 | .valid_modes_mask = REGULATOR_MODE_NORMAL, | 346 | .valid_modes_mask = REGULATOR_MODE_NORMAL, |
347 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
350 | .apply_uV = 1, | 348 | .apply_uV = 1, |
351 | }, | 349 | }, |
352 | }, | 350 | }, |
@@ -355,10 +353,8 @@ struct pcf50633_platform_data gta02_pcf_pdata = { | |||
355 | .min_uV = 3000000, | 353 | .min_uV = 3000000, |
356 | .max_uV = 3000000, | 354 | .max_uV = 3000000, |
357 | .valid_modes_mask = REGULATOR_MODE_NORMAL, | 355 | .valid_modes_mask = REGULATOR_MODE_NORMAL, |
356 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
358 | .apply_uV = 1, | 357 | .apply_uV = 1, |
359 | .state_mem = { | ||
360 | .enabled = 1, | ||
361 | }, | ||
362 | }, | 358 | }, |
363 | }, | 359 | }, |
364 | [PCF50633_REGULATOR_LDO6] = { | 360 | [PCF50633_REGULATOR_LDO6] = { |
@@ -373,9 +369,6 @@ struct pcf50633_platform_data gta02_pcf_pdata = { | |||
373 | .min_uV = 1800000, | 369 | .min_uV = 1800000, |
374 | .max_uV = 1800000, | 370 | .max_uV = 1800000, |
375 | .valid_modes_mask = REGULATOR_MODE_NORMAL, | 371 | .valid_modes_mask = REGULATOR_MODE_NORMAL, |
376 | .state_mem = { | ||
377 | .enabled = 1, | ||
378 | }, | ||
379 | }, | 372 | }, |
380 | }, | 373 | }, |
381 | 374 | ||
@@ -489,6 +482,43 @@ static struct s3c2410_hcd_info gta02_usb_info __initdata = { | |||
489 | }, | 482 | }, |
490 | }; | 483 | }; |
491 | 484 | ||
485 | /* Touchscreen */ | ||
486 | static struct s3c2410_ts_mach_info gta02_ts_info = { | ||
487 | .delay = 10000, | ||
488 | .presc = 0xff, /* slow as we can go */ | ||
489 | .oversampling_shift = 2, | ||
490 | }; | ||
491 | |||
492 | /* Buttons */ | ||
493 | static struct gpio_keys_button gta02_buttons[] = { | ||
494 | { | ||
495 | .gpio = GTA02_GPIO_AUX_KEY, | ||
496 | .code = KEY_PHONE, | ||
497 | .desc = "Aux", | ||
498 | .type = EV_KEY, | ||
499 | .debounce_interval = 100, | ||
500 | }, | ||
501 | { | ||
502 | .gpio = GTA02_GPIO_HOLD_KEY, | ||
503 | .code = KEY_PAUSE, | ||
504 | .desc = "Hold", | ||
505 | .type = EV_KEY, | ||
506 | .debounce_interval = 100, | ||
507 | }, | ||
508 | }; | ||
509 | |||
510 | static struct gpio_keys_platform_data gta02_buttons_pdata = { | ||
511 | .buttons = gta02_buttons, | ||
512 | .nbuttons = ARRAY_SIZE(gta02_buttons), | ||
513 | }; | ||
514 | |||
515 | static struct platform_device gta02_buttons_device = { | ||
516 | .name = "gpio-keys", | ||
517 | .id = -1, | ||
518 | .dev = { | ||
519 | .platform_data = >a02_buttons_pdata, | ||
520 | }, | ||
521 | }; | ||
492 | 522 | ||
493 | static void __init gta02_map_io(void) | 523 | static void __init gta02_map_io(void) |
494 | { | 524 | { |
@@ -509,7 +539,11 @@ static struct platform_device *gta02_devices[] __initdata = { | |||
509 | >a02_nor_flash, | 539 | >a02_nor_flash, |
510 | &s3c24xx_pwm_device, | 540 | &s3c24xx_pwm_device, |
511 | &s3c_device_iis, | 541 | &s3c_device_iis, |
542 | &samsung_asoc_dma, | ||
512 | &s3c_device_i2c0, | 543 | &s3c_device_i2c0, |
544 | >a02_buttons_device, | ||
545 | &s3c_device_adc, | ||
546 | &s3c_device_ts, | ||
513 | }; | 547 | }; |
514 | 548 | ||
515 | /* These guys DO need to be children of PMU. */ | 549 | /* These guys DO need to be children of PMU. */ |
@@ -559,6 +593,7 @@ static void __init gta02_machine_init(void) | |||
559 | #endif | 593 | #endif |
560 | 594 | ||
561 | s3c24xx_udc_set_platdata(>a02_udc_cfg); | 595 | s3c24xx_udc_set_platdata(>a02_udc_cfg); |
596 | s3c24xx_ts_set_platdata(>a02_ts_info); | ||
562 | s3c_ohci_set_platdata(>a02_usb_info); | 597 | s3c_ohci_set_platdata(>a02_usb_info); |
563 | s3c_nand_set_platdata(>a02_nand_info); | 598 | s3c_nand_set_platdata(>a02_nand_info); |
564 | s3c_i2c0_set_platdata(NULL); | 599 | s3c_i2c0_set_platdata(NULL); |
@@ -567,6 +602,8 @@ static void __init gta02_machine_init(void) | |||
567 | 602 | ||
568 | platform_add_devices(gta02_devices, ARRAY_SIZE(gta02_devices)); | 603 | platform_add_devices(gta02_devices, ARRAY_SIZE(gta02_devices)); |
569 | pm_power_off = gta02_poweroff; | 604 | pm_power_off = gta02_poweroff; |
605 | |||
606 | regulator_has_full_constraints(); | ||
570 | } | 607 | } |
571 | 608 | ||
572 | 609 | ||
diff --git a/arch/arm/mach-s3c64xx/Kconfig b/arch/arm/mach-s3c64xx/Kconfig index 579d2f0f4dd0..e4177e22557b 100644 --- a/arch/arm/mach-s3c64xx/Kconfig +++ b/arch/arm/mach-s3c64xx/Kconfig | |||
@@ -143,6 +143,7 @@ config MACH_SMDK6410 | |||
143 | select S3C_DEV_USB_HSOTG | 143 | select S3C_DEV_USB_HSOTG |
144 | select S3C_DEV_WDT | 144 | select S3C_DEV_WDT |
145 | select SAMSUNG_DEV_KEYPAD | 145 | select SAMSUNG_DEV_KEYPAD |
146 | select SAMSUNG_DEV_PWM | ||
146 | select HAVE_S3C2410_WATCHDOG if WATCHDOG | 147 | select HAVE_S3C2410_WATCHDOG if WATCHDOG |
147 | select S3C64XX_SETUP_SDHCI | 148 | select S3C64XX_SETUP_SDHCI |
148 | select S3C64XX_SETUP_I2C1 | 149 | select S3C64XX_SETUP_I2C1 |
@@ -231,7 +232,7 @@ config MACH_HMT | |||
231 | select S3C_DEV_NAND | 232 | select S3C_DEV_NAND |
232 | select S3C_DEV_USB_HOST | 233 | select S3C_DEV_USB_HOST |
233 | select S3C64XX_SETUP_FB_24BPP | 234 | select S3C64XX_SETUP_FB_24BPP |
234 | select HAVE_PWM | 235 | select SAMSUNG_DEV_PWM |
235 | help | 236 | help |
236 | Machine support for the Airgoo HMT | 237 | Machine support for the Airgoo HMT |
237 | 238 | ||
@@ -249,8 +250,8 @@ config MACH_SMARTQ | |||
249 | select S3C64XX_SETUP_SDHCI | 250 | select S3C64XX_SETUP_SDHCI |
250 | select S3C64XX_SETUP_FB_24BPP | 251 | select S3C64XX_SETUP_FB_24BPP |
251 | select SAMSUNG_DEV_ADC | 252 | select SAMSUNG_DEV_ADC |
253 | select SAMSUNG_DEV_PWM | ||
252 | select SAMSUNG_DEV_TS | 254 | select SAMSUNG_DEV_TS |
253 | select HAVE_PWM | ||
254 | help | 255 | help |
255 | Shared machine support for SmartQ 5/7 | 256 | Shared machine support for SmartQ 5/7 |
256 | 257 | ||
diff --git a/arch/arm/mach-s3c64xx/cpufreq.c b/arch/arm/mach-s3c64xx/cpufreq.c index 74c0e8347de5..4375b97588b8 100644 --- a/arch/arm/mach-s3c64xx/cpufreq.c +++ b/arch/arm/mach-s3c64xx/cpufreq.c | |||
@@ -181,7 +181,7 @@ static void __init s3c64xx_cpufreq_config_regulator(void) | |||
181 | } | 181 | } |
182 | #endif | 182 | #endif |
183 | 183 | ||
184 | static int __init s3c64xx_cpufreq_driver_init(struct cpufreq_policy *policy) | 184 | static int s3c64xx_cpufreq_driver_init(struct cpufreq_policy *policy) |
185 | { | 185 | { |
186 | int ret; | 186 | int ret; |
187 | struct cpufreq_frequency_table *freq; | 187 | struct cpufreq_frequency_table *freq; |
diff --git a/arch/arm/mach-s3c64xx/mach-smdk6410.c b/arch/arm/mach-s3c64xx/mach-smdk6410.c index a80a3163dd30..686a4f270b12 100644 --- a/arch/arm/mach-s3c64xx/mach-smdk6410.c +++ b/arch/arm/mach-s3c64xx/mach-smdk6410.c | |||
@@ -29,6 +29,7 @@ | |||
29 | #include <linux/smsc911x.h> | 29 | #include <linux/smsc911x.h> |
30 | #include <linux/regulator/fixed.h> | 30 | #include <linux/regulator/fixed.h> |
31 | #include <linux/regulator/machine.h> | 31 | #include <linux/regulator/machine.h> |
32 | #include <linux/pwm_backlight.h> | ||
32 | 33 | ||
33 | #ifdef CONFIG_SMDK6410_WM1190_EV1 | 34 | #ifdef CONFIG_SMDK6410_WM1190_EV1 |
34 | #include <linux/mfd/wm8350/core.h> | 35 | #include <linux/mfd/wm8350/core.h> |
@@ -49,6 +50,7 @@ | |||
49 | #include <mach/hardware.h> | 50 | #include <mach/hardware.h> |
50 | #include <mach/regs-fb.h> | 51 | #include <mach/regs-fb.h> |
51 | #include <mach/map.h> | 52 | #include <mach/map.h> |
53 | #include <mach/gpio-bank-f.h> | ||
52 | 54 | ||
53 | #include <asm/irq.h> | 55 | #include <asm/irq.h> |
54 | #include <asm/mach-types.h> | 56 | #include <asm/mach-types.h> |
@@ -119,7 +121,6 @@ static void smdk6410_lcd_power_set(struct plat_lcd_data *pd, | |||
119 | { | 121 | { |
120 | if (power) { | 122 | if (power) { |
121 | gpio_direction_output(S3C64XX_GPF(13), 1); | 123 | gpio_direction_output(S3C64XX_GPF(13), 1); |
122 | gpio_direction_output(S3C64XX_GPF(15), 1); | ||
123 | 124 | ||
124 | /* fire nRESET on power up */ | 125 | /* fire nRESET on power up */ |
125 | gpio_direction_output(S3C64XX_GPN(5), 0); | 126 | gpio_direction_output(S3C64XX_GPN(5), 0); |
@@ -127,7 +128,6 @@ static void smdk6410_lcd_power_set(struct plat_lcd_data *pd, | |||
127 | gpio_direction_output(S3C64XX_GPN(5), 1); | 128 | gpio_direction_output(S3C64XX_GPN(5), 1); |
128 | msleep(1); | 129 | msleep(1); |
129 | } else { | 130 | } else { |
130 | gpio_direction_output(S3C64XX_GPF(15), 0); | ||
131 | gpio_direction_output(S3C64XX_GPF(13), 0); | 131 | gpio_direction_output(S3C64XX_GPF(13), 0); |
132 | } | 132 | } |
133 | } | 133 | } |
@@ -270,6 +270,45 @@ static struct samsung_keypad_platdata smdk6410_keypad_data __initdata = { | |||
270 | .cols = 8, | 270 | .cols = 8, |
271 | }; | 271 | }; |
272 | 272 | ||
273 | static int smdk6410_backlight_init(struct device *dev) | ||
274 | { | ||
275 | int ret; | ||
276 | |||
277 | ret = gpio_request(S3C64XX_GPF(15), "Backlight"); | ||
278 | if (ret) { | ||
279 | printk(KERN_ERR "failed to request GPF for PWM-OUT1\n"); | ||
280 | return ret; | ||
281 | } | ||
282 | |||
283 | /* Configure GPIO pin with S3C64XX_GPF15_PWM_TOUT1 */ | ||
284 | s3c_gpio_cfgpin(S3C64XX_GPF(15), S3C_GPIO_SFN(2)); | ||
285 | |||
286 | return 0; | ||
287 | } | ||
288 | |||
289 | static void smdk6410_backlight_exit(struct device *dev) | ||
290 | { | ||
291 | s3c_gpio_cfgpin(S3C64XX_GPF(15), S3C_GPIO_OUTPUT); | ||
292 | gpio_free(S3C64XX_GPF(15)); | ||
293 | } | ||
294 | |||
295 | static struct platform_pwm_backlight_data smdk6410_backlight_data = { | ||
296 | .pwm_id = 1, | ||
297 | .max_brightness = 255, | ||
298 | .dft_brightness = 255, | ||
299 | .pwm_period_ns = 78770, | ||
300 | .init = smdk6410_backlight_init, | ||
301 | .exit = smdk6410_backlight_exit, | ||
302 | }; | ||
303 | |||
304 | static struct platform_device smdk6410_backlight_device = { | ||
305 | .name = "pwm-backlight", | ||
306 | .dev = { | ||
307 | .parent = &s3c_device_timer[1].dev, | ||
308 | .platform_data = &smdk6410_backlight_data, | ||
309 | }, | ||
310 | }; | ||
311 | |||
273 | static struct map_desc smdk6410_iodesc[] = {}; | 312 | static struct map_desc smdk6410_iodesc[] = {}; |
274 | 313 | ||
275 | static struct platform_device *smdk6410_devices[] __initdata = { | 314 | static struct platform_device *smdk6410_devices[] __initdata = { |
@@ -299,6 +338,8 @@ static struct platform_device *smdk6410_devices[] __initdata = { | |||
299 | &s3c_device_rtc, | 338 | &s3c_device_rtc, |
300 | &s3c_device_ts, | 339 | &s3c_device_ts, |
301 | &s3c_device_wdt, | 340 | &s3c_device_wdt, |
341 | &s3c_device_timer[1], | ||
342 | &smdk6410_backlight_device, | ||
302 | }; | 343 | }; |
303 | 344 | ||
304 | #ifdef CONFIG_REGULATOR | 345 | #ifdef CONFIG_REGULATOR |
@@ -694,7 +735,6 @@ static void __init smdk6410_machine_init(void) | |||
694 | 735 | ||
695 | gpio_request(S3C64XX_GPN(5), "LCD power"); | 736 | gpio_request(S3C64XX_GPN(5), "LCD power"); |
696 | gpio_request(S3C64XX_GPF(13), "LCD power"); | 737 | gpio_request(S3C64XX_GPF(13), "LCD power"); |
697 | gpio_request(S3C64XX_GPF(15), "LCD power"); | ||
698 | 738 | ||
699 | i2c_register_board_info(0, i2c_devs0, ARRAY_SIZE(i2c_devs0)); | 739 | i2c_register_board_info(0, i2c_devs0, ARRAY_SIZE(i2c_devs0)); |
700 | i2c_register_board_info(1, i2c_devs1, ARRAY_SIZE(i2c_devs1)); | 740 | i2c_register_board_info(1, i2c_devs1, ARRAY_SIZE(i2c_devs1)); |
diff --git a/arch/arm/mach-s5p64x0/Kconfig b/arch/arm/mach-s5p64x0/Kconfig index 164d2783d381..017af4c4293c 100644 --- a/arch/arm/mach-s5p64x0/Kconfig +++ b/arch/arm/mach-s5p64x0/Kconfig | |||
@@ -10,12 +10,14 @@ if ARCH_S5P64X0 | |||
10 | config CPU_S5P6440 | 10 | config CPU_S5P6440 |
11 | bool | 11 | bool |
12 | select S3C_PL330_DMA | 12 | select S3C_PL330_DMA |
13 | select S5P_HRT | ||
13 | help | 14 | help |
14 | Enable S5P6440 CPU support | 15 | Enable S5P6440 CPU support |
15 | 16 | ||
16 | config CPU_S5P6450 | 17 | config CPU_S5P6450 |
17 | bool | 18 | bool |
18 | select S3C_PL330_DMA | 19 | select S3C_PL330_DMA |
20 | select S5P_HRT | ||
19 | help | 21 | help |
20 | Enable S5P6450 CPU support | 22 | Enable S5P6450 CPU support |
21 | 23 | ||
@@ -34,6 +36,7 @@ config MACH_SMDK6440 | |||
34 | select S3C_DEV_WDT | 36 | select S3C_DEV_WDT |
35 | select S3C64XX_DEV_SPI | 37 | select S3C64XX_DEV_SPI |
36 | select SAMSUNG_DEV_ADC | 38 | select SAMSUNG_DEV_ADC |
39 | select SAMSUNG_DEV_PWM | ||
37 | select SAMSUNG_DEV_TS | 40 | select SAMSUNG_DEV_TS |
38 | select S5P64X0_SETUP_I2C1 | 41 | select S5P64X0_SETUP_I2C1 |
39 | help | 42 | help |
@@ -47,6 +50,7 @@ config MACH_SMDK6450 | |||
47 | select S3C_DEV_WDT | 50 | select S3C_DEV_WDT |
48 | select S3C64XX_DEV_SPI | 51 | select S3C64XX_DEV_SPI |
49 | select SAMSUNG_DEV_ADC | 52 | select SAMSUNG_DEV_ADC |
53 | select SAMSUNG_DEV_PWM | ||
50 | select SAMSUNG_DEV_TS | 54 | select SAMSUNG_DEV_TS |
51 | select S5P64X0_SETUP_I2C1 | 55 | select S5P64X0_SETUP_I2C1 |
52 | help | 56 | help |
diff --git a/arch/arm/mach-s5p64x0/mach-smdk6440.c b/arch/arm/mach-s5p64x0/mach-smdk6440.c index e5beb84e2393..2d559f10fd47 100644 --- a/arch/arm/mach-s5p64x0/mach-smdk6440.c +++ b/arch/arm/mach-s5p64x0/mach-smdk6440.c | |||
@@ -22,6 +22,7 @@ | |||
22 | #include <linux/module.h> | 22 | #include <linux/module.h> |
23 | #include <linux/clk.h> | 23 | #include <linux/clk.h> |
24 | #include <linux/gpio.h> | 24 | #include <linux/gpio.h> |
25 | #include <linux/pwm_backlight.h> | ||
25 | 26 | ||
26 | #include <asm/mach/arch.h> | 27 | #include <asm/mach/arch.h> |
27 | #include <asm/mach/map.h> | 28 | #include <asm/mach/map.h> |
@@ -32,6 +33,7 @@ | |||
32 | #include <mach/map.h> | 33 | #include <mach/map.h> |
33 | #include <mach/regs-clock.h> | 34 | #include <mach/regs-clock.h> |
34 | #include <mach/i2c.h> | 35 | #include <mach/i2c.h> |
36 | #include <mach/regs-gpio.h> | ||
35 | 37 | ||
36 | #include <plat/regs-serial.h> | 38 | #include <plat/regs-serial.h> |
37 | #include <plat/gpio-cfg.h> | 39 | #include <plat/gpio-cfg.h> |
@@ -43,6 +45,7 @@ | |||
43 | #include <plat/pll.h> | 45 | #include <plat/pll.h> |
44 | #include <plat/adc.h> | 46 | #include <plat/adc.h> |
45 | #include <plat/ts.h> | 47 | #include <plat/ts.h> |
48 | #include <plat/s5p-time.h> | ||
46 | 49 | ||
47 | #define SMDK6440_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ | 50 | #define SMDK6440_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ |
48 | S3C2410_UCON_RXILEVEL | \ | 51 | S3C2410_UCON_RXILEVEL | \ |
@@ -88,6 +91,45 @@ static struct s3c2410_uartcfg smdk6440_uartcfgs[] __initdata = { | |||
88 | }, | 91 | }, |
89 | }; | 92 | }; |
90 | 93 | ||
94 | static int smdk6440_backlight_init(struct device *dev) | ||
95 | { | ||
96 | int ret; | ||
97 | |||
98 | ret = gpio_request(S5P6440_GPF(15), "Backlight"); | ||
99 | if (ret) { | ||
100 | printk(KERN_ERR "failed to request GPF for PWM-OUT1\n"); | ||
101 | return ret; | ||
102 | } | ||
103 | |||
104 | /* Configure GPIO pin with S5P6440_GPF15_PWM_TOUT1 */ | ||
105 | s3c_gpio_cfgpin(S5P6440_GPF(15), S3C_GPIO_SFN(2)); | ||
106 | |||
107 | return 0; | ||
108 | } | ||
109 | |||
110 | static void smdk6440_backlight_exit(struct device *dev) | ||
111 | { | ||
112 | s3c_gpio_cfgpin(S5P6440_GPF(15), S3C_GPIO_OUTPUT); | ||
113 | gpio_free(S5P6440_GPF(15)); | ||
114 | } | ||
115 | |||
116 | static struct platform_pwm_backlight_data smdk6440_backlight_data = { | ||
117 | .pwm_id = 1, | ||
118 | .max_brightness = 255, | ||
119 | .dft_brightness = 255, | ||
120 | .pwm_period_ns = 78770, | ||
121 | .init = smdk6440_backlight_init, | ||
122 | .exit = smdk6440_backlight_exit, | ||
123 | }; | ||
124 | |||
125 | static struct platform_device smdk6440_backlight_device = { | ||
126 | .name = "pwm-backlight", | ||
127 | .dev = { | ||
128 | .parent = &s3c_device_timer[1].dev, | ||
129 | .platform_data = &smdk6440_backlight_data, | ||
130 | }, | ||
131 | }; | ||
132 | |||
91 | static struct platform_device *smdk6440_devices[] __initdata = { | 133 | static struct platform_device *smdk6440_devices[] __initdata = { |
92 | &s3c_device_adc, | 134 | &s3c_device_adc, |
93 | &s3c_device_rtc, | 135 | &s3c_device_rtc, |
@@ -97,6 +139,8 @@ static struct platform_device *smdk6440_devices[] __initdata = { | |||
97 | &s3c_device_wdt, | 139 | &s3c_device_wdt, |
98 | &samsung_asoc_dma, | 140 | &samsung_asoc_dma, |
99 | &s5p6440_device_iis, | 141 | &s5p6440_device_iis, |
142 | &s3c_device_timer[1], | ||
143 | &smdk6440_backlight_device, | ||
100 | }; | 144 | }; |
101 | 145 | ||
102 | static struct s3c2410_platform_i2c s5p6440_i2c0_data __initdata = { | 146 | static struct s3c2410_platform_i2c s5p6440_i2c0_data __initdata = { |
@@ -136,6 +180,7 @@ static void __init smdk6440_map_io(void) | |||
136 | s5p_init_io(NULL, 0, S5P64X0_SYS_ID); | 180 | s5p_init_io(NULL, 0, S5P64X0_SYS_ID); |
137 | s3c24xx_init_clocks(12000000); | 181 | s3c24xx_init_clocks(12000000); |
138 | s3c24xx_init_uarts(smdk6440_uartcfgs, ARRAY_SIZE(smdk6440_uartcfgs)); | 182 | s3c24xx_init_uarts(smdk6440_uartcfgs, ARRAY_SIZE(smdk6440_uartcfgs)); |
183 | s5p_set_timer_source(S5P_PWM3, S5P_PWM4); | ||
139 | } | 184 | } |
140 | 185 | ||
141 | static void __init smdk6440_machine_init(void) | 186 | static void __init smdk6440_machine_init(void) |
@@ -159,5 +204,5 @@ MACHINE_START(SMDK6440, "SMDK6440") | |||
159 | .init_irq = s5p6440_init_irq, | 204 | .init_irq = s5p6440_init_irq, |
160 | .map_io = smdk6440_map_io, | 205 | .map_io = smdk6440_map_io, |
161 | .init_machine = smdk6440_machine_init, | 206 | .init_machine = smdk6440_machine_init, |
162 | .timer = &s3c24xx_timer, | 207 | .timer = &s5p_timer, |
163 | MACHINE_END | 208 | MACHINE_END |
diff --git a/arch/arm/mach-s5p64x0/mach-smdk6450.c b/arch/arm/mach-s5p64x0/mach-smdk6450.c index 3a20de0a9264..d19c4690ee97 100644 --- a/arch/arm/mach-s5p64x0/mach-smdk6450.c +++ b/arch/arm/mach-s5p64x0/mach-smdk6450.c | |||
@@ -22,6 +22,7 @@ | |||
22 | #include <linux/module.h> | 22 | #include <linux/module.h> |
23 | #include <linux/clk.h> | 23 | #include <linux/clk.h> |
24 | #include <linux/gpio.h> | 24 | #include <linux/gpio.h> |
25 | #include <linux/pwm_backlight.h> | ||
25 | 26 | ||
26 | #include <asm/mach/arch.h> | 27 | #include <asm/mach/arch.h> |
27 | #include <asm/mach/map.h> | 28 | #include <asm/mach/map.h> |
@@ -32,6 +33,7 @@ | |||
32 | #include <mach/map.h> | 33 | #include <mach/map.h> |
33 | #include <mach/regs-clock.h> | 34 | #include <mach/regs-clock.h> |
34 | #include <mach/i2c.h> | 35 | #include <mach/i2c.h> |
36 | #include <mach/regs-gpio.h> | ||
35 | 37 | ||
36 | #include <plat/regs-serial.h> | 38 | #include <plat/regs-serial.h> |
37 | #include <plat/gpio-cfg.h> | 39 | #include <plat/gpio-cfg.h> |
@@ -43,6 +45,7 @@ | |||
43 | #include <plat/pll.h> | 45 | #include <plat/pll.h> |
44 | #include <plat/adc.h> | 46 | #include <plat/adc.h> |
45 | #include <plat/ts.h> | 47 | #include <plat/ts.h> |
48 | #include <plat/s5p-time.h> | ||
46 | 49 | ||
47 | #define SMDK6450_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ | 50 | #define SMDK6450_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ |
48 | S3C2410_UCON_RXILEVEL | \ | 51 | S3C2410_UCON_RXILEVEL | \ |
@@ -106,6 +109,45 @@ static struct s3c2410_uartcfg smdk6450_uartcfgs[] __initdata = { | |||
106 | #endif | 109 | #endif |
107 | }; | 110 | }; |
108 | 111 | ||
112 | static int smdk6450_backlight_init(struct device *dev) | ||
113 | { | ||
114 | int ret; | ||
115 | |||
116 | ret = gpio_request(S5P6450_GPF(15), "Backlight"); | ||
117 | if (ret) { | ||
118 | printk(KERN_ERR "failed to request GPF for PWM-OUT1\n"); | ||
119 | return ret; | ||
120 | } | ||
121 | |||
122 | /* Configure GPIO pin with S5P6450_GPF15_PWM_TOUT1 */ | ||
123 | s3c_gpio_cfgpin(S5P6450_GPF(15), S3C_GPIO_SFN(2)); | ||
124 | |||
125 | return 0; | ||
126 | } | ||
127 | |||
128 | static void smdk6450_backlight_exit(struct device *dev) | ||
129 | { | ||
130 | s3c_gpio_cfgpin(S5P6450_GPF(15), S3C_GPIO_OUTPUT); | ||
131 | gpio_free(S5P6450_GPF(15)); | ||
132 | } | ||
133 | |||
134 | static struct platform_pwm_backlight_data smdk6450_backlight_data = { | ||
135 | .pwm_id = 1, | ||
136 | .max_brightness = 255, | ||
137 | .dft_brightness = 255, | ||
138 | .pwm_period_ns = 78770, | ||
139 | .init = smdk6450_backlight_init, | ||
140 | .exit = smdk6450_backlight_exit, | ||
141 | }; | ||
142 | |||
143 | static struct platform_device smdk6450_backlight_device = { | ||
144 | .name = "pwm-backlight", | ||
145 | .dev = { | ||
146 | .parent = &s3c_device_timer[1].dev, | ||
147 | .platform_data = &smdk6450_backlight_data, | ||
148 | }, | ||
149 | }; | ||
150 | |||
109 | static struct platform_device *smdk6450_devices[] __initdata = { | 151 | static struct platform_device *smdk6450_devices[] __initdata = { |
110 | &s3c_device_adc, | 152 | &s3c_device_adc, |
111 | &s3c_device_rtc, | 153 | &s3c_device_rtc, |
@@ -115,6 +157,8 @@ static struct platform_device *smdk6450_devices[] __initdata = { | |||
115 | &s3c_device_wdt, | 157 | &s3c_device_wdt, |
116 | &samsung_asoc_dma, | 158 | &samsung_asoc_dma, |
117 | &s5p6450_device_iis0, | 159 | &s5p6450_device_iis0, |
160 | &s3c_device_timer[1], | ||
161 | &smdk6450_backlight_device, | ||
118 | /* s5p6450_device_spi0 will be added */ | 162 | /* s5p6450_device_spi0 will be added */ |
119 | }; | 163 | }; |
120 | 164 | ||
@@ -155,6 +199,7 @@ static void __init smdk6450_map_io(void) | |||
155 | s5p_init_io(NULL, 0, S5P64X0_SYS_ID); | 199 | s5p_init_io(NULL, 0, S5P64X0_SYS_ID); |
156 | s3c24xx_init_clocks(19200000); | 200 | s3c24xx_init_clocks(19200000); |
157 | s3c24xx_init_uarts(smdk6450_uartcfgs, ARRAY_SIZE(smdk6450_uartcfgs)); | 201 | s3c24xx_init_uarts(smdk6450_uartcfgs, ARRAY_SIZE(smdk6450_uartcfgs)); |
202 | s5p_set_timer_source(S5P_PWM3, S5P_PWM4); | ||
158 | } | 203 | } |
159 | 204 | ||
160 | static void __init smdk6450_machine_init(void) | 205 | static void __init smdk6450_machine_init(void) |
@@ -178,5 +223,5 @@ MACHINE_START(SMDK6450, "SMDK6450") | |||
178 | .init_irq = s5p6450_init_irq, | 223 | .init_irq = s5p6450_init_irq, |
179 | .map_io = smdk6450_map_io, | 224 | .map_io = smdk6450_map_io, |
180 | .init_machine = smdk6450_machine_init, | 225 | .init_machine = smdk6450_machine_init, |
181 | .timer = &s3c24xx_timer, | 226 | .timer = &s5p_timer, |
182 | MACHINE_END | 227 | MACHINE_END |
diff --git a/arch/arm/mach-s5pc100/Kconfig b/arch/arm/mach-s5pc100/Kconfig index b8fbf2fcba6f..608722ff4f28 100644 --- a/arch/arm/mach-s5pc100/Kconfig +++ b/arch/arm/mach-s5pc100/Kconfig | |||
@@ -58,6 +58,7 @@ config MACH_SMDKC100 | |||
58 | select SAMSUNG_DEV_ADC | 58 | select SAMSUNG_DEV_ADC |
59 | select SAMSUNG_DEV_IDE | 59 | select SAMSUNG_DEV_IDE |
60 | select SAMSUNG_DEV_KEYPAD | 60 | select SAMSUNG_DEV_KEYPAD |
61 | select SAMSUNG_DEV_PWM | ||
61 | select SAMSUNG_DEV_TS | 62 | select SAMSUNG_DEV_TS |
62 | select S5PC100_SETUP_FB_24BPP | 63 | select S5PC100_SETUP_FB_24BPP |
63 | select S5PC100_SETUP_I2C1 | 64 | select S5PC100_SETUP_I2C1 |
diff --git a/arch/arm/mach-s5pc100/gpiolib.c b/arch/arm/mach-s5pc100/gpiolib.c index 20856eb7dd51..2842394b28b5 100644 --- a/arch/arm/mach-s5pc100/gpiolib.c +++ b/arch/arm/mach-s5pc100/gpiolib.c | |||
@@ -348,6 +348,7 @@ static __init int s5pc100_gpiolib_init(void) | |||
348 | } | 348 | } |
349 | 349 | ||
350 | samsung_gpiolib_add_4bit_chips(s5pc100_gpio_chips, nr_chips); | 350 | samsung_gpiolib_add_4bit_chips(s5pc100_gpio_chips, nr_chips); |
351 | s5p_register_gpioint_bank(IRQ_GPIOINT, 0, S5P_GPIOINT_GROUP_MAXNR); | ||
351 | 352 | ||
352 | return 0; | 353 | return 0; |
353 | } | 354 | } |
diff --git a/arch/arm/mach-s5pc100/mach-smdkc100.c b/arch/arm/mach-s5pc100/mach-smdkc100.c index dd192a27524d..0525cb3ef406 100644 --- a/arch/arm/mach-s5pc100/mach-smdkc100.c +++ b/arch/arm/mach-s5pc100/mach-smdkc100.c | |||
@@ -23,12 +23,15 @@ | |||
23 | #include <linux/fb.h> | 23 | #include <linux/fb.h> |
24 | #include <linux/delay.h> | 24 | #include <linux/delay.h> |
25 | #include <linux/input.h> | 25 | #include <linux/input.h> |
26 | #include <linux/pwm_backlight.h> | ||
26 | 27 | ||
27 | #include <asm/mach/arch.h> | 28 | #include <asm/mach/arch.h> |
28 | #include <asm/mach/map.h> | 29 | #include <asm/mach/map.h> |
29 | 30 | ||
30 | #include <mach/map.h> | 31 | #include <mach/map.h> |
31 | #include <mach/regs-fb.h> | 32 | #include <mach/regs-fb.h> |
33 | #include <mach/regs-gpio.h> | ||
34 | |||
32 | #include <video/platform_lcd.h> | 35 | #include <video/platform_lcd.h> |
33 | 36 | ||
34 | #include <asm/irq.h> | 37 | #include <asm/irq.h> |
@@ -107,9 +110,6 @@ static struct i2c_board_info i2c_devs1[] __initdata = { | |||
107 | static void smdkc100_lcd_power_set(struct plat_lcd_data *pd, | 110 | static void smdkc100_lcd_power_set(struct plat_lcd_data *pd, |
108 | unsigned int power) | 111 | unsigned int power) |
109 | { | 112 | { |
110 | /* backlight */ | ||
111 | gpio_direction_output(S5PC100_GPD(0), power); | ||
112 | |||
113 | if (power) { | 113 | if (power) { |
114 | /* module reset */ | 114 | /* module reset */ |
115 | gpio_direction_output(S5PC100_GPH0(6), 1); | 115 | gpio_direction_output(S5PC100_GPH0(6), 1); |
@@ -179,6 +179,45 @@ static struct samsung_keypad_platdata smdkc100_keypad_data __initdata = { | |||
179 | .cols = 8, | 179 | .cols = 8, |
180 | }; | 180 | }; |
181 | 181 | ||
182 | static int smdkc100_backlight_init(struct device *dev) | ||
183 | { | ||
184 | int ret; | ||
185 | |||
186 | ret = gpio_request(S5PC100_GPD(0), "Backlight"); | ||
187 | if (ret) { | ||
188 | printk(KERN_ERR "failed to request GPF for PWM-OUT0\n"); | ||
189 | return ret; | ||
190 | } | ||
191 | |||
192 | /* Configure GPIO pin with S5PC100_GPD_TOUT_0 */ | ||
193 | s3c_gpio_cfgpin(S5PC100_GPD(0), S3C_GPIO_SFN(2)); | ||
194 | |||
195 | return 0; | ||
196 | } | ||
197 | |||
198 | static void smdkc100_backlight_exit(struct device *dev) | ||
199 | { | ||
200 | s3c_gpio_cfgpin(S5PC100_GPD(0), S3C_GPIO_OUTPUT); | ||
201 | gpio_free(S5PC100_GPD(0)); | ||
202 | } | ||
203 | |||
204 | static struct platform_pwm_backlight_data smdkc100_backlight_data = { | ||
205 | .pwm_id = 0, | ||
206 | .max_brightness = 255, | ||
207 | .dft_brightness = 255, | ||
208 | .pwm_period_ns = 78770, | ||
209 | .init = smdkc100_backlight_init, | ||
210 | .exit = smdkc100_backlight_exit, | ||
211 | }; | ||
212 | |||
213 | static struct platform_device smdkc100_backlight_device = { | ||
214 | .name = "pwm-backlight", | ||
215 | .dev = { | ||
216 | .parent = &s3c_device_timer[0].dev, | ||
217 | .platform_data = &smdkc100_backlight_data, | ||
218 | }, | ||
219 | }; | ||
220 | |||
182 | static struct platform_device *smdkc100_devices[] __initdata = { | 221 | static struct platform_device *smdkc100_devices[] __initdata = { |
183 | &s3c_device_adc, | 222 | &s3c_device_adc, |
184 | &s3c_device_cfcon, | 223 | &s3c_device_cfcon, |
@@ -200,6 +239,8 @@ static struct platform_device *smdkc100_devices[] __initdata = { | |||
200 | &s5p_device_fimc1, | 239 | &s5p_device_fimc1, |
201 | &s5p_device_fimc2, | 240 | &s5p_device_fimc2, |
202 | &s5pc100_device_spdif, | 241 | &s5pc100_device_spdif, |
242 | &s3c_device_timer[0], | ||
243 | &smdkc100_backlight_device, | ||
203 | }; | 244 | }; |
204 | 245 | ||
205 | static struct s3c2410_ts_mach_info s3c_ts_platform __initdata = { | 246 | static struct s3c2410_ts_mach_info s3c_ts_platform __initdata = { |
@@ -233,7 +274,6 @@ static void __init smdkc100_machine_init(void) | |||
233 | s5pc100_spdif_setup_gpio(S5PC100_SPDIF_GPD); | 274 | s5pc100_spdif_setup_gpio(S5PC100_SPDIF_GPD); |
234 | 275 | ||
235 | /* LCD init */ | 276 | /* LCD init */ |
236 | gpio_request(S5PC100_GPD(0), "GPD"); | ||
237 | gpio_request(S5PC100_GPH0(6), "GPH0"); | 277 | gpio_request(S5PC100_GPH0(6), "GPH0"); |
238 | smdkc100_lcd_power_set(&smdkc100_lcd_power_data, 0); | 278 | smdkc100_lcd_power_set(&smdkc100_lcd_power_data, 0); |
239 | platform_add_devices(smdkc100_devices, ARRAY_SIZE(smdkc100_devices)); | 279 | platform_add_devices(smdkc100_devices, ARRAY_SIZE(smdkc100_devices)); |
diff --git a/arch/arm/mach-s5pv210/Kconfig b/arch/arm/mach-s5pv210/Kconfig index 53aabef1e9ce..37b5a97594a5 100644 --- a/arch/arm/mach-s5pv210/Kconfig +++ b/arch/arm/mach-s5pv210/Kconfig | |||
@@ -13,6 +13,7 @@ config CPU_S5PV210 | |||
13 | bool | 13 | bool |
14 | select S3C_PL330_DMA | 14 | select S3C_PL330_DMA |
15 | select S5P_EXT_INT | 15 | select S5P_EXT_INT |
16 | select S5P_HRT | ||
16 | select S5PV210_PM if PM | 17 | select S5PV210_PM if PM |
17 | help | 18 | help |
18 | Enable S5PV210 CPU support | 19 | Enable S5PV210 CPU support |
@@ -53,6 +54,11 @@ config S5PV210_SETUP_SDHCI_GPIO | |||
53 | help | 54 | help |
54 | Common setup code for SDHCI gpio. | 55 | Common setup code for SDHCI gpio. |
55 | 56 | ||
57 | config S5PV210_SETUP_FIMC | ||
58 | bool | ||
59 | help | ||
60 | Common setup code for the camera interfaces. | ||
61 | |||
56 | menu "S5PC110 Machines" | 62 | menu "S5PC110 Machines" |
57 | 63 | ||
58 | config MACH_AQUILA | 64 | config MACH_AQUILA |
@@ -130,6 +136,7 @@ config MACH_SMDKV210 | |||
130 | select SAMSUNG_DEV_ADC | 136 | select SAMSUNG_DEV_ADC |
131 | select SAMSUNG_DEV_IDE | 137 | select SAMSUNG_DEV_IDE |
132 | select SAMSUNG_DEV_KEYPAD | 138 | select SAMSUNG_DEV_KEYPAD |
139 | select SAMSUNG_DEV_PWM | ||
133 | select SAMSUNG_DEV_TS | 140 | select SAMSUNG_DEV_TS |
134 | select S5PV210_SETUP_FB_24BPP | 141 | select S5PV210_SETUP_FB_24BPP |
135 | select S5PV210_SETUP_I2C1 | 142 | select S5PV210_SETUP_I2C1 |
diff --git a/arch/arm/mach-s5pv210/Makefile b/arch/arm/mach-s5pv210/Makefile index ff1a0db57a2f..11f17907b4e8 100644 --- a/arch/arm/mach-s5pv210/Makefile +++ b/arch/arm/mach-s5pv210/Makefile | |||
@@ -31,6 +31,7 @@ obj-y += dev-audio.o | |||
31 | obj-$(CONFIG_S3C64XX_DEV_SPI) += dev-spi.o | 31 | obj-$(CONFIG_S3C64XX_DEV_SPI) += dev-spi.o |
32 | 32 | ||
33 | obj-$(CONFIG_S5PV210_SETUP_FB_24BPP) += setup-fb-24bpp.o | 33 | obj-$(CONFIG_S5PV210_SETUP_FB_24BPP) += setup-fb-24bpp.o |
34 | obj-$(CONFIG_S5PV210_SETUP_FIMC) += setup-fimc.o | ||
34 | obj-$(CONFIG_S5PV210_SETUP_I2C1) += setup-i2c1.o | 35 | obj-$(CONFIG_S5PV210_SETUP_I2C1) += setup-i2c1.o |
35 | obj-$(CONFIG_S5PV210_SETUP_I2C2) += setup-i2c2.o | 36 | obj-$(CONFIG_S5PV210_SETUP_I2C2) += setup-i2c2.o |
36 | obj-$(CONFIG_S5PV210_SETUP_IDE) += setup-ide.o | 37 | obj-$(CONFIG_S5PV210_SETUP_IDE) += setup-ide.o |
diff --git a/arch/arm/mach-s5pv210/gpiolib.c b/arch/arm/mach-s5pv210/gpiolib.c index ab673effd767..1ba20a703e05 100644 --- a/arch/arm/mach-s5pv210/gpiolib.c +++ b/arch/arm/mach-s5pv210/gpiolib.c | |||
@@ -281,6 +281,7 @@ static __init int s5pv210_gpiolib_init(void) | |||
281 | } | 281 | } |
282 | 282 | ||
283 | samsung_gpiolib_add_4bit_chips(s5pv210_gpio_4bit, nr_chips); | 283 | samsung_gpiolib_add_4bit_chips(s5pv210_gpio_4bit, nr_chips); |
284 | s5p_register_gpioint_bank(IRQ_GPIOINT, 0, S5P_GPIOINT_GROUP_MAXNR); | ||
284 | 285 | ||
285 | return 0; | 286 | return 0; |
286 | } | 287 | } |
diff --git a/arch/arm/mach-s5pv210/include/mach/regs-clock.h b/arch/arm/mach-s5pv210/include/mach/regs-clock.h index 4c45b74def5f..78925c516346 100644 --- a/arch/arm/mach-s5pv210/include/mach/regs-clock.h +++ b/arch/arm/mach-s5pv210/include/mach/regs-clock.h | |||
@@ -146,6 +146,10 @@ | |||
146 | #define S5P_OM_STAT S5P_CLKREG(0xE100) | 146 | #define S5P_OM_STAT S5P_CLKREG(0xE100) |
147 | #define S5P_USB_PHY_CONTROL S5P_CLKREG(0xE80C) | 147 | #define S5P_USB_PHY_CONTROL S5P_CLKREG(0xE80C) |
148 | #define S5P_DAC_CONTROL S5P_CLKREG(0xE810) | 148 | #define S5P_DAC_CONTROL S5P_CLKREG(0xE810) |
149 | #define S5P_MIPI_DPHY_CONTROL(x) S5P_CLKREG(0xE814) | ||
150 | #define S5P_MIPI_DPHY_ENABLE (1 << 0) | ||
151 | #define S5P_MIPI_DPHY_SRESETN (1 << 1) | ||
152 | #define S5P_MIPI_DPHY_MRESETN (1 << 2) | ||
149 | 153 | ||
150 | #define S5P_INFORM0 S5P_CLKREG(0xF000) | 154 | #define S5P_INFORM0 S5P_CLKREG(0xF000) |
151 | #define S5P_INFORM1 S5P_CLKREG(0xF004) | 155 | #define S5P_INFORM1 S5P_CLKREG(0xF004) |
@@ -161,7 +165,6 @@ | |||
161 | #define S5P_MDNIE_SEL S5P_CLKREG(0x7008) | 165 | #define S5P_MDNIE_SEL S5P_CLKREG(0x7008) |
162 | #define S5P_MIPI_PHY_CON0 S5P_CLKREG(0x7200) | 166 | #define S5P_MIPI_PHY_CON0 S5P_CLKREG(0x7200) |
163 | #define S5P_MIPI_PHY_CON1 S5P_CLKREG(0x7204) | 167 | #define S5P_MIPI_PHY_CON1 S5P_CLKREG(0x7204) |
164 | #define S5P_MIPI_DPHY_CONTROL S5P_CLKREG(0xE814) | ||
165 | 168 | ||
166 | #define S5P_IDLE_CFG_TL_MASK (3 << 30) | 169 | #define S5P_IDLE_CFG_TL_MASK (3 << 30) |
167 | #define S5P_IDLE_CFG_TM_MASK (3 << 28) | 170 | #define S5P_IDLE_CFG_TM_MASK (3 << 28) |
diff --git a/arch/arm/mach-s5pv210/mach-aquila.c b/arch/arm/mach-s5pv210/mach-aquila.c index 557add4fc56c..4e1d8ff5ae59 100644 --- a/arch/arm/mach-s5pv210/mach-aquila.c +++ b/arch/arm/mach-s5pv210/mach-aquila.c | |||
@@ -39,6 +39,7 @@ | |||
39 | #include <plat/fb.h> | 39 | #include <plat/fb.h> |
40 | #include <plat/fimc-core.h> | 40 | #include <plat/fimc-core.h> |
41 | #include <plat/sdhci.h> | 41 | #include <plat/sdhci.h> |
42 | #include <plat/s5p-time.h> | ||
42 | 43 | ||
43 | /* Following are default values for UCON, ULCON and UFCON UART registers */ | 44 | /* Following are default values for UCON, ULCON and UFCON UART registers */ |
44 | #define AQUILA_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ | 45 | #define AQUILA_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ |
@@ -296,13 +297,11 @@ static struct regulator_init_data aquila_ldo17_data = { | |||
296 | }; | 297 | }; |
297 | 298 | ||
298 | /* BUCK */ | 299 | /* BUCK */ |
299 | static struct regulator_consumer_supply buck1_consumer[] = { | 300 | static struct regulator_consumer_supply buck1_consumer = |
300 | { .supply = "vddarm", }, | 301 | REGULATOR_SUPPLY("vddarm", NULL); |
301 | }; | ||
302 | 302 | ||
303 | static struct regulator_consumer_supply buck2_consumer[] = { | 303 | static struct regulator_consumer_supply buck2_consumer = |
304 | { .supply = "vddint", }, | 304 | REGULATOR_SUPPLY("vddint", NULL); |
305 | }; | ||
306 | 305 | ||
307 | static struct regulator_init_data aquila_buck1_data = { | 306 | static struct regulator_init_data aquila_buck1_data = { |
308 | .constraints = { | 307 | .constraints = { |
@@ -313,8 +312,8 @@ static struct regulator_init_data aquila_buck1_data = { | |||
313 | .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE | | 312 | .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE | |
314 | REGULATOR_CHANGE_STATUS, | 313 | REGULATOR_CHANGE_STATUS, |
315 | }, | 314 | }, |
316 | .num_consumer_supplies = ARRAY_SIZE(buck1_consumer), | 315 | .num_consumer_supplies = 1, |
317 | .consumer_supplies = buck1_consumer, | 316 | .consumer_supplies = &buck1_consumer, |
318 | }; | 317 | }; |
319 | 318 | ||
320 | static struct regulator_init_data aquila_buck2_data = { | 319 | static struct regulator_init_data aquila_buck2_data = { |
@@ -326,8 +325,8 @@ static struct regulator_init_data aquila_buck2_data = { | |||
326 | .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE | | 325 | .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE | |
327 | REGULATOR_CHANGE_STATUS, | 326 | REGULATOR_CHANGE_STATUS, |
328 | }, | 327 | }, |
329 | .num_consumer_supplies = ARRAY_SIZE(buck2_consumer), | 328 | .num_consumer_supplies = 1, |
330 | .consumer_supplies = buck2_consumer, | 329 | .consumer_supplies = &buck2_consumer, |
331 | }; | 330 | }; |
332 | 331 | ||
333 | static struct regulator_init_data aquila_buck3_data = { | 332 | static struct regulator_init_data aquila_buck3_data = { |
@@ -391,26 +390,14 @@ static struct max8998_platform_data aquila_max8998_pdata = { | |||
391 | #endif | 390 | #endif |
392 | 391 | ||
393 | static struct regulator_consumer_supply wm8994_fixed_voltage0_supplies[] = { | 392 | static struct regulator_consumer_supply wm8994_fixed_voltage0_supplies[] = { |
394 | { | 393 | REGULATOR_SUPPLY("DBVDD", "5-001a"), |
395 | .dev_name = "5-001a", | 394 | REGULATOR_SUPPLY("AVDD2", "5-001a"), |
396 | .supply = "DBVDD", | 395 | REGULATOR_SUPPLY("CPVDD", "5-001a"), |
397 | }, { | ||
398 | .dev_name = "5-001a", | ||
399 | .supply = "AVDD2", | ||
400 | }, { | ||
401 | .dev_name = "5-001a", | ||
402 | .supply = "CPVDD", | ||
403 | }, | ||
404 | }; | 396 | }; |
405 | 397 | ||
406 | static struct regulator_consumer_supply wm8994_fixed_voltage1_supplies[] = { | 398 | static struct regulator_consumer_supply wm8994_fixed_voltage1_supplies[] = { |
407 | { | 399 | REGULATOR_SUPPLY("SPKVDD1", "5-001a"), |
408 | .dev_name = "5-001a", | 400 | REGULATOR_SUPPLY("SPKVDD2", "5-001a"), |
409 | .supply = "SPKVDD1", | ||
410 | }, { | ||
411 | .dev_name = "5-001a", | ||
412 | .supply = "SPKVDD2", | ||
413 | }, | ||
414 | }; | 401 | }; |
415 | 402 | ||
416 | static struct regulator_init_data wm8994_fixed_voltage0_init_data = { | 403 | static struct regulator_init_data wm8994_fixed_voltage0_init_data = { |
@@ -459,15 +446,11 @@ static struct platform_device wm8994_fixed_voltage1 = { | |||
459 | }, | 446 | }, |
460 | }; | 447 | }; |
461 | 448 | ||
462 | static struct regulator_consumer_supply wm8994_avdd1_supply = { | 449 | static struct regulator_consumer_supply wm8994_avdd1_supply = |
463 | .dev_name = "5-001a", | 450 | REGULATOR_SUPPLY("AVDD1", "5-001a"); |
464 | .supply = "AVDD1", | ||
465 | }; | ||
466 | 451 | ||
467 | static struct regulator_consumer_supply wm8994_dcvdd_supply = { | 452 | static struct regulator_consumer_supply wm8994_dcvdd_supply = |
468 | .dev_name = "5-001a", | 453 | REGULATOR_SUPPLY("DCVDD", "5-001a"); |
469 | .supply = "DCVDD", | ||
470 | }; | ||
471 | 454 | ||
472 | static struct regulator_init_data wm8994_ldo1_data = { | 455 | static struct regulator_init_data wm8994_ldo1_data = { |
473 | .constraints = { | 456 | .constraints = { |
@@ -664,6 +647,7 @@ static void __init aquila_map_io(void) | |||
664 | s5p_init_io(NULL, 0, S5P_VA_CHIPID); | 647 | s5p_init_io(NULL, 0, S5P_VA_CHIPID); |
665 | s3c24xx_init_clocks(24000000); | 648 | s3c24xx_init_clocks(24000000); |
666 | s3c24xx_init_uarts(aquila_uartcfgs, ARRAY_SIZE(aquila_uartcfgs)); | 649 | s3c24xx_init_uarts(aquila_uartcfgs, ARRAY_SIZE(aquila_uartcfgs)); |
650 | s5p_set_timer_source(S5P_PWM3, S5P_PWM4); | ||
667 | } | 651 | } |
668 | 652 | ||
669 | static void __init aquila_machine_init(void) | 653 | static void __init aquila_machine_init(void) |
@@ -698,5 +682,5 @@ MACHINE_START(AQUILA, "Aquila") | |||
698 | .init_irq = s5pv210_init_irq, | 682 | .init_irq = s5pv210_init_irq, |
699 | .map_io = aquila_map_io, | 683 | .map_io = aquila_map_io, |
700 | .init_machine = aquila_machine_init, | 684 | .init_machine = aquila_machine_init, |
701 | .timer = &s3c24xx_timer, | 685 | .timer = &s5p_timer, |
702 | MACHINE_END | 686 | MACHINE_END |
diff --git a/arch/arm/mach-s5pv210/mach-goni.c b/arch/arm/mach-s5pv210/mach-goni.c index 056f5c769b0a..243291722c66 100644 --- a/arch/arm/mach-s5pv210/mach-goni.c +++ b/arch/arm/mach-s5pv210/mach-goni.c | |||
@@ -45,6 +45,7 @@ | |||
45 | #include <plat/keypad.h> | 45 | #include <plat/keypad.h> |
46 | #include <plat/sdhci.h> | 46 | #include <plat/sdhci.h> |
47 | #include <plat/clock.h> | 47 | #include <plat/clock.h> |
48 | #include <plat/s5p-time.h> | ||
48 | 49 | ||
49 | /* Following are default values for UCON, ULCON and UFCON UART registers */ | 50 | /* Following are default values for UCON, ULCON and UFCON UART registers */ |
50 | #define GONI_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ | 51 | #define GONI_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ |
@@ -108,6 +109,8 @@ static struct s3c_fb_pd_win goni_fb_win0 = { | |||
108 | }, | 109 | }, |
109 | .max_bpp = 32, | 110 | .max_bpp = 32, |
110 | .default_bpp = 16, | 111 | .default_bpp = 16, |
112 | .virtual_x = 480, | ||
113 | .virtual_y = 2 * 800, | ||
111 | }; | 114 | }; |
112 | 115 | ||
113 | static struct s3c_fb_platdata goni_lcd_pdata __initdata = { | 116 | static struct s3c_fb_platdata goni_lcd_pdata __initdata = { |
@@ -269,10 +272,30 @@ static void __init goni_tsp_init(void) | |||
269 | /* MAX8998 regulators */ | 272 | /* MAX8998 regulators */ |
270 | #if defined(CONFIG_REGULATOR_MAX8998) || defined(CONFIG_REGULATOR_MAX8998_MODULE) | 273 | #if defined(CONFIG_REGULATOR_MAX8998) || defined(CONFIG_REGULATOR_MAX8998_MODULE) |
271 | 274 | ||
275 | static struct regulator_consumer_supply goni_ldo3_consumers[] = { | ||
276 | REGULATOR_SUPPLY("vusb_a", "s3c-hsotg"), | ||
277 | }; | ||
278 | |||
272 | static struct regulator_consumer_supply goni_ldo5_consumers[] = { | 279 | static struct regulator_consumer_supply goni_ldo5_consumers[] = { |
273 | REGULATOR_SUPPLY("vmmc", "s3c-sdhci.0"), | 280 | REGULATOR_SUPPLY("vmmc", "s3c-sdhci.0"), |
274 | }; | 281 | }; |
275 | 282 | ||
283 | static struct regulator_consumer_supply goni_ldo8_consumers[] = { | ||
284 | REGULATOR_SUPPLY("vusb_d", "s3c-hsotg"), | ||
285 | }; | ||
286 | |||
287 | static struct regulator_consumer_supply goni_ldo11_consumers[] = { | ||
288 | REGULATOR_SUPPLY("vddio", "0-0030"), /* "CAM_IO_2.8V" */ | ||
289 | }; | ||
290 | |||
291 | static struct regulator_consumer_supply goni_ldo13_consumers[] = { | ||
292 | REGULATOR_SUPPLY("vdda", "0-0030"), /* "CAM_A_2.8V" */ | ||
293 | }; | ||
294 | |||
295 | static struct regulator_consumer_supply goni_ldo14_consumers[] = { | ||
296 | REGULATOR_SUPPLY("vdd_core", "0-0030"), /* "CAM_CIF_1.8V" */ | ||
297 | }; | ||
298 | |||
276 | static struct regulator_init_data goni_ldo2_data = { | 299 | static struct regulator_init_data goni_ldo2_data = { |
277 | .constraints = { | 300 | .constraints = { |
278 | .name = "VALIVE_1.1V", | 301 | .name = "VALIVE_1.1V", |
@@ -292,8 +315,10 @@ static struct regulator_init_data goni_ldo3_data = { | |||
292 | .min_uV = 1100000, | 315 | .min_uV = 1100000, |
293 | .max_uV = 1100000, | 316 | .max_uV = 1100000, |
294 | .apply_uV = 1, | 317 | .apply_uV = 1, |
295 | .always_on = 1, | 318 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, |
296 | }, | 319 | }, |
320 | .num_consumer_supplies = ARRAY_SIZE(goni_ldo3_consumers), | ||
321 | .consumer_supplies = goni_ldo3_consumers, | ||
297 | }; | 322 | }; |
298 | 323 | ||
299 | static struct regulator_init_data goni_ldo4_data = { | 324 | static struct regulator_init_data goni_ldo4_data = { |
@@ -311,6 +336,7 @@ static struct regulator_init_data goni_ldo5_data = { | |||
311 | .min_uV = 2800000, | 336 | .min_uV = 2800000, |
312 | .max_uV = 2800000, | 337 | .max_uV = 2800000, |
313 | .apply_uV = 1, | 338 | .apply_uV = 1, |
339 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
314 | }, | 340 | }, |
315 | .num_consumer_supplies = ARRAY_SIZE(goni_ldo5_consumers), | 341 | .num_consumer_supplies = ARRAY_SIZE(goni_ldo5_consumers), |
316 | .consumer_supplies = goni_ldo5_consumers, | 342 | .consumer_supplies = goni_ldo5_consumers, |
@@ -341,8 +367,10 @@ static struct regulator_init_data goni_ldo8_data = { | |||
341 | .min_uV = 3300000, | 367 | .min_uV = 3300000, |
342 | .max_uV = 3300000, | 368 | .max_uV = 3300000, |
343 | .apply_uV = 1, | 369 | .apply_uV = 1, |
344 | .always_on = 1, | 370 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, |
345 | }, | 371 | }, |
372 | .num_consumer_supplies = ARRAY_SIZE(goni_ldo8_consumers), | ||
373 | .consumer_supplies = goni_ldo8_consumers, | ||
346 | }; | 374 | }; |
347 | 375 | ||
348 | static struct regulator_init_data goni_ldo9_data = { | 376 | static struct regulator_init_data goni_ldo9_data = { |
@@ -351,7 +379,6 @@ static struct regulator_init_data goni_ldo9_data = { | |||
351 | .min_uV = 2800000, | 379 | .min_uV = 2800000, |
352 | .max_uV = 2800000, | 380 | .max_uV = 2800000, |
353 | .apply_uV = 1, | 381 | .apply_uV = 1, |
354 | .always_on = 1, | ||
355 | }, | 382 | }, |
356 | }; | 383 | }; |
357 | 384 | ||
@@ -371,8 +398,10 @@ static struct regulator_init_data goni_ldo11_data = { | |||
371 | .min_uV = 2800000, | 398 | .min_uV = 2800000, |
372 | .max_uV = 2800000, | 399 | .max_uV = 2800000, |
373 | .apply_uV = 1, | 400 | .apply_uV = 1, |
374 | .always_on = 1, | 401 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, |
375 | }, | 402 | }, |
403 | .num_consumer_supplies = ARRAY_SIZE(goni_ldo11_consumers), | ||
404 | .consumer_supplies = goni_ldo11_consumers, | ||
376 | }; | 405 | }; |
377 | 406 | ||
378 | static struct regulator_init_data goni_ldo12_data = { | 407 | static struct regulator_init_data goni_ldo12_data = { |
@@ -381,7 +410,6 @@ static struct regulator_init_data goni_ldo12_data = { | |||
381 | .min_uV = 1200000, | 410 | .min_uV = 1200000, |
382 | .max_uV = 1200000, | 411 | .max_uV = 1200000, |
383 | .apply_uV = 1, | 412 | .apply_uV = 1, |
384 | .always_on = 1, | ||
385 | }, | 413 | }, |
386 | }; | 414 | }; |
387 | 415 | ||
@@ -391,8 +419,10 @@ static struct regulator_init_data goni_ldo13_data = { | |||
391 | .min_uV = 2800000, | 419 | .min_uV = 2800000, |
392 | .max_uV = 2800000, | 420 | .max_uV = 2800000, |
393 | .apply_uV = 1, | 421 | .apply_uV = 1, |
394 | .always_on = 1, | 422 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, |
395 | }, | 423 | }, |
424 | .num_consumer_supplies = ARRAY_SIZE(goni_ldo13_consumers), | ||
425 | .consumer_supplies = goni_ldo13_consumers, | ||
396 | }; | 426 | }; |
397 | 427 | ||
398 | static struct regulator_init_data goni_ldo14_data = { | 428 | static struct regulator_init_data goni_ldo14_data = { |
@@ -401,8 +431,10 @@ static struct regulator_init_data goni_ldo14_data = { | |||
401 | .min_uV = 1800000, | 431 | .min_uV = 1800000, |
402 | .max_uV = 1800000, | 432 | .max_uV = 1800000, |
403 | .apply_uV = 1, | 433 | .apply_uV = 1, |
404 | .always_on = 1, | 434 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, |
405 | }, | 435 | }, |
436 | .num_consumer_supplies = ARRAY_SIZE(goni_ldo14_consumers), | ||
437 | .consumer_supplies = goni_ldo14_consumers, | ||
406 | }; | 438 | }; |
407 | 439 | ||
408 | static struct regulator_init_data goni_ldo15_data = { | 440 | static struct regulator_init_data goni_ldo15_data = { |
@@ -411,7 +443,6 @@ static struct regulator_init_data goni_ldo15_data = { | |||
411 | .min_uV = 3300000, | 443 | .min_uV = 3300000, |
412 | .max_uV = 3300000, | 444 | .max_uV = 3300000, |
413 | .apply_uV = 1, | 445 | .apply_uV = 1, |
414 | .always_on = 1, | ||
415 | }, | 446 | }, |
416 | }; | 447 | }; |
417 | 448 | ||
@@ -421,7 +452,6 @@ static struct regulator_init_data goni_ldo16_data = { | |||
421 | .min_uV = 1800000, | 452 | .min_uV = 1800000, |
422 | .max_uV = 1800000, | 453 | .max_uV = 1800000, |
423 | .apply_uV = 1, | 454 | .apply_uV = 1, |
424 | .always_on = 1, | ||
425 | }, | 455 | }, |
426 | }; | 456 | }; |
427 | 457 | ||
@@ -436,13 +466,11 @@ static struct regulator_init_data goni_ldo17_data = { | |||
436 | }; | 466 | }; |
437 | 467 | ||
438 | /* BUCK */ | 468 | /* BUCK */ |
439 | static struct regulator_consumer_supply buck1_consumer[] = { | 469 | static struct regulator_consumer_supply buck1_consumer = |
440 | { .supply = "vddarm", }, | 470 | REGULATOR_SUPPLY("vddarm", NULL); |
441 | }; | ||
442 | 471 | ||
443 | static struct regulator_consumer_supply buck2_consumer[] = { | 472 | static struct regulator_consumer_supply buck2_consumer = |
444 | { .supply = "vddint", }, | 473 | REGULATOR_SUPPLY("vddint", NULL); |
445 | }; | ||
446 | 474 | ||
447 | static struct regulator_init_data goni_buck1_data = { | 475 | static struct regulator_init_data goni_buck1_data = { |
448 | .constraints = { | 476 | .constraints = { |
@@ -453,8 +481,8 @@ static struct regulator_init_data goni_buck1_data = { | |||
453 | .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE | | 481 | .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE | |
454 | REGULATOR_CHANGE_STATUS, | 482 | REGULATOR_CHANGE_STATUS, |
455 | }, | 483 | }, |
456 | .num_consumer_supplies = ARRAY_SIZE(buck1_consumer), | 484 | .num_consumer_supplies = 1, |
457 | .consumer_supplies = buck1_consumer, | 485 | .consumer_supplies = &buck1_consumer, |
458 | }; | 486 | }; |
459 | 487 | ||
460 | static struct regulator_init_data goni_buck2_data = { | 488 | static struct regulator_init_data goni_buck2_data = { |
@@ -466,8 +494,8 @@ static struct regulator_init_data goni_buck2_data = { | |||
466 | .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE | | 494 | .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE | |
467 | REGULATOR_CHANGE_STATUS, | 495 | REGULATOR_CHANGE_STATUS, |
468 | }, | 496 | }, |
469 | .num_consumer_supplies = ARRAY_SIZE(buck2_consumer), | 497 | .num_consumer_supplies = 1, |
470 | .consumer_supplies = buck2_consumer, | 498 | .consumer_supplies = &buck2_consumer, |
471 | }; | 499 | }; |
472 | 500 | ||
473 | static struct regulator_init_data goni_buck3_data = { | 501 | static struct regulator_init_data goni_buck3_data = { |
@@ -531,26 +559,14 @@ static struct max8998_platform_data goni_max8998_pdata = { | |||
531 | #endif | 559 | #endif |
532 | 560 | ||
533 | static struct regulator_consumer_supply wm8994_fixed_voltage0_supplies[] = { | 561 | static struct regulator_consumer_supply wm8994_fixed_voltage0_supplies[] = { |
534 | { | 562 | REGULATOR_SUPPLY("DBVDD", "5-001a"), |
535 | .dev_name = "5-001a", | 563 | REGULATOR_SUPPLY("AVDD2", "5-001a"), |
536 | .supply = "DBVDD", | 564 | REGULATOR_SUPPLY("CPVDD", "5-001a"), |
537 | }, { | ||
538 | .dev_name = "5-001a", | ||
539 | .supply = "AVDD2", | ||
540 | }, { | ||
541 | .dev_name = "5-001a", | ||
542 | .supply = "CPVDD", | ||
543 | }, | ||
544 | }; | 565 | }; |
545 | 566 | ||
546 | static struct regulator_consumer_supply wm8994_fixed_voltage1_supplies[] = { | 567 | static struct regulator_consumer_supply wm8994_fixed_voltage1_supplies[] = { |
547 | { | 568 | REGULATOR_SUPPLY("SPKVDD1", "5-001a"), |
548 | .dev_name = "5-001a", | 569 | REGULATOR_SUPPLY("SPKVDD2", "5-001a"), |
549 | .supply = "SPKVDD1", | ||
550 | }, { | ||
551 | .dev_name = "5-001a", | ||
552 | .supply = "SPKVDD2", | ||
553 | }, | ||
554 | }; | 570 | }; |
555 | 571 | ||
556 | static struct regulator_init_data wm8994_fixed_voltage0_init_data = { | 572 | static struct regulator_init_data wm8994_fixed_voltage0_init_data = { |
@@ -599,15 +615,11 @@ static struct platform_device wm8994_fixed_voltage1 = { | |||
599 | }, | 615 | }, |
600 | }; | 616 | }; |
601 | 617 | ||
602 | static struct regulator_consumer_supply wm8994_avdd1_supply = { | 618 | static struct regulator_consumer_supply wm8994_avdd1_supply = |
603 | .dev_name = "5-001a", | 619 | REGULATOR_SUPPLY("AVDD1", "5-001a"); |
604 | .supply = "AVDD1", | ||
605 | }; | ||
606 | 620 | ||
607 | static struct regulator_consumer_supply wm8994_dcvdd_supply = { | 621 | static struct regulator_consumer_supply wm8994_dcvdd_supply = |
608 | .dev_name = "5-001a", | 622 | REGULATOR_SUPPLY("DCVDD", "5-001a"); |
609 | .supply = "DCVDD", | ||
610 | }; | ||
611 | 623 | ||
612 | static struct regulator_init_data wm8994_ldo1_data = { | 624 | static struct regulator_init_data wm8994_ldo1_data = { |
613 | .constraints = { | 625 | .constraints = { |
@@ -794,6 +806,7 @@ static struct platform_device *goni_devices[] __initdata = { | |||
794 | &goni_i2c_gpio5, | 806 | &goni_i2c_gpio5, |
795 | &mmc2_fixed_voltage, | 807 | &mmc2_fixed_voltage, |
796 | &goni_device_gpiokeys, | 808 | &goni_device_gpiokeys, |
809 | &s3c_device_i2c0, | ||
797 | &s5p_device_fimc0, | 810 | &s5p_device_fimc0, |
798 | &s5p_device_fimc1, | 811 | &s5p_device_fimc1, |
799 | &s5p_device_fimc2, | 812 | &s5p_device_fimc2, |
@@ -823,6 +836,7 @@ static void __init goni_map_io(void) | |||
823 | s5p_init_io(NULL, 0, S5P_VA_CHIPID); | 836 | s5p_init_io(NULL, 0, S5P_VA_CHIPID); |
824 | s3c24xx_init_clocks(24000000); | 837 | s3c24xx_init_clocks(24000000); |
825 | s3c24xx_init_uarts(goni_uartcfgs, ARRAY_SIZE(goni_uartcfgs)); | 838 | s3c24xx_init_uarts(goni_uartcfgs, ARRAY_SIZE(goni_uartcfgs)); |
839 | s5p_set_timer_source(S5P_PWM3, S5P_PWM4); | ||
826 | } | 840 | } |
827 | 841 | ||
828 | static void __init goni_machine_init(void) | 842 | static void __init goni_machine_init(void) |
@@ -830,6 +844,9 @@ static void __init goni_machine_init(void) | |||
830 | /* Radio: call before I2C 1 registeration */ | 844 | /* Radio: call before I2C 1 registeration */ |
831 | goni_radio_init(); | 845 | goni_radio_init(); |
832 | 846 | ||
847 | /* I2C0 */ | ||
848 | s3c_i2c0_set_platdata(NULL); | ||
849 | |||
833 | /* I2C1 */ | 850 | /* I2C1 */ |
834 | s3c_i2c1_set_platdata(NULL); | 851 | s3c_i2c1_set_platdata(NULL); |
835 | i2c_register_board_info(1, i2c1_devs, ARRAY_SIZE(i2c1_devs)); | 852 | i2c_register_board_info(1, i2c1_devs, ARRAY_SIZE(i2c1_devs)); |
@@ -873,5 +890,5 @@ MACHINE_START(GONI, "GONI") | |||
873 | .init_irq = s5pv210_init_irq, | 890 | .init_irq = s5pv210_init_irq, |
874 | .map_io = goni_map_io, | 891 | .map_io = goni_map_io, |
875 | .init_machine = goni_machine_init, | 892 | .init_machine = goni_machine_init, |
876 | .timer = &s3c24xx_timer, | 893 | .timer = &s5p_timer, |
877 | MACHINE_END | 894 | MACHINE_END |
diff --git a/arch/arm/mach-s5pv210/mach-smdkc110.c b/arch/arm/mach-s5pv210/mach-smdkc110.c index ce11a02eabf3..6c412c8ceccc 100644 --- a/arch/arm/mach-s5pv210/mach-smdkc110.c +++ b/arch/arm/mach-s5pv210/mach-smdkc110.c | |||
@@ -30,6 +30,7 @@ | |||
30 | #include <plat/ata.h> | 30 | #include <plat/ata.h> |
31 | #include <plat/iic.h> | 31 | #include <plat/iic.h> |
32 | #include <plat/pm.h> | 32 | #include <plat/pm.h> |
33 | #include <plat/s5p-time.h> | ||
33 | 34 | ||
34 | /* Following are default values for UCON, ULCON and UFCON UART registers */ | 35 | /* Following are default values for UCON, ULCON and UFCON UART registers */ |
35 | #define SMDKC110_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ | 36 | #define SMDKC110_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ |
@@ -111,6 +112,7 @@ static void __init smdkc110_map_io(void) | |||
111 | s5p_init_io(NULL, 0, S5P_VA_CHIPID); | 112 | s5p_init_io(NULL, 0, S5P_VA_CHIPID); |
112 | s3c24xx_init_clocks(24000000); | 113 | s3c24xx_init_clocks(24000000); |
113 | s3c24xx_init_uarts(smdkv210_uartcfgs, ARRAY_SIZE(smdkv210_uartcfgs)); | 114 | s3c24xx_init_uarts(smdkv210_uartcfgs, ARRAY_SIZE(smdkv210_uartcfgs)); |
115 | s5p_set_timer_source(S5P_PWM3, S5P_PWM4); | ||
114 | } | 116 | } |
115 | 117 | ||
116 | static void __init smdkc110_machine_init(void) | 118 | static void __init smdkc110_machine_init(void) |
@@ -138,5 +140,5 @@ MACHINE_START(SMDKC110, "SMDKC110") | |||
138 | .init_irq = s5pv210_init_irq, | 140 | .init_irq = s5pv210_init_irq, |
139 | .map_io = smdkc110_map_io, | 141 | .map_io = smdkc110_map_io, |
140 | .init_machine = smdkc110_machine_init, | 142 | .init_machine = smdkc110_machine_init, |
141 | .timer = &s3c24xx_timer, | 143 | .timer = &s5p_timer, |
142 | MACHINE_END | 144 | MACHINE_END |
diff --git a/arch/arm/mach-s5pv210/mach-smdkv210.c b/arch/arm/mach-s5pv210/mach-smdkv210.c index bc9fdb52a020..bc08ac42e7cc 100644 --- a/arch/arm/mach-s5pv210/mach-smdkv210.c +++ b/arch/arm/mach-s5pv210/mach-smdkv210.c | |||
@@ -18,6 +18,7 @@ | |||
18 | #include <linux/fb.h> | 18 | #include <linux/fb.h> |
19 | #include <linux/gpio.h> | 19 | #include <linux/gpio.h> |
20 | #include <linux/delay.h> | 20 | #include <linux/delay.h> |
21 | #include <linux/pwm_backlight.h> | ||
21 | 22 | ||
22 | #include <asm/mach/arch.h> | 23 | #include <asm/mach/arch.h> |
23 | #include <asm/mach/map.h> | 24 | #include <asm/mach/map.h> |
@@ -43,6 +44,8 @@ | |||
43 | #include <plat/keypad.h> | 44 | #include <plat/keypad.h> |
44 | #include <plat/pm.h> | 45 | #include <plat/pm.h> |
45 | #include <plat/fb.h> | 46 | #include <plat/fb.h> |
47 | #include <plat/gpio-cfg.h> | ||
48 | #include <plat/s5p-time.h> | ||
46 | 49 | ||
47 | /* Following are default values for UCON, ULCON and UFCON UART registers */ | 50 | /* Following are default values for UCON, ULCON and UFCON UART registers */ |
48 | #define SMDKV210_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ | 51 | #define SMDKV210_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ |
@@ -208,6 +211,45 @@ static struct s3c_fb_platdata smdkv210_lcd0_pdata __initdata = { | |||
208 | .setup_gpio = s5pv210_fb_gpio_setup_24bpp, | 211 | .setup_gpio = s5pv210_fb_gpio_setup_24bpp, |
209 | }; | 212 | }; |
210 | 213 | ||
214 | static int smdkv210_backlight_init(struct device *dev) | ||
215 | { | ||
216 | int ret; | ||
217 | |||
218 | ret = gpio_request(S5PV210_GPD0(3), "Backlight"); | ||
219 | if (ret) { | ||
220 | printk(KERN_ERR "failed to request GPD for PWM-OUT 3\n"); | ||
221 | return ret; | ||
222 | } | ||
223 | |||
224 | /* Configure GPIO pin with S5PV210_GPD_0_3_TOUT_3 */ | ||
225 | s3c_gpio_cfgpin(S5PV210_GPD0(3), S3C_GPIO_SFN(2)); | ||
226 | |||
227 | return 0; | ||
228 | } | ||
229 | |||
230 | static void smdkv210_backlight_exit(struct device *dev) | ||
231 | { | ||
232 | s3c_gpio_cfgpin(S5PV210_GPD0(3), S3C_GPIO_OUTPUT); | ||
233 | gpio_free(S5PV210_GPD0(3)); | ||
234 | } | ||
235 | |||
236 | static struct platform_pwm_backlight_data smdkv210_backlight_data = { | ||
237 | .pwm_id = 3, | ||
238 | .max_brightness = 255, | ||
239 | .dft_brightness = 255, | ||
240 | .pwm_period_ns = 78770, | ||
241 | .init = smdkv210_backlight_init, | ||
242 | .exit = smdkv210_backlight_exit, | ||
243 | }; | ||
244 | |||
245 | static struct platform_device smdkv210_backlight_device = { | ||
246 | .name = "pwm-backlight", | ||
247 | .dev = { | ||
248 | .parent = &s3c_device_timer[3].dev, | ||
249 | .platform_data = &smdkv210_backlight_data, | ||
250 | }, | ||
251 | }; | ||
252 | |||
211 | static struct platform_device *smdkv210_devices[] __initdata = { | 253 | static struct platform_device *smdkv210_devices[] __initdata = { |
212 | &s3c_device_adc, | 254 | &s3c_device_adc, |
213 | &s3c_device_cfcon, | 255 | &s3c_device_cfcon, |
@@ -229,6 +271,8 @@ static struct platform_device *smdkv210_devices[] __initdata = { | |||
229 | &samsung_device_keypad, | 271 | &samsung_device_keypad, |
230 | &smdkv210_dm9000, | 272 | &smdkv210_dm9000, |
231 | &smdkv210_lcd_lte480wv, | 273 | &smdkv210_lcd_lte480wv, |
274 | &s3c_device_timer[3], | ||
275 | &smdkv210_backlight_device, | ||
232 | }; | 276 | }; |
233 | 277 | ||
234 | static void __init smdkv210_dm9000_init(void) | 278 | static void __init smdkv210_dm9000_init(void) |
@@ -272,6 +316,7 @@ static void __init smdkv210_map_io(void) | |||
272 | s5p_init_io(NULL, 0, S5P_VA_CHIPID); | 316 | s5p_init_io(NULL, 0, S5P_VA_CHIPID); |
273 | s3c24xx_init_clocks(24000000); | 317 | s3c24xx_init_clocks(24000000); |
274 | s3c24xx_init_uarts(smdkv210_uartcfgs, ARRAY_SIZE(smdkv210_uartcfgs)); | 318 | s3c24xx_init_uarts(smdkv210_uartcfgs, ARRAY_SIZE(smdkv210_uartcfgs)); |
319 | s5p_set_timer_source(S5P_PWM2, S5P_PWM4); | ||
275 | } | 320 | } |
276 | 321 | ||
277 | static void __init smdkv210_machine_init(void) | 322 | static void __init smdkv210_machine_init(void) |
@@ -306,5 +351,5 @@ MACHINE_START(SMDKV210, "SMDKV210") | |||
306 | .init_irq = s5pv210_init_irq, | 351 | .init_irq = s5pv210_init_irq, |
307 | .map_io = smdkv210_map_io, | 352 | .map_io = smdkv210_map_io, |
308 | .init_machine = smdkv210_machine_init, | 353 | .init_machine = smdkv210_machine_init, |
309 | .timer = &s3c24xx_timer, | 354 | .timer = &s5p_timer, |
310 | MACHINE_END | 355 | MACHINE_END |
diff --git a/arch/arm/mach-s5pv210/mach-torbreck.c b/arch/arm/mach-s5pv210/mach-torbreck.c index 043c938806b0..925fc0dc6252 100644 --- a/arch/arm/mach-s5pv210/mach-torbreck.c +++ b/arch/arm/mach-s5pv210/mach-torbreck.c | |||
@@ -27,6 +27,7 @@ | |||
27 | #include <plat/devs.h> | 27 | #include <plat/devs.h> |
28 | #include <plat/cpu.h> | 28 | #include <plat/cpu.h> |
29 | #include <plat/iic.h> | 29 | #include <plat/iic.h> |
30 | #include <plat/s5p-time.h> | ||
30 | 31 | ||
31 | /* Following are default values for UCON, ULCON and UFCON UART registers */ | 32 | /* Following are default values for UCON, ULCON and UFCON UART registers */ |
32 | #define TORBRECK_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ | 33 | #define TORBRECK_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ |
@@ -104,6 +105,7 @@ static void __init torbreck_map_io(void) | |||
104 | s5p_init_io(NULL, 0, S5P_VA_CHIPID); | 105 | s5p_init_io(NULL, 0, S5P_VA_CHIPID); |
105 | s3c24xx_init_clocks(24000000); | 106 | s3c24xx_init_clocks(24000000); |
106 | s3c24xx_init_uarts(torbreck_uartcfgs, ARRAY_SIZE(torbreck_uartcfgs)); | 107 | s3c24xx_init_uarts(torbreck_uartcfgs, ARRAY_SIZE(torbreck_uartcfgs)); |
108 | s5p_set_timer_source(S5P_PWM3, S5P_PWM4); | ||
107 | } | 109 | } |
108 | 110 | ||
109 | static void __init torbreck_machine_init(void) | 111 | static void __init torbreck_machine_init(void) |
@@ -127,5 +129,5 @@ MACHINE_START(TORBRECK, "TORBRECK") | |||
127 | .init_irq = s5pv210_init_irq, | 129 | .init_irq = s5pv210_init_irq, |
128 | .map_io = torbreck_map_io, | 130 | .map_io = torbreck_map_io, |
129 | .init_machine = torbreck_machine_init, | 131 | .init_machine = torbreck_machine_init, |
130 | .timer = &s3c24xx_timer, | 132 | .timer = &s5p_timer, |
131 | MACHINE_END | 133 | MACHINE_END |
diff --git a/arch/arm/mach-s5pv210/setup-fimc.c b/arch/arm/mach-s5pv210/setup-fimc.c new file mode 100644 index 000000000000..54cc5b11be0b --- /dev/null +++ b/arch/arm/mach-s5pv210/setup-fimc.c | |||
@@ -0,0 +1,43 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2011 Samsung Electronics Co., Ltd. | ||
3 | * | ||
4 | * S5PV210 camera interface GPIO configuration. | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | |||
11 | #include <linux/gpio.h> | ||
12 | #include <plat/gpio-cfg.h> | ||
13 | #include <plat/camport.h> | ||
14 | |||
15 | int s5pv210_fimc_setup_gpio(enum s5p_camport_id id) | ||
16 | { | ||
17 | u32 gpio8, gpio5; | ||
18 | int ret; | ||
19 | |||
20 | switch (id) { | ||
21 | case S5P_CAMPORT_A: | ||
22 | gpio8 = S5PV210_GPE0(0); | ||
23 | gpio5 = S5PV210_GPE1(0); | ||
24 | break; | ||
25 | |||
26 | case S5P_CAMPORT_B: | ||
27 | gpio8 = S5PV210_GPJ0(0); | ||
28 | gpio5 = S5PV210_GPJ1(0); | ||
29 | break; | ||
30 | |||
31 | default: | ||
32 | WARN(1, "Wrong camport id: %d\n", id); | ||
33 | return -EINVAL; | ||
34 | } | ||
35 | |||
36 | ret = s3c_gpio_cfgall_range(gpio8, 8, S3C_GPIO_SFN(2), | ||
37 | S3C_GPIO_PULL_UP); | ||
38 | if (ret) | ||
39 | return ret; | ||
40 | |||
41 | return s3c_gpio_cfgall_range(gpio5, 5, S3C_GPIO_SFN(2), | ||
42 | S3C_GPIO_PULL_UP); | ||
43 | } | ||
diff --git a/arch/arm/mach-s5pv310/Kconfig b/arch/arm/mach-s5pv310/Kconfig deleted file mode 100644 index b2a9acc5185f..000000000000 --- a/arch/arm/mach-s5pv310/Kconfig +++ /dev/null | |||
@@ -1,151 +0,0 @@ | |||
1 | # arch/arm/mach-s5pv310/Kconfig | ||
2 | # | ||
3 | # Copyright (c) 2010 Samsung Electronics Co., Ltd. | ||
4 | # http://www.samsung.com/ | ||
5 | # | ||
6 | # Licensed under GPLv2 | ||
7 | |||
8 | # Configuration options for the S5PV310 | ||
9 | |||
10 | if ARCH_S5PV310 | ||
11 | |||
12 | config CPU_S5PV310 | ||
13 | bool | ||
14 | select S3C_PL330_DMA | ||
15 | help | ||
16 | Enable S5PV310 CPU support | ||
17 | |||
18 | config S5PV310_DEV_PD | ||
19 | bool | ||
20 | help | ||
21 | Compile in platform device definitions for Power Domain | ||
22 | |||
23 | config S5PV310_SETUP_I2C1 | ||
24 | bool | ||
25 | help | ||
26 | Common setup code for i2c bus 1. | ||
27 | |||
28 | config S5PV310_SETUP_I2C2 | ||
29 | bool | ||
30 | help | ||
31 | Common setup code for i2c bus 2. | ||
32 | |||
33 | config S5PV310_SETUP_I2C3 | ||
34 | bool | ||
35 | help | ||
36 | Common setup code for i2c bus 3. | ||
37 | |||
38 | config S5PV310_SETUP_I2C4 | ||
39 | bool | ||
40 | help | ||
41 | Common setup code for i2c bus 4. | ||
42 | |||
43 | config S5PV310_SETUP_I2C5 | ||
44 | bool | ||
45 | help | ||
46 | Common setup code for i2c bus 5. | ||
47 | |||
48 | config S5PV310_SETUP_I2C6 | ||
49 | bool | ||
50 | help | ||
51 | Common setup code for i2c bus 6. | ||
52 | |||
53 | config S5PV310_SETUP_I2C7 | ||
54 | bool | ||
55 | help | ||
56 | Common setup code for i2c bus 7. | ||
57 | |||
58 | config S5PV310_SETUP_SDHCI | ||
59 | bool | ||
60 | select S5PV310_SETUP_SDHCI_GPIO | ||
61 | help | ||
62 | Internal helper functions for S5PV310 based SDHCI systems. | ||
63 | |||
64 | config S5PV310_SETUP_SDHCI_GPIO | ||
65 | bool | ||
66 | help | ||
67 | Common setup code for SDHCI gpio. | ||
68 | |||
69 | config S5PV310_DEV_SYSMMU | ||
70 | bool | ||
71 | help | ||
72 | Common setup code for SYSTEM MMU in S5PV310 | ||
73 | |||
74 | # machine support | ||
75 | |||
76 | menu "S5PC210 Machines" | ||
77 | |||
78 | config MACH_SMDKC210 | ||
79 | bool "SMDKC210" | ||
80 | select CPU_S5PV310 | ||
81 | select S3C_DEV_RTC | ||
82 | select S3C_DEV_WDT | ||
83 | select S3C_DEV_I2C1 | ||
84 | select S3C_DEV_HSMMC | ||
85 | select S3C_DEV_HSMMC1 | ||
86 | select S3C_DEV_HSMMC2 | ||
87 | select S3C_DEV_HSMMC3 | ||
88 | select S5PV310_DEV_PD | ||
89 | select S5PV310_SETUP_I2C1 | ||
90 | select S5PV310_SETUP_SDHCI | ||
91 | select S5PV310_DEV_SYSMMU | ||
92 | help | ||
93 | Machine support for Samsung SMDKC210 | ||
94 | S5PC210(MCP) is one of package option of S5PV310 | ||
95 | |||
96 | config MACH_UNIVERSAL_C210 | ||
97 | bool "Mobile UNIVERSAL_C210 Board" | ||
98 | select CPU_S5PV310 | ||
99 | select S5P_DEV_ONENAND | ||
100 | select S3C_DEV_HSMMC | ||
101 | select S3C_DEV_HSMMC2 | ||
102 | select S3C_DEV_HSMMC3 | ||
103 | select S5PV310_SETUP_SDHCI | ||
104 | select S3C_DEV_I2C1 | ||
105 | select S5PV310_SETUP_I2C1 | ||
106 | help | ||
107 | Machine support for Samsung Mobile Universal S5PC210 Reference | ||
108 | Board. S5PC210(MCP) is one of package option of S5PV310 | ||
109 | |||
110 | endmenu | ||
111 | |||
112 | menu "S5PV310 Machines" | ||
113 | |||
114 | config MACH_SMDKV310 | ||
115 | bool "SMDKV310" | ||
116 | select CPU_S5PV310 | ||
117 | select S3C_DEV_RTC | ||
118 | select S3C_DEV_WDT | ||
119 | select S3C_DEV_I2C1 | ||
120 | select S3C_DEV_HSMMC | ||
121 | select S3C_DEV_HSMMC1 | ||
122 | select S3C_DEV_HSMMC2 | ||
123 | select S3C_DEV_HSMMC3 | ||
124 | select S5PV310_DEV_PD | ||
125 | select S5PV310_DEV_SYSMMU | ||
126 | select S5PV310_SETUP_I2C1 | ||
127 | select S5PV310_SETUP_SDHCI | ||
128 | help | ||
129 | Machine support for Samsung SMDKV310 | ||
130 | |||
131 | endmenu | ||
132 | |||
133 | comment "Configuration for HSMMC bus width" | ||
134 | |||
135 | menu "Use 8-bit bus width" | ||
136 | |||
137 | config S5PV310_SDHCI_CH0_8BIT | ||
138 | bool "Channel 0 with 8-bit bus" | ||
139 | help | ||
140 | Support HSMMC Channel 0 8-bit bus. | ||
141 | If selected, Channel 1 is disabled. | ||
142 | |||
143 | config S5PV310_SDHCI_CH2_8BIT | ||
144 | bool "Channel 2 with 8-bit bus" | ||
145 | help | ||
146 | Support HSMMC Channel 2 8-bit bus. | ||
147 | If selected, Channel 3 is disabled. | ||
148 | |||
149 | endmenu | ||
150 | |||
151 | endif | ||
diff --git a/arch/arm/mach-s5pv310/Makefile b/arch/arm/mach-s5pv310/Makefile deleted file mode 100644 index 036fb383b830..000000000000 --- a/arch/arm/mach-s5pv310/Makefile +++ /dev/null | |||
@@ -1,43 +0,0 @@ | |||
1 | # arch/arm/mach-s5pv310/Makefile | ||
2 | # | ||
3 | # Copyright (c) 2010 Samsung Electronics Co., Ltd. | ||
4 | # http://www.samsung.com/ | ||
5 | # | ||
6 | # Licensed under GPLv2 | ||
7 | |||
8 | obj-y := | ||
9 | obj-m := | ||
10 | obj-n := | ||
11 | obj- := | ||
12 | |||
13 | # Core support for S5PV310 system | ||
14 | |||
15 | obj-$(CONFIG_CPU_S5PV310) += cpu.o init.o clock.o irq-combiner.o | ||
16 | obj-$(CONFIG_CPU_S5PV310) += setup-i2c0.o time.o gpiolib.o irq-eint.o dma.o | ||
17 | obj-$(CONFIG_CPU_FREQ) += cpufreq.o | ||
18 | |||
19 | obj-$(CONFIG_SMP) += platsmp.o headsmp.o | ||
20 | obj-$(CONFIG_LOCAL_TIMERS) += localtimer.o | ||
21 | obj-$(CONFIG_HOTPLUG_CPU) += hotplug.o | ||
22 | |||
23 | # machine support | ||
24 | |||
25 | obj-$(CONFIG_MACH_SMDKC210) += mach-smdkc210.o | ||
26 | obj-$(CONFIG_MACH_SMDKV310) += mach-smdkv310.o | ||
27 | obj-$(CONFIG_MACH_UNIVERSAL_C210) += mach-universal_c210.o | ||
28 | |||
29 | # device support | ||
30 | |||
31 | obj-y += dev-audio.o | ||
32 | obj-$(CONFIG_S5PV310_DEV_PD) += dev-pd.o | ||
33 | obj-$(CONFIG_S5PV310_DEV_SYSMMU) += dev-sysmmu.o | ||
34 | |||
35 | obj-$(CONFIG_S5PV310_SETUP_I2C1) += setup-i2c1.o | ||
36 | obj-$(CONFIG_S5PV310_SETUP_I2C2) += setup-i2c2.o | ||
37 | obj-$(CONFIG_S5PV310_SETUP_I2C3) += setup-i2c3.o | ||
38 | obj-$(CONFIG_S5PV310_SETUP_I2C4) += setup-i2c4.o | ||
39 | obj-$(CONFIG_S5PV310_SETUP_I2C5) += setup-i2c5.o | ||
40 | obj-$(CONFIG_S5PV310_SETUP_I2C6) += setup-i2c6.o | ||
41 | obj-$(CONFIG_S5PV310_SETUP_I2C7) += setup-i2c7.o | ||
42 | obj-$(CONFIG_S5PV310_SETUP_SDHCI) += setup-sdhci.o | ||
43 | obj-$(CONFIG_S5PV310_SETUP_SDHCI_GPIO) += setup-sdhci-gpio.o | ||
diff --git a/arch/arm/mach-s5pv310/gpiolib.c b/arch/arm/mach-s5pv310/gpiolib.c deleted file mode 100644 index 55217b8923ec..000000000000 --- a/arch/arm/mach-s5pv310/gpiolib.c +++ /dev/null | |||
@@ -1,304 +0,0 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/gpiolib.c | ||
2 | * | ||
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * S5PV310 - GPIOlib support | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #include <linux/kernel.h> | ||
14 | #include <linux/irq.h> | ||
15 | #include <linux/io.h> | ||
16 | #include <linux/gpio.h> | ||
17 | |||
18 | #include <mach/map.h> | ||
19 | |||
20 | #include <plat/gpio-core.h> | ||
21 | #include <plat/gpio-cfg.h> | ||
22 | #include <plat/gpio-cfg-helpers.h> | ||
23 | |||
24 | static struct s3c_gpio_cfg gpio_cfg = { | ||
25 | .set_config = s3c_gpio_setcfg_s3c64xx_4bit, | ||
26 | .set_pull = s3c_gpio_setpull_updown, | ||
27 | .get_pull = s3c_gpio_getpull_updown, | ||
28 | }; | ||
29 | |||
30 | static struct s3c_gpio_cfg gpio_cfg_noint = { | ||
31 | .set_config = s3c_gpio_setcfg_s3c64xx_4bit, | ||
32 | .set_pull = s3c_gpio_setpull_updown, | ||
33 | .get_pull = s3c_gpio_getpull_updown, | ||
34 | }; | ||
35 | |||
36 | /* | ||
37 | * Following are the gpio banks in v310. | ||
38 | * | ||
39 | * The 'config' member when left to NULL, is initialized to the default | ||
40 | * structure gpio_cfg in the init function below. | ||
41 | * | ||
42 | * The 'base' member is also initialized in the init function below. | ||
43 | * Note: The initialization of 'base' member of s3c_gpio_chip structure | ||
44 | * uses the above macro and depends on the banks being listed in order here. | ||
45 | */ | ||
46 | static struct s3c_gpio_chip s5pv310_gpio_part1_4bit[] = { | ||
47 | { | ||
48 | .chip = { | ||
49 | .base = S5PV310_GPA0(0), | ||
50 | .ngpio = S5PV310_GPIO_A0_NR, | ||
51 | .label = "GPA0", | ||
52 | }, | ||
53 | }, { | ||
54 | .chip = { | ||
55 | .base = S5PV310_GPA1(0), | ||
56 | .ngpio = S5PV310_GPIO_A1_NR, | ||
57 | .label = "GPA1", | ||
58 | }, | ||
59 | }, { | ||
60 | .chip = { | ||
61 | .base = S5PV310_GPB(0), | ||
62 | .ngpio = S5PV310_GPIO_B_NR, | ||
63 | .label = "GPB", | ||
64 | }, | ||
65 | }, { | ||
66 | .chip = { | ||
67 | .base = S5PV310_GPC0(0), | ||
68 | .ngpio = S5PV310_GPIO_C0_NR, | ||
69 | .label = "GPC0", | ||
70 | }, | ||
71 | }, { | ||
72 | .chip = { | ||
73 | .base = S5PV310_GPC1(0), | ||
74 | .ngpio = S5PV310_GPIO_C1_NR, | ||
75 | .label = "GPC1", | ||
76 | }, | ||
77 | }, { | ||
78 | .chip = { | ||
79 | .base = S5PV310_GPD0(0), | ||
80 | .ngpio = S5PV310_GPIO_D0_NR, | ||
81 | .label = "GPD0", | ||
82 | }, | ||
83 | }, { | ||
84 | .chip = { | ||
85 | .base = S5PV310_GPD1(0), | ||
86 | .ngpio = S5PV310_GPIO_D1_NR, | ||
87 | .label = "GPD1", | ||
88 | }, | ||
89 | }, { | ||
90 | .chip = { | ||
91 | .base = S5PV310_GPE0(0), | ||
92 | .ngpio = S5PV310_GPIO_E0_NR, | ||
93 | .label = "GPE0", | ||
94 | }, | ||
95 | }, { | ||
96 | .chip = { | ||
97 | .base = S5PV310_GPE1(0), | ||
98 | .ngpio = S5PV310_GPIO_E1_NR, | ||
99 | .label = "GPE1", | ||
100 | }, | ||
101 | }, { | ||
102 | .chip = { | ||
103 | .base = S5PV310_GPE2(0), | ||
104 | .ngpio = S5PV310_GPIO_E2_NR, | ||
105 | .label = "GPE2", | ||
106 | }, | ||
107 | }, { | ||
108 | .chip = { | ||
109 | .base = S5PV310_GPE3(0), | ||
110 | .ngpio = S5PV310_GPIO_E3_NR, | ||
111 | .label = "GPE3", | ||
112 | }, | ||
113 | }, { | ||
114 | .chip = { | ||
115 | .base = S5PV310_GPE4(0), | ||
116 | .ngpio = S5PV310_GPIO_E4_NR, | ||
117 | .label = "GPE4", | ||
118 | }, | ||
119 | }, { | ||
120 | .chip = { | ||
121 | .base = S5PV310_GPF0(0), | ||
122 | .ngpio = S5PV310_GPIO_F0_NR, | ||
123 | .label = "GPF0", | ||
124 | }, | ||
125 | }, { | ||
126 | .chip = { | ||
127 | .base = S5PV310_GPF1(0), | ||
128 | .ngpio = S5PV310_GPIO_F1_NR, | ||
129 | .label = "GPF1", | ||
130 | }, | ||
131 | }, { | ||
132 | .chip = { | ||
133 | .base = S5PV310_GPF2(0), | ||
134 | .ngpio = S5PV310_GPIO_F2_NR, | ||
135 | .label = "GPF2", | ||
136 | }, | ||
137 | }, { | ||
138 | .chip = { | ||
139 | .base = S5PV310_GPF3(0), | ||
140 | .ngpio = S5PV310_GPIO_F3_NR, | ||
141 | .label = "GPF3", | ||
142 | }, | ||
143 | }, | ||
144 | }; | ||
145 | |||
146 | static struct s3c_gpio_chip s5pv310_gpio_part2_4bit[] = { | ||
147 | { | ||
148 | .chip = { | ||
149 | .base = S5PV310_GPJ0(0), | ||
150 | .ngpio = S5PV310_GPIO_J0_NR, | ||
151 | .label = "GPJ0", | ||
152 | }, | ||
153 | }, { | ||
154 | .chip = { | ||
155 | .base = S5PV310_GPJ1(0), | ||
156 | .ngpio = S5PV310_GPIO_J1_NR, | ||
157 | .label = "GPJ1", | ||
158 | }, | ||
159 | }, { | ||
160 | .chip = { | ||
161 | .base = S5PV310_GPK0(0), | ||
162 | .ngpio = S5PV310_GPIO_K0_NR, | ||
163 | .label = "GPK0", | ||
164 | }, | ||
165 | }, { | ||
166 | .chip = { | ||
167 | .base = S5PV310_GPK1(0), | ||
168 | .ngpio = S5PV310_GPIO_K1_NR, | ||
169 | .label = "GPK1", | ||
170 | }, | ||
171 | }, { | ||
172 | .chip = { | ||
173 | .base = S5PV310_GPK2(0), | ||
174 | .ngpio = S5PV310_GPIO_K2_NR, | ||
175 | .label = "GPK2", | ||
176 | }, | ||
177 | }, { | ||
178 | .chip = { | ||
179 | .base = S5PV310_GPK3(0), | ||
180 | .ngpio = S5PV310_GPIO_K3_NR, | ||
181 | .label = "GPK3", | ||
182 | }, | ||
183 | }, { | ||
184 | .chip = { | ||
185 | .base = S5PV310_GPL0(0), | ||
186 | .ngpio = S5PV310_GPIO_L0_NR, | ||
187 | .label = "GPL0", | ||
188 | }, | ||
189 | }, { | ||
190 | .chip = { | ||
191 | .base = S5PV310_GPL1(0), | ||
192 | .ngpio = S5PV310_GPIO_L1_NR, | ||
193 | .label = "GPL1", | ||
194 | }, | ||
195 | }, { | ||
196 | .chip = { | ||
197 | .base = S5PV310_GPL2(0), | ||
198 | .ngpio = S5PV310_GPIO_L2_NR, | ||
199 | .label = "GPL2", | ||
200 | }, | ||
201 | }, { | ||
202 | .base = (S5P_VA_GPIO2 + 0xC00), | ||
203 | .config = &gpio_cfg_noint, | ||
204 | .irq_base = IRQ_EINT(0), | ||
205 | .chip = { | ||
206 | .base = S5PV310_GPX0(0), | ||
207 | .ngpio = S5PV310_GPIO_X0_NR, | ||
208 | .label = "GPX0", | ||
209 | .to_irq = samsung_gpiolib_to_irq, | ||
210 | }, | ||
211 | }, { | ||
212 | .base = (S5P_VA_GPIO2 + 0xC20), | ||
213 | .config = &gpio_cfg_noint, | ||
214 | .irq_base = IRQ_EINT(8), | ||
215 | .chip = { | ||
216 | .base = S5PV310_GPX1(0), | ||
217 | .ngpio = S5PV310_GPIO_X1_NR, | ||
218 | .label = "GPX1", | ||
219 | .to_irq = samsung_gpiolib_to_irq, | ||
220 | }, | ||
221 | }, { | ||
222 | .base = (S5P_VA_GPIO2 + 0xC40), | ||
223 | .config = &gpio_cfg_noint, | ||
224 | .irq_base = IRQ_EINT(16), | ||
225 | .chip = { | ||
226 | .base = S5PV310_GPX2(0), | ||
227 | .ngpio = S5PV310_GPIO_X2_NR, | ||
228 | .label = "GPX2", | ||
229 | .to_irq = samsung_gpiolib_to_irq, | ||
230 | }, | ||
231 | }, { | ||
232 | .base = (S5P_VA_GPIO2 + 0xC60), | ||
233 | .config = &gpio_cfg_noint, | ||
234 | .irq_base = IRQ_EINT(24), | ||
235 | .chip = { | ||
236 | .base = S5PV310_GPX3(0), | ||
237 | .ngpio = S5PV310_GPIO_X3_NR, | ||
238 | .label = "GPX3", | ||
239 | .to_irq = samsung_gpiolib_to_irq, | ||
240 | }, | ||
241 | }, | ||
242 | }; | ||
243 | |||
244 | static struct s3c_gpio_chip s5pv310_gpio_part3_4bit[] = { | ||
245 | { | ||
246 | .chip = { | ||
247 | .base = S5PV310_GPZ(0), | ||
248 | .ngpio = S5PV310_GPIO_Z_NR, | ||
249 | .label = "GPZ", | ||
250 | }, | ||
251 | }, | ||
252 | }; | ||
253 | |||
254 | static __init int s5pv310_gpiolib_init(void) | ||
255 | { | ||
256 | struct s3c_gpio_chip *chip; | ||
257 | int i; | ||
258 | int nr_chips; | ||
259 | |||
260 | /* GPIO part 1 */ | ||
261 | |||
262 | chip = s5pv310_gpio_part1_4bit; | ||
263 | nr_chips = ARRAY_SIZE(s5pv310_gpio_part1_4bit); | ||
264 | |||
265 | for (i = 0; i < nr_chips; i++, chip++) { | ||
266 | if (chip->config == NULL) | ||
267 | chip->config = &gpio_cfg; | ||
268 | if (chip->base == NULL) | ||
269 | chip->base = S5P_VA_GPIO1 + (i) * 0x20; | ||
270 | } | ||
271 | |||
272 | samsung_gpiolib_add_4bit_chips(s5pv310_gpio_part1_4bit, nr_chips); | ||
273 | |||
274 | /* GPIO part 2 */ | ||
275 | |||
276 | chip = s5pv310_gpio_part2_4bit; | ||
277 | nr_chips = ARRAY_SIZE(s5pv310_gpio_part2_4bit); | ||
278 | |||
279 | for (i = 0; i < nr_chips; i++, chip++) { | ||
280 | if (chip->config == NULL) | ||
281 | chip->config = &gpio_cfg; | ||
282 | if (chip->base == NULL) | ||
283 | chip->base = S5P_VA_GPIO2 + (i) * 0x20; | ||
284 | } | ||
285 | |||
286 | samsung_gpiolib_add_4bit_chips(s5pv310_gpio_part2_4bit, nr_chips); | ||
287 | |||
288 | /* GPIO part 3 */ | ||
289 | |||
290 | chip = s5pv310_gpio_part3_4bit; | ||
291 | nr_chips = ARRAY_SIZE(s5pv310_gpio_part3_4bit); | ||
292 | |||
293 | for (i = 0; i < nr_chips; i++, chip++) { | ||
294 | if (chip->config == NULL) | ||
295 | chip->config = &gpio_cfg; | ||
296 | if (chip->base == NULL) | ||
297 | chip->base = S5P_VA_GPIO3 + (i) * 0x20; | ||
298 | } | ||
299 | |||
300 | samsung_gpiolib_add_4bit_chips(s5pv310_gpio_part3_4bit, nr_chips); | ||
301 | |||
302 | return 0; | ||
303 | } | ||
304 | core_initcall(s5pv310_gpiolib_init); | ||
diff --git a/arch/arm/mach-s5pv310/include/mach/gpio.h b/arch/arm/mach-s5pv310/include/mach/gpio.h deleted file mode 100644 index 20cb80c23466..000000000000 --- a/arch/arm/mach-s5pv310/include/mach/gpio.h +++ /dev/null | |||
@@ -1,135 +0,0 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/gpio.h | ||
2 | * | ||
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com/ | ||
5 | * | ||
6 | * S5PV310 - GPIO lib support | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __ASM_ARCH_GPIO_H | ||
14 | #define __ASM_ARCH_GPIO_H __FILE__ | ||
15 | |||
16 | #define gpio_get_value __gpio_get_value | ||
17 | #define gpio_set_value __gpio_set_value | ||
18 | #define gpio_cansleep __gpio_cansleep | ||
19 | #define gpio_to_irq __gpio_to_irq | ||
20 | |||
21 | /* Practically, GPIO banks upto GPZ are the configurable gpio banks */ | ||
22 | |||
23 | /* GPIO bank sizes */ | ||
24 | #define S5PV310_GPIO_A0_NR (8) | ||
25 | #define S5PV310_GPIO_A1_NR (6) | ||
26 | #define S5PV310_GPIO_B_NR (8) | ||
27 | #define S5PV310_GPIO_C0_NR (5) | ||
28 | #define S5PV310_GPIO_C1_NR (5) | ||
29 | #define S5PV310_GPIO_D0_NR (4) | ||
30 | #define S5PV310_GPIO_D1_NR (4) | ||
31 | #define S5PV310_GPIO_E0_NR (5) | ||
32 | #define S5PV310_GPIO_E1_NR (8) | ||
33 | #define S5PV310_GPIO_E2_NR (6) | ||
34 | #define S5PV310_GPIO_E3_NR (8) | ||
35 | #define S5PV310_GPIO_E4_NR (8) | ||
36 | #define S5PV310_GPIO_F0_NR (8) | ||
37 | #define S5PV310_GPIO_F1_NR (8) | ||
38 | #define S5PV310_GPIO_F2_NR (8) | ||
39 | #define S5PV310_GPIO_F3_NR (6) | ||
40 | #define S5PV310_GPIO_J0_NR (8) | ||
41 | #define S5PV310_GPIO_J1_NR (5) | ||
42 | #define S5PV310_GPIO_K0_NR (7) | ||
43 | #define S5PV310_GPIO_K1_NR (7) | ||
44 | #define S5PV310_GPIO_K2_NR (7) | ||
45 | #define S5PV310_GPIO_K3_NR (7) | ||
46 | #define S5PV310_GPIO_L0_NR (8) | ||
47 | #define S5PV310_GPIO_L1_NR (3) | ||
48 | #define S5PV310_GPIO_L2_NR (8) | ||
49 | #define S5PV310_GPIO_X0_NR (8) | ||
50 | #define S5PV310_GPIO_X1_NR (8) | ||
51 | #define S5PV310_GPIO_X2_NR (8) | ||
52 | #define S5PV310_GPIO_X3_NR (8) | ||
53 | #define S5PV310_GPIO_Z_NR (7) | ||
54 | |||
55 | /* GPIO bank numbers */ | ||
56 | |||
57 | #define S5PV310_GPIO_NEXT(__gpio) \ | ||
58 | ((__gpio##_START) + (__gpio##_NR) + CONFIG_S3C_GPIO_SPACE + 1) | ||
59 | |||
60 | enum s5p_gpio_number { | ||
61 | S5PV310_GPIO_A0_START = 0, | ||
62 | S5PV310_GPIO_A1_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_A0), | ||
63 | S5PV310_GPIO_B_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_A1), | ||
64 | S5PV310_GPIO_C0_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_B), | ||
65 | S5PV310_GPIO_C1_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_C0), | ||
66 | S5PV310_GPIO_D0_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_C1), | ||
67 | S5PV310_GPIO_D1_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_D0), | ||
68 | S5PV310_GPIO_E0_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_D1), | ||
69 | S5PV310_GPIO_E1_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_E0), | ||
70 | S5PV310_GPIO_E2_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_E1), | ||
71 | S5PV310_GPIO_E3_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_E2), | ||
72 | S5PV310_GPIO_E4_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_E3), | ||
73 | S5PV310_GPIO_F0_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_E4), | ||
74 | S5PV310_GPIO_F1_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_F0), | ||
75 | S5PV310_GPIO_F2_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_F1), | ||
76 | S5PV310_GPIO_F3_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_F2), | ||
77 | S5PV310_GPIO_J0_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_F3), | ||
78 | S5PV310_GPIO_J1_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_J0), | ||
79 | S5PV310_GPIO_K0_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_J1), | ||
80 | S5PV310_GPIO_K1_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_K0), | ||
81 | S5PV310_GPIO_K2_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_K1), | ||
82 | S5PV310_GPIO_K3_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_K2), | ||
83 | S5PV310_GPIO_L0_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_K3), | ||
84 | S5PV310_GPIO_L1_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_L0), | ||
85 | S5PV310_GPIO_L2_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_L1), | ||
86 | S5PV310_GPIO_X0_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_L2), | ||
87 | S5PV310_GPIO_X1_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_X0), | ||
88 | S5PV310_GPIO_X2_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_X1), | ||
89 | S5PV310_GPIO_X3_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_X2), | ||
90 | S5PV310_GPIO_Z_START = S5PV310_GPIO_NEXT(S5PV310_GPIO_X3), | ||
91 | }; | ||
92 | |||
93 | /* S5PV310 GPIO number definitions */ | ||
94 | #define S5PV310_GPA0(_nr) (S5PV310_GPIO_A0_START + (_nr)) | ||
95 | #define S5PV310_GPA1(_nr) (S5PV310_GPIO_A1_START + (_nr)) | ||
96 | #define S5PV310_GPB(_nr) (S5PV310_GPIO_B_START + (_nr)) | ||
97 | #define S5PV310_GPC0(_nr) (S5PV310_GPIO_C0_START + (_nr)) | ||
98 | #define S5PV310_GPC1(_nr) (S5PV310_GPIO_C1_START + (_nr)) | ||
99 | #define S5PV310_GPD0(_nr) (S5PV310_GPIO_D0_START + (_nr)) | ||
100 | #define S5PV310_GPD1(_nr) (S5PV310_GPIO_D1_START + (_nr)) | ||
101 | #define S5PV310_GPE0(_nr) (S5PV310_GPIO_E0_START + (_nr)) | ||
102 | #define S5PV310_GPE1(_nr) (S5PV310_GPIO_E1_START + (_nr)) | ||
103 | #define S5PV310_GPE2(_nr) (S5PV310_GPIO_E2_START + (_nr)) | ||
104 | #define S5PV310_GPE3(_nr) (S5PV310_GPIO_E3_START + (_nr)) | ||
105 | #define S5PV310_GPE4(_nr) (S5PV310_GPIO_E4_START + (_nr)) | ||
106 | #define S5PV310_GPF0(_nr) (S5PV310_GPIO_F0_START + (_nr)) | ||
107 | #define S5PV310_GPF1(_nr) (S5PV310_GPIO_F1_START + (_nr)) | ||
108 | #define S5PV310_GPF2(_nr) (S5PV310_GPIO_F2_START + (_nr)) | ||
109 | #define S5PV310_GPF3(_nr) (S5PV310_GPIO_F3_START + (_nr)) | ||
110 | #define S5PV310_GPJ0(_nr) (S5PV310_GPIO_J0_START + (_nr)) | ||
111 | #define S5PV310_GPJ1(_nr) (S5PV310_GPIO_J1_START + (_nr)) | ||
112 | #define S5PV310_GPK0(_nr) (S5PV310_GPIO_K0_START + (_nr)) | ||
113 | #define S5PV310_GPK1(_nr) (S5PV310_GPIO_K1_START + (_nr)) | ||
114 | #define S5PV310_GPK2(_nr) (S5PV310_GPIO_K2_START + (_nr)) | ||
115 | #define S5PV310_GPK3(_nr) (S5PV310_GPIO_K3_START + (_nr)) | ||
116 | #define S5PV310_GPL0(_nr) (S5PV310_GPIO_L0_START + (_nr)) | ||
117 | #define S5PV310_GPL1(_nr) (S5PV310_GPIO_L1_START + (_nr)) | ||
118 | #define S5PV310_GPL2(_nr) (S5PV310_GPIO_L2_START + (_nr)) | ||
119 | #define S5PV310_GPX0(_nr) (S5PV310_GPIO_X0_START + (_nr)) | ||
120 | #define S5PV310_GPX1(_nr) (S5PV310_GPIO_X1_START + (_nr)) | ||
121 | #define S5PV310_GPX2(_nr) (S5PV310_GPIO_X2_START + (_nr)) | ||
122 | #define S5PV310_GPX3(_nr) (S5PV310_GPIO_X3_START + (_nr)) | ||
123 | #define S5PV310_GPZ(_nr) (S5PV310_GPIO_Z_START + (_nr)) | ||
124 | |||
125 | /* the end of the S5PV310 specific gpios */ | ||
126 | #define S5PV310_GPIO_END (S5PV310_GPZ(S5PV310_GPIO_Z_NR) + 1) | ||
127 | #define S3C_GPIO_END S5PV310_GPIO_END | ||
128 | |||
129 | /* define the number of gpios we need to the one after the GPZ() range */ | ||
130 | #define ARCH_NR_GPIOS (S5PV310_GPZ(S5PV310_GPIO_Z_NR) + \ | ||
131 | CONFIG_SAMSUNG_GPIO_EXTRA + 1) | ||
132 | |||
133 | #include <asm-generic/gpio.h> | ||
134 | |||
135 | #endif /* __ASM_ARCH_GPIO_H */ | ||
diff --git a/arch/arm/mach-s5pv310/include/mach/map.h b/arch/arm/mach-s5pv310/include/mach/map.h deleted file mode 100644 index 901657fa7a12..000000000000 --- a/arch/arm/mach-s5pv310/include/mach/map.h +++ /dev/null | |||
@@ -1,144 +0,0 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/map.h | ||
2 | * | ||
3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com/ | ||
5 | * | ||
6 | * S5PV310 - Memory map definitions | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __ASM_ARCH_MAP_H | ||
14 | #define __ASM_ARCH_MAP_H __FILE__ | ||
15 | |||
16 | #include <plat/map-base.h> | ||
17 | |||
18 | /* | ||
19 | * S5PV310 UART offset is 0x10000 but the older S5P SoCs are 0x400. | ||
20 | * So need to define it, and here is to avoid redefinition warning. | ||
21 | */ | ||
22 | #define S3C_UART_OFFSET (0x10000) | ||
23 | |||
24 | #include <plat/map-s5p.h> | ||
25 | |||
26 | #define S5PV310_PA_SYSRAM 0x02025000 | ||
27 | |||
28 | #define S5PV310_PA_I2S0 0x03830000 | ||
29 | #define S5PV310_PA_I2S1 0xE3100000 | ||
30 | #define S5PV310_PA_I2S2 0xE2A00000 | ||
31 | |||
32 | #define S5PV310_PA_PCM0 0x03840000 | ||
33 | #define S5PV310_PA_PCM1 0x13980000 | ||
34 | #define S5PV310_PA_PCM2 0x13990000 | ||
35 | |||
36 | #define S5PV310_PA_SROM_BANK(x) (0x04000000 + ((x) * 0x01000000)) | ||
37 | |||
38 | #define S5PC210_PA_ONENAND 0x0C000000 | ||
39 | #define S5PC210_PA_ONENAND_DMA 0x0C600000 | ||
40 | |||
41 | #define S5PV310_PA_CHIPID 0x10000000 | ||
42 | |||
43 | #define S5PV310_PA_SYSCON 0x10010000 | ||
44 | #define S5PV310_PA_PMU 0x10020000 | ||
45 | #define S5PV310_PA_CMU 0x10030000 | ||
46 | |||
47 | #define S5PV310_PA_WATCHDOG 0x10060000 | ||
48 | #define S5PV310_PA_RTC 0x10070000 | ||
49 | |||
50 | #define S5PV310_PA_DMC0 0x10400000 | ||
51 | |||
52 | #define S5PV310_PA_COMBINER 0x10448000 | ||
53 | |||
54 | #define S5PV310_PA_COREPERI 0x10500000 | ||
55 | #define S5PV310_PA_GIC_CPU 0x10500100 | ||
56 | #define S5PV310_PA_TWD 0x10500600 | ||
57 | #define S5PV310_PA_GIC_DIST 0x10501000 | ||
58 | #define S5PV310_PA_L2CC 0x10502000 | ||
59 | |||
60 | #define S5PV310_PA_MDMA 0x10810000 | ||
61 | #define S5PV310_PA_PDMA0 0x12680000 | ||
62 | #define S5PV310_PA_PDMA1 0x12690000 | ||
63 | |||
64 | #define S5PV310_PA_SYSMMU_MDMA 0x10A40000 | ||
65 | #define S5PV310_PA_SYSMMU_SSS 0x10A50000 | ||
66 | #define S5PV310_PA_SYSMMU_FIMC0 0x11A20000 | ||
67 | #define S5PV310_PA_SYSMMU_FIMC1 0x11A30000 | ||
68 | #define S5PV310_PA_SYSMMU_FIMC2 0x11A40000 | ||
69 | #define S5PV310_PA_SYSMMU_FIMC3 0x11A50000 | ||
70 | #define S5PV310_PA_SYSMMU_JPEG 0x11A60000 | ||
71 | #define S5PV310_PA_SYSMMU_FIMD0 0x11E20000 | ||
72 | #define S5PV310_PA_SYSMMU_FIMD1 0x12220000 | ||
73 | #define S5PV310_PA_SYSMMU_PCIe 0x12620000 | ||
74 | #define S5PV310_PA_SYSMMU_G2D 0x12A20000 | ||
75 | #define S5PV310_PA_SYSMMU_ROTATOR 0x12A30000 | ||
76 | #define S5PV310_PA_SYSMMU_MDMA2 0x12A40000 | ||
77 | #define S5PV310_PA_SYSMMU_TV 0x12E20000 | ||
78 | #define S5PV310_PA_SYSMMU_MFC_L 0x13620000 | ||
79 | #define S5PV310_PA_SYSMMU_MFC_R 0x13630000 | ||
80 | |||
81 | #define S5PV310_PA_GPIO1 0x11400000 | ||
82 | #define S5PV310_PA_GPIO2 0x11000000 | ||
83 | #define S5PV310_PA_GPIO3 0x03860000 | ||
84 | |||
85 | #define S5PV310_PA_MIPI_CSIS0 0x11880000 | ||
86 | #define S5PV310_PA_MIPI_CSIS1 0x11890000 | ||
87 | |||
88 | #define S5PV310_PA_HSMMC(x) (0x12510000 + ((x) * 0x10000)) | ||
89 | |||
90 | #define S5PV310_PA_SROMC 0x12570000 | ||
91 | |||
92 | #define S5PV310_PA_UART 0x13800000 | ||
93 | |||
94 | #define S5PV310_PA_IIC(x) (0x13860000 + ((x) * 0x10000)) | ||
95 | |||
96 | #define S5PV310_PA_AC97 0x139A0000 | ||
97 | |||
98 | #define S5PV310_PA_TIMER 0x139D0000 | ||
99 | |||
100 | #define S5PV310_PA_SDRAM 0x40000000 | ||
101 | |||
102 | #define S5PV310_PA_SPDIF 0xE1100000 | ||
103 | |||
104 | /* Compatibiltiy Defines */ | ||
105 | |||
106 | #define S3C_PA_HSMMC0 S5PV310_PA_HSMMC(0) | ||
107 | #define S3C_PA_HSMMC1 S5PV310_PA_HSMMC(1) | ||
108 | #define S3C_PA_HSMMC2 S5PV310_PA_HSMMC(2) | ||
109 | #define S3C_PA_HSMMC3 S5PV310_PA_HSMMC(3) | ||
110 | #define S3C_PA_IIC S5PV310_PA_IIC(0) | ||
111 | #define S3C_PA_IIC1 S5PV310_PA_IIC(1) | ||
112 | #define S3C_PA_IIC2 S5PV310_PA_IIC(2) | ||
113 | #define S3C_PA_IIC3 S5PV310_PA_IIC(3) | ||
114 | #define S3C_PA_IIC4 S5PV310_PA_IIC(4) | ||
115 | #define S3C_PA_IIC5 S5PV310_PA_IIC(5) | ||
116 | #define S3C_PA_IIC6 S5PV310_PA_IIC(6) | ||
117 | #define S3C_PA_IIC7 S5PV310_PA_IIC(7) | ||
118 | #define S3C_PA_RTC S5PV310_PA_RTC | ||
119 | #define S3C_PA_WDT S5PV310_PA_WATCHDOG | ||
120 | |||
121 | #define S5P_PA_CHIPID S5PV310_PA_CHIPID | ||
122 | #define S5P_PA_MIPI_CSIS0 S5PV310_PA_MIPI_CSIS0 | ||
123 | #define S5P_PA_MIPI_CSIS1 S5PV310_PA_MIPI_CSIS1 | ||
124 | #define S5P_PA_ONENAND S5PC210_PA_ONENAND | ||
125 | #define S5P_PA_ONENAND_DMA S5PC210_PA_ONENAND_DMA | ||
126 | #define S5P_PA_SDRAM S5PV310_PA_SDRAM | ||
127 | #define S5P_PA_SROMC S5PV310_PA_SROMC | ||
128 | #define S5P_PA_SYSCON S5PV310_PA_SYSCON | ||
129 | #define S5P_PA_TIMER S5PV310_PA_TIMER | ||
130 | |||
131 | /* UART */ | ||
132 | |||
133 | #define S3C_PA_UART S5PV310_PA_UART | ||
134 | |||
135 | #define S5P_PA_UART(x) (S3C_PA_UART + ((x) * S3C_UART_OFFSET)) | ||
136 | #define S5P_PA_UART0 S5P_PA_UART(0) | ||
137 | #define S5P_PA_UART1 S5P_PA_UART(1) | ||
138 | #define S5P_PA_UART2 S5P_PA_UART(2) | ||
139 | #define S5P_PA_UART3 S5P_PA_UART(3) | ||
140 | #define S5P_PA_UART4 S5P_PA_UART(4) | ||
141 | |||
142 | #define S5P_SZ_UART SZ_256 | ||
143 | |||
144 | #endif /* __ASM_ARCH_MAP_H */ | ||
diff --git a/arch/arm/mach-s5pv310/include/mach/regs-gpio.h b/arch/arm/mach-s5pv310/include/mach/regs-gpio.h deleted file mode 100644 index 82e9e0c9d452..000000000000 --- a/arch/arm/mach-s5pv310/include/mach/regs-gpio.h +++ /dev/null | |||
@@ -1,42 +0,0 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/regs-gpio.h | ||
2 | * | ||
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * S5PV310 - GPIO (including EINT) register definitions | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __ASM_ARCH_REGS_GPIO_H | ||
14 | #define __ASM_ARCH_REGS_GPIO_H __FILE__ | ||
15 | |||
16 | #include <mach/map.h> | ||
17 | #include <mach/irqs.h> | ||
18 | |||
19 | #define S5PV310_EINT40CON (S5P_VA_GPIO2 + 0xE00) | ||
20 | #define S5P_EINT_CON(x) (S5PV310_EINT40CON + ((x) * 0x4)) | ||
21 | |||
22 | #define S5PV310_EINT40FLTCON0 (S5P_VA_GPIO2 + 0xE80) | ||
23 | #define S5P_EINT_FLTCON(x) (S5PV310_EINT40FLTCON0 + ((x) * 0x4)) | ||
24 | |||
25 | #define S5PV310_EINT40MASK (S5P_VA_GPIO2 + 0xF00) | ||
26 | #define S5P_EINT_MASK(x) (S5PV310_EINT40MASK + ((x) * 0x4)) | ||
27 | |||
28 | #define S5PV310_EINT40PEND (S5P_VA_GPIO2 + 0xF40) | ||
29 | #define S5P_EINT_PEND(x) (S5PV310_EINT40PEND + ((x) * 0x4)) | ||
30 | |||
31 | #define EINT_REG_NR(x) (EINT_OFFSET(x) >> 3) | ||
32 | |||
33 | #define eint_irq_to_bit(irq) (1 << (EINT_OFFSET(irq) & 0x7)) | ||
34 | |||
35 | #define EINT_MODE S3C_GPIO_SFN(0xf) | ||
36 | |||
37 | #define EINT_GPIO_0(x) S5PV310_GPX0(x) | ||
38 | #define EINT_GPIO_1(x) S5PV310_GPX1(x) | ||
39 | #define EINT_GPIO_2(x) S5PV310_GPX2(x) | ||
40 | #define EINT_GPIO_3(x) S5PV310_GPX3(x) | ||
41 | |||
42 | #endif /* __ASM_ARCH_REGS_GPIO_H */ | ||
diff --git a/arch/arm/mach-s5pv310/include/mach/regs-pmu.h b/arch/arm/mach-s5pv310/include/mach/regs-pmu.h deleted file mode 100644 index fb333d0f6073..000000000000 --- a/arch/arm/mach-s5pv310/include/mach/regs-pmu.h +++ /dev/null | |||
@@ -1,30 +0,0 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/regs-pmu.h | ||
2 | * | ||
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * S5PV310 - Power management unit definition | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __ASM_ARCH_REGS_PMU_H | ||
14 | #define __ASM_ARCH_REGS_PMU_H __FILE__ | ||
15 | |||
16 | #include <mach/map.h> | ||
17 | |||
18 | #define S5P_PMUREG(x) (S5P_VA_PMU + (x)) | ||
19 | |||
20 | #define S5P_PMU_CAM_CONF S5P_PMUREG(0x3C00) | ||
21 | #define S5P_PMU_TV_CONF S5P_PMUREG(0x3C20) | ||
22 | #define S5P_PMU_MFC_CONF S5P_PMUREG(0x3C40) | ||
23 | #define S5P_PMU_G3D_CONF S5P_PMUREG(0x3C60) | ||
24 | #define S5P_PMU_LCD0_CONF S5P_PMUREG(0x3C80) | ||
25 | #define S5P_PMU_LCD1_CONF S5P_PMUREG(0x3CA0) | ||
26 | #define S5P_PMU_GPS_CONF S5P_PMUREG(0x3CE0) | ||
27 | |||
28 | #define S5P_INT_LOCAL_PWR_EN 0x7 | ||
29 | |||
30 | #endif /* __ASM_ARCH_REGS_PMU_H */ | ||
diff --git a/arch/arm/mach-s5pv310/include/mach/sysmmu.h b/arch/arm/mach-s5pv310/include/mach/sysmmu.h deleted file mode 100644 index 598fc5c9211b..000000000000 --- a/arch/arm/mach-s5pv310/include/mach/sysmmu.h +++ /dev/null | |||
@@ -1,122 +0,0 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/include/mach/sysmmu.h | ||
2 | * | ||
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com/ | ||
5 | * | ||
6 | * Samsung sysmmu driver for S5PV310 | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __ASM_ARM_ARCH_SYSMMU_H | ||
14 | #define __ASM_ARM_ARCH_SYSMMU_H __FILE__ | ||
15 | |||
16 | #define S5PV310_SYSMMU_TOTAL_IPNUM 16 | ||
17 | #define S5P_SYSMMU_TOTAL_IPNUM S5PV310_SYSMMU_TOTAL_IPNUM | ||
18 | |||
19 | enum s5pv310_sysmmu_ips { | ||
20 | SYSMMU_MDMA, | ||
21 | SYSMMU_SSS, | ||
22 | SYSMMU_FIMC0, | ||
23 | SYSMMU_FIMC1, | ||
24 | SYSMMU_FIMC2, | ||
25 | SYSMMU_FIMC3, | ||
26 | SYSMMU_JPEG, | ||
27 | SYSMMU_FIMD0, | ||
28 | SYSMMU_FIMD1, | ||
29 | SYSMMU_PCIe, | ||
30 | SYSMMU_G2D, | ||
31 | SYSMMU_ROTATOR, | ||
32 | SYSMMU_MDMA2, | ||
33 | SYSMMU_TV, | ||
34 | SYSMMU_MFC_L, | ||
35 | SYSMMU_MFC_R, | ||
36 | }; | ||
37 | |||
38 | static char *sysmmu_ips_name[S5PV310_SYSMMU_TOTAL_IPNUM] = { | ||
39 | "SYSMMU_MDMA" , | ||
40 | "SYSMMU_SSS" , | ||
41 | "SYSMMU_FIMC0" , | ||
42 | "SYSMMU_FIMC1" , | ||
43 | "SYSMMU_FIMC2" , | ||
44 | "SYSMMU_FIMC3" , | ||
45 | "SYSMMU_JPEG" , | ||
46 | "SYSMMU_FIMD0" , | ||
47 | "SYSMMU_FIMD1" , | ||
48 | "SYSMMU_PCIe" , | ||
49 | "SYSMMU_G2D" , | ||
50 | "SYSMMU_ROTATOR", | ||
51 | "SYSMMU_MDMA2" , | ||
52 | "SYSMMU_TV" , | ||
53 | "SYSMMU_MFC_L" , | ||
54 | "SYSMMU_MFC_R" , | ||
55 | }; | ||
56 | |||
57 | typedef enum s5pv310_sysmmu_ips sysmmu_ips; | ||
58 | |||
59 | struct sysmmu_tt_info { | ||
60 | unsigned long *pgd; | ||
61 | unsigned long pgd_paddr; | ||
62 | unsigned long *pte; | ||
63 | }; | ||
64 | |||
65 | struct sysmmu_controller { | ||
66 | const char *name; | ||
67 | |||
68 | /* channels registers */ | ||
69 | void __iomem *regs; | ||
70 | |||
71 | /* channel irq */ | ||
72 | unsigned int irq; | ||
73 | |||
74 | sysmmu_ips ips; | ||
75 | |||
76 | /* Translation Table Info. */ | ||
77 | struct sysmmu_tt_info *tt_info; | ||
78 | |||
79 | struct resource *mem; | ||
80 | struct device *dev; | ||
81 | |||
82 | /* SysMMU controller enable - true : enable */ | ||
83 | bool enable; | ||
84 | }; | ||
85 | |||
86 | /** | ||
87 | * s5p_sysmmu_enable() - enable system mmu of ip | ||
88 | * @ips: The ip connected system mmu. | ||
89 | * | ||
90 | * This function enable system mmu to transfer address | ||
91 | * from virtual address to physical address | ||
92 | */ | ||
93 | int s5p_sysmmu_enable(sysmmu_ips ips); | ||
94 | |||
95 | /** | ||
96 | * s5p_sysmmu_disable() - disable sysmmu mmu of ip | ||
97 | * @ips: The ip connected system mmu. | ||
98 | * | ||
99 | * This function disable system mmu to transfer address | ||
100 | * from virtual address to physical address | ||
101 | */ | ||
102 | int s5p_sysmmu_disable(sysmmu_ips ips); | ||
103 | |||
104 | /** | ||
105 | * s5p_sysmmu_set_tablebase_pgd() - set page table base address to refer page table | ||
106 | * @ips: The ip connected system mmu. | ||
107 | * @pgd: The page table base address. | ||
108 | * | ||
109 | * This function set page table base address | ||
110 | * When system mmu transfer address from virtaul address to physical address, | ||
111 | * system mmu refer address information from page table | ||
112 | */ | ||
113 | int s5p_sysmmu_set_tablebase_pgd(sysmmu_ips ips, unsigned long pgd); | ||
114 | |||
115 | /** | ||
116 | * s5p_sysmmu_tlb_invalidate() - flush all TLB entry in system mmu | ||
117 | * @ips: The ip connected system mmu. | ||
118 | * | ||
119 | * This function flush all TLB entry in system mmu | ||
120 | */ | ||
121 | int s5p_sysmmu_tlb_invalidate(sysmmu_ips ips); | ||
122 | #endif /* __ASM_ARM_ARCH_SYSMMU_H */ | ||
diff --git a/arch/arm/mach-s5pv310/mach-universal_c210.c b/arch/arm/mach-s5pv310/mach-universal_c210.c deleted file mode 100644 index 36bc3cf825e3..000000000000 --- a/arch/arm/mach-s5pv310/mach-universal_c210.c +++ /dev/null | |||
@@ -1,237 +0,0 @@ | |||
1 | /* linux/arch/arm/mach-s5pv310/mach-universal_c210.c | ||
2 | * | ||
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | ||
4 | * | ||
5 | * This program is free software; you can redistribute it and/or modify | ||
6 | * it under the terms of the GNU General Public License version 2 as | ||
7 | * published by the Free Software Foundation. | ||
8 | */ | ||
9 | |||
10 | #include <linux/platform_device.h> | ||
11 | #include <linux/serial_core.h> | ||
12 | #include <linux/input.h> | ||
13 | #include <linux/i2c.h> | ||
14 | #include <linux/gpio_keys.h> | ||
15 | #include <linux/gpio.h> | ||
16 | #include <linux/regulator/machine.h> | ||
17 | #include <linux/regulator/fixed.h> | ||
18 | #include <linux/mmc/host.h> | ||
19 | |||
20 | #include <asm/mach/arch.h> | ||
21 | #include <asm/mach-types.h> | ||
22 | |||
23 | #include <plat/regs-serial.h> | ||
24 | #include <plat/s5pv310.h> | ||
25 | #include <plat/cpu.h> | ||
26 | #include <plat/devs.h> | ||
27 | #include <plat/sdhci.h> | ||
28 | |||
29 | #include <mach/map.h> | ||
30 | |||
31 | /* Following are default values for UCON, ULCON and UFCON UART registers */ | ||
32 | #define UNIVERSAL_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \ | ||
33 | S3C2410_UCON_RXILEVEL | \ | ||
34 | S3C2410_UCON_TXIRQMODE | \ | ||
35 | S3C2410_UCON_RXIRQMODE | \ | ||
36 | S3C2410_UCON_RXFIFO_TOI | \ | ||
37 | S3C2443_UCON_RXERR_IRQEN) | ||
38 | |||
39 | #define UNIVERSAL_ULCON_DEFAULT S3C2410_LCON_CS8 | ||
40 | |||
41 | #define UNIVERSAL_UFCON_DEFAULT (S3C2410_UFCON_FIFOMODE | \ | ||
42 | S5PV210_UFCON_TXTRIG256 | \ | ||
43 | S5PV210_UFCON_RXTRIG256) | ||
44 | |||
45 | static struct s3c2410_uartcfg universal_uartcfgs[] __initdata = { | ||
46 | [0] = { | ||
47 | .hwport = 0, | ||
48 | .ucon = UNIVERSAL_UCON_DEFAULT, | ||
49 | .ulcon = UNIVERSAL_ULCON_DEFAULT, | ||
50 | .ufcon = UNIVERSAL_UFCON_DEFAULT, | ||
51 | }, | ||
52 | [1] = { | ||
53 | .hwport = 1, | ||
54 | .ucon = UNIVERSAL_UCON_DEFAULT, | ||
55 | .ulcon = UNIVERSAL_ULCON_DEFAULT, | ||
56 | .ufcon = UNIVERSAL_UFCON_DEFAULT, | ||
57 | }, | ||
58 | [2] = { | ||
59 | .hwport = 2, | ||
60 | .ucon = UNIVERSAL_UCON_DEFAULT, | ||
61 | .ulcon = UNIVERSAL_ULCON_DEFAULT, | ||
62 | .ufcon = UNIVERSAL_UFCON_DEFAULT, | ||
63 | }, | ||
64 | [3] = { | ||
65 | .hwport = 3, | ||
66 | .ucon = UNIVERSAL_UCON_DEFAULT, | ||
67 | .ulcon = UNIVERSAL_ULCON_DEFAULT, | ||
68 | .ufcon = UNIVERSAL_UFCON_DEFAULT, | ||
69 | }, | ||
70 | }; | ||
71 | |||
72 | static struct gpio_keys_button universal_gpio_keys_tables[] = { | ||
73 | { | ||
74 | .code = KEY_VOLUMEUP, | ||
75 | .gpio = S5PV310_GPX2(0), /* XEINT16 */ | ||
76 | .desc = "gpio-keys: KEY_VOLUMEUP", | ||
77 | .type = EV_KEY, | ||
78 | .active_low = 1, | ||
79 | .debounce_interval = 1, | ||
80 | }, { | ||
81 | .code = KEY_VOLUMEDOWN, | ||
82 | .gpio = S5PV310_GPX2(1), /* XEINT17 */ | ||
83 | .desc = "gpio-keys: KEY_VOLUMEDOWN", | ||
84 | .type = EV_KEY, | ||
85 | .active_low = 1, | ||
86 | .debounce_interval = 1, | ||
87 | }, { | ||
88 | .code = KEY_CONFIG, | ||
89 | .gpio = S5PV310_GPX2(2), /* XEINT18 */ | ||
90 | .desc = "gpio-keys: KEY_CONFIG", | ||
91 | .type = EV_KEY, | ||
92 | .active_low = 1, | ||
93 | .debounce_interval = 1, | ||
94 | }, { | ||
95 | .code = KEY_CAMERA, | ||
96 | .gpio = S5PV310_GPX2(3), /* XEINT19 */ | ||
97 | .desc = "gpio-keys: KEY_CAMERA", | ||
98 | .type = EV_KEY, | ||
99 | .active_low = 1, | ||
100 | .debounce_interval = 1, | ||
101 | }, { | ||
102 | .code = KEY_OK, | ||
103 | .gpio = S5PV310_GPX3(5), /* XEINT29 */ | ||
104 | .desc = "gpio-keys: KEY_OK", | ||
105 | .type = EV_KEY, | ||
106 | .active_low = 1, | ||
107 | .debounce_interval = 1, | ||
108 | }, | ||
109 | }; | ||
110 | |||
111 | static struct gpio_keys_platform_data universal_gpio_keys_data = { | ||
112 | .buttons = universal_gpio_keys_tables, | ||
113 | .nbuttons = ARRAY_SIZE(universal_gpio_keys_tables), | ||
114 | }; | ||
115 | |||
116 | static struct platform_device universal_gpio_keys = { | ||
117 | .name = "gpio-keys", | ||
118 | .dev = { | ||
119 | .platform_data = &universal_gpio_keys_data, | ||
120 | }, | ||
121 | }; | ||
122 | |||
123 | /* eMMC */ | ||
124 | static struct s3c_sdhci_platdata universal_hsmmc0_data __initdata = { | ||
125 | .max_width = 8, | ||
126 | .host_caps = (MMC_CAP_8_BIT_DATA | MMC_CAP_4_BIT_DATA | | ||
127 | MMC_CAP_MMC_HIGHSPEED | MMC_CAP_SD_HIGHSPEED | | ||
128 | MMC_CAP_DISABLE), | ||
129 | .cd_type = S3C_SDHCI_CD_PERMANENT, | ||
130 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | ||
131 | }; | ||
132 | |||
133 | static struct regulator_consumer_supply mmc0_supplies[] = { | ||
134 | REGULATOR_SUPPLY("vmmc", "s3c-sdhci.0"), | ||
135 | }; | ||
136 | |||
137 | static struct regulator_init_data mmc0_fixed_voltage_init_data = { | ||
138 | .constraints = { | ||
139 | .name = "VMEM_VDD_2.8V", | ||
140 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
141 | }, | ||
142 | .num_consumer_supplies = ARRAY_SIZE(mmc0_supplies), | ||
143 | .consumer_supplies = mmc0_supplies, | ||
144 | }; | ||
145 | |||
146 | static struct fixed_voltage_config mmc0_fixed_voltage_config = { | ||
147 | .supply_name = "MASSMEMORY_EN", | ||
148 | .microvolts = 2800000, | ||
149 | .gpio = S5PV310_GPE1(3), | ||
150 | .enable_high = true, | ||
151 | .init_data = &mmc0_fixed_voltage_init_data, | ||
152 | }; | ||
153 | |||
154 | static struct platform_device mmc0_fixed_voltage = { | ||
155 | .name = "reg-fixed-voltage", | ||
156 | .id = 0, | ||
157 | .dev = { | ||
158 | .platform_data = &mmc0_fixed_voltage_config, | ||
159 | }, | ||
160 | }; | ||
161 | |||
162 | /* SD */ | ||
163 | static struct s3c_sdhci_platdata universal_hsmmc2_data __initdata = { | ||
164 | .max_width = 4, | ||
165 | .host_caps = MMC_CAP_4_BIT_DATA | | ||
166 | MMC_CAP_MMC_HIGHSPEED | MMC_CAP_SD_HIGHSPEED | | ||
167 | MMC_CAP_DISABLE, | ||
168 | .ext_cd_gpio = S5PV310_GPX3(4), /* XEINT_28 */ | ||
169 | .ext_cd_gpio_invert = 1, | ||
170 | .cd_type = S3C_SDHCI_CD_GPIO, | ||
171 | .clk_type = S3C_SDHCI_CLK_DIV_EXTERNAL, | ||
172 | }; | ||
173 | |||
174 | /* WiFi */ | ||
175 | static struct s3c_sdhci_platdata universal_hsmmc3_data __initdata = { | ||
176 | .max_width = 4, | ||
177 | .host_caps = MMC_CAP_4_BIT_DATA | | ||
178 | MMC_CAP_MMC_HIGHSPEED | MMC_CAP_SD_HIGHSPEED | | ||
179 | MMC_CAP_DISABLE, | ||
180 | .cd_type = S3C_SDHCI_CD_EXTERNAL, | ||
181 | }; | ||
182 | |||
183 | static void __init universal_sdhci_init(void) | ||
184 | { | ||
185 | s3c_sdhci0_set_platdata(&universal_hsmmc0_data); | ||
186 | s3c_sdhci2_set_platdata(&universal_hsmmc2_data); | ||
187 | s3c_sdhci3_set_platdata(&universal_hsmmc3_data); | ||
188 | } | ||
189 | |||
190 | /* I2C0 */ | ||
191 | static struct i2c_board_info i2c0_devs[] __initdata = { | ||
192 | /* Camera, To be updated */ | ||
193 | }; | ||
194 | |||
195 | /* I2C1 */ | ||
196 | static struct i2c_board_info i2c1_devs[] __initdata = { | ||
197 | /* Gyro, To be updated */ | ||
198 | }; | ||
199 | |||
200 | static struct platform_device *universal_devices[] __initdata = { | ||
201 | /* Samsung Platform Devices */ | ||
202 | &mmc0_fixed_voltage, | ||
203 | &s3c_device_hsmmc0, | ||
204 | &s3c_device_hsmmc2, | ||
205 | &s3c_device_hsmmc3, | ||
206 | |||
207 | /* Universal Devices */ | ||
208 | &universal_gpio_keys, | ||
209 | &s5p_device_onenand, | ||
210 | }; | ||
211 | |||
212 | static void __init universal_map_io(void) | ||
213 | { | ||
214 | s5p_init_io(NULL, 0, S5P_VA_CHIPID); | ||
215 | s3c24xx_init_clocks(24000000); | ||
216 | s3c24xx_init_uarts(universal_uartcfgs, ARRAY_SIZE(universal_uartcfgs)); | ||
217 | } | ||
218 | |||
219 | static void __init universal_machine_init(void) | ||
220 | { | ||
221 | universal_sdhci_init(); | ||
222 | |||
223 | i2c_register_board_info(0, i2c0_devs, ARRAY_SIZE(i2c0_devs)); | ||
224 | i2c_register_board_info(1, i2c1_devs, ARRAY_SIZE(i2c1_devs)); | ||
225 | |||
226 | /* Last */ | ||
227 | platform_add_devices(universal_devices, ARRAY_SIZE(universal_devices)); | ||
228 | } | ||
229 | |||
230 | MACHINE_START(UNIVERSAL_C210, "UNIVERSAL_C210") | ||
231 | /* Maintainer: Kyungmin Park <kyungmin.park@samsung.com> */ | ||
232 | .boot_params = S5P_PA_SDRAM + 0x100, | ||
233 | .init_irq = s5pv310_init_irq, | ||
234 | .map_io = universal_map_io, | ||
235 | .init_machine = universal_machine_init, | ||
236 | .timer = &s5pv310_timer, | ||
237 | MACHINE_END | ||
diff --git a/arch/arm/mm/Kconfig b/arch/arm/mm/Kconfig index 2bd4ccfb3538..c2eafd993bc3 100644 --- a/arch/arm/mm/Kconfig +++ b/arch/arm/mm/Kconfig | |||
@@ -812,7 +812,7 @@ config CACHE_L2X0 | |||
812 | bool "Enable the L2x0 outer cache controller" | 812 | bool "Enable the L2x0 outer cache controller" |
813 | depends on REALVIEW_EB_ARM11MP || MACH_REALVIEW_PB11MP || MACH_REALVIEW_PB1176 || \ | 813 | depends on REALVIEW_EB_ARM11MP || MACH_REALVIEW_PB11MP || MACH_REALVIEW_PB1176 || \ |
814 | REALVIEW_EB_A9MP || SOC_IMX35 || SOC_IMX31 || MACH_REALVIEW_PBX || \ | 814 | REALVIEW_EB_A9MP || SOC_IMX35 || SOC_IMX31 || MACH_REALVIEW_PBX || \ |
815 | ARCH_NOMADIK || ARCH_OMAP4 || ARCH_S5PV310 || ARCH_TEGRA || \ | 815 | ARCH_NOMADIK || ARCH_OMAP4 || ARCH_EXYNOS4 || ARCH_TEGRA || \ |
816 | ARCH_U8500 || ARCH_VEXPRESS_CA9X4 || ARCH_SHMOBILE | 816 | ARCH_U8500 || ARCH_VEXPRESS_CA9X4 || ARCH_SHMOBILE |
817 | default y | 817 | default y |
818 | select OUTER_CACHE | 818 | select OUTER_CACHE |
diff --git a/arch/arm/plat-s3c24xx/Kconfig b/arch/arm/plat-s3c24xx/Kconfig index eb105e61c746..d9c4096ebf45 100644 --- a/arch/arm/plat-s3c24xx/Kconfig +++ b/arch/arm/plat-s3c24xx/Kconfig | |||
@@ -56,13 +56,6 @@ config S3C24XX_DCLK | |||
56 | help | 56 | help |
57 | Clock code for supporting DCLK/CLKOUT on S3C24XX architectures | 57 | Clock code for supporting DCLK/CLKOUT on S3C24XX architectures |
58 | 58 | ||
59 | config S3C24XX_PWM | ||
60 | bool "PWM device support" | ||
61 | select HAVE_PWM | ||
62 | help | ||
63 | Support for exporting the PWM timer blocks via the pwm device | ||
64 | system. | ||
65 | |||
66 | # gpio configurations | 59 | # gpio configurations |
67 | 60 | ||
68 | config S3C24XX_GPIO_EXTRA | 61 | config S3C24XX_GPIO_EXTRA |
diff --git a/arch/arm/plat-s5p/Kconfig b/arch/arm/plat-s5p/Kconfig index 557f8c507f6d..849229716586 100644 --- a/arch/arm/plat-s5p/Kconfig +++ b/arch/arm/plat-s5p/Kconfig | |||
@@ -7,10 +7,10 @@ | |||
7 | 7 | ||
8 | config PLAT_S5P | 8 | config PLAT_S5P |
9 | bool | 9 | bool |
10 | depends on (ARCH_S5P64X0 || ARCH_S5P6442 || ARCH_S5PC100 || ARCH_S5PV210 || ARCH_S5PV310) | 10 | depends on (ARCH_S5P64X0 || ARCH_S5P6442 || ARCH_S5PC100 || ARCH_S5PV210 || ARCH_EXYNOS4) |
11 | default y | 11 | default y |
12 | select ARM_VIC if !ARCH_S5PV310 | 12 | select ARM_VIC if !ARCH_EXYNOS4 |
13 | select ARM_GIC if ARCH_S5PV310 | 13 | select ARM_GIC if ARCH_EXYNOS4 |
14 | select NO_IOPORT | 14 | select NO_IOPORT |
15 | select ARCH_REQUIRE_GPIOLIB | 15 | select ARCH_REQUIRE_GPIOLIB |
16 | select S3C_GPIO_TRACK | 16 | select S3C_GPIO_TRACK |
@@ -37,11 +37,16 @@ config S5P_GPIO_INT | |||
37 | help | 37 | help |
38 | Common code for the GPIO interrupts (other than external interrupts.) | 38 | Common code for the GPIO interrupts (other than external interrupts.) |
39 | 39 | ||
40 | config S5P_HRT | ||
41 | bool | ||
42 | help | ||
43 | Use the High Resolution timer support | ||
44 | |||
40 | comment "System MMU" | 45 | comment "System MMU" |
41 | 46 | ||
42 | config S5P_SYSTEM_MMU | 47 | config S5P_SYSTEM_MMU |
43 | bool "S5P SYSTEM MMU" | 48 | bool "S5P SYSTEM MMU" |
44 | depends on ARCH_S5PV310 | 49 | depends on ARCH_EXYNOS4 |
45 | help | 50 | help |
46 | Say Y here if you want to enable System MMU | 51 | Say Y here if you want to enable System MMU |
47 | 52 | ||
@@ -60,6 +65,11 @@ config S5P_DEV_FIMC2 | |||
60 | help | 65 | help |
61 | Compile in platform device definitions for FIMC controller 2 | 66 | Compile in platform device definitions for FIMC controller 2 |
62 | 67 | ||
68 | config S5P_DEV_FIMC3 | ||
69 | bool | ||
70 | help | ||
71 | Compile in platform device definitions for FIMC controller 3 | ||
72 | |||
63 | config S5P_DEV_ONENAND | 73 | config S5P_DEV_ONENAND |
64 | bool | 74 | bool |
65 | help | 75 | help |
@@ -74,3 +84,8 @@ config S5P_DEV_CSIS1 | |||
74 | bool | 84 | bool |
75 | help | 85 | help |
76 | Compile in platform device definitions for MIPI-CSIS channel 1 | 86 | Compile in platform device definitions for MIPI-CSIS channel 1 |
87 | |||
88 | config S5P_SETUP_MIPIPHY | ||
89 | bool | ||
90 | help | ||
91 | Compile in common setup code for MIPI-CSIS and MIPI-DSIM devices | ||
diff --git a/arch/arm/plat-s5p/Makefile b/arch/arm/plat-s5p/Makefile index 4bd5cf908977..42afff7f60be 100644 --- a/arch/arm/plat-s5p/Makefile +++ b/arch/arm/plat-s5p/Makefile | |||
@@ -22,12 +22,15 @@ obj-$(CONFIG_S5P_GPIO_INT) += irq-gpioint.o | |||
22 | obj-$(CONFIG_S5P_SYSTEM_MMU) += sysmmu.o | 22 | obj-$(CONFIG_S5P_SYSTEM_MMU) += sysmmu.o |
23 | obj-$(CONFIG_PM) += pm.o | 23 | obj-$(CONFIG_PM) += pm.o |
24 | obj-$(CONFIG_PM) += irq-pm.o | 24 | obj-$(CONFIG_PM) += irq-pm.o |
25 | obj-$(CONFIG_S5P_HRT) += s5p-time.o | ||
25 | 26 | ||
26 | # devices | 27 | # devices |
27 | 28 | ||
28 | obj-$(CONFIG_S5P_DEV_FIMC0) += dev-fimc0.o | 29 | obj-$(CONFIG_S5P_DEV_FIMC0) += dev-fimc0.o |
29 | obj-$(CONFIG_S5P_DEV_FIMC1) += dev-fimc1.o | 30 | obj-$(CONFIG_S5P_DEV_FIMC1) += dev-fimc1.o |
30 | obj-$(CONFIG_S5P_DEV_FIMC2) += dev-fimc2.o | 31 | obj-$(CONFIG_S5P_DEV_FIMC2) += dev-fimc2.o |
32 | obj-$(CONFIG_S5P_DEV_FIMC3) += dev-fimc3.o | ||
31 | obj-$(CONFIG_S5P_DEV_ONENAND) += dev-onenand.o | 33 | obj-$(CONFIG_S5P_DEV_ONENAND) += dev-onenand.o |
32 | obj-$(CONFIG_S5P_DEV_CSIS0) += dev-csis0.o | 34 | obj-$(CONFIG_S5P_DEV_CSIS0) += dev-csis0.o |
33 | obj-$(CONFIG_S5P_DEV_CSIS1) += dev-csis1.o | 35 | obj-$(CONFIG_S5P_DEV_CSIS1) += dev-csis1.o |
36 | obj-$(CONFIG_S5P_SETUP_MIPIPHY) += setup-mipiphy.o | ||
diff --git a/arch/arm/plat-s5p/cpu.c b/arch/arm/plat-s5p/cpu.c index 047d31c1bbd8..c3bfe9b13acf 100644 --- a/arch/arm/plat-s5p/cpu.c +++ b/arch/arm/plat-s5p/cpu.c | |||
@@ -1,7 +1,7 @@ | |||
1 | /* linux/arch/arm/plat-s5p/cpu.c | 1 | /* linux/arch/arm/plat-s5p/cpu.c |
2 | * | 2 | * |
3 | * Copyright (c) 2009 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2009-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com/ | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * S5P CPU Support | 6 | * S5P CPU Support |
7 | * | 7 | * |
@@ -12,17 +12,20 @@ | |||
12 | 12 | ||
13 | #include <linux/init.h> | 13 | #include <linux/init.h> |
14 | #include <linux/module.h> | 14 | #include <linux/module.h> |
15 | #include <mach/map.h> | 15 | |
16 | #include <asm/mach/arch.h> | 16 | #include <asm/mach/arch.h> |
17 | #include <asm/mach/map.h> | 17 | #include <asm/mach/map.h> |
18 | |||
19 | #include <mach/map.h> | ||
18 | #include <mach/regs-clock.h> | 20 | #include <mach/regs-clock.h> |
21 | |||
19 | #include <plat/cpu.h> | 22 | #include <plat/cpu.h> |
20 | #include <plat/s5p6440.h> | 23 | #include <plat/s5p6440.h> |
21 | #include <plat/s5p6442.h> | 24 | #include <plat/s5p6442.h> |
22 | #include <plat/s5p6450.h> | 25 | #include <plat/s5p6450.h> |
23 | #include <plat/s5pc100.h> | 26 | #include <plat/s5pc100.h> |
24 | #include <plat/s5pv210.h> | 27 | #include <plat/s5pv210.h> |
25 | #include <plat/s5pv310.h> | 28 | #include <plat/exynos4.h> |
26 | 29 | ||
27 | /* table of supported CPUs */ | 30 | /* table of supported CPUs */ |
28 | 31 | ||
@@ -31,7 +34,7 @@ static const char name_s5p6442[] = "S5P6442"; | |||
31 | static const char name_s5p6450[] = "S5P6450"; | 34 | static const char name_s5p6450[] = "S5P6450"; |
32 | static const char name_s5pc100[] = "S5PC100"; | 35 | static const char name_s5pc100[] = "S5PC100"; |
33 | static const char name_s5pv210[] = "S5PV210/S5PC110"; | 36 | static const char name_s5pv210[] = "S5PV210/S5PC110"; |
34 | static const char name_s5pv310[] = "S5PV310"; | 37 | static const char name_exynos4210[] = "EXYNOS4210"; |
35 | 38 | ||
36 | static struct cpu_table cpu_ids[] __initdata = { | 39 | static struct cpu_table cpu_ids[] __initdata = { |
37 | { | 40 | { |
@@ -75,13 +78,13 @@ static struct cpu_table cpu_ids[] __initdata = { | |||
75 | .init = s5pv210_init, | 78 | .init = s5pv210_init, |
76 | .name = name_s5pv210, | 79 | .name = name_s5pv210, |
77 | }, { | 80 | }, { |
78 | .idcode = 0x43200000, | 81 | .idcode = 0x43210000, |
79 | .idmask = 0xfffff000, | 82 | .idmask = 0xfffff000, |
80 | .map_io = s5pv310_map_io, | 83 | .map_io = exynos4_map_io, |
81 | .init_clocks = s5pv310_init_clocks, | 84 | .init_clocks = exynos4_init_clocks, |
82 | .init_uarts = s5pv310_init_uarts, | 85 | .init_uarts = exynos4_init_uarts, |
83 | .init = s5pv310_init, | 86 | .init = exynos4_init, |
84 | .name = name_s5pv310, | 87 | .name = name_exynos4210, |
85 | }, | 88 | }, |
86 | }; | 89 | }; |
87 | 90 | ||
diff --git a/arch/arm/plat-s5p/dev-csis0.c b/arch/arm/plat-s5p/dev-csis0.c index dfab1c85f54f..e3aabef5e347 100644 --- a/arch/arm/plat-s5p/dev-csis0.c +++ b/arch/arm/plat-s5p/dev-csis0.c | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * Copyright (C) 2010 Samsung Electronics | 2 | * Copyright (C) 2010-2011 Samsung Electronics Co., Ltd. |
3 | * | 3 | * |
4 | * S5P series device definition for MIPI-CSIS channel 0 | 4 | * S5P series device definition for MIPI-CSIS channel 0 |
5 | * | 5 | * |
diff --git a/arch/arm/plat-s5p/dev-csis1.c b/arch/arm/plat-s5p/dev-csis1.c index e3053f27fbbf..08b91b580207 100644 --- a/arch/arm/plat-s5p/dev-csis1.c +++ b/arch/arm/plat-s5p/dev-csis1.c | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * Copyright (C) 2010 Samsung Electronics | 2 | * Copyright (C) 2010-2011 Samsung Electronics Co., Ltd. |
3 | * | 3 | * |
4 | * S5P series device definition for MIPI-CSIS channel 1 | 4 | * S5P series device definition for MIPI-CSIS channel 1 |
5 | * | 5 | * |
diff --git a/arch/arm/plat-s5p/dev-fimc3.c b/arch/arm/plat-s5p/dev-fimc3.c new file mode 100644 index 000000000000..ef31beca386c --- /dev/null +++ b/arch/arm/plat-s5p/dev-fimc3.c | |||
@@ -0,0 +1,43 @@ | |||
1 | /* linux/arch/arm/plat-s5p/dev-fimc3.c | ||
2 | * | ||
3 | * Copyright (c) 2010 Samsung Electronics | ||
4 | * | ||
5 | * Base S5P FIMC3 resource and device definitions | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License version 2 as | ||
9 | * published by the Free Software Foundation. | ||
10 | */ | ||
11 | |||
12 | #include <linux/kernel.h> | ||
13 | #include <linux/dma-mapping.h> | ||
14 | #include <linux/platform_device.h> | ||
15 | #include <linux/interrupt.h> | ||
16 | #include <linux/ioport.h> | ||
17 | #include <mach/map.h> | ||
18 | |||
19 | static struct resource s5p_fimc3_resource[] = { | ||
20 | [0] = { | ||
21 | .start = S5P_PA_FIMC3, | ||
22 | .end = S5P_PA_FIMC3 + SZ_4K - 1, | ||
23 | .flags = IORESOURCE_MEM, | ||
24 | }, | ||
25 | [1] = { | ||
26 | .start = IRQ_FIMC3, | ||
27 | .end = IRQ_FIMC3, | ||
28 | .flags = IORESOURCE_IRQ, | ||
29 | }, | ||
30 | }; | ||
31 | |||
32 | static u64 s5p_fimc3_dma_mask = DMA_BIT_MASK(32); | ||
33 | |||
34 | struct platform_device s5p_device_fimc3 = { | ||
35 | .name = "s5p-fimc", | ||
36 | .id = 3, | ||
37 | .num_resources = ARRAY_SIZE(s5p_fimc3_resource), | ||
38 | .resource = s5p_fimc3_resource, | ||
39 | .dev = { | ||
40 | .dma_mask = &s5p_fimc3_dma_mask, | ||
41 | .coherent_dma_mask = DMA_BIT_MASK(32), | ||
42 | }, | ||
43 | }; | ||
diff --git a/arch/arm/plat-s5p/include/plat/camport.h b/arch/arm/plat-s5p/include/plat/camport.h new file mode 100644 index 000000000000..71688c8ba288 --- /dev/null +++ b/arch/arm/plat-s5p/include/plat/camport.h | |||
@@ -0,0 +1,28 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2011 Samsung Electronics Co., Ltd. | ||
3 | * | ||
4 | * S5P series camera interface helper functions | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | |||
11 | #ifndef PLAT_S5P_CAMPORT_H_ | ||
12 | #define PLAT_S5P_CAMPORT_H_ __FILE__ | ||
13 | |||
14 | enum s5p_camport_id { | ||
15 | S5P_CAMPORT_A, | ||
16 | S5P_CAMPORT_B, | ||
17 | }; | ||
18 | |||
19 | /* | ||
20 | * The helper functions to configure GPIO for the camera parallel bus. | ||
21 | * The camera port can be multiplexed with any FIMC entity, even multiple | ||
22 | * FIMC entities are allowed to be attached to a single port simultaneously. | ||
23 | * These functions are to be used in the board setup code. | ||
24 | */ | ||
25 | int s5pv210_fimc_setup_gpio(enum s5p_camport_id id); | ||
26 | int exynos4_fimc_setup_gpio(enum s5p_camport_id id); | ||
27 | |||
28 | #endif | ||
diff --git a/arch/arm/plat-s5p/include/plat/csis.h b/arch/arm/plat-s5p/include/plat/csis.h deleted file mode 100644 index 51e308c7981d..000000000000 --- a/arch/arm/plat-s5p/include/plat/csis.h +++ /dev/null | |||
@@ -1,28 +0,0 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2010 Samsung Electronics | ||
3 | * | ||
4 | * S5P series MIPI CSI slave device support | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | |||
11 | #ifndef PLAT_S5P_CSIS_H_ | ||
12 | #define PLAT_S5P_CSIS_H_ __FILE__ | ||
13 | |||
14 | /** | ||
15 | * struct s5p_platform_mipi_csis - platform data for MIPI-CSIS | ||
16 | * @clk_rate: bus clock frequency | ||
17 | * @lanes: number of data lanes used | ||
18 | * @alignment: data alignment in bits | ||
19 | * @hs_settle: HS-RX settle time | ||
20 | */ | ||
21 | struct s5p_platform_mipi_csis { | ||
22 | unsigned long clk_rate; | ||
23 | u8 lanes; | ||
24 | u8 alignment; | ||
25 | u8 hs_settle; | ||
26 | }; | ||
27 | |||
28 | #endif /* PLAT_S5P_CSIS_H_ */ | ||
diff --git a/arch/arm/plat-s5p/include/plat/exynos4.h b/arch/arm/plat-s5p/include/plat/exynos4.h new file mode 100644 index 000000000000..907caab53dcf --- /dev/null +++ b/arch/arm/plat-s5p/include/plat/exynos4.h | |||
@@ -0,0 +1,34 @@ | |||
1 | /* linux/arch/arm/plat-s5p/include/plat/exynos4.h | ||
2 | * | ||
3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * Header file for exynos4 cpu support | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | /* Common init code for EXYNOS4 related SoCs */ | ||
14 | |||
15 | extern void exynos4_common_init_uarts(struct s3c2410_uartcfg *cfg, int no); | ||
16 | extern void exynos4_register_clocks(void); | ||
17 | extern void exynos4_setup_clocks(void); | ||
18 | |||
19 | #ifdef CONFIG_CPU_EXYNOS4210 | ||
20 | |||
21 | extern int exynos4_init(void); | ||
22 | extern void exynos4_init_irq(void); | ||
23 | extern void exynos4_map_io(void); | ||
24 | extern void exynos4_init_clocks(int xtal); | ||
25 | extern struct sys_timer exynos4_timer; | ||
26 | |||
27 | #define exynos4_init_uarts exynos4_common_init_uarts | ||
28 | |||
29 | #else | ||
30 | #define exynos4_init_clocks NULL | ||
31 | #define exynos4_init_uarts NULL | ||
32 | #define exynos4_map_io NULL | ||
33 | #define exynos4_init NULL | ||
34 | #endif | ||
diff --git a/arch/arm/plat-s5p/include/plat/mipi_csis.h b/arch/arm/plat-s5p/include/plat/mipi_csis.h new file mode 100644 index 000000000000..9bd254c5ed22 --- /dev/null +++ b/arch/arm/plat-s5p/include/plat/mipi_csis.h | |||
@@ -0,0 +1,43 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2010-2011 Samsung Electronics Co., Ltd. | ||
3 | * | ||
4 | * S5P series MIPI CSI slave device support | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | |||
11 | #ifndef PLAT_S5P_MIPI_CSIS_H_ | ||
12 | #define PLAT_S5P_MIPI_CSIS_H_ __FILE__ | ||
13 | |||
14 | struct platform_device; | ||
15 | |||
16 | /** | ||
17 | * struct s5p_platform_mipi_csis - platform data for S5P MIPI-CSIS driver | ||
18 | * @clk_rate: bus clock frequency | ||
19 | * @lanes: number of data lanes used | ||
20 | * @alignment: data alignment in bits | ||
21 | * @hs_settle: HS-RX settle time | ||
22 | * @fixed_phy_vdd: false to enable external D-PHY regulator management in the | ||
23 | * driver or true in case this regulator has no enable function | ||
24 | * @phy_enable: pointer to a callback controlling D-PHY enable/reset | ||
25 | */ | ||
26 | struct s5p_platform_mipi_csis { | ||
27 | unsigned long clk_rate; | ||
28 | u8 lanes; | ||
29 | u8 alignment; | ||
30 | u8 hs_settle; | ||
31 | bool fixed_phy_vdd; | ||
32 | int (*phy_enable)(struct platform_device *pdev, bool on); | ||
33 | }; | ||
34 | |||
35 | /** | ||
36 | * s5p_csis_phy_enable - global MIPI-CSI receiver D-PHY control | ||
37 | * @pdev: MIPI-CSIS platform device | ||
38 | * @on: true to enable D-PHY and deassert its reset | ||
39 | * false to disable D-PHY | ||
40 | */ | ||
41 | int s5p_csis_phy_enable(struct platform_device *pdev, bool on); | ||
42 | |||
43 | #endif /* PLAT_S5P_MIPI_CSIS_H_ */ | ||
diff --git a/arch/arm/plat-s5p/include/plat/s5p-time.h b/arch/arm/plat-s5p/include/plat/s5p-time.h new file mode 100644 index 000000000000..575e88109db8 --- /dev/null +++ b/arch/arm/plat-s5p/include/plat/s5p-time.h | |||
@@ -0,0 +1,40 @@ | |||
1 | /* linux/arch/arm/plat-s5p/include/plat/s5p-time.h | ||
2 | * | ||
3 | * Copyright 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com/ | ||
5 | * | ||
6 | * Header file for s5p time support | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __ASM_PLAT_S5P_TIME_H | ||
14 | #define __ASM_PLAT_S5P_TIME_H __FILE__ | ||
15 | |||
16 | /* S5P HR-Timer Clock mode */ | ||
17 | enum s5p_timer_mode { | ||
18 | S5P_PWM0, | ||
19 | S5P_PWM1, | ||
20 | S5P_PWM2, | ||
21 | S5P_PWM3, | ||
22 | S5P_PWM4, | ||
23 | }; | ||
24 | |||
25 | struct s5p_timer_source { | ||
26 | unsigned int event_id; | ||
27 | unsigned int source_id; | ||
28 | }; | ||
29 | |||
30 | /* Be able to sleep for atleast 4 seconds (usually more) */ | ||
31 | #define S5PTIMER_MIN_RANGE 4 | ||
32 | |||
33 | #define TCNT_MAX 0xffffffff | ||
34 | #define NON_PERIODIC 0 | ||
35 | #define PERIODIC 1 | ||
36 | |||
37 | extern void __init s5p_set_timer_source(enum s5p_timer_mode event, | ||
38 | enum s5p_timer_mode source); | ||
39 | extern struct sys_timer s5p_timer; | ||
40 | #endif /* __ASM_PLAT_S5P_TIME_H */ | ||
diff --git a/arch/arm/plat-s5p/include/plat/s5pv310.h b/arch/arm/plat-s5p/include/plat/s5pv310.h deleted file mode 100644 index 769c991ceb37..000000000000 --- a/arch/arm/plat-s5p/include/plat/s5pv310.h +++ /dev/null | |||
@@ -1,34 +0,0 @@ | |||
1 | /* linux/arch/arm/plat-s5p/include/plat/s5pv310.h | ||
2 | * | ||
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com/ | ||
5 | * | ||
6 | * Header file for s5pv310 cpu support | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | /* Common init code for S5PV310 related SoCs */ | ||
14 | |||
15 | extern void s5pv310_common_init_uarts(struct s3c2410_uartcfg *cfg, int no); | ||
16 | extern void s5pv310_register_clocks(void); | ||
17 | extern void s5pv310_setup_clocks(void); | ||
18 | |||
19 | #ifdef CONFIG_CPU_S5PV310 | ||
20 | |||
21 | extern int s5pv310_init(void); | ||
22 | extern void s5pv310_init_irq(void); | ||
23 | extern void s5pv310_map_io(void); | ||
24 | extern void s5pv310_init_clocks(int xtal); | ||
25 | extern struct sys_timer s5pv310_timer; | ||
26 | |||
27 | #define s5pv310_init_uarts s5pv310_common_init_uarts | ||
28 | |||
29 | #else | ||
30 | #define s5pv310_init_clocks NULL | ||
31 | #define s5pv310_init_uarts NULL | ||
32 | #define s5pv310_map_io NULL | ||
33 | #define s5pv310_init NULL | ||
34 | #endif | ||
diff --git a/arch/arm/plat-s5p/include/plat/sysmmu.h b/arch/arm/plat-s5p/include/plat/sysmmu.h new file mode 100644 index 000000000000..bf5283c2a19d --- /dev/null +++ b/arch/arm/plat-s5p/include/plat/sysmmu.h | |||
@@ -0,0 +1,95 @@ | |||
1 | /* linux/arch/arm/plat-s5p/include/plat/sysmmu.h | ||
2 | * | ||
3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * Samsung System MMU driver for S5P platform | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __ASM__PLAT_SYSMMU_H | ||
14 | #define __ASM__PLAT_SYSMMU_H __FILE__ | ||
15 | |||
16 | enum S5P_SYSMMU_INTERRUPT_TYPE { | ||
17 | SYSMMU_PAGEFAULT, | ||
18 | SYSMMU_AR_MULTIHIT, | ||
19 | SYSMMU_AW_MULTIHIT, | ||
20 | SYSMMU_BUSERROR, | ||
21 | SYSMMU_AR_SECURITY, | ||
22 | SYSMMU_AR_ACCESS, | ||
23 | SYSMMU_AW_SECURITY, | ||
24 | SYSMMU_AW_PROTECTION, /* 7 */ | ||
25 | SYSMMU_FAULTS_NUM | ||
26 | }; | ||
27 | |||
28 | #ifdef CONFIG_S5P_SYSTEM_MMU | ||
29 | |||
30 | #include <mach/sysmmu.h> | ||
31 | |||
32 | /** | ||
33 | * s5p_sysmmu_enable() - enable system mmu of ip | ||
34 | * @ips: The ip connected system mmu. | ||
35 | * #pgd: Base physical address of the 1st level page table | ||
36 | * | ||
37 | * This function enable system mmu to transfer address | ||
38 | * from virtual address to physical address | ||
39 | */ | ||
40 | void s5p_sysmmu_enable(sysmmu_ips ips, unsigned long pgd); | ||
41 | |||
42 | /** | ||
43 | * s5p_sysmmu_disable() - disable sysmmu mmu of ip | ||
44 | * @ips: The ip connected system mmu. | ||
45 | * | ||
46 | * This function disable system mmu to transfer address | ||
47 | * from virtual address to physical address | ||
48 | */ | ||
49 | void s5p_sysmmu_disable(sysmmu_ips ips); | ||
50 | |||
51 | /** | ||
52 | * s5p_sysmmu_set_tablebase_pgd() - set page table base address to refer page table | ||
53 | * @ips: The ip connected system mmu. | ||
54 | * @pgd: The page table base address. | ||
55 | * | ||
56 | * This function set page table base address | ||
57 | * When system mmu transfer address from virtaul address to physical address, | ||
58 | * system mmu refer address information from page table | ||
59 | */ | ||
60 | void s5p_sysmmu_set_tablebase_pgd(sysmmu_ips ips, unsigned long pgd); | ||
61 | |||
62 | /** | ||
63 | * s5p_sysmmu_tlb_invalidate() - flush all TLB entry in system mmu | ||
64 | * @ips: The ip connected system mmu. | ||
65 | * | ||
66 | * This function flush all TLB entry in system mmu | ||
67 | */ | ||
68 | void s5p_sysmmu_tlb_invalidate(sysmmu_ips ips); | ||
69 | |||
70 | /** s5p_sysmmu_set_fault_handler() - Fault handler for System MMUs | ||
71 | * @itype: type of fault. | ||
72 | * @pgtable_base: the physical address of page table base. This is 0 if @ips is | ||
73 | * SYSMMU_BUSERROR. | ||
74 | * @fault_addr: the device (virtual) address that the System MMU tried to | ||
75 | * translated. This is 0 if @ips is SYSMMU_BUSERROR. | ||
76 | * Called when interrupt occurred by the System MMUs | ||
77 | * The device drivers of peripheral devices that has a System MMU can implement | ||
78 | * a fault handler to resolve address translation fault by System MMU. | ||
79 | * The meanings of return value and parameters are described below. | ||
80 | |||
81 | * return value: non-zero if the fault is correctly resolved. | ||
82 | * zero if the fault is not handled. | ||
83 | */ | ||
84 | void s5p_sysmmu_set_fault_handler(sysmmu_ips ips, | ||
85 | int (*handler)(enum S5P_SYSMMU_INTERRUPT_TYPE itype, | ||
86 | unsigned long pgtable_base, | ||
87 | unsigned long fault_addr)); | ||
88 | #else | ||
89 | #define s5p_sysmmu_enable(ips, pgd) do { } while (0) | ||
90 | #define s5p_sysmmu_disable(ips) do { } while (0) | ||
91 | #define s5p_sysmmu_set_tablebase_pgd(ips, pgd) do { } while (0) | ||
92 | #define s5p_sysmmu_tlb_invalidate(ips) do { } while (0) | ||
93 | #define s5p_sysmmu_set_fault_handler(ips, handler) do { } while (0) | ||
94 | #endif | ||
95 | #endif /* __ASM_PLAT_SYSMMU_H */ | ||
diff --git a/arch/arm/plat-s5p/irq-gpioint.c b/arch/arm/plat-s5p/irq-gpioint.c index 3b6bf89d1739..cd87d3256e03 100644 --- a/arch/arm/plat-s5p/irq-gpioint.c +++ b/arch/arm/plat-s5p/irq-gpioint.c | |||
@@ -17,82 +17,79 @@ | |||
17 | #include <linux/irq.h> | 17 | #include <linux/irq.h> |
18 | #include <linux/io.h> | 18 | #include <linux/io.h> |
19 | #include <linux/gpio.h> | 19 | #include <linux/gpio.h> |
20 | #include <linux/slab.h> | ||
20 | 21 | ||
21 | #include <mach/map.h> | 22 | #include <mach/map.h> |
22 | #include <plat/gpio-core.h> | 23 | #include <plat/gpio-core.h> |
23 | #include <plat/gpio-cfg.h> | 24 | #include <plat/gpio-cfg.h> |
24 | 25 | ||
25 | #define S5P_GPIOREG(x) (S5P_VA_GPIO + (x)) | 26 | #define GPIO_BASE(chip) (((unsigned long)(chip)->base) & 0xFFFFF000u) |
26 | 27 | ||
27 | #define GPIOINT_CON_OFFSET 0x700 | 28 | #define CON_OFFSET 0x700 |
28 | #define GPIOINT_MASK_OFFSET 0x900 | 29 | #define MASK_OFFSET 0x900 |
29 | #define GPIOINT_PEND_OFFSET 0xA00 | 30 | #define PEND_OFFSET 0xA00 |
31 | #define REG_OFFSET(x) ((x) << 2) | ||
30 | 32 | ||
31 | static struct s3c_gpio_chip *irq_chips[S5P_GPIOINT_GROUP_MAXNR]; | 33 | struct s5p_gpioint_bank { |
32 | 34 | struct list_head list; | |
33 | static int s5p_gpioint_get_group(struct irq_data *data) | 35 | int start; |
34 | { | 36 | int nr_groups; |
35 | struct gpio_chip *chip = irq_data_get_irq_data(data); | 37 | int irq; |
36 | struct s3c_gpio_chip *s3c_chip = container_of(chip, | 38 | struct s3c_gpio_chip **chips; |
37 | struct s3c_gpio_chip, chip); | 39 | void (*handler)(unsigned int, struct irq_desc *); |
38 | int group; | 40 | }; |
39 | |||
40 | for (group = 0; group < S5P_GPIOINT_GROUP_MAXNR; group++) | ||
41 | if (s3c_chip == irq_chips[group]) | ||
42 | break; | ||
43 | 41 | ||
44 | return group; | 42 | LIST_HEAD(banks); |
45 | } | ||
46 | 43 | ||
47 | static int s5p_gpioint_get_offset(struct irq_data *data) | 44 | static int s5p_gpioint_get_offset(struct irq_data *data) |
48 | { | 45 | { |
49 | struct gpio_chip *chip = irq_data_get_irq_data(data); | 46 | struct s3c_gpio_chip *chip = irq_data_get_irq_data(data); |
50 | struct s3c_gpio_chip *s3c_chip = container_of(chip, | 47 | return data->irq - chip->irq_base; |
51 | struct s3c_gpio_chip, chip); | ||
52 | |||
53 | return data->irq - s3c_chip->irq_base; | ||
54 | } | 48 | } |
55 | 49 | ||
56 | static void s5p_gpioint_ack(struct irq_data *data) | 50 | static void s5p_gpioint_ack(struct irq_data *data) |
57 | { | 51 | { |
52 | struct s3c_gpio_chip *chip = irq_data_get_irq_data(data); | ||
58 | int group, offset, pend_offset; | 53 | int group, offset, pend_offset; |
59 | unsigned int value; | 54 | unsigned int value; |
60 | 55 | ||
61 | group = s5p_gpioint_get_group(data); | 56 | group = chip->group; |
62 | offset = s5p_gpioint_get_offset(data); | 57 | offset = s5p_gpioint_get_offset(data); |
63 | pend_offset = group << 2; | 58 | pend_offset = REG_OFFSET(group); |
64 | 59 | ||
65 | value = __raw_readl(S5P_GPIOREG(GPIOINT_PEND_OFFSET) + pend_offset); | 60 | value = __raw_readl(GPIO_BASE(chip) + PEND_OFFSET + pend_offset); |
66 | value |= 1 << offset; | 61 | value |= BIT(offset); |
67 | __raw_writel(value, S5P_GPIOREG(GPIOINT_PEND_OFFSET) + pend_offset); | 62 | __raw_writel(value, GPIO_BASE(chip) + PEND_OFFSET + pend_offset); |
68 | } | 63 | } |
69 | 64 | ||
70 | static void s5p_gpioint_mask(struct irq_data *data) | 65 | static void s5p_gpioint_mask(struct irq_data *data) |
71 | { | 66 | { |
67 | struct s3c_gpio_chip *chip = irq_data_get_irq_data(data); | ||
72 | int group, offset, mask_offset; | 68 | int group, offset, mask_offset; |
73 | unsigned int value; | 69 | unsigned int value; |
74 | 70 | ||
75 | group = s5p_gpioint_get_group(data); | 71 | group = chip->group; |
76 | offset = s5p_gpioint_get_offset(data); | 72 | offset = s5p_gpioint_get_offset(data); |
77 | mask_offset = group << 2; | 73 | mask_offset = REG_OFFSET(group); |
78 | 74 | ||
79 | value = __raw_readl(S5P_GPIOREG(GPIOINT_MASK_OFFSET) + mask_offset); | 75 | value = __raw_readl(GPIO_BASE(chip) + MASK_OFFSET + mask_offset); |
80 | value |= 1 << offset; | 76 | value |= BIT(offset); |
81 | __raw_writel(value, S5P_GPIOREG(GPIOINT_MASK_OFFSET) + mask_offset); | 77 | __raw_writel(value, GPIO_BASE(chip) + MASK_OFFSET + mask_offset); |
82 | } | 78 | } |
83 | 79 | ||
84 | static void s5p_gpioint_unmask(struct irq_data *data) | 80 | static void s5p_gpioint_unmask(struct irq_data *data) |
85 | { | 81 | { |
82 | struct s3c_gpio_chip *chip = irq_data_get_irq_data(data); | ||
86 | int group, offset, mask_offset; | 83 | int group, offset, mask_offset; |
87 | unsigned int value; | 84 | unsigned int value; |
88 | 85 | ||
89 | group = s5p_gpioint_get_group(data); | 86 | group = chip->group; |
90 | offset = s5p_gpioint_get_offset(data); | 87 | offset = s5p_gpioint_get_offset(data); |
91 | mask_offset = group << 2; | 88 | mask_offset = REG_OFFSET(group); |
92 | 89 | ||
93 | value = __raw_readl(S5P_GPIOREG(GPIOINT_MASK_OFFSET) + mask_offset); | 90 | value = __raw_readl(GPIO_BASE(chip) + MASK_OFFSET + mask_offset); |
94 | value &= ~(1 << offset); | 91 | value &= ~BIT(offset); |
95 | __raw_writel(value, S5P_GPIOREG(GPIOINT_MASK_OFFSET) + mask_offset); | 92 | __raw_writel(value, GPIO_BASE(chip) + MASK_OFFSET + mask_offset); |
96 | } | 93 | } |
97 | 94 | ||
98 | static void s5p_gpioint_mask_ack(struct irq_data *data) | 95 | static void s5p_gpioint_mask_ack(struct irq_data *data) |
@@ -103,12 +100,13 @@ static void s5p_gpioint_mask_ack(struct irq_data *data) | |||
103 | 100 | ||
104 | static int s5p_gpioint_set_type(struct irq_data *data, unsigned int type) | 101 | static int s5p_gpioint_set_type(struct irq_data *data, unsigned int type) |
105 | { | 102 | { |
103 | struct s3c_gpio_chip *chip = irq_data_get_irq_data(data); | ||
106 | int group, offset, con_offset; | 104 | int group, offset, con_offset; |
107 | unsigned int value; | 105 | unsigned int value; |
108 | 106 | ||
109 | group = s5p_gpioint_get_group(data); | 107 | group = chip->group; |
110 | offset = s5p_gpioint_get_offset(data); | 108 | offset = s5p_gpioint_get_offset(data); |
111 | con_offset = group << 2; | 109 | con_offset = REG_OFFSET(group); |
112 | 110 | ||
113 | switch (type) { | 111 | switch (type) { |
114 | case IRQ_TYPE_EDGE_RISING: | 112 | case IRQ_TYPE_EDGE_RISING: |
@@ -132,15 +130,15 @@ static int s5p_gpioint_set_type(struct irq_data *data, unsigned int type) | |||
132 | return -EINVAL; | 130 | return -EINVAL; |
133 | } | 131 | } |
134 | 132 | ||
135 | value = __raw_readl(S5P_GPIOREG(GPIOINT_CON_OFFSET) + con_offset); | 133 | value = __raw_readl(GPIO_BASE(chip) + CON_OFFSET + con_offset); |
136 | value &= ~(0x7 << (offset * 0x4)); | 134 | value &= ~(0x7 << (offset * 0x4)); |
137 | value |= (type << (offset * 0x4)); | 135 | value |= (type << (offset * 0x4)); |
138 | __raw_writel(value, S5P_GPIOREG(GPIOINT_CON_OFFSET) + con_offset); | 136 | __raw_writel(value, GPIO_BASE(chip) + CON_OFFSET + con_offset); |
139 | 137 | ||
140 | return 0; | 138 | return 0; |
141 | } | 139 | } |
142 | 140 | ||
143 | struct irq_chip s5p_gpioint = { | 141 | static struct irq_chip s5p_gpioint = { |
144 | .name = "s5p_gpioint", | 142 | .name = "s5p_gpioint", |
145 | .irq_ack = s5p_gpioint_ack, | 143 | .irq_ack = s5p_gpioint_ack, |
146 | .irq_mask = s5p_gpioint_mask, | 144 | .irq_mask = s5p_gpioint_mask, |
@@ -151,30 +149,29 @@ struct irq_chip s5p_gpioint = { | |||
151 | 149 | ||
152 | static void s5p_gpioint_handler(unsigned int irq, struct irq_desc *desc) | 150 | static void s5p_gpioint_handler(unsigned int irq, struct irq_desc *desc) |
153 | { | 151 | { |
154 | int group, offset, pend_offset, mask_offset; | 152 | struct s5p_gpioint_bank *bank = get_irq_data(irq); |
155 | int real_irq; | 153 | int group, pend_offset, mask_offset; |
156 | unsigned int pend, mask; | 154 | unsigned int pend, mask; |
157 | 155 | ||
158 | for (group = 0; group < S5P_GPIOINT_GROUP_MAXNR; group++) { | 156 | for (group = 0; group < bank->nr_groups; group++) { |
159 | pend_offset = group << 2; | 157 | struct s3c_gpio_chip *chip = bank->chips[group]; |
160 | pend = __raw_readl(S5P_GPIOREG(GPIOINT_PEND_OFFSET) + | 158 | if (!chip) |
161 | pend_offset); | 159 | continue; |
160 | |||
161 | pend_offset = REG_OFFSET(group); | ||
162 | pend = __raw_readl(GPIO_BASE(chip) + PEND_OFFSET + pend_offset); | ||
162 | if (!pend) | 163 | if (!pend) |
163 | continue; | 164 | continue; |
164 | 165 | ||
165 | mask_offset = group << 2; | 166 | mask_offset = REG_OFFSET(group); |
166 | mask = __raw_readl(S5P_GPIOREG(GPIOINT_MASK_OFFSET) + | 167 | mask = __raw_readl(GPIO_BASE(chip) + MASK_OFFSET + mask_offset); |
167 | mask_offset); | ||
168 | pend &= ~mask; | 168 | pend &= ~mask; |
169 | 169 | ||
170 | for (offset = 0; offset < 8; offset++) { | 170 | while (pend) { |
171 | if (pend & (1 << offset)) { | 171 | int offset = fls(pend) - 1; |
172 | struct s3c_gpio_chip *chip = irq_chips[group]; | 172 | int real_irq = chip->irq_base + offset; |
173 | if (chip) { | 173 | generic_handle_irq(real_irq); |
174 | real_irq = chip->irq_base + offset; | 174 | pend &= ~BIT(offset); |
175 | generic_handle_irq(real_irq); | ||
176 | } | ||
177 | } | ||
178 | } | 175 | } |
179 | } | 176 | } |
180 | } | 177 | } |
@@ -182,27 +179,48 @@ static void s5p_gpioint_handler(unsigned int irq, struct irq_desc *desc) | |||
182 | static __init int s5p_gpioint_add(struct s3c_gpio_chip *chip) | 179 | static __init int s5p_gpioint_add(struct s3c_gpio_chip *chip) |
183 | { | 180 | { |
184 | static int used_gpioint_groups = 0; | 181 | static int used_gpioint_groups = 0; |
185 | static bool handler_registered = 0; | ||
186 | int irq, group = chip->group; | 182 | int irq, group = chip->group; |
187 | int i; | 183 | int i; |
184 | struct s5p_gpioint_bank *bank = NULL; | ||
188 | 185 | ||
189 | if (used_gpioint_groups >= S5P_GPIOINT_GROUP_COUNT) | 186 | if (used_gpioint_groups >= S5P_GPIOINT_GROUP_COUNT) |
190 | return -ENOMEM; | 187 | return -ENOMEM; |
191 | 188 | ||
189 | list_for_each_entry(bank, &banks, list) { | ||
190 | if (group >= bank->start && | ||
191 | group < bank->start + bank->nr_groups) | ||
192 | break; | ||
193 | } | ||
194 | if (!bank) | ||
195 | return -EINVAL; | ||
196 | |||
197 | if (!bank->handler) { | ||
198 | bank->chips = kzalloc(sizeof(struct s3c_gpio_chip *) * | ||
199 | bank->nr_groups, GFP_KERNEL); | ||
200 | if (!bank->chips) | ||
201 | return -ENOMEM; | ||
202 | |||
203 | set_irq_chained_handler(bank->irq, s5p_gpioint_handler); | ||
204 | set_irq_data(bank->irq, bank); | ||
205 | bank->handler = s5p_gpioint_handler; | ||
206 | printk(KERN_INFO "Registered chained gpio int handler for interrupt %d.\n", | ||
207 | bank->irq); | ||
208 | } | ||
209 | |||
210 | /* | ||
211 | * chained GPIO irq has been sucessfully registered, allocate new gpio | ||
212 | * int group and assign irq nubmers | ||
213 | */ | ||
214 | |||
192 | chip->irq_base = S5P_GPIOINT_BASE + | 215 | chip->irq_base = S5P_GPIOINT_BASE + |
193 | used_gpioint_groups * S5P_GPIOINT_GROUP_SIZE; | 216 | used_gpioint_groups * S5P_GPIOINT_GROUP_SIZE; |
194 | used_gpioint_groups++; | 217 | used_gpioint_groups++; |
195 | 218 | ||
196 | if (!handler_registered) { | 219 | bank->chips[group - bank->start] = chip; |
197 | set_irq_chained_handler(IRQ_GPIOINT, s5p_gpioint_handler); | ||
198 | handler_registered = 1; | ||
199 | } | ||
200 | |||
201 | irq_chips[group] = chip; | ||
202 | for (i = 0; i < chip->chip.ngpio; i++) { | 220 | for (i = 0; i < chip->chip.ngpio; i++) { |
203 | irq = chip->irq_base + i; | 221 | irq = chip->irq_base + i; |
204 | set_irq_chip(irq, &s5p_gpioint); | 222 | set_irq_chip(irq, &s5p_gpioint); |
205 | set_irq_data(irq, &chip->chip); | 223 | set_irq_data(irq, chip); |
206 | set_irq_handler(irq, handle_level_irq); | 224 | set_irq_handler(irq, handle_level_irq); |
207 | set_irq_flags(irq, IRQF_VALID); | 225 | set_irq_flags(irq, IRQF_VALID); |
208 | } | 226 | } |
@@ -235,3 +253,19 @@ int __init s5p_register_gpio_interrupt(int pin) | |||
235 | } | 253 | } |
236 | return ret; | 254 | return ret; |
237 | } | 255 | } |
256 | |||
257 | int __init s5p_register_gpioint_bank(int chain_irq, int start, int nr_groups) | ||
258 | { | ||
259 | struct s5p_gpioint_bank *bank; | ||
260 | |||
261 | bank = kzalloc(sizeof(*bank), GFP_KERNEL); | ||
262 | if (!bank) | ||
263 | return -ENOMEM; | ||
264 | |||
265 | bank->start = start; | ||
266 | bank->nr_groups = nr_groups; | ||
267 | bank->irq = chain_irq; | ||
268 | |||
269 | list_add_tail(&bank->list, &banks); | ||
270 | return 0; | ||
271 | } | ||
diff --git a/arch/arm/plat-s5p/s5p-time.c b/arch/arm/plat-s5p/s5p-time.c new file mode 100644 index 000000000000..8090403eec0f --- /dev/null +++ b/arch/arm/plat-s5p/s5p-time.c | |||
@@ -0,0 +1,448 @@ | |||
1 | /* linux/arch/arm/plat-s5p/s5p-time.c | ||
2 | * | ||
3 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com/ | ||
5 | * | ||
6 | * S5P - Common hr-timer support | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #include <linux/sched.h> | ||
14 | #include <linux/interrupt.h> | ||
15 | #include <linux/irq.h> | ||
16 | #include <linux/err.h> | ||
17 | #include <linux/clk.h> | ||
18 | #include <linux/clockchips.h> | ||
19 | #include <linux/platform_device.h> | ||
20 | |||
21 | #include <asm/smp_twd.h> | ||
22 | #include <asm/mach/time.h> | ||
23 | #include <asm/mach/arch.h> | ||
24 | #include <asm/mach/map.h> | ||
25 | #include <asm/sched_clock.h> | ||
26 | |||
27 | #include <mach/map.h> | ||
28 | #include <plat/devs.h> | ||
29 | #include <plat/regs-timer.h> | ||
30 | #include <plat/s5p-time.h> | ||
31 | |||
32 | static struct clk *tin_event; | ||
33 | static struct clk *tin_source; | ||
34 | static struct clk *tdiv_event; | ||
35 | static struct clk *tdiv_source; | ||
36 | static struct clk *timerclk; | ||
37 | static struct s5p_timer_source timer_source; | ||
38 | static unsigned long clock_count_per_tick; | ||
39 | static void s5p_timer_resume(void); | ||
40 | |||
41 | static void s5p_time_stop(enum s5p_timer_mode mode) | ||
42 | { | ||
43 | unsigned long tcon; | ||
44 | |||
45 | tcon = __raw_readl(S3C2410_TCON); | ||
46 | |||
47 | switch (mode) { | ||
48 | case S5P_PWM0: | ||
49 | tcon &= ~S3C2410_TCON_T0START; | ||
50 | break; | ||
51 | |||
52 | case S5P_PWM1: | ||
53 | tcon &= ~S3C2410_TCON_T1START; | ||
54 | break; | ||
55 | |||
56 | case S5P_PWM2: | ||
57 | tcon &= ~S3C2410_TCON_T2START; | ||
58 | break; | ||
59 | |||
60 | case S5P_PWM3: | ||
61 | tcon &= ~S3C2410_TCON_T3START; | ||
62 | break; | ||
63 | |||
64 | case S5P_PWM4: | ||
65 | tcon &= ~S3C2410_TCON_T4START; | ||
66 | break; | ||
67 | |||
68 | default: | ||
69 | printk(KERN_ERR "Invalid Timer %d\n", mode); | ||
70 | break; | ||
71 | } | ||
72 | __raw_writel(tcon, S3C2410_TCON); | ||
73 | } | ||
74 | |||
75 | static void s5p_time_setup(enum s5p_timer_mode mode, unsigned long tcnt) | ||
76 | { | ||
77 | unsigned long tcon; | ||
78 | |||
79 | tcon = __raw_readl(S3C2410_TCON); | ||
80 | |||
81 | tcnt--; | ||
82 | |||
83 | switch (mode) { | ||
84 | case S5P_PWM0: | ||
85 | tcon &= ~(0x0f << 0); | ||
86 | tcon |= S3C2410_TCON_T0MANUALUPD; | ||
87 | break; | ||
88 | |||
89 | case S5P_PWM1: | ||
90 | tcon &= ~(0x0f << 8); | ||
91 | tcon |= S3C2410_TCON_T1MANUALUPD; | ||
92 | break; | ||
93 | |||
94 | case S5P_PWM2: | ||
95 | tcon &= ~(0x0f << 12); | ||
96 | tcon |= S3C2410_TCON_T2MANUALUPD; | ||
97 | break; | ||
98 | |||
99 | case S5P_PWM3: | ||
100 | tcon &= ~(0x0f << 16); | ||
101 | tcon |= S3C2410_TCON_T3MANUALUPD; | ||
102 | break; | ||
103 | |||
104 | case S5P_PWM4: | ||
105 | tcon &= ~(0x07 << 20); | ||
106 | tcon |= S3C2410_TCON_T4MANUALUPD; | ||
107 | break; | ||
108 | |||
109 | default: | ||
110 | printk(KERN_ERR "Invalid Timer %d\n", mode); | ||
111 | break; | ||
112 | } | ||
113 | |||
114 | __raw_writel(tcnt, S3C2410_TCNTB(mode)); | ||
115 | __raw_writel(tcnt, S3C2410_TCMPB(mode)); | ||
116 | __raw_writel(tcon, S3C2410_TCON); | ||
117 | } | ||
118 | |||
119 | static void s5p_time_start(enum s5p_timer_mode mode, bool periodic) | ||
120 | { | ||
121 | unsigned long tcon; | ||
122 | |||
123 | tcon = __raw_readl(S3C2410_TCON); | ||
124 | |||
125 | switch (mode) { | ||
126 | case S5P_PWM0: | ||
127 | tcon |= S3C2410_TCON_T0START; | ||
128 | tcon &= ~S3C2410_TCON_T0MANUALUPD; | ||
129 | |||
130 | if (periodic) | ||
131 | tcon |= S3C2410_TCON_T0RELOAD; | ||
132 | else | ||
133 | tcon &= ~S3C2410_TCON_T0RELOAD; | ||
134 | break; | ||
135 | |||
136 | case S5P_PWM1: | ||
137 | tcon |= S3C2410_TCON_T1START; | ||
138 | tcon &= ~S3C2410_TCON_T1MANUALUPD; | ||
139 | |||
140 | if (periodic) | ||
141 | tcon |= S3C2410_TCON_T1RELOAD; | ||
142 | else | ||
143 | tcon &= ~S3C2410_TCON_T1RELOAD; | ||
144 | break; | ||
145 | |||
146 | case S5P_PWM2: | ||
147 | tcon |= S3C2410_TCON_T2START; | ||
148 | tcon &= ~S3C2410_TCON_T2MANUALUPD; | ||
149 | |||
150 | if (periodic) | ||
151 | tcon |= S3C2410_TCON_T2RELOAD; | ||
152 | else | ||
153 | tcon &= ~S3C2410_TCON_T2RELOAD; | ||
154 | break; | ||
155 | |||
156 | case S5P_PWM3: | ||
157 | tcon |= S3C2410_TCON_T3START; | ||
158 | tcon &= ~S3C2410_TCON_T3MANUALUPD; | ||
159 | |||
160 | if (periodic) | ||
161 | tcon |= S3C2410_TCON_T3RELOAD; | ||
162 | else | ||
163 | tcon &= ~S3C2410_TCON_T3RELOAD; | ||
164 | break; | ||
165 | |||
166 | case S5P_PWM4: | ||
167 | tcon |= S3C2410_TCON_T4START; | ||
168 | tcon &= ~S3C2410_TCON_T4MANUALUPD; | ||
169 | |||
170 | if (periodic) | ||
171 | tcon |= S3C2410_TCON_T4RELOAD; | ||
172 | else | ||
173 | tcon &= ~S3C2410_TCON_T4RELOAD; | ||
174 | break; | ||
175 | |||
176 | default: | ||
177 | printk(KERN_ERR "Invalid Timer %d\n", mode); | ||
178 | break; | ||
179 | } | ||
180 | __raw_writel(tcon, S3C2410_TCON); | ||
181 | } | ||
182 | |||
183 | static int s5p_set_next_event(unsigned long cycles, | ||
184 | struct clock_event_device *evt) | ||
185 | { | ||
186 | s5p_time_setup(timer_source.event_id, cycles); | ||
187 | s5p_time_start(timer_source.event_id, NON_PERIODIC); | ||
188 | |||
189 | return 0; | ||
190 | } | ||
191 | |||
192 | static void s5p_set_mode(enum clock_event_mode mode, | ||
193 | struct clock_event_device *evt) | ||
194 | { | ||
195 | s5p_time_stop(timer_source.event_id); | ||
196 | |||
197 | switch (mode) { | ||
198 | case CLOCK_EVT_MODE_PERIODIC: | ||
199 | s5p_time_setup(timer_source.event_id, clock_count_per_tick); | ||
200 | s5p_time_start(timer_source.event_id, PERIODIC); | ||
201 | break; | ||
202 | |||
203 | case CLOCK_EVT_MODE_ONESHOT: | ||
204 | break; | ||
205 | |||
206 | case CLOCK_EVT_MODE_UNUSED: | ||
207 | case CLOCK_EVT_MODE_SHUTDOWN: | ||
208 | break; | ||
209 | |||
210 | case CLOCK_EVT_MODE_RESUME: | ||
211 | s5p_timer_resume(); | ||
212 | break; | ||
213 | } | ||
214 | } | ||
215 | |||
216 | static void s5p_timer_resume(void) | ||
217 | { | ||
218 | /* event timer restart */ | ||
219 | s5p_time_setup(timer_source.event_id, clock_count_per_tick); | ||
220 | s5p_time_start(timer_source.event_id, PERIODIC); | ||
221 | |||
222 | /* source timer restart */ | ||
223 | s5p_time_setup(timer_source.source_id, TCNT_MAX); | ||
224 | s5p_time_start(timer_source.source_id, PERIODIC); | ||
225 | } | ||
226 | |||
227 | void __init s5p_set_timer_source(enum s5p_timer_mode event, | ||
228 | enum s5p_timer_mode source) | ||
229 | { | ||
230 | s3c_device_timer[event].dev.bus = &platform_bus_type; | ||
231 | s3c_device_timer[source].dev.bus = &platform_bus_type; | ||
232 | |||
233 | timer_source.event_id = event; | ||
234 | timer_source.source_id = source; | ||
235 | } | ||
236 | |||
237 | static struct clock_event_device time_event_device = { | ||
238 | .name = "s5p_event_timer", | ||
239 | .features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT, | ||
240 | .rating = 200, | ||
241 | .set_next_event = s5p_set_next_event, | ||
242 | .set_mode = s5p_set_mode, | ||
243 | }; | ||
244 | |||
245 | static irqreturn_t s5p_clock_event_isr(int irq, void *dev_id) | ||
246 | { | ||
247 | struct clock_event_device *evt = dev_id; | ||
248 | |||
249 | evt->event_handler(evt); | ||
250 | |||
251 | return IRQ_HANDLED; | ||
252 | } | ||
253 | |||
254 | static struct irqaction s5p_clock_event_irq = { | ||
255 | .name = "s5p_time_irq", | ||
256 | .flags = IRQF_DISABLED | IRQF_TIMER | IRQF_IRQPOLL, | ||
257 | .handler = s5p_clock_event_isr, | ||
258 | .dev_id = &time_event_device, | ||
259 | }; | ||
260 | |||
261 | static void __init s5p_clockevent_init(void) | ||
262 | { | ||
263 | unsigned long pclk; | ||
264 | unsigned long clock_rate; | ||
265 | unsigned int irq_number; | ||
266 | struct clk *tscaler; | ||
267 | |||
268 | pclk = clk_get_rate(timerclk); | ||
269 | |||
270 | tscaler = clk_get_parent(tdiv_event); | ||
271 | |||
272 | clk_set_rate(tscaler, pclk / 2); | ||
273 | clk_set_rate(tdiv_event, pclk / 2); | ||
274 | clk_set_parent(tin_event, tdiv_event); | ||
275 | |||
276 | clock_rate = clk_get_rate(tin_event); | ||
277 | clock_count_per_tick = clock_rate / HZ; | ||
278 | |||
279 | clockevents_calc_mult_shift(&time_event_device, | ||
280 | clock_rate, S5PTIMER_MIN_RANGE); | ||
281 | time_event_device.max_delta_ns = | ||
282 | clockevent_delta2ns(-1, &time_event_device); | ||
283 | time_event_device.min_delta_ns = | ||
284 | clockevent_delta2ns(1, &time_event_device); | ||
285 | |||
286 | time_event_device.cpumask = cpumask_of(0); | ||
287 | clockevents_register_device(&time_event_device); | ||
288 | |||
289 | irq_number = timer_source.event_id + IRQ_TIMER0; | ||
290 | setup_irq(irq_number, &s5p_clock_event_irq); | ||
291 | } | ||
292 | |||
293 | static cycle_t s5p_timer_read(struct clocksource *cs) | ||
294 | { | ||
295 | unsigned long offset = 0; | ||
296 | |||
297 | switch (timer_source.source_id) { | ||
298 | case S5P_PWM0: | ||
299 | case S5P_PWM1: | ||
300 | case S5P_PWM2: | ||
301 | case S5P_PWM3: | ||
302 | offset = (timer_source.source_id * 0x0c) + 0x14; | ||
303 | break; | ||
304 | |||
305 | case S5P_PWM4: | ||
306 | offset = 0x40; | ||
307 | break; | ||
308 | |||
309 | default: | ||
310 | printk(KERN_ERR "Invalid Timer %d\n", timer_source.source_id); | ||
311 | return 0; | ||
312 | } | ||
313 | |||
314 | return (cycle_t) ~__raw_readl(S3C_TIMERREG(offset)); | ||
315 | } | ||
316 | |||
317 | /* | ||
318 | * Override the global weak sched_clock symbol with this | ||
319 | * local implementation which uses the clocksource to get some | ||
320 | * better resolution when scheduling the kernel. We accept that | ||
321 | * this wraps around for now, since it is just a relative time | ||
322 | * stamp. (Inspired by U300 implementation.) | ||
323 | */ | ||
324 | static DEFINE_CLOCK_DATA(cd); | ||
325 | |||
326 | unsigned long long notrace sched_clock(void) | ||
327 | { | ||
328 | u32 cyc; | ||
329 | unsigned long offset = 0; | ||
330 | |||
331 | switch (timer_source.source_id) { | ||
332 | case S5P_PWM0: | ||
333 | case S5P_PWM1: | ||
334 | case S5P_PWM2: | ||
335 | case S5P_PWM3: | ||
336 | offset = (timer_source.source_id * 0x0c) + 0x14; | ||
337 | break; | ||
338 | |||
339 | case S5P_PWM4: | ||
340 | offset = 0x40; | ||
341 | break; | ||
342 | |||
343 | default: | ||
344 | printk(KERN_ERR "Invalid Timer %d\n", timer_source.source_id); | ||
345 | return 0; | ||
346 | } | ||
347 | |||
348 | cyc = ~__raw_readl(S3C_TIMERREG(offset)); | ||
349 | return cyc_to_sched_clock(&cd, cyc, (u32)~0); | ||
350 | } | ||
351 | |||
352 | static void notrace s5p_update_sched_clock(void) | ||
353 | { | ||
354 | u32 cyc; | ||
355 | unsigned long offset = 0; | ||
356 | |||
357 | switch (timer_source.source_id) { | ||
358 | case S5P_PWM0: | ||
359 | case S5P_PWM1: | ||
360 | case S5P_PWM2: | ||
361 | case S5P_PWM3: | ||
362 | offset = (timer_source.source_id * 0x0c) + 0x14; | ||
363 | break; | ||
364 | |||
365 | case S5P_PWM4: | ||
366 | offset = 0x40; | ||
367 | break; | ||
368 | |||
369 | default: | ||
370 | printk(KERN_ERR "Invalid Timer %d\n", timer_source.source_id); | ||
371 | } | ||
372 | |||
373 | cyc = ~__raw_readl(S3C_TIMERREG(offset)); | ||
374 | update_sched_clock(&cd, cyc, (u32)~0); | ||
375 | } | ||
376 | |||
377 | struct clocksource time_clocksource = { | ||
378 | .name = "s5p_clocksource_timer", | ||
379 | .rating = 250, | ||
380 | .read = s5p_timer_read, | ||
381 | .mask = CLOCKSOURCE_MASK(32), | ||
382 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, | ||
383 | }; | ||
384 | |||
385 | static void __init s5p_clocksource_init(void) | ||
386 | { | ||
387 | unsigned long pclk; | ||
388 | unsigned long clock_rate; | ||
389 | |||
390 | pclk = clk_get_rate(timerclk); | ||
391 | |||
392 | clk_set_rate(tdiv_source, pclk / 2); | ||
393 | clk_set_parent(tin_source, tdiv_source); | ||
394 | |||
395 | clock_rate = clk_get_rate(tin_source); | ||
396 | |||
397 | init_sched_clock(&cd, s5p_update_sched_clock, 32, clock_rate); | ||
398 | |||
399 | s5p_time_setup(timer_source.source_id, TCNT_MAX); | ||
400 | s5p_time_start(timer_source.source_id, PERIODIC); | ||
401 | |||
402 | if (clocksource_register_hz(&time_clocksource, clock_rate)) | ||
403 | panic("%s: can't register clocksource\n", time_clocksource.name); | ||
404 | } | ||
405 | |||
406 | static void __init s5p_timer_resources(void) | ||
407 | { | ||
408 | |||
409 | unsigned long event_id = timer_source.event_id; | ||
410 | unsigned long source_id = timer_source.source_id; | ||
411 | |||
412 | timerclk = clk_get(NULL, "timers"); | ||
413 | if (IS_ERR(timerclk)) | ||
414 | panic("failed to get timers clock for timer"); | ||
415 | |||
416 | clk_enable(timerclk); | ||
417 | |||
418 | tin_event = clk_get(&s3c_device_timer[event_id].dev, "pwm-tin"); | ||
419 | if (IS_ERR(tin_event)) | ||
420 | panic("failed to get pwm-tin clock for event timer"); | ||
421 | |||
422 | tdiv_event = clk_get(&s3c_device_timer[event_id].dev, "pwm-tdiv"); | ||
423 | if (IS_ERR(tdiv_event)) | ||
424 | panic("failed to get pwm-tdiv clock for event timer"); | ||
425 | |||
426 | clk_enable(tin_event); | ||
427 | |||
428 | tin_source = clk_get(&s3c_device_timer[source_id].dev, "pwm-tin"); | ||
429 | if (IS_ERR(tin_source)) | ||
430 | panic("failed to get pwm-tin clock for source timer"); | ||
431 | |||
432 | tdiv_source = clk_get(&s3c_device_timer[source_id].dev, "pwm-tdiv"); | ||
433 | if (IS_ERR(tdiv_source)) | ||
434 | panic("failed to get pwm-tdiv clock for source timer"); | ||
435 | |||
436 | clk_enable(tin_source); | ||
437 | } | ||
438 | |||
439 | static void __init s5p_timer_init(void) | ||
440 | { | ||
441 | s5p_timer_resources(); | ||
442 | s5p_clockevent_init(); | ||
443 | s5p_clocksource_init(); | ||
444 | } | ||
445 | |||
446 | struct sys_timer s5p_timer = { | ||
447 | .init = s5p_timer_init, | ||
448 | }; | ||
diff --git a/arch/arm/plat-s5p/setup-mipiphy.c b/arch/arm/plat-s5p/setup-mipiphy.c new file mode 100644 index 000000000000..683c466c0e6a --- /dev/null +++ b/arch/arm/plat-s5p/setup-mipiphy.c | |||
@@ -0,0 +1,63 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2011 Samsung Electronics Co., Ltd. | ||
3 | * | ||
4 | * S5P - Helper functions for MIPI-CSIS and MIPI-DSIM D-PHY control | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | |||
11 | #include <linux/kernel.h> | ||
12 | #include <linux/platform_device.h> | ||
13 | #include <linux/io.h> | ||
14 | #include <linux/spinlock.h> | ||
15 | #include <mach/regs-clock.h> | ||
16 | |||
17 | static int __s5p_mipi_phy_control(struct platform_device *pdev, | ||
18 | bool on, u32 reset) | ||
19 | { | ||
20 | static DEFINE_SPINLOCK(lock); | ||
21 | void __iomem *addr; | ||
22 | unsigned long flags; | ||
23 | int pid; | ||
24 | u32 cfg; | ||
25 | |||
26 | if (!pdev) | ||
27 | return -EINVAL; | ||
28 | |||
29 | pid = (pdev->id == -1) ? 0 : pdev->id; | ||
30 | |||
31 | if (pid != 0 && pid != 1) | ||
32 | return -EINVAL; | ||
33 | |||
34 | addr = S5P_MIPI_DPHY_CONTROL(pid); | ||
35 | |||
36 | spin_lock_irqsave(&lock, flags); | ||
37 | |||
38 | cfg = __raw_readl(addr); | ||
39 | cfg = on ? (cfg | reset) : (cfg & ~reset); | ||
40 | __raw_writel(cfg, addr); | ||
41 | |||
42 | if (on) { | ||
43 | cfg |= S5P_MIPI_DPHY_ENABLE; | ||
44 | } else if (!(cfg & (S5P_MIPI_DPHY_SRESETN | | ||
45 | S5P_MIPI_DPHY_MRESETN) & ~reset)) { | ||
46 | cfg &= ~S5P_MIPI_DPHY_ENABLE; | ||
47 | } | ||
48 | |||
49 | __raw_writel(cfg, addr); | ||
50 | spin_unlock_irqrestore(&lock, flags); | ||
51 | |||
52 | return 0; | ||
53 | } | ||
54 | |||
55 | int s5p_csis_phy_enable(struct platform_device *pdev, bool on) | ||
56 | { | ||
57 | return __s5p_mipi_phy_control(pdev, on, S5P_MIPI_DPHY_SRESETN); | ||
58 | } | ||
59 | |||
60 | int s5p_dsim_phy_enable(struct platform_device *pdev, bool on) | ||
61 | { | ||
62 | return __s5p_mipi_phy_control(pdev, on, S5P_MIPI_DPHY_MRESETN); | ||
63 | } | ||
diff --git a/arch/arm/plat-s5p/sysmmu.c b/arch/arm/plat-s5p/sysmmu.c index ffe8a48bc3c1..54f5eddc921d 100644 --- a/arch/arm/plat-s5p/sysmmu.c +++ b/arch/arm/plat-s5p/sysmmu.c | |||
@@ -12,280 +12,266 @@ | |||
12 | #include <linux/interrupt.h> | 12 | #include <linux/interrupt.h> |
13 | #include <linux/platform_device.h> | 13 | #include <linux/platform_device.h> |
14 | 14 | ||
15 | #include <asm/pgtable.h> | ||
16 | |||
15 | #include <mach/map.h> | 17 | #include <mach/map.h> |
16 | #include <mach/regs-sysmmu.h> | 18 | #include <mach/regs-sysmmu.h> |
17 | #include <mach/sysmmu.h> | 19 | #include <plat/sysmmu.h> |
20 | |||
21 | #define CTRL_ENABLE 0x5 | ||
22 | #define CTRL_BLOCK 0x7 | ||
23 | #define CTRL_DISABLE 0x0 | ||
24 | |||
25 | static struct device *dev; | ||
26 | |||
27 | static unsigned short fault_reg_offset[SYSMMU_FAULTS_NUM] = { | ||
28 | S5P_PAGE_FAULT_ADDR, | ||
29 | S5P_AR_FAULT_ADDR, | ||
30 | S5P_AW_FAULT_ADDR, | ||
31 | S5P_DEFAULT_SLAVE_ADDR, | ||
32 | S5P_AR_FAULT_ADDR, | ||
33 | S5P_AR_FAULT_ADDR, | ||
34 | S5P_AW_FAULT_ADDR, | ||
35 | S5P_AW_FAULT_ADDR | ||
36 | }; | ||
37 | |||
38 | static char *sysmmu_fault_name[SYSMMU_FAULTS_NUM] = { | ||
39 | "PAGE FAULT", | ||
40 | "AR MULTI-HIT FAULT", | ||
41 | "AW MULTI-HIT FAULT", | ||
42 | "BUS ERROR", | ||
43 | "AR SECURITY PROTECTION FAULT", | ||
44 | "AR ACCESS PROTECTION FAULT", | ||
45 | "AW SECURITY PROTECTION FAULT", | ||
46 | "AW ACCESS PROTECTION FAULT" | ||
47 | }; | ||
18 | 48 | ||
19 | struct sysmmu_controller s5p_sysmmu_cntlrs[S5P_SYSMMU_TOTAL_IPNUM]; | 49 | static int (*fault_handlers[S5P_SYSMMU_TOTAL_IPNUM])( |
50 | enum S5P_SYSMMU_INTERRUPT_TYPE itype, | ||
51 | unsigned long pgtable_base, | ||
52 | unsigned long fault_addr); | ||
20 | 53 | ||
21 | void s5p_sysmmu_register(struct sysmmu_controller *sysmmuconp) | 54 | /* |
55 | * If adjacent 2 bits are true, the system MMU is enabled. | ||
56 | * The system MMU is disabled, otherwise. | ||
57 | */ | ||
58 | static unsigned long sysmmu_states; | ||
59 | |||
60 | static inline void set_sysmmu_active(sysmmu_ips ips) | ||
22 | { | 61 | { |
23 | unsigned int reg_mmu_ctrl; | 62 | sysmmu_states |= 3 << (ips * 2); |
24 | unsigned int reg_mmu_status; | ||
25 | unsigned int reg_pt_base_addr; | ||
26 | unsigned int reg_int_status; | ||
27 | unsigned int reg_page_ft_addr; | ||
28 | |||
29 | reg_int_status = __raw_readl(sysmmuconp->regs + S5P_INT_STATUS); | ||
30 | reg_mmu_ctrl = __raw_readl(sysmmuconp->regs + S5P_MMU_CTRL); | ||
31 | reg_mmu_status = __raw_readl(sysmmuconp->regs + S5P_MMU_STATUS); | ||
32 | reg_pt_base_addr = __raw_readl(sysmmuconp->regs + S5P_PT_BASE_ADDR); | ||
33 | reg_page_ft_addr = __raw_readl(sysmmuconp->regs + S5P_PAGE_FAULT_ADDR); | ||
34 | |||
35 | printk(KERN_INFO "%s: ips:%s\n", __func__, sysmmuconp->name); | ||
36 | printk(KERN_INFO "%s: MMU_CTRL:0x%X, ", __func__, reg_mmu_ctrl); | ||
37 | printk(KERN_INFO "MMU_STATUS:0x%X, PT_BASE_ADDR:0x%X\n", reg_mmu_status, reg_pt_base_addr); | ||
38 | printk(KERN_INFO "%s: INT_STATUS:0x%X, PAGE_FAULT_ADDR:0x%X\n", __func__, reg_int_status, reg_page_ft_addr); | ||
39 | |||
40 | switch (reg_int_status & 0xFF) { | ||
41 | case 0x1: | ||
42 | printk(KERN_INFO "%s: Page fault\n", __func__); | ||
43 | printk(KERN_INFO "%s: Virtual address causing last page fault or bus error : 0x%x\n", __func__ , reg_page_ft_addr); | ||
44 | break; | ||
45 | case 0x2: | ||
46 | printk(KERN_INFO "%s: AR multi-hit fault\n", __func__); | ||
47 | break; | ||
48 | case 0x4: | ||
49 | printk(KERN_INFO "%s: AW multi-hit fault\n", __func__); | ||
50 | break; | ||
51 | case 0x8: | ||
52 | printk(KERN_INFO "%s: Bus error\n", __func__); | ||
53 | break; | ||
54 | case 0x10: | ||
55 | printk(KERN_INFO "%s: AR Security protection fault\n", __func__); | ||
56 | break; | ||
57 | case 0x20: | ||
58 | printk(KERN_INFO "%s: AR Access protection fault\n", __func__); | ||
59 | break; | ||
60 | case 0x40: | ||
61 | printk(KERN_INFO "%s: AW Security protection fault\n", __func__); | ||
62 | break; | ||
63 | case 0x80: | ||
64 | printk(KERN_INFO "%s: AW Access protection fault\n", __func__); | ||
65 | break; | ||
66 | } | ||
67 | } | 63 | } |
68 | 64 | ||
69 | static irqreturn_t s5p_sysmmu_irq(int irq, void *dev_id) | 65 | static inline void set_sysmmu_inactive(sysmmu_ips ips) |
70 | { | 66 | { |
71 | unsigned int i; | 67 | sysmmu_states &= ~(3 << (ips * 2)); |
72 | unsigned int reg_int_status; | ||
73 | struct sysmmu_controller *sysmmuconp; | ||
74 | |||
75 | for (i = 0; i < S5P_SYSMMU_TOTAL_IPNUM; i++) { | ||
76 | sysmmuconp = &s5p_sysmmu_cntlrs[i]; | ||
77 | |||
78 | if (sysmmuconp->enable == true) { | ||
79 | reg_int_status = __raw_readl(sysmmuconp->regs + S5P_INT_STATUS); | ||
80 | |||
81 | if (reg_int_status & 0xFF) | ||
82 | s5p_sysmmu_register(sysmmuconp); | ||
83 | } | ||
84 | } | ||
85 | return IRQ_HANDLED; | ||
86 | } | 68 | } |
87 | 69 | ||
88 | int s5p_sysmmu_set_tablebase_pgd(sysmmu_ips ips, unsigned long pgd) | 70 | static inline int is_sysmmu_active(sysmmu_ips ips) |
89 | { | 71 | { |
90 | struct sysmmu_controller *sysmmuconp = NULL; | 72 | return sysmmu_states & (3 << (ips * 2)); |
91 | 73 | } | |
92 | sysmmuconp = &s5p_sysmmu_cntlrs[ips]; | ||
93 | |||
94 | if (sysmmuconp == NULL) { | ||
95 | printk(KERN_ERR "failed to get ip's sysmmu info\n"); | ||
96 | return 1; | ||
97 | } | ||
98 | |||
99 | /* Set sysmmu page table base address */ | ||
100 | __raw_writel(pgd, sysmmuconp->regs + S5P_PT_BASE_ADDR); | ||
101 | 74 | ||
102 | if (s5p_sysmmu_tlb_invalidate(ips) != 0) | 75 | static void __iomem *sysmmusfrs[S5P_SYSMMU_TOTAL_IPNUM]; |
103 | printk(KERN_ERR "failed s5p_sysmmu_tlb_invalidate\n"); | ||
104 | 76 | ||
105 | return 0; | 77 | static inline void sysmmu_block(sysmmu_ips ips) |
78 | { | ||
79 | __raw_writel(CTRL_BLOCK, sysmmusfrs[ips] + S5P_MMU_CTRL); | ||
80 | dev_dbg(dev, "%s is blocked.\n", sysmmu_ips_name[ips]); | ||
106 | } | 81 | } |
107 | 82 | ||
108 | static int s5p_sysmmu_set_tablebase(sysmmu_ips ips) | 83 | static inline void sysmmu_unblock(sysmmu_ips ips) |
109 | { | 84 | { |
110 | unsigned int pg; | 85 | __raw_writel(CTRL_ENABLE, sysmmusfrs[ips] + S5P_MMU_CTRL); |
111 | struct sysmmu_controller *sysmmuconp; | 86 | dev_dbg(dev, "%s is unblocked.\n", sysmmu_ips_name[ips]); |
87 | } | ||
112 | 88 | ||
113 | sysmmuconp = &s5p_sysmmu_cntlrs[ips]; | 89 | static inline void __sysmmu_tlb_invalidate(sysmmu_ips ips) |
90 | { | ||
91 | __raw_writel(0x1, sysmmusfrs[ips] + S5P_MMU_FLUSH); | ||
92 | dev_dbg(dev, "TLB of %s is invalidated.\n", sysmmu_ips_name[ips]); | ||
93 | } | ||
114 | 94 | ||
115 | if (sysmmuconp == NULL) { | 95 | static inline void __sysmmu_set_ptbase(sysmmu_ips ips, unsigned long pgd) |
116 | printk(KERN_ERR "failed to get ip's sysmmu info\n"); | 96 | { |
117 | return 1; | 97 | if (unlikely(pgd == 0)) { |
98 | pgd = (unsigned long)ZERO_PAGE(0); | ||
99 | __raw_writel(0x20, sysmmusfrs[ips] + S5P_MMU_CFG); /* 4KB LV1 */ | ||
100 | } else { | ||
101 | __raw_writel(0x0, sysmmusfrs[ips] + S5P_MMU_CFG); /* 16KB LV1 */ | ||
118 | } | 102 | } |
119 | 103 | ||
120 | __asm__("mrc p15, 0, %0, c2, c0, 0" \ | 104 | __raw_writel(pgd, sysmmusfrs[ips] + S5P_PT_BASE_ADDR); |
121 | : "=r" (pg) : : "cc"); \ | ||
122 | pg &= ~0x3fff; | ||
123 | 105 | ||
124 | printk(KERN_INFO "%s: CP15 TTBR0 : 0x%x\n", __func__, pg); | 106 | dev_dbg(dev, "Page table base of %s is initialized with 0x%08lX.\n", |
125 | 107 | sysmmu_ips_name[ips], pgd); | |
126 | /* Set sysmmu page table base address */ | 108 | __sysmmu_tlb_invalidate(ips); |
127 | __raw_writel(pg, sysmmuconp->regs + S5P_PT_BASE_ADDR); | 109 | } |
128 | 110 | ||
129 | return 0; | 111 | void sysmmu_set_fault_handler(sysmmu_ips ips, |
112 | int (*handler)(enum S5P_SYSMMU_INTERRUPT_TYPE itype, | ||
113 | unsigned long pgtable_base, | ||
114 | unsigned long fault_addr)) | ||
115 | { | ||
116 | BUG_ON(!((ips >= SYSMMU_MDMA) && (ips < S5P_SYSMMU_TOTAL_IPNUM))); | ||
117 | fault_handlers[ips] = handler; | ||
130 | } | 118 | } |
131 | 119 | ||
132 | int s5p_sysmmu_enable(sysmmu_ips ips) | 120 | static irqreturn_t s5p_sysmmu_irq(int irq, void *dev_id) |
133 | { | 121 | { |
134 | unsigned int reg; | 122 | /* SYSMMU is in blocked when interrupt occurred. */ |
123 | unsigned long base = 0; | ||
124 | sysmmu_ips ips = (sysmmu_ips)dev_id; | ||
125 | enum S5P_SYSMMU_INTERRUPT_TYPE itype; | ||
135 | 126 | ||
136 | struct sysmmu_controller *sysmmuconp; | 127 | itype = (enum S5P_SYSMMU_INTERRUPT_TYPE) |
128 | __ffs(__raw_readl(sysmmusfrs[ips] + S5P_INT_STATUS)); | ||
137 | 129 | ||
138 | sysmmuconp = &s5p_sysmmu_cntlrs[ips]; | 130 | BUG_ON(!((itype >= 0) && (itype < 8))); |
139 | 131 | ||
140 | if (sysmmuconp == NULL) { | 132 | dev_alert(dev, "%s occurred by %s.\n", sysmmu_fault_name[itype], |
141 | printk(KERN_ERR "failed to get ip's sysmmu info\n"); | 133 | sysmmu_ips_name[ips]); |
142 | return 1; | ||
143 | } | ||
144 | 134 | ||
145 | s5p_sysmmu_set_tablebase(ips); | 135 | if (fault_handlers[ips]) { |
136 | unsigned long addr; | ||
146 | 137 | ||
147 | /* replacement policy : LRU */ | 138 | base = __raw_readl(sysmmusfrs[ips] + S5P_PT_BASE_ADDR); |
148 | reg = __raw_readl(sysmmuconp->regs + S5P_MMU_CFG); | 139 | addr = __raw_readl(sysmmusfrs[ips] + fault_reg_offset[itype]); |
149 | reg |= 0x1; | ||
150 | __raw_writel(reg, sysmmuconp->regs + S5P_MMU_CFG); | ||
151 | 140 | ||
152 | /* Enable interrupt, Enable MMU */ | 141 | if (fault_handlers[ips](itype, base, addr)) { |
153 | reg = __raw_readl(sysmmuconp->regs + S5P_MMU_CTRL); | 142 | __raw_writel(1 << itype, |
154 | reg |= (0x1 << 2) | (0x1 << 0); | 143 | sysmmusfrs[ips] + S5P_INT_CLEAR); |
144 | dev_notice(dev, "%s from %s is resolved." | ||
145 | " Retrying translation.\n", | ||
146 | sysmmu_fault_name[itype], sysmmu_ips_name[ips]); | ||
147 | } else { | ||
148 | base = 0; | ||
149 | } | ||
150 | } | ||
155 | 151 | ||
156 | __raw_writel(reg, sysmmuconp->regs + S5P_MMU_CTRL); | 152 | sysmmu_unblock(ips); |
157 | 153 | ||
158 | sysmmuconp->enable = true; | 154 | if (!base) |
155 | dev_notice(dev, "%s from %s is not handled.\n", | ||
156 | sysmmu_fault_name[itype], sysmmu_ips_name[ips]); | ||
159 | 157 | ||
160 | return 0; | 158 | return IRQ_HANDLED; |
161 | } | 159 | } |
162 | 160 | ||
163 | int s5p_sysmmu_disable(sysmmu_ips ips) | 161 | void s5p_sysmmu_set_tablebase_pgd(sysmmu_ips ips, unsigned long pgd) |
164 | { | 162 | { |
165 | unsigned int reg; | 163 | if (is_sysmmu_active(ips)) { |
166 | 164 | sysmmu_block(ips); | |
167 | struct sysmmu_controller *sysmmuconp = NULL; | 165 | __sysmmu_set_ptbase(ips, pgd); |
168 | 166 | sysmmu_unblock(ips); | |
169 | if (ips > S5P_SYSMMU_TOTAL_IPNUM) | 167 | } else { |
170 | printk(KERN_ERR "failed to get ips parameter\n"); | 168 | dev_dbg(dev, "%s is disabled. " |
171 | 169 | "Skipping initializing page table base.\n", | |
172 | sysmmuconp = &s5p_sysmmu_cntlrs[ips]; | 170 | sysmmu_ips_name[ips]); |
173 | |||
174 | if (sysmmuconp == NULL) { | ||
175 | printk(KERN_ERR "failed to get ip's sysmmu info\n"); | ||
176 | return 1; | ||
177 | } | 171 | } |
172 | } | ||
178 | 173 | ||
179 | reg = __raw_readl(sysmmuconp->regs + S5P_MMU_CFG); | 174 | void s5p_sysmmu_enable(sysmmu_ips ips, unsigned long pgd) |
180 | 175 | { | |
181 | /* replacement policy : LRU */ | 176 | if (!is_sysmmu_active(ips)) { |
182 | reg |= 0x1; | 177 | sysmmu_clk_enable(ips); |
183 | __raw_writel(reg, sysmmuconp->regs + S5P_MMU_CFG); | ||
184 | |||
185 | reg = __raw_readl(sysmmuconp->regs + S5P_MMU_CTRL); | ||
186 | 178 | ||
187 | /* Disable MMU */ | 179 | __sysmmu_set_ptbase(ips, pgd); |
188 | reg &= ~0x1; | ||
189 | __raw_writel(reg, sysmmuconp->regs + S5P_MMU_CTRL); | ||
190 | 180 | ||
191 | sysmmuconp->enable = false; | 181 | __raw_writel(CTRL_ENABLE, sysmmusfrs[ips] + S5P_MMU_CTRL); |
192 | 182 | ||
193 | return 0; | 183 | set_sysmmu_active(ips); |
184 | dev_dbg(dev, "%s is enabled.\n", sysmmu_ips_name[ips]); | ||
185 | } else { | ||
186 | dev_dbg(dev, "%s is already enabled.\n", sysmmu_ips_name[ips]); | ||
187 | } | ||
194 | } | 188 | } |
195 | 189 | ||
196 | int s5p_sysmmu_tlb_invalidate(sysmmu_ips ips) | 190 | void s5p_sysmmu_disable(sysmmu_ips ips) |
197 | { | 191 | { |
198 | unsigned int reg; | 192 | if (is_sysmmu_active(ips)) { |
199 | struct sysmmu_controller *sysmmuconp = NULL; | 193 | __raw_writel(CTRL_DISABLE, sysmmusfrs[ips] + S5P_MMU_CTRL); |
200 | 194 | set_sysmmu_inactive(ips); | |
201 | sysmmuconp = &s5p_sysmmu_cntlrs[ips]; | 195 | sysmmu_clk_disable(ips); |
202 | 196 | dev_dbg(dev, "%s is disabled.\n", sysmmu_ips_name[ips]); | |
203 | if (sysmmuconp == NULL) { | 197 | } else { |
204 | printk(KERN_ERR "failed to get ip's sysmmu info\n"); | 198 | dev_dbg(dev, "%s is already disabled.\n", sysmmu_ips_name[ips]); |
205 | return 1; | ||
206 | } | 199 | } |
200 | } | ||
207 | 201 | ||
208 | /* set Block MMU for flush TLB */ | 202 | void s5p_sysmmu_tlb_invalidate(sysmmu_ips ips) |
209 | reg = __raw_readl(sysmmuconp->regs + S5P_MMU_CTRL); | 203 | { |
210 | reg |= 0x1 << 1; | 204 | if (is_sysmmu_active(ips)) { |
211 | __raw_writel(reg, sysmmuconp->regs + S5P_MMU_CTRL); | 205 | sysmmu_block(ips); |
212 | 206 | __sysmmu_tlb_invalidate(ips); | |
213 | /* flush all TLB entry */ | 207 | sysmmu_unblock(ips); |
214 | __raw_writel(0x1, sysmmuconp->regs + S5P_MMU_FLUSH); | 208 | } else { |
215 | 209 | dev_dbg(dev, "%s is disabled. " | |
216 | /* set Un-block MMU after flush TLB */ | 210 | "Skipping invalidating TLB.\n", sysmmu_ips_name[ips]); |
217 | reg = __raw_readl(sysmmuconp->regs + S5P_MMU_CTRL); | 211 | } |
218 | reg &= ~(0x1 << 1); | ||
219 | __raw_writel(reg, sysmmuconp->regs + S5P_MMU_CTRL); | ||
220 | |||
221 | return 0; | ||
222 | } | 212 | } |
223 | 213 | ||
224 | static int s5p_sysmmu_probe(struct platform_device *pdev) | 214 | static int s5p_sysmmu_probe(struct platform_device *pdev) |
225 | { | 215 | { |
226 | int i; | 216 | int i, ret; |
227 | int ret; | 217 | struct resource *res, *mem; |
228 | struct resource *res; | 218 | |
229 | struct sysmmu_controller *sysmmuconp; | 219 | dev = &pdev->dev; |
230 | sysmmu_ips ips; | ||
231 | 220 | ||
232 | for (i = 0; i < S5P_SYSMMU_TOTAL_IPNUM; i++) { | 221 | for (i = 0; i < S5P_SYSMMU_TOTAL_IPNUM; i++) { |
233 | sysmmuconp = &s5p_sysmmu_cntlrs[i]; | 222 | int irq; |
234 | if (sysmmuconp == NULL) { | ||
235 | printk(KERN_ERR "failed to get ip's sysmmu info\n"); | ||
236 | ret = -ENOENT; | ||
237 | goto err_res; | ||
238 | } | ||
239 | 223 | ||
240 | sysmmuconp->name = sysmmu_ips_name[i]; | 224 | sysmmu_clk_init(dev, i); |
225 | sysmmu_clk_disable(i); | ||
241 | 226 | ||
242 | res = platform_get_resource(pdev, IORESOURCE_MEM, i); | 227 | res = platform_get_resource(pdev, IORESOURCE_MEM, i); |
243 | if (!res) { | 228 | if (!res) { |
244 | printk(KERN_ERR "failed to get sysmmu resource\n"); | 229 | dev_err(dev, "Failed to get the resource of %s.\n", |
230 | sysmmu_ips_name[i]); | ||
245 | ret = -ENODEV; | 231 | ret = -ENODEV; |
246 | goto err_res; | 232 | goto err_res; |
247 | } | 233 | } |
248 | 234 | ||
249 | sysmmuconp->mem = request_mem_region(res->start, | 235 | mem = request_mem_region(res->start, |
250 | ((res->end) - (res->start)) + 1, pdev->name); | 236 | ((res->end) - (res->start)) + 1, pdev->name); |
251 | if (!sysmmuconp->mem) { | 237 | if (!mem) { |
252 | pr_err("failed to request sysmmu memory region\n"); | 238 | dev_err(dev, "Failed to request the memory region of %s.\n", |
239 | sysmmu_ips_name[i]); | ||
253 | ret = -EBUSY; | 240 | ret = -EBUSY; |
254 | goto err_res; | 241 | goto err_res; |
255 | } | 242 | } |
256 | 243 | ||
257 | sysmmuconp->regs = ioremap(res->start, res->end - res->start + 1); | 244 | sysmmusfrs[i] = ioremap(res->start, res->end - res->start + 1); |
258 | if (!sysmmuconp->regs) { | 245 | if (!sysmmusfrs[i]) { |
259 | pr_err("failed to sysmmu ioremap\n"); | 246 | dev_err(dev, "Failed to ioremap() for %s.\n", |
247 | sysmmu_ips_name[i]); | ||
260 | ret = -ENXIO; | 248 | ret = -ENXIO; |
261 | goto err_reg; | 249 | goto err_reg; |
262 | } | 250 | } |
263 | 251 | ||
264 | sysmmuconp->irq = platform_get_irq(pdev, i); | 252 | irq = platform_get_irq(pdev, i); |
265 | if (sysmmuconp->irq <= 0) { | 253 | if (irq <= 0) { |
266 | pr_err("failed to get sysmmu irq resource\n"); | 254 | dev_err(dev, "Failed to get the IRQ resource of %s.\n", |
255 | sysmmu_ips_name[i]); | ||
267 | ret = -ENOENT; | 256 | ret = -ENOENT; |
268 | goto err_map; | 257 | goto err_map; |
269 | } | 258 | } |
270 | 259 | ||
271 | ret = request_irq(sysmmuconp->irq, s5p_sysmmu_irq, IRQF_DISABLED, pdev->name, sysmmuconp); | 260 | if (request_irq(irq, s5p_sysmmu_irq, IRQF_DISABLED, |
272 | if (ret) { | 261 | pdev->name, (void *)i)) { |
273 | pr_err("failed to request irq\n"); | 262 | dev_err(dev, "Failed to request IRQ for %s.\n", |
263 | sysmmu_ips_name[i]); | ||
274 | ret = -ENOENT; | 264 | ret = -ENOENT; |
275 | goto err_map; | 265 | goto err_map; |
276 | } | 266 | } |
277 | |||
278 | ips = (sysmmu_ips)i; | ||
279 | |||
280 | sysmmuconp->ips = ips; | ||
281 | } | 267 | } |
282 | 268 | ||
283 | return 0; | 269 | return 0; |
284 | 270 | ||
285 | err_reg: | ||
286 | release_mem_region((resource_size_t)sysmmuconp->mem, (resource_size_t)((res->end) - (res->start) + 1)); | ||
287 | err_map: | 271 | err_map: |
288 | iounmap(sysmmuconp->regs); | 272 | iounmap(sysmmusfrs[i]); |
273 | err_reg: | ||
274 | release_mem_region(mem->start, resource_size(mem)); | ||
289 | err_res: | 275 | err_res: |
290 | return ret; | 276 | return ret; |
291 | } | 277 | } |
diff --git a/arch/arm/plat-samsung/Kconfig b/arch/arm/plat-samsung/Kconfig index 32be05cf82a3..be72100b81b4 100644 --- a/arch/arm/plat-samsung/Kconfig +++ b/arch/arm/plat-samsung/Kconfig | |||
@@ -273,6 +273,19 @@ config SAMSUNG_DEV_KEYPAD | |||
273 | help | 273 | help |
274 | Compile in platform device definitions for keypad | 274 | Compile in platform device definitions for keypad |
275 | 275 | ||
276 | config SAMSUNG_DEV_PWM | ||
277 | bool | ||
278 | default y if ARCH_S3C2410 | ||
279 | help | ||
280 | Compile in platform device definition for PWM Timer | ||
281 | |||
282 | config S3C24XX_PWM | ||
283 | bool "PWM device support" | ||
284 | select HAVE_PWM | ||
285 | help | ||
286 | Support for exporting the PWM timer blocks via the pwm device | ||
287 | system | ||
288 | |||
276 | # DMA | 289 | # DMA |
277 | 290 | ||
278 | config S3C_DMA | 291 | config S3C_DMA |
diff --git a/arch/arm/plat-samsung/Makefile b/arch/arm/plat-samsung/Makefile index 29932f88a8d6..e9de58a2e294 100644 --- a/arch/arm/plat-samsung/Makefile +++ b/arch/arm/plat-samsung/Makefile | |||
@@ -59,6 +59,7 @@ obj-$(CONFIG_SAMSUNG_DEV_ADC) += dev-adc.o | |||
59 | obj-$(CONFIG_SAMSUNG_DEV_IDE) += dev-ide.o | 59 | obj-$(CONFIG_SAMSUNG_DEV_IDE) += dev-ide.o |
60 | obj-$(CONFIG_SAMSUNG_DEV_TS) += dev-ts.o | 60 | obj-$(CONFIG_SAMSUNG_DEV_TS) += dev-ts.o |
61 | obj-$(CONFIG_SAMSUNG_DEV_KEYPAD) += dev-keypad.o | 61 | obj-$(CONFIG_SAMSUNG_DEV_KEYPAD) += dev-keypad.o |
62 | obj-$(CONFIG_SAMSUNG_DEV_PWM) += dev-pwm.o | ||
62 | 63 | ||
63 | # DMA support | 64 | # DMA support |
64 | 65 | ||
diff --git a/arch/arm/plat-samsung/dev-pwm.c b/arch/arm/plat-samsung/dev-pwm.c new file mode 100644 index 000000000000..dab47b0e1900 --- /dev/null +++ b/arch/arm/plat-samsung/dev-pwm.c | |||
@@ -0,0 +1,53 @@ | |||
1 | /* linux/arch/arm/plat-samsung/dev-pwm.c | ||
2 | * | ||
3 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * Copyright (c) 2007 Ben Dooks | ||
7 | * Copyright (c) 2008 Simtec Electronics | ||
8 | * Ben Dooks <ben@simtec.co.uk>, <ben-linux@fluff.org> | ||
9 | * | ||
10 | * S3C series device definition for the PWM timer | ||
11 | * | ||
12 | * This program is free software; you can redistribute it and/or modify | ||
13 | * it under the terms of the GNU General Public License version 2 as | ||
14 | * published by the Free Software Foundation. | ||
15 | */ | ||
16 | |||
17 | #include <linux/kernel.h> | ||
18 | #include <linux/platform_device.h> | ||
19 | |||
20 | #include <mach/irqs.h> | ||
21 | |||
22 | #include <plat/devs.h> | ||
23 | |||
24 | #define TIMER_RESOURCE_SIZE (1) | ||
25 | |||
26 | #define TIMER_RESOURCE(_tmr, _irq) \ | ||
27 | (struct resource [TIMER_RESOURCE_SIZE]) { \ | ||
28 | [0] = { \ | ||
29 | .start = _irq, \ | ||
30 | .end = _irq, \ | ||
31 | .flags = IORESOURCE_IRQ \ | ||
32 | } \ | ||
33 | } | ||
34 | |||
35 | #define DEFINE_S3C_TIMER(_tmr_no, _irq) \ | ||
36 | .name = "s3c24xx-pwm", \ | ||
37 | .id = _tmr_no, \ | ||
38 | .num_resources = TIMER_RESOURCE_SIZE, \ | ||
39 | .resource = TIMER_RESOURCE(_tmr_no, _irq), \ | ||
40 | |||
41 | /* | ||
42 | * since we already have an static mapping for the timer, | ||
43 | * we do not bother setting any IO resource for the base. | ||
44 | */ | ||
45 | |||
46 | struct platform_device s3c_device_timer[] = { | ||
47 | [0] = { DEFINE_S3C_TIMER(0, IRQ_TIMER0) }, | ||
48 | [1] = { DEFINE_S3C_TIMER(1, IRQ_TIMER1) }, | ||
49 | [2] = { DEFINE_S3C_TIMER(2, IRQ_TIMER2) }, | ||
50 | [3] = { DEFINE_S3C_TIMER(3, IRQ_TIMER3) }, | ||
51 | [4] = { DEFINE_S3C_TIMER(4, IRQ_TIMER4) }, | ||
52 | }; | ||
53 | EXPORT_SYMBOL(s3c_device_timer); | ||
diff --git a/arch/arm/plat-samsung/include/plat/cpu.h b/arch/arm/plat-samsung/include/plat/cpu.h index 9addb3dfb4bc..cedfff51c82b 100644 --- a/arch/arm/plat-samsung/include/plat/cpu.h +++ b/arch/arm/plat-samsung/include/plat/cpu.h | |||
@@ -82,6 +82,7 @@ extern struct sysdev_class s3c64xx_sysclass; | |||
82 | extern struct sysdev_class s5p64x0_sysclass; | 82 | extern struct sysdev_class s5p64x0_sysclass; |
83 | extern struct sysdev_class s5p6442_sysclass; | 83 | extern struct sysdev_class s5p6442_sysclass; |
84 | extern struct sysdev_class s5pv210_sysclass; | 84 | extern struct sysdev_class s5pv210_sysclass; |
85 | extern struct sysdev_class exynos4_sysclass; | ||
85 | 86 | ||
86 | extern void (*s5pc1xx_idle)(void); | 87 | extern void (*s5pc1xx_idle)(void); |
87 | 88 | ||
diff --git a/arch/arm/plat-samsung/include/plat/devs.h b/arch/arm/plat-samsung/include/plat/devs.h index b4d208b42957..f0da6b70fba4 100644 --- a/arch/arm/plat-samsung/include/plat/devs.h +++ b/arch/arm/plat-samsung/include/plat/devs.h | |||
@@ -1,5 +1,8 @@ | |||
1 | /* arch/arm/plat-samsung/include/plat/devs.h | 1 | /* arch/arm/plat-samsung/include/plat/devs.h |
2 | * | 2 | * |
3 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
3 | * Copyright (c) 2004 Simtec Electronics | 6 | * Copyright (c) 2004 Simtec Electronics |
4 | * Ben Dooks <ben@simtec.co.uk> | 7 | * Ben Dooks <ben@simtec.co.uk> |
5 | * | 8 | * |
@@ -96,15 +99,16 @@ extern struct platform_device s5pv210_device_iis1; | |||
96 | extern struct platform_device s5pv210_device_iis2; | 99 | extern struct platform_device s5pv210_device_iis2; |
97 | extern struct platform_device s5pv210_device_spdif; | 100 | extern struct platform_device s5pv210_device_spdif; |
98 | 101 | ||
99 | extern struct platform_device s5pv310_device_ac97; | 102 | extern struct platform_device exynos4_device_ac97; |
100 | extern struct platform_device s5pv310_device_pcm0; | 103 | extern struct platform_device exynos4_device_pcm0; |
101 | extern struct platform_device s5pv310_device_pcm1; | 104 | extern struct platform_device exynos4_device_pcm1; |
102 | extern struct platform_device s5pv310_device_pcm2; | 105 | extern struct platform_device exynos4_device_pcm2; |
103 | extern struct platform_device s5pv310_device_i2s0; | 106 | extern struct platform_device exynos4_device_i2s0; |
104 | extern struct platform_device s5pv310_device_i2s1; | 107 | extern struct platform_device exynos4_device_i2s1; |
105 | extern struct platform_device s5pv310_device_i2s2; | 108 | extern struct platform_device exynos4_device_i2s2; |
106 | extern struct platform_device s5pv310_device_spdif; | 109 | extern struct platform_device exynos4_device_spdif; |
107 | extern struct platform_device s5pv310_device_pd[]; | 110 | extern struct platform_device exynos4_device_pd[]; |
111 | extern struct platform_device exynos4_device_ahci; | ||
108 | 112 | ||
109 | extern struct platform_device s5p6442_device_pcm0; | 113 | extern struct platform_device s5p6442_device_pcm0; |
110 | extern struct platform_device s5p6442_device_pcm1; | 114 | extern struct platform_device s5p6442_device_pcm1; |
@@ -133,11 +137,12 @@ extern struct platform_device samsung_device_keypad; | |||
133 | extern struct platform_device s5p_device_fimc0; | 137 | extern struct platform_device s5p_device_fimc0; |
134 | extern struct platform_device s5p_device_fimc1; | 138 | extern struct platform_device s5p_device_fimc1; |
135 | extern struct platform_device s5p_device_fimc2; | 139 | extern struct platform_device s5p_device_fimc2; |
140 | extern struct platform_device s5p_device_fimc3; | ||
136 | 141 | ||
137 | extern struct platform_device s5p_device_mipi_csis0; | 142 | extern struct platform_device s5p_device_mipi_csis0; |
138 | extern struct platform_device s5p_device_mipi_csis1; | 143 | extern struct platform_device s5p_device_mipi_csis1; |
139 | 144 | ||
140 | extern struct platform_device s5pv310_device_sysmmu; | 145 | extern struct platform_device exynos4_device_sysmmu; |
141 | 146 | ||
142 | /* s3c2440 specific devices */ | 147 | /* s3c2440 specific devices */ |
143 | 148 | ||
diff --git a/arch/arm/plat-samsung/include/plat/fimc-core.h b/arch/arm/plat-samsung/include/plat/fimc-core.h index 81a3bfeeccad..945a99d59563 100644 --- a/arch/arm/plat-samsung/include/plat/fimc-core.h +++ b/arch/arm/plat-samsung/include/plat/fimc-core.h | |||
@@ -38,6 +38,11 @@ static inline void s3c_fimc_setname(int id, char *name) | |||
38 | s5p_device_fimc2.name = name; | 38 | s5p_device_fimc2.name = name; |
39 | break; | 39 | break; |
40 | #endif | 40 | #endif |
41 | #ifdef CONFIG_S5P_DEV_FIMC3 | ||
42 | case 3: | ||
43 | s5p_device_fimc3.name = name; | ||
44 | break; | ||
45 | #endif | ||
41 | } | 46 | } |
42 | } | 47 | } |
43 | 48 | ||
diff --git a/arch/arm/plat-samsung/include/plat/gpio-cfg.h b/arch/arm/plat-samsung/include/plat/gpio-cfg.h index e4b5cf126fa9..5e04fa6eda74 100644 --- a/arch/arm/plat-samsung/include/plat/gpio-cfg.h +++ b/arch/arm/plat-samsung/include/plat/gpio-cfg.h | |||
@@ -225,4 +225,20 @@ extern int s5p_gpio_set_drvstr(unsigned int pin, s5p_gpio_drvstr_t drvstr); | |||
225 | */ | 225 | */ |
226 | extern int s5p_register_gpio_interrupt(int pin); | 226 | extern int s5p_register_gpio_interrupt(int pin); |
227 | 227 | ||
228 | /** s5p_register_gpioint_bank() - add gpio bank for further gpio interrupt | ||
229 | * registration (see s5p_register_gpio_interrupt function) | ||
230 | * @chain_irq: chained irq number for the gpio int handler for this bank | ||
231 | * @start: start gpio group number of this bank | ||
232 | * @nr_groups: number of gpio groups handled by this bank | ||
233 | * | ||
234 | * This functions registers initial information about gpio banks that | ||
235 | * can be later used by the s5p_register_gpio_interrupt() function to | ||
236 | * enable support for gpio interrupt for particular gpio group. | ||
237 | */ | ||
238 | #ifdef CONFIG_S5P_GPIO_INT | ||
239 | extern int s5p_register_gpioint_bank(int chain_irq, int start, int nr_groups); | ||
240 | #else | ||
241 | #define s5p_register_gpioint_bank(chain_irq, start, nr_groups) do { } while (0) | ||
242 | #endif | ||
243 | |||
228 | #endif /* __PLAT_GPIO_CFG_H */ | 244 | #endif /* __PLAT_GPIO_CFG_H */ |
diff --git a/arch/arm/plat-samsung/include/plat/pd.h b/arch/arm/plat-samsung/include/plat/pd.h index 5f0ad85783db..abb4bc32716a 100644 --- a/arch/arm/plat-samsung/include/plat/pd.h +++ b/arch/arm/plat-samsung/include/plat/pd.h | |||
@@ -1,6 +1,6 @@ | |||
1 | /* linux/arch/arm/plat-samsung/include/plat/pd.h | 1 | /* linux/arch/arm/plat-samsung/include/plat/pd.h |
2 | * | 2 | * |
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | 3 | * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd. |
4 | * http://www.samsung.com | 4 | * http://www.samsung.com |
5 | * | 5 | * |
6 | * This program is free software; you can redistribute it and/or modify | 6 | * This program is free software; you can redistribute it and/or modify |
@@ -17,7 +17,7 @@ struct samsung_pd_info { | |||
17 | void __iomem *base; | 17 | void __iomem *base; |
18 | }; | 18 | }; |
19 | 19 | ||
20 | enum s5pv310_pd_block { | 20 | enum exynos4_pd_block { |
21 | PD_MFC, | 21 | PD_MFC, |
22 | PD_G3D, | 22 | PD_G3D, |
23 | PD_LCD0, | 23 | PD_LCD0, |
diff --git a/arch/arm/plat-samsung/include/plat/sdhci.h b/arch/arm/plat-samsung/include/plat/sdhci.h index 5a41a0b69eec..b0bdf16549d5 100644 --- a/arch/arm/plat-samsung/include/plat/sdhci.h +++ b/arch/arm/plat-samsung/include/plat/sdhci.h | |||
@@ -1,4 +1,7 @@ | |||
1 | /* linux/arch/arm/plat-s3c/include/plat/sdhci.h | 1 | /* linux/arch/arm/plat-samsung/include/plat/sdhci.h |
2 | * | ||
3 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
2 | * | 5 | * |
3 | * Copyright 2008 Openmoko, Inc. | 6 | * Copyright 2008 Openmoko, Inc. |
4 | * Copyright 2008 Simtec Electronics | 7 | * Copyright 2008 Simtec Electronics |
@@ -119,10 +122,10 @@ extern void s5pv210_setup_sdhci0_cfg_gpio(struct platform_device *, int w); | |||
119 | extern void s5pv210_setup_sdhci1_cfg_gpio(struct platform_device *, int w); | 122 | extern void s5pv210_setup_sdhci1_cfg_gpio(struct platform_device *, int w); |
120 | extern void s5pv210_setup_sdhci2_cfg_gpio(struct platform_device *, int w); | 123 | extern void s5pv210_setup_sdhci2_cfg_gpio(struct platform_device *, int w); |
121 | extern void s5pv210_setup_sdhci3_cfg_gpio(struct platform_device *, int w); | 124 | extern void s5pv210_setup_sdhci3_cfg_gpio(struct platform_device *, int w); |
122 | extern void s5pv310_setup_sdhci0_cfg_gpio(struct platform_device *, int w); | 125 | extern void exynos4_setup_sdhci0_cfg_gpio(struct platform_device *, int w); |
123 | extern void s5pv310_setup_sdhci1_cfg_gpio(struct platform_device *, int w); | 126 | extern void exynos4_setup_sdhci1_cfg_gpio(struct platform_device *, int w); |
124 | extern void s5pv310_setup_sdhci2_cfg_gpio(struct platform_device *, int w); | 127 | extern void exynos4_setup_sdhci2_cfg_gpio(struct platform_device *, int w); |
125 | extern void s5pv310_setup_sdhci3_cfg_gpio(struct platform_device *, int w); | 128 | extern void exynos4_setup_sdhci3_cfg_gpio(struct platform_device *, int w); |
126 | 129 | ||
127 | /* S3C2416 SDHCI setup */ | 130 | /* S3C2416 SDHCI setup */ |
128 | 131 | ||
@@ -334,57 +337,57 @@ static inline void s5pv210_default_sdhci3(void) { } | |||
334 | 337 | ||
335 | #endif /* CONFIG_S5PV210_SETUP_SDHCI */ | 338 | #endif /* CONFIG_S5PV210_SETUP_SDHCI */ |
336 | 339 | ||
337 | /* S5PV310 SDHCI setup */ | 340 | /* EXYNOS4 SDHCI setup */ |
338 | #ifdef CONFIG_S5PV310_SETUP_SDHCI | 341 | #ifdef CONFIG_EXYNOS4_SETUP_SDHCI |
339 | extern char *s5pv310_hsmmc_clksrcs[4]; | 342 | extern char *exynos4_hsmmc_clksrcs[4]; |
340 | 343 | ||
341 | extern void s5pv310_setup_sdhci_cfg_card(struct platform_device *dev, | 344 | extern void exynos4_setup_sdhci_cfg_card(struct platform_device *dev, |
342 | void __iomem *r, | 345 | void __iomem *r, |
343 | struct mmc_ios *ios, | 346 | struct mmc_ios *ios, |
344 | struct mmc_card *card); | 347 | struct mmc_card *card); |
345 | 348 | ||
346 | static inline void s5pv310_default_sdhci0(void) | 349 | static inline void exynos4_default_sdhci0(void) |
347 | { | 350 | { |
348 | #ifdef CONFIG_S3C_DEV_HSMMC | 351 | #ifdef CONFIG_S3C_DEV_HSMMC |
349 | s3c_hsmmc0_def_platdata.clocks = s5pv310_hsmmc_clksrcs; | 352 | s3c_hsmmc0_def_platdata.clocks = exynos4_hsmmc_clksrcs; |
350 | s3c_hsmmc0_def_platdata.cfg_gpio = s5pv310_setup_sdhci0_cfg_gpio; | 353 | s3c_hsmmc0_def_platdata.cfg_gpio = exynos4_setup_sdhci0_cfg_gpio; |
351 | s3c_hsmmc0_def_platdata.cfg_card = s5pv310_setup_sdhci_cfg_card; | 354 | s3c_hsmmc0_def_platdata.cfg_card = exynos4_setup_sdhci_cfg_card; |
352 | #endif | 355 | #endif |
353 | } | 356 | } |
354 | 357 | ||
355 | static inline void s5pv310_default_sdhci1(void) | 358 | static inline void exynos4_default_sdhci1(void) |
356 | { | 359 | { |
357 | #ifdef CONFIG_S3C_DEV_HSMMC1 | 360 | #ifdef CONFIG_S3C_DEV_HSMMC1 |
358 | s3c_hsmmc1_def_platdata.clocks = s5pv310_hsmmc_clksrcs; | 361 | s3c_hsmmc1_def_platdata.clocks = exynos4_hsmmc_clksrcs; |
359 | s3c_hsmmc1_def_platdata.cfg_gpio = s5pv310_setup_sdhci1_cfg_gpio; | 362 | s3c_hsmmc1_def_platdata.cfg_gpio = exynos4_setup_sdhci1_cfg_gpio; |
360 | s3c_hsmmc1_def_platdata.cfg_card = s5pv310_setup_sdhci_cfg_card; | 363 | s3c_hsmmc1_def_platdata.cfg_card = exynos4_setup_sdhci_cfg_card; |
361 | #endif | 364 | #endif |
362 | } | 365 | } |
363 | 366 | ||
364 | static inline void s5pv310_default_sdhci2(void) | 367 | static inline void exynos4_default_sdhci2(void) |
365 | { | 368 | { |
366 | #ifdef CONFIG_S3C_DEV_HSMMC2 | 369 | #ifdef CONFIG_S3C_DEV_HSMMC2 |
367 | s3c_hsmmc2_def_platdata.clocks = s5pv310_hsmmc_clksrcs; | 370 | s3c_hsmmc2_def_platdata.clocks = exynos4_hsmmc_clksrcs; |
368 | s3c_hsmmc2_def_platdata.cfg_gpio = s5pv310_setup_sdhci2_cfg_gpio; | 371 | s3c_hsmmc2_def_platdata.cfg_gpio = exynos4_setup_sdhci2_cfg_gpio; |
369 | s3c_hsmmc2_def_platdata.cfg_card = s5pv310_setup_sdhci_cfg_card; | 372 | s3c_hsmmc2_def_platdata.cfg_card = exynos4_setup_sdhci_cfg_card; |
370 | #endif | 373 | #endif |
371 | } | 374 | } |
372 | 375 | ||
373 | static inline void s5pv310_default_sdhci3(void) | 376 | static inline void exynos4_default_sdhci3(void) |
374 | { | 377 | { |
375 | #ifdef CONFIG_S3C_DEV_HSMMC3 | 378 | #ifdef CONFIG_S3C_DEV_HSMMC3 |
376 | s3c_hsmmc3_def_platdata.clocks = s5pv310_hsmmc_clksrcs; | 379 | s3c_hsmmc3_def_platdata.clocks = exynos4_hsmmc_clksrcs; |
377 | s3c_hsmmc3_def_platdata.cfg_gpio = s5pv310_setup_sdhci3_cfg_gpio; | 380 | s3c_hsmmc3_def_platdata.cfg_gpio = exynos4_setup_sdhci3_cfg_gpio; |
378 | s3c_hsmmc3_def_platdata.cfg_card = s5pv310_setup_sdhci_cfg_card; | 381 | s3c_hsmmc3_def_platdata.cfg_card = exynos4_setup_sdhci_cfg_card; |
379 | #endif | 382 | #endif |
380 | } | 383 | } |
381 | 384 | ||
382 | #else | 385 | #else |
383 | static inline void s5pv310_default_sdhci0(void) { } | 386 | static inline void exynos4_default_sdhci0(void) { } |
384 | static inline void s5pv310_default_sdhci1(void) { } | 387 | static inline void exynos4_default_sdhci1(void) { } |
385 | static inline void s5pv310_default_sdhci2(void) { } | 388 | static inline void exynos4_default_sdhci2(void) { } |
386 | static inline void s5pv310_default_sdhci3(void) { } | 389 | static inline void exynos4_default_sdhci3(void) { } |
387 | 390 | ||
388 | #endif /* CONFIG_S5PV310_SETUP_SDHCI */ | 391 | #endif /* CONFIG_EXYNOS4_SETUP_SDHCI */ |
389 | 392 | ||
390 | #endif /* __PLAT_S3C_SDHCI_H */ | 393 | #endif /* __PLAT_S3C_SDHCI_H */ |
diff --git a/arch/arm/plat-samsung/pwm.c b/arch/arm/plat-samsung/pwm.c index 2eeb49fa056d..f37457c52064 100644 --- a/arch/arm/plat-samsung/pwm.c +++ b/arch/arm/plat-samsung/pwm.c | |||
@@ -20,10 +20,8 @@ | |||
20 | #include <linux/io.h> | 20 | #include <linux/io.h> |
21 | #include <linux/pwm.h> | 21 | #include <linux/pwm.h> |
22 | 22 | ||
23 | #include <mach/irqs.h> | ||
24 | #include <mach/map.h> | 23 | #include <mach/map.h> |
25 | 24 | ||
26 | #include <plat/devs.h> | ||
27 | #include <plat/regs-timer.h> | 25 | #include <plat/regs-timer.h> |
28 | 26 | ||
29 | struct pwm_device { | 27 | struct pwm_device { |
@@ -47,37 +45,6 @@ struct pwm_device { | |||
47 | 45 | ||
48 | static struct clk *clk_scaler[2]; | 46 | static struct clk *clk_scaler[2]; |
49 | 47 | ||
50 | /* Standard setup for a timer block. */ | ||
51 | |||
52 | #define TIMER_RESOURCE_SIZE (1) | ||
53 | |||
54 | #define TIMER_RESOURCE(_tmr, _irq) \ | ||
55 | (struct resource [TIMER_RESOURCE_SIZE]) { \ | ||
56 | [0] = { \ | ||
57 | .start = _irq, \ | ||
58 | .end = _irq, \ | ||
59 | .flags = IORESOURCE_IRQ \ | ||
60 | } \ | ||
61 | } | ||
62 | |||
63 | #define DEFINE_S3C_TIMER(_tmr_no, _irq) \ | ||
64 | .name = "s3c24xx-pwm", \ | ||
65 | .id = _tmr_no, \ | ||
66 | .num_resources = TIMER_RESOURCE_SIZE, \ | ||
67 | .resource = TIMER_RESOURCE(_tmr_no, _irq), \ | ||
68 | |||
69 | /* since we already have an static mapping for the timer, we do not | ||
70 | * bother setting any IO resource for the base. | ||
71 | */ | ||
72 | |||
73 | struct platform_device s3c_device_timer[] = { | ||
74 | [0] = { DEFINE_S3C_TIMER(0, IRQ_TIMER0) }, | ||
75 | [1] = { DEFINE_S3C_TIMER(1, IRQ_TIMER1) }, | ||
76 | [2] = { DEFINE_S3C_TIMER(2, IRQ_TIMER2) }, | ||
77 | [3] = { DEFINE_S3C_TIMER(3, IRQ_TIMER3) }, | ||
78 | [4] = { DEFINE_S3C_TIMER(4, IRQ_TIMER4) }, | ||
79 | }; | ||
80 | |||
81 | static inline int pwm_is_tdiv(struct pwm_device *pwm) | 48 | static inline int pwm_is_tdiv(struct pwm_device *pwm) |
82 | { | 49 | { |
83 | return clk_get_parent(pwm->clk) == pwm->clk_div; | 50 | return clk_get_parent(pwm->clk) == pwm->clk_div; |