diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2014-10-08 17:06:53 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2014-10-08 17:06:53 -0400 |
commit | 212fe84a6f215c39795a76517c1c02114d428681 (patch) | |
tree | 4692680312616d6a5c562f2d494c12d21b697237 /arch/arm/mach-at91 | |
parent | 4a4743e840d06a5772be7c21110807165c5b3c9f (diff) | |
parent | 05301fe7de11dac87638f1728f8ee8b31bc1cf31 (diff) |
Merge tag 'cleanup-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc
Pull ARM SoC cleanups from Arnd Bergmann:
"This time around, the cleanup branch contains mostly code removal. A
number of board files for at91, imx and msm have become obsolete
because of the DT conversion and are now ready to be removed. The
OMAP platform has traditionally had its own DMA engine abstraction and
as this is being phased out, a lot of the original code is now unused
and can be removed as well.
S3C24xx can be simplified now that the restart code is a proper device
driver.
Finally, a number of cleanups in shmobile are done to prepare for the
addition of new code in other branches"
* tag 'cleanup-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc: (43 commits)
ARM: at91: Remove the support for the RSI EWS board
arm: mach-omap2: Convert pr_warning to pr_warn
ARM: OMAP: Remove unused pieces of legacy DMA API
ARM: at91: remove board file for Acme Systems Fox G20
ARM: orion5x: Convert pr_warning to pr_warn
ARM: S3C24XX: remove separate restart code
ARM: EXYNOS: Do not calculate boot address twice
ARM: sunxi: Remove sun4i reboot code from mach directory
ARM: imx: Remove mach-mxt_td60 board file
ARM: shmobile: armadillo800eva legacy: Use rmobile_add_devices_to_domains()
ARM: shmobile: r8a7740: Clean up pm domain table
ARM: shmobile: r8a7740: Use rmobile_add_devices_to_domains()
ARM: shmobile: sh7372: Make domain_devices[] static __initdata
ARM: shmobile: mackerel: Make domain_devices[] static __initdata
clocksource: tcb_clksrc: sanitize IRQ request
ARM: at91/tclib: mask interruptions at shutdown and probe
ARM: at91/tclib: move initialization from alloc to probe
ARM: at91/tclib: prefer using of devm_* functions
ARM: clps711x: Switch CLPS711X subarch to use clk and clocksource driver
ARM: shmobile: r8a7791 is now called "R-Car M2-W"
...
Diffstat (limited to 'arch/arm/mach-at91')
-rw-r--r-- | arch/arm/mach-at91/Kconfig | 17 | ||||
-rw-r--r-- | arch/arm/mach-at91/Kconfig.non_dt | 18 | ||||
-rw-r--r-- | arch/arm/mach-at91/Makefile | 5 | ||||
-rw-r--r-- | arch/arm/mach-at91/board-dt-rm9200.c | 13 | ||||
-rw-r--r-- | arch/arm/mach-at91/board-dt-sam9.c | 13 | ||||
-rw-r--r-- | arch/arm/mach-at91/board-dt-sama5.c | 13 | ||||
-rw-r--r-- | arch/arm/mach-at91/board-foxg20.c | 272 | ||||
-rw-r--r-- | arch/arm/mach-at91/board-rsi-ews.c | 232 | ||||
-rw-r--r-- | arch/arm/mach-at91/irq.c | 270 | ||||
-rw-r--r-- | arch/arm/mach-at91/pm.c | 32 | ||||
-rw-r--r-- | arch/arm/mach-at91/setup.c | 3 |
11 files changed, 45 insertions, 843 deletions
diff --git a/arch/arm/mach-at91/Kconfig b/arch/arm/mach-at91/Kconfig index 6cc6f7aebdae..dd28e1fedbdc 100644 --- a/arch/arm/mach-at91/Kconfig +++ b/arch/arm/mach-at91/Kconfig | |||
@@ -28,6 +28,11 @@ config OLD_CLK_AT91 | |||
28 | bool | 28 | bool |
29 | default AT91_PMC_UNIT && AT91_USE_OLD_CLK | 29 | default AT91_PMC_UNIT && AT91_USE_OLD_CLK |
30 | 30 | ||
31 | config OLD_IRQ_AT91 | ||
32 | bool | ||
33 | select MULTI_IRQ_HANDLER | ||
34 | select SPARSE_IRQ | ||
35 | |||
31 | config AT91_SAM9_ALT_RESET | 36 | config AT91_SAM9_ALT_RESET |
32 | bool | 37 | bool |
33 | default !ARCH_AT91X40 | 38 | default !ARCH_AT91X40 |
@@ -45,18 +50,16 @@ config HAVE_AT91_SMD | |||
45 | config SOC_AT91SAM9 | 50 | config SOC_AT91SAM9 |
46 | bool | 51 | bool |
47 | select AT91_SAM9_TIME | 52 | select AT91_SAM9_TIME |
53 | select ATMEL_AIC_IRQ if !OLD_IRQ_AT91 | ||
48 | select CPU_ARM926T | 54 | select CPU_ARM926T |
49 | select GENERIC_CLOCKEVENTS | 55 | select GENERIC_CLOCKEVENTS |
50 | select MULTI_IRQ_HANDLER | ||
51 | select SPARSE_IRQ | ||
52 | 56 | ||
53 | config SOC_SAMA5 | 57 | config SOC_SAMA5 |
54 | bool | 58 | bool |
55 | select AT91_SAM9_TIME | 59 | select AT91_SAM9_TIME |
60 | select ATMEL_AIC5_IRQ | ||
56 | select CPU_V7 | 61 | select CPU_V7 |
57 | select GENERIC_CLOCKEVENTS | 62 | select GENERIC_CLOCKEVENTS |
58 | select MULTI_IRQ_HANDLER | ||
59 | select SPARSE_IRQ | ||
60 | select USE_OF | 63 | select USE_OF |
61 | 64 | ||
62 | menu "Atmel AT91 System-on-Chip" | 65 | menu "Atmel AT91 System-on-Chip" |
@@ -70,8 +73,7 @@ config ARCH_AT91X40 | |||
70 | depends on !MMU | 73 | depends on !MMU |
71 | select CPU_ARM7TDMI | 74 | select CPU_ARM7TDMI |
72 | select ARCH_USES_GETTIMEOFFSET | 75 | select ARCH_USES_GETTIMEOFFSET |
73 | select MULTI_IRQ_HANDLER | 76 | select OLD_IRQ_AT91 |
74 | select SPARSE_IRQ | ||
75 | 77 | ||
76 | help | 78 | help |
77 | Select this if you are using one of Atmel's AT91X40 SoC. | 79 | Select this if you are using one of Atmel's AT91X40 SoC. |
@@ -108,11 +110,10 @@ endif | |||
108 | if SOC_SAM_V4_V5 | 110 | if SOC_SAM_V4_V5 |
109 | config SOC_AT91RM9200 | 111 | config SOC_AT91RM9200 |
110 | bool "AT91RM9200" | 112 | bool "AT91RM9200" |
113 | select ATMEL_AIC_IRQ if !OLD_IRQ_AT91 | ||
111 | select CPU_ARM920T | 114 | select CPU_ARM920T |
112 | select GENERIC_CLOCKEVENTS | 115 | select GENERIC_CLOCKEVENTS |
113 | select HAVE_AT91_DBGU0 | 116 | select HAVE_AT91_DBGU0 |
114 | select MULTI_IRQ_HANDLER | ||
115 | select SPARSE_IRQ | ||
116 | select HAVE_AT91_USB_CLK | 117 | select HAVE_AT91_USB_CLK |
117 | 118 | ||
118 | config SOC_AT91SAM9260 | 119 | config SOC_AT91SAM9260 |
diff --git a/arch/arm/mach-at91/Kconfig.non_dt b/arch/arm/mach-at91/Kconfig.non_dt index 44ace320d2e1..d8e88219edb4 100644 --- a/arch/arm/mach-at91/Kconfig.non_dt +++ b/arch/arm/mach-at91/Kconfig.non_dt | |||
@@ -14,31 +14,37 @@ config ARCH_AT91RM9200 | |||
14 | bool "AT91RM9200" | 14 | bool "AT91RM9200" |
15 | select SOC_AT91RM9200 | 15 | select SOC_AT91RM9200 |
16 | select AT91_USE_OLD_CLK | 16 | select AT91_USE_OLD_CLK |
17 | select OLD_IRQ_AT91 | ||
17 | 18 | ||
18 | config ARCH_AT91SAM9260 | 19 | config ARCH_AT91SAM9260 |
19 | bool "AT91SAM9260 or AT91SAM9XE or AT91SAM9G20" | 20 | bool "AT91SAM9260 or AT91SAM9XE or AT91SAM9G20" |
20 | select SOC_AT91SAM9260 | 21 | select SOC_AT91SAM9260 |
21 | select AT91_USE_OLD_CLK | 22 | select AT91_USE_OLD_CLK |
23 | select OLD_IRQ_AT91 | ||
22 | 24 | ||
23 | config ARCH_AT91SAM9261 | 25 | config ARCH_AT91SAM9261 |
24 | bool "AT91SAM9261 or AT91SAM9G10" | 26 | bool "AT91SAM9261 or AT91SAM9G10" |
25 | select SOC_AT91SAM9261 | 27 | select SOC_AT91SAM9261 |
26 | select AT91_USE_OLD_CLK | 28 | select AT91_USE_OLD_CLK |
29 | select OLD_IRQ_AT91 | ||
27 | 30 | ||
28 | config ARCH_AT91SAM9263 | 31 | config ARCH_AT91SAM9263 |
29 | bool "AT91SAM9263" | 32 | bool "AT91SAM9263" |
30 | select SOC_AT91SAM9263 | 33 | select SOC_AT91SAM9263 |
31 | select AT91_USE_OLD_CLK | 34 | select AT91_USE_OLD_CLK |
35 | select OLD_IRQ_AT91 | ||
32 | 36 | ||
33 | config ARCH_AT91SAM9RL | 37 | config ARCH_AT91SAM9RL |
34 | bool "AT91SAM9RL" | 38 | bool "AT91SAM9RL" |
35 | select SOC_AT91SAM9RL | 39 | select SOC_AT91SAM9RL |
36 | select AT91_USE_OLD_CLK | 40 | select AT91_USE_OLD_CLK |
41 | select OLD_IRQ_AT91 | ||
37 | 42 | ||
38 | config ARCH_AT91SAM9G45 | 43 | config ARCH_AT91SAM9G45 |
39 | bool "AT91SAM9G45" | 44 | bool "AT91SAM9G45" |
40 | select SOC_AT91SAM9G45 | 45 | select SOC_AT91SAM9G45 |
41 | select AT91_USE_OLD_CLK | 46 | select AT91_USE_OLD_CLK |
47 | select OLD_IRQ_AT91 | ||
42 | 48 | ||
43 | endchoice | 49 | endchoice |
44 | 50 | ||
@@ -132,12 +138,6 @@ config MACH_ECO920 | |||
132 | bool "eco920" | 138 | bool "eco920" |
133 | help | 139 | help |
134 | Select this if you are using the eco920 board | 140 | Select this if you are using the eco920 board |
135 | |||
136 | config MACH_RSI_EWS | ||
137 | bool "RSI Embedded Webserver" | ||
138 | depends on ARCH_AT91RM9200 | ||
139 | help | ||
140 | Select this if you are using RSIs EWS board. | ||
141 | endif | 141 | endif |
142 | 142 | ||
143 | # ---------------------------------------------------------- | 143 | # ---------------------------------------------------------- |
@@ -212,12 +212,6 @@ config MACH_CPU9G20 | |||
212 | Select this if you are using a Eukrea Electromatique's | 212 | Select this if you are using a Eukrea Electromatique's |
213 | CPU9G20 Board <http://www.eukrea.com/> | 213 | CPU9G20 Board <http://www.eukrea.com/> |
214 | 214 | ||
215 | config MACH_ACMENETUSFOXG20 | ||
216 | bool "Acme Systems srl FOX Board G20" | ||
217 | help | ||
218 | Select this if you are using Acme Systems | ||
219 | FOX Board G20 <http://www.acmesystems.it> | ||
220 | |||
221 | config MACH_PORTUXG20 | 215 | config MACH_PORTUXG20 |
222 | bool "taskit PortuxG20" | 216 | bool "taskit PortuxG20" |
223 | help | 217 | help |
diff --git a/arch/arm/mach-at91/Makefile b/arch/arm/mach-at91/Makefile index 78e9cec282f4..40946f4e8921 100644 --- a/arch/arm/mach-at91/Makefile +++ b/arch/arm/mach-at91/Makefile | |||
@@ -2,11 +2,12 @@ | |||
2 | # Makefile for the linux kernel. | 2 | # Makefile for the linux kernel. |
3 | # | 3 | # |
4 | 4 | ||
5 | obj-y := irq.o gpio.o setup.o sysirq_mask.o | 5 | obj-y := gpio.o setup.o sysirq_mask.o |
6 | obj-m := | 6 | obj-m := |
7 | obj-n := | 7 | obj-n := |
8 | obj- := | 8 | obj- := |
9 | 9 | ||
10 | obj-$(CONFIG_OLD_IRQ_AT91) += irq.o | ||
10 | obj-$(CONFIG_OLD_CLK_AT91) += clock.o | 11 | obj-$(CONFIG_OLD_CLK_AT91) += clock.o |
11 | obj-$(CONFIG_AT91_SAM9_ALT_RESET) += at91sam9_alt_reset.o | 12 | obj-$(CONFIG_AT91_SAM9_ALT_RESET) += at91sam9_alt_reset.o |
12 | obj-$(CONFIG_AT91_SAM9G45_RESET) += at91sam9g45_reset.o | 13 | obj-$(CONFIG_AT91_SAM9G45_RESET) += at91sam9g45_reset.o |
@@ -46,7 +47,6 @@ obj-$(CONFIG_MACH_ECBAT91) += board-ecbat91.o | |||
46 | obj-$(CONFIG_MACH_YL9200) += board-yl-9200.o | 47 | obj-$(CONFIG_MACH_YL9200) += board-yl-9200.o |
47 | obj-$(CONFIG_MACH_CPUAT91) += board-cpuat91.o | 48 | obj-$(CONFIG_MACH_CPUAT91) += board-cpuat91.o |
48 | obj-$(CONFIG_MACH_ECO920) += board-eco920.o | 49 | obj-$(CONFIG_MACH_ECO920) += board-eco920.o |
49 | obj-$(CONFIG_MACH_RSI_EWS) += board-rsi-ews.o | ||
50 | 50 | ||
51 | # AT91SAM9260 board-specific support | 51 | # AT91SAM9260 board-specific support |
52 | obj-$(CONFIG_MACH_AT91SAM9260EK) += board-sam9260ek.o | 52 | obj-$(CONFIG_MACH_AT91SAM9260EK) += board-sam9260ek.o |
@@ -69,7 +69,6 @@ obj-$(CONFIG_MACH_AT91SAM9RLEK) += board-sam9rlek.o | |||
69 | # AT91SAM9G20 board-specific support | 69 | # AT91SAM9G20 board-specific support |
70 | obj-$(CONFIG_MACH_AT91SAM9G20EK) += board-sam9g20ek.o | 70 | obj-$(CONFIG_MACH_AT91SAM9G20EK) += board-sam9g20ek.o |
71 | obj-$(CONFIG_MACH_CPU9G20) += board-cpu9krea.o | 71 | obj-$(CONFIG_MACH_CPU9G20) += board-cpu9krea.o |
72 | obj-$(CONFIG_MACH_ACMENETUSFOXG20) += board-foxg20.o | ||
73 | obj-$(CONFIG_MACH_STAMP9G20) += board-stamp9g20.o | 72 | obj-$(CONFIG_MACH_STAMP9G20) += board-stamp9g20.o |
74 | obj-$(CONFIG_MACH_PORTUXG20) += board-stamp9g20.o | 73 | obj-$(CONFIG_MACH_PORTUXG20) += board-stamp9g20.o |
75 | obj-$(CONFIG_MACH_PCONTROL_G20) += board-pcontrol-g20.o board-stamp9g20.o | 74 | obj-$(CONFIG_MACH_PCONTROL_G20) += board-pcontrol-g20.o board-stamp9g20.o |
diff --git a/arch/arm/mach-at91/board-dt-rm9200.c b/arch/arm/mach-at91/board-dt-rm9200.c index f4b6e91843e4..226563f850b8 100644 --- a/arch/arm/mach-at91/board-dt-rm9200.c +++ b/arch/arm/mach-at91/board-dt-rm9200.c | |||
@@ -25,17 +25,6 @@ | |||
25 | #include "at91_aic.h" | 25 | #include "at91_aic.h" |
26 | #include "generic.h" | 26 | #include "generic.h" |
27 | 27 | ||
28 | |||
29 | static const struct of_device_id irq_of_match[] __initconst = { | ||
30 | { .compatible = "atmel,at91rm9200-aic", .data = at91_aic_of_init }, | ||
31 | { /*sentinel*/ } | ||
32 | }; | ||
33 | |||
34 | static void __init at91rm9200_dt_init_irq(void) | ||
35 | { | ||
36 | of_irq_init(irq_of_match); | ||
37 | } | ||
38 | |||
39 | static void __init at91rm9200_dt_timer_init(void) | 28 | static void __init at91rm9200_dt_timer_init(void) |
40 | { | 29 | { |
41 | #if defined(CONFIG_COMMON_CLK) | 30 | #if defined(CONFIG_COMMON_CLK) |
@@ -52,8 +41,6 @@ static const char *at91rm9200_dt_board_compat[] __initdata = { | |||
52 | DT_MACHINE_START(at91rm9200_dt, "Atmel AT91RM9200 (Device Tree)") | 41 | DT_MACHINE_START(at91rm9200_dt, "Atmel AT91RM9200 (Device Tree)") |
53 | .init_time = at91rm9200_dt_timer_init, | 42 | .init_time = at91rm9200_dt_timer_init, |
54 | .map_io = at91_map_io, | 43 | .map_io = at91_map_io, |
55 | .handle_irq = at91_aic_handle_irq, | ||
56 | .init_early = at91rm9200_dt_initialize, | 44 | .init_early = at91rm9200_dt_initialize, |
57 | .init_irq = at91rm9200_dt_init_irq, | ||
58 | .dt_compat = at91rm9200_dt_board_compat, | 45 | .dt_compat = at91rm9200_dt_board_compat, |
59 | MACHINE_END | 46 | MACHINE_END |
diff --git a/arch/arm/mach-at91/board-dt-sam9.c b/arch/arm/mach-at91/board-dt-sam9.c index 575b0be66ca8..dfa8d48146fe 100644 --- a/arch/arm/mach-at91/board-dt-sam9.c +++ b/arch/arm/mach-at91/board-dt-sam9.c | |||
@@ -34,17 +34,6 @@ static void __init sam9_dt_timer_init(void) | |||
34 | at91sam926x_pit_init(); | 34 | at91sam926x_pit_init(); |
35 | } | 35 | } |
36 | 36 | ||
37 | static const struct of_device_id irq_of_match[] __initconst = { | ||
38 | |||
39 | { .compatible = "atmel,at91rm9200-aic", .data = at91_aic_of_init }, | ||
40 | { /*sentinel*/ } | ||
41 | }; | ||
42 | |||
43 | static void __init at91_dt_init_irq(void) | ||
44 | { | ||
45 | of_irq_init(irq_of_match); | ||
46 | } | ||
47 | |||
48 | static const char *at91_dt_board_compat[] __initdata = { | 37 | static const char *at91_dt_board_compat[] __initdata = { |
49 | "atmel,at91sam9", | 38 | "atmel,at91sam9", |
50 | NULL | 39 | NULL |
@@ -54,8 +43,6 @@ DT_MACHINE_START(at91sam_dt, "Atmel AT91SAM (Device Tree)") | |||
54 | /* Maintainer: Atmel */ | 43 | /* Maintainer: Atmel */ |
55 | .init_time = sam9_dt_timer_init, | 44 | .init_time = sam9_dt_timer_init, |
56 | .map_io = at91_map_io, | 45 | .map_io = at91_map_io, |
57 | .handle_irq = at91_aic_handle_irq, | ||
58 | .init_early = at91_dt_initialize, | 46 | .init_early = at91_dt_initialize, |
59 | .init_irq = at91_dt_init_irq, | ||
60 | .dt_compat = at91_dt_board_compat, | 47 | .dt_compat = at91_dt_board_compat, |
61 | MACHINE_END | 48 | MACHINE_END |
diff --git a/arch/arm/mach-at91/board-dt-sama5.c b/arch/arm/mach-at91/board-dt-sama5.c index 075ec0576ada..d6fe04bcaabd 100644 --- a/arch/arm/mach-at91/board-dt-sama5.c +++ b/arch/arm/mach-at91/board-dt-sama5.c | |||
@@ -35,17 +35,6 @@ static void __init sama5_dt_timer_init(void) | |||
35 | at91sam926x_pit_init(); | 35 | at91sam926x_pit_init(); |
36 | } | 36 | } |
37 | 37 | ||
38 | static const struct of_device_id irq_of_match[] __initconst = { | ||
39 | |||
40 | { .compatible = "atmel,sama5d3-aic", .data = at91_aic5_of_init }, | ||
41 | { /*sentinel*/ } | ||
42 | }; | ||
43 | |||
44 | static void __init at91_dt_init_irq(void) | ||
45 | { | ||
46 | of_irq_init(irq_of_match); | ||
47 | } | ||
48 | |||
49 | static int ksz9021rn_phy_fixup(struct phy_device *phy) | 38 | static int ksz9021rn_phy_fixup(struct phy_device *phy) |
50 | { | 39 | { |
51 | int value; | 40 | int value; |
@@ -82,9 +71,7 @@ DT_MACHINE_START(sama5_dt, "Atmel SAMA5 (Device Tree)") | |||
82 | /* Maintainer: Atmel */ | 71 | /* Maintainer: Atmel */ |
83 | .init_time = sama5_dt_timer_init, | 72 | .init_time = sama5_dt_timer_init, |
84 | .map_io = at91_map_io, | 73 | .map_io = at91_map_io, |
85 | .handle_irq = at91_aic5_handle_irq, | ||
86 | .init_early = at91_dt_initialize, | 74 | .init_early = at91_dt_initialize, |
87 | .init_irq = at91_dt_init_irq, | ||
88 | .init_machine = sama5_dt_device_init, | 75 | .init_machine = sama5_dt_device_init, |
89 | .dt_compat = sama5_dt_board_compat, | 76 | .dt_compat = sama5_dt_board_compat, |
90 | MACHINE_END | 77 | MACHINE_END |
diff --git a/arch/arm/mach-at91/board-foxg20.c b/arch/arm/mach-at91/board-foxg20.c deleted file mode 100644 index 8b22c60bb238..000000000000 --- a/arch/arm/mach-at91/board-foxg20.c +++ /dev/null | |||
@@ -1,272 +0,0 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2005 SAN People | ||
3 | * Copyright (C) 2008 Atmel | ||
4 | * Copyright (C) 2010 Lee McLoughlin - lee@lmmrtech.com | ||
5 | * Copyright (C) 2010 Sergio Tanzilli - tanzilli@acmesystems.it | ||
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 as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | |||
22 | #include <linux/types.h> | ||
23 | #include <linux/init.h> | ||
24 | #include <linux/mm.h> | ||
25 | #include <linux/module.h> | ||
26 | #include <linux/platform_device.h> | ||
27 | #include <linux/spi/spi.h> | ||
28 | #include <linux/spi/at73c213.h> | ||
29 | #include <linux/gpio.h> | ||
30 | #include <linux/gpio_keys.h> | ||
31 | #include <linux/input.h> | ||
32 | #include <linux/clk.h> | ||
33 | #include <linux/w1-gpio.h> | ||
34 | |||
35 | #include <mach/hardware.h> | ||
36 | #include <asm/setup.h> | ||
37 | #include <asm/mach-types.h> | ||
38 | #include <asm/irq.h> | ||
39 | |||
40 | #include <asm/mach/arch.h> | ||
41 | #include <asm/mach/map.h> | ||
42 | #include <asm/mach/irq.h> | ||
43 | |||
44 | #include <mach/at91sam9_smc.h> | ||
45 | |||
46 | #include "at91_aic.h" | ||
47 | #include "board.h" | ||
48 | #include "sam9_smc.h" | ||
49 | #include "generic.h" | ||
50 | #include "gpio.h" | ||
51 | |||
52 | /* | ||
53 | * The FOX Board G20 hardware comes as the "Netus G20" board with | ||
54 | * just the cpu, ram, dataflash and two header connectors. | ||
55 | * This is plugged into the FOX Board which provides the ethernet, | ||
56 | * usb, rtc, leds, switch, ... | ||
57 | * | ||
58 | * For more info visit: http://www.acmesystems.it/foxg20 | ||
59 | */ | ||
60 | |||
61 | |||
62 | static void __init foxg20_init_early(void) | ||
63 | { | ||
64 | /* Initialize processor: 18.432 MHz crystal */ | ||
65 | at91_initialize(18432000); | ||
66 | } | ||
67 | |||
68 | /* | ||
69 | * USB Host port | ||
70 | */ | ||
71 | static struct at91_usbh_data __initdata foxg20_usbh_data = { | ||
72 | .ports = 2, | ||
73 | .vbus_pin = {-EINVAL, -EINVAL}, | ||
74 | .overcurrent_pin= {-EINVAL, -EINVAL}, | ||
75 | }; | ||
76 | |||
77 | /* | ||
78 | * USB Device port | ||
79 | */ | ||
80 | static struct at91_udc_data __initdata foxg20_udc_data = { | ||
81 | .vbus_pin = AT91_PIN_PC6, | ||
82 | .pullup_pin = -EINVAL, /* pull-up driven by UDC */ | ||
83 | }; | ||
84 | |||
85 | |||
86 | /* | ||
87 | * SPI devices. | ||
88 | */ | ||
89 | static struct spi_board_info foxg20_spi_devices[] = { | ||
90 | #if !IS_ENABLED(CONFIG_MMC_ATMELMCI) | ||
91 | { | ||
92 | .modalias = "mtd_dataflash", | ||
93 | .chip_select = 1, | ||
94 | .max_speed_hz = 15 * 1000 * 1000, | ||
95 | .bus_num = 0, | ||
96 | }, | ||
97 | #endif | ||
98 | }; | ||
99 | |||
100 | |||
101 | /* | ||
102 | * MACB Ethernet device | ||
103 | */ | ||
104 | static struct macb_platform_data __initdata foxg20_macb_data = { | ||
105 | .phy_irq_pin = AT91_PIN_PA7, | ||
106 | .is_rmii = 1, | ||
107 | }; | ||
108 | |||
109 | /* | ||
110 | * MCI (SD/MMC) | ||
111 | * det_pin, wp_pin and vcc_pin are not connected | ||
112 | */ | ||
113 | static struct mci_platform_data __initdata foxg20_mci0_data = { | ||
114 | .slot[1] = { | ||
115 | .bus_width = 4, | ||
116 | .detect_pin = -EINVAL, | ||
117 | .wp_pin = -EINVAL, | ||
118 | }, | ||
119 | }; | ||
120 | |||
121 | |||
122 | /* | ||
123 | * LEDs | ||
124 | */ | ||
125 | static struct gpio_led foxg20_leds[] = { | ||
126 | { /* user led, red */ | ||
127 | .name = "user_led", | ||
128 | .gpio = AT91_PIN_PC7, | ||
129 | .active_low = 0, | ||
130 | .default_trigger = "heartbeat", | ||
131 | }, | ||
132 | }; | ||
133 | |||
134 | |||
135 | /* | ||
136 | * GPIO Buttons | ||
137 | */ | ||
138 | #if defined(CONFIG_KEYBOARD_GPIO) || defined(CONFIG_KEYBOARD_GPIO_MODULE) | ||
139 | static struct gpio_keys_button foxg20_buttons[] = { | ||
140 | { | ||
141 | .gpio = AT91_PIN_PC4, | ||
142 | .code = BTN_1, | ||
143 | .desc = "Button 1", | ||
144 | .active_low = 1, | ||
145 | .wakeup = 1, | ||
146 | }, | ||
147 | }; | ||
148 | |||
149 | static struct gpio_keys_platform_data foxg20_button_data = { | ||
150 | .buttons = foxg20_buttons, | ||
151 | .nbuttons = ARRAY_SIZE(foxg20_buttons), | ||
152 | }; | ||
153 | |||
154 | static struct platform_device foxg20_button_device = { | ||
155 | .name = "gpio-keys", | ||
156 | .id = -1, | ||
157 | .num_resources = 0, | ||
158 | .dev = { | ||
159 | .platform_data = &foxg20_button_data, | ||
160 | } | ||
161 | }; | ||
162 | |||
163 | static void __init foxg20_add_device_buttons(void) | ||
164 | { | ||
165 | at91_set_gpio_input(AT91_PIN_PC4, 1); /* btn1 */ | ||
166 | at91_set_deglitch(AT91_PIN_PC4, 1); | ||
167 | |||
168 | platform_device_register(&foxg20_button_device); | ||
169 | } | ||
170 | #else | ||
171 | static void __init foxg20_add_device_buttons(void) {} | ||
172 | #endif | ||
173 | |||
174 | |||
175 | #if defined(CONFIG_W1_MASTER_GPIO) || defined(CONFIG_W1_MASTER_GPIO_MODULE) | ||
176 | static struct w1_gpio_platform_data w1_gpio_pdata = { | ||
177 | /* If you choose to use a pin other than PB16 it needs to be 3.3V */ | ||
178 | .pin = AT91_PIN_PB16, | ||
179 | .is_open_drain = 1, | ||
180 | .ext_pullup_enable_pin = -EINVAL, | ||
181 | }; | ||
182 | |||
183 | static struct platform_device w1_device = { | ||
184 | .name = "w1-gpio", | ||
185 | .id = -1, | ||
186 | .dev.platform_data = &w1_gpio_pdata, | ||
187 | }; | ||
188 | |||
189 | static void __init at91_add_device_w1(void) | ||
190 | { | ||
191 | at91_set_GPIO_periph(w1_gpio_pdata.pin, 1); | ||
192 | at91_set_multi_drive(w1_gpio_pdata.pin, 1); | ||
193 | platform_device_register(&w1_device); | ||
194 | } | ||
195 | |||
196 | #endif | ||
197 | |||
198 | |||
199 | static struct i2c_board_info __initdata foxg20_i2c_devices[] = { | ||
200 | { | ||
201 | I2C_BOARD_INFO("24c512", 0x50), | ||
202 | }, | ||
203 | }; | ||
204 | |||
205 | |||
206 | static void __init foxg20_board_init(void) | ||
207 | { | ||
208 | /* Serial */ | ||
209 | /* DBGU on ttyS0. (Rx & Tx only) */ | ||
210 | at91_register_uart(0, 0, 0); | ||
211 | |||
212 | /* USART0 on ttyS1. (Rx, Tx, CTS, RTS, DTR, DSR, DCD, RI) */ | ||
213 | at91_register_uart(AT91SAM9260_ID_US0, 1, | ||
214 | ATMEL_UART_CTS | ||
215 | | ATMEL_UART_RTS | ||
216 | | ATMEL_UART_DTR | ||
217 | | ATMEL_UART_DSR | ||
218 | | ATMEL_UART_DCD | ||
219 | | ATMEL_UART_RI); | ||
220 | |||
221 | /* USART1 on ttyS2. (Rx, Tx, RTS, CTS) */ | ||
222 | at91_register_uart(AT91SAM9260_ID_US1, 2, | ||
223 | ATMEL_UART_CTS | ||
224 | | ATMEL_UART_RTS); | ||
225 | |||
226 | /* USART2 on ttyS3. (Rx & Tx only) */ | ||
227 | at91_register_uart(AT91SAM9260_ID_US2, 3, 0); | ||
228 | |||
229 | /* USART3 on ttyS4. (Rx, Tx, RTS, CTS) */ | ||
230 | at91_register_uart(AT91SAM9260_ID_US3, 4, | ||
231 | ATMEL_UART_CTS | ||
232 | | ATMEL_UART_RTS); | ||
233 | |||
234 | /* USART4 on ttyS5. (Rx & Tx only) */ | ||
235 | at91_register_uart(AT91SAM9260_ID_US4, 5, 0); | ||
236 | |||
237 | /* USART5 on ttyS6. (Rx & Tx only) */ | ||
238 | at91_register_uart(AT91SAM9260_ID_US5, 6, 0); | ||
239 | |||
240 | /* Set the internal pull-up resistor on DRXD */ | ||
241 | at91_set_A_periph(AT91_PIN_PB14, 1); | ||
242 | at91_add_device_serial(); | ||
243 | /* USB Host */ | ||
244 | at91_add_device_usbh(&foxg20_usbh_data); | ||
245 | /* USB Device */ | ||
246 | at91_add_device_udc(&foxg20_udc_data); | ||
247 | /* SPI */ | ||
248 | at91_add_device_spi(foxg20_spi_devices, ARRAY_SIZE(foxg20_spi_devices)); | ||
249 | /* Ethernet */ | ||
250 | at91_add_device_eth(&foxg20_macb_data); | ||
251 | /* MMC */ | ||
252 | at91_add_device_mci(0, &foxg20_mci0_data); | ||
253 | /* I2C */ | ||
254 | at91_add_device_i2c(foxg20_i2c_devices, ARRAY_SIZE(foxg20_i2c_devices)); | ||
255 | /* LEDs */ | ||
256 | at91_gpio_leds(foxg20_leds, ARRAY_SIZE(foxg20_leds)); | ||
257 | /* Push Buttons */ | ||
258 | foxg20_add_device_buttons(); | ||
259 | #if defined(CONFIG_W1_MASTER_GPIO) || defined(CONFIG_W1_MASTER_GPIO_MODULE) | ||
260 | at91_add_device_w1(); | ||
261 | #endif | ||
262 | } | ||
263 | |||
264 | MACHINE_START(ACMENETUSFOXG20, "Acme Systems srl FOX Board G20") | ||
265 | /* Maintainer: Sergio Tanzilli */ | ||
266 | .init_time = at91sam926x_pit_init, | ||
267 | .map_io = at91_map_io, | ||
268 | .handle_irq = at91_aic_handle_irq, | ||
269 | .init_early = foxg20_init_early, | ||
270 | .init_irq = at91_init_irq_default, | ||
271 | .init_machine = foxg20_board_init, | ||
272 | MACHINE_END | ||
diff --git a/arch/arm/mach-at91/board-rsi-ews.c b/arch/arm/mach-at91/board-rsi-ews.c deleted file mode 100644 index f28e8b74df4b..000000000000 --- a/arch/arm/mach-at91/board-rsi-ews.c +++ /dev/null | |||
@@ -1,232 +0,0 @@ | |||
1 | /* | ||
2 | * board-rsi-ews.c | ||
3 | * | ||
4 | * Copyright (C) | ||
5 | * 2005 SAN People, | ||
6 | * 2008-2011 R-S-I Elektrotechnik GmbH & Co. KG | ||
7 | * | ||
8 | * Licensed under GPLv2 or later. | ||
9 | */ | ||
10 | |||
11 | #include <linux/types.h> | ||
12 | #include <linux/init.h> | ||
13 | #include <linux/mm.h> | ||
14 | #include <linux/module.h> | ||
15 | #include <linux/platform_device.h> | ||
16 | #include <linux/spi/spi.h> | ||
17 | #include <linux/mtd/physmap.h> | ||
18 | |||
19 | #include <asm/setup.h> | ||
20 | #include <asm/mach-types.h> | ||
21 | #include <asm/irq.h> | ||
22 | |||
23 | #include <asm/mach/arch.h> | ||
24 | #include <asm/mach/map.h> | ||
25 | #include <asm/mach/irq.h> | ||
26 | |||
27 | #include <mach/hardware.h> | ||
28 | |||
29 | #include <linux/gpio.h> | ||
30 | |||
31 | #include "at91_aic.h" | ||
32 | #include "board.h" | ||
33 | #include "generic.h" | ||
34 | #include "gpio.h" | ||
35 | |||
36 | static void __init rsi_ews_init_early(void) | ||
37 | { | ||
38 | /* Initialize processor: 18.432 MHz crystal */ | ||
39 | at91_initialize(18432000); | ||
40 | } | ||
41 | |||
42 | /* | ||
43 | * Ethernet | ||
44 | */ | ||
45 | static struct macb_platform_data rsi_ews_eth_data __initdata = { | ||
46 | .phy_irq_pin = AT91_PIN_PC4, | ||
47 | .is_rmii = 1, | ||
48 | }; | ||
49 | |||
50 | /* | ||
51 | * USB Host | ||
52 | */ | ||
53 | static struct at91_usbh_data rsi_ews_usbh_data __initdata = { | ||
54 | .ports = 1, | ||
55 | .vbus_pin = {-EINVAL, -EINVAL}, | ||
56 | .overcurrent_pin= {-EINVAL, -EINVAL}, | ||
57 | }; | ||
58 | |||
59 | /* | ||
60 | * SD/MC | ||
61 | */ | ||
62 | static struct mci_platform_data __initdata rsi_ews_mci0_data = { | ||
63 | .slot[0] = { | ||
64 | .bus_width = 4, | ||
65 | .detect_pin = AT91_PIN_PB27, | ||
66 | .wp_pin = AT91_PIN_PB29, | ||
67 | }, | ||
68 | }; | ||
69 | |||
70 | /* | ||
71 | * I2C | ||
72 | */ | ||
73 | static struct i2c_board_info rsi_ews_i2c_devices[] __initdata = { | ||
74 | { | ||
75 | I2C_BOARD_INFO("ds1337", 0x68), | ||
76 | }, | ||
77 | { | ||
78 | I2C_BOARD_INFO("24c01", 0x50), | ||
79 | } | ||
80 | }; | ||
81 | |||
82 | /* | ||
83 | * LEDs | ||
84 | */ | ||
85 | static struct gpio_led rsi_ews_leds[] = { | ||
86 | { | ||
87 | .name = "led0", | ||
88 | .gpio = AT91_PIN_PB6, | ||
89 | .active_low = 0, | ||
90 | }, | ||
91 | { | ||
92 | .name = "led1", | ||
93 | .gpio = AT91_PIN_PB7, | ||
94 | .active_low = 0, | ||
95 | }, | ||
96 | { | ||
97 | .name = "led2", | ||
98 | .gpio = AT91_PIN_PB8, | ||
99 | .active_low = 0, | ||
100 | }, | ||
101 | { | ||
102 | .name = "led3", | ||
103 | .gpio = AT91_PIN_PB9, | ||
104 | .active_low = 0, | ||
105 | }, | ||
106 | }; | ||
107 | |||
108 | /* | ||
109 | * DataFlash | ||
110 | */ | ||
111 | static struct spi_board_info rsi_ews_spi_devices[] = { | ||
112 | { /* DataFlash chip 1*/ | ||
113 | .modalias = "mtd_dataflash", | ||
114 | .chip_select = 0, | ||
115 | .max_speed_hz = 5 * 1000 * 1000, | ||
116 | }, | ||
117 | { /* DataFlash chip 2*/ | ||
118 | .modalias = "mtd_dataflash", | ||
119 | .chip_select = 1, | ||
120 | .max_speed_hz = 5 * 1000 * 1000, | ||
121 | }, | ||
122 | }; | ||
123 | |||
124 | /* | ||
125 | * NOR flash | ||
126 | */ | ||
127 | static struct mtd_partition rsiews_nor_partitions[] = { | ||
128 | { | ||
129 | .name = "boot", | ||
130 | .offset = 0, | ||
131 | .size = 3 * SZ_128K, | ||
132 | .mask_flags = MTD_WRITEABLE | ||
133 | }, | ||
134 | { | ||
135 | .name = "kernel", | ||
136 | .offset = MTDPART_OFS_NXTBLK, | ||
137 | .size = SZ_2M - (3 * SZ_128K) | ||
138 | }, | ||
139 | { | ||
140 | .name = "root", | ||
141 | .offset = MTDPART_OFS_NXTBLK, | ||
142 | .size = SZ_8M | ||
143 | }, | ||
144 | { | ||
145 | .name = "kernelupd", | ||
146 | .offset = MTDPART_OFS_NXTBLK, | ||
147 | .size = 3 * SZ_512K, | ||
148 | .mask_flags = MTD_WRITEABLE | ||
149 | }, | ||
150 | { | ||
151 | .name = "rootupd", | ||
152 | .offset = MTDPART_OFS_NXTBLK, | ||
153 | .size = 9 * SZ_512K, | ||
154 | .mask_flags = MTD_WRITEABLE | ||
155 | }, | ||
156 | }; | ||
157 | |||
158 | static struct physmap_flash_data rsiews_nor_data = { | ||
159 | .width = 2, | ||
160 | .parts = rsiews_nor_partitions, | ||
161 | .nr_parts = ARRAY_SIZE(rsiews_nor_partitions), | ||
162 | }; | ||
163 | |||
164 | #define NOR_BASE AT91_CHIPSELECT_0 | ||
165 | #define NOR_SIZE SZ_16M | ||
166 | |||
167 | static struct resource nor_flash_resources[] = { | ||
168 | { | ||
169 | .start = NOR_BASE, | ||
170 | .end = NOR_BASE + NOR_SIZE - 1, | ||
171 | .flags = IORESOURCE_MEM, | ||
172 | } | ||
173 | }; | ||
174 | |||
175 | static struct platform_device rsiews_nor_flash = { | ||
176 | .name = "physmap-flash", | ||
177 | .id = 0, | ||
178 | .dev = { | ||
179 | .platform_data = &rsiews_nor_data, | ||
180 | }, | ||
181 | .resource = nor_flash_resources, | ||
182 | .num_resources = ARRAY_SIZE(nor_flash_resources), | ||
183 | }; | ||
184 | |||
185 | /* | ||
186 | * Init Func | ||
187 | */ | ||
188 | static void __init rsi_ews_board_init(void) | ||
189 | { | ||
190 | /* Serial */ | ||
191 | /* DBGU on ttyS0. (Rx & Tx only) */ | ||
192 | /* This one is for debugging */ | ||
193 | at91_register_uart(0, 0, 0); | ||
194 | |||
195 | /* USART1 on ttyS2. (Rx, Tx, CTS, RTS, DTR, DSR, DCD, RI) */ | ||
196 | /* Dialin/-out modem interface */ | ||
197 | at91_register_uart(AT91RM9200_ID_US1, 2, ATMEL_UART_CTS | ATMEL_UART_RTS | ||
198 | | ATMEL_UART_DTR | ATMEL_UART_DSR | ATMEL_UART_DCD | ||
199 | | ATMEL_UART_RI); | ||
200 | |||
201 | /* USART3 on ttyS4. (Rx, Tx, RTS) */ | ||
202 | /* RS485 communication */ | ||
203 | at91_register_uart(AT91RM9200_ID_US3, 4, ATMEL_UART_RTS); | ||
204 | at91_add_device_serial(); | ||
205 | at91_set_gpio_output(AT91_PIN_PA21, 0); | ||
206 | /* Ethernet */ | ||
207 | at91_add_device_eth(&rsi_ews_eth_data); | ||
208 | /* USB Host */ | ||
209 | at91_add_device_usbh(&rsi_ews_usbh_data); | ||
210 | /* I2C */ | ||
211 | at91_add_device_i2c(rsi_ews_i2c_devices, | ||
212 | ARRAY_SIZE(rsi_ews_i2c_devices)); | ||
213 | /* SPI */ | ||
214 | at91_add_device_spi(rsi_ews_spi_devices, | ||
215 | ARRAY_SIZE(rsi_ews_spi_devices)); | ||
216 | /* MMC */ | ||
217 | at91_add_device_mci(0, &rsi_ews_mci0_data); | ||
218 | /* NOR Flash */ | ||
219 | platform_device_register(&rsiews_nor_flash); | ||
220 | /* LEDs */ | ||
221 | at91_gpio_leds(rsi_ews_leds, ARRAY_SIZE(rsi_ews_leds)); | ||
222 | } | ||
223 | |||
224 | MACHINE_START(RSI_EWS, "RSI EWS") | ||
225 | /* Maintainer: Josef Holzmayr <holzmayr@rsi-elektrotechnik.de> */ | ||
226 | .init_time = at91rm9200_timer_init, | ||
227 | .map_io = at91_map_io, | ||
228 | .handle_irq = at91_aic_handle_irq, | ||
229 | .init_early = rsi_ews_init_early, | ||
230 | .init_irq = at91_init_irq_default, | ||
231 | .init_machine = rsi_ews_board_init, | ||
232 | MACHINE_END | ||
diff --git a/arch/arm/mach-at91/irq.c b/arch/arm/mach-at91/irq.c index 3d192c5aee66..cdb3ec9efd2b 100644 --- a/arch/arm/mach-at91/irq.c +++ b/arch/arm/mach-at91/irq.c | |||
@@ -48,11 +48,6 @@ void __iomem *at91_aic_base; | |||
48 | static struct irq_domain *at91_aic_domain; | 48 | static struct irq_domain *at91_aic_domain; |
49 | static struct device_node *at91_aic_np; | 49 | static struct device_node *at91_aic_np; |
50 | static unsigned int n_irqs = NR_AIC_IRQS; | 50 | static unsigned int n_irqs = NR_AIC_IRQS; |
51 | static unsigned long at91_aic_caps = 0; | ||
52 | |||
53 | /* AIC5 introduces a Source Select Register */ | ||
54 | #define AT91_AIC_CAP_AIC5 (1 << 0) | ||
55 | #define has_aic5() (at91_aic_caps & AT91_AIC_CAP_AIC5) | ||
56 | 51 | ||
57 | #ifdef CONFIG_PM | 52 | #ifdef CONFIG_PM |
58 | 53 | ||
@@ -92,50 +87,14 @@ static int at91_aic_set_wake(struct irq_data *d, unsigned value) | |||
92 | 87 | ||
93 | void at91_irq_suspend(void) | 88 | void at91_irq_suspend(void) |
94 | { | 89 | { |
95 | int bit = -1; | 90 | at91_aic_write(AT91_AIC_IDCR, *backups); |
96 | 91 | at91_aic_write(AT91_AIC_IECR, *wakeups); | |
97 | if (has_aic5()) { | ||
98 | /* disable enabled irqs */ | ||
99 | while ((bit = find_next_bit(backups, n_irqs, bit + 1)) < n_irqs) { | ||
100 | at91_aic_write(AT91_AIC5_SSR, | ||
101 | bit & AT91_AIC5_INTSEL_MSK); | ||
102 | at91_aic_write(AT91_AIC5_IDCR, 1); | ||
103 | } | ||
104 | /* enable wakeup irqs */ | ||
105 | bit = -1; | ||
106 | while ((bit = find_next_bit(wakeups, n_irqs, bit + 1)) < n_irqs) { | ||
107 | at91_aic_write(AT91_AIC5_SSR, | ||
108 | bit & AT91_AIC5_INTSEL_MSK); | ||
109 | at91_aic_write(AT91_AIC5_IECR, 1); | ||
110 | } | ||
111 | } else { | ||
112 | at91_aic_write(AT91_AIC_IDCR, *backups); | ||
113 | at91_aic_write(AT91_AIC_IECR, *wakeups); | ||
114 | } | ||
115 | } | 92 | } |
116 | 93 | ||
117 | void at91_irq_resume(void) | 94 | void at91_irq_resume(void) |
118 | { | 95 | { |
119 | int bit = -1; | 96 | at91_aic_write(AT91_AIC_IDCR, *wakeups); |
120 | 97 | at91_aic_write(AT91_AIC_IECR, *backups); | |
121 | if (has_aic5()) { | ||
122 | /* disable wakeup irqs */ | ||
123 | while ((bit = find_next_bit(wakeups, n_irqs, bit + 1)) < n_irqs) { | ||
124 | at91_aic_write(AT91_AIC5_SSR, | ||
125 | bit & AT91_AIC5_INTSEL_MSK); | ||
126 | at91_aic_write(AT91_AIC5_IDCR, 1); | ||
127 | } | ||
128 | /* enable irqs disabled for suspend */ | ||
129 | bit = -1; | ||
130 | while ((bit = find_next_bit(backups, n_irqs, bit + 1)) < n_irqs) { | ||
131 | at91_aic_write(AT91_AIC5_SSR, | ||
132 | bit & AT91_AIC5_INTSEL_MSK); | ||
133 | at91_aic_write(AT91_AIC5_IECR, 1); | ||
134 | } | ||
135 | } else { | ||
136 | at91_aic_write(AT91_AIC_IDCR, *wakeups); | ||
137 | at91_aic_write(AT91_AIC_IECR, *backups); | ||
138 | } | ||
139 | } | 98 | } |
140 | 99 | ||
141 | #else | 100 | #else |
@@ -169,21 +128,6 @@ at91_aic_handle_irq(struct pt_regs *regs) | |||
169 | handle_IRQ(irqnr, regs); | 128 | handle_IRQ(irqnr, regs); |
170 | } | 129 | } |
171 | 130 | ||
172 | asmlinkage void __exception_irq_entry | ||
173 | at91_aic5_handle_irq(struct pt_regs *regs) | ||
174 | { | ||
175 | u32 irqnr; | ||
176 | u32 irqstat; | ||
177 | |||
178 | irqnr = at91_aic_read(AT91_AIC5_IVR); | ||
179 | irqstat = at91_aic_read(AT91_AIC5_ISR); | ||
180 | |||
181 | if (!irqstat) | ||
182 | at91_aic_write(AT91_AIC5_EOICR, 0); | ||
183 | else | ||
184 | handle_IRQ(irqnr, regs); | ||
185 | } | ||
186 | |||
187 | static void at91_aic_mask_irq(struct irq_data *d) | 131 | static void at91_aic_mask_irq(struct irq_data *d) |
188 | { | 132 | { |
189 | /* Disable interrupt on AIC */ | 133 | /* Disable interrupt on AIC */ |
@@ -192,15 +136,6 @@ static void at91_aic_mask_irq(struct irq_data *d) | |||
192 | clear_backup(d->hwirq); | 136 | clear_backup(d->hwirq); |
193 | } | 137 | } |
194 | 138 | ||
195 | static void __maybe_unused at91_aic5_mask_irq(struct irq_data *d) | ||
196 | { | ||
197 | /* Disable interrupt on AIC5 */ | ||
198 | at91_aic_write(AT91_AIC5_SSR, d->hwirq & AT91_AIC5_INTSEL_MSK); | ||
199 | at91_aic_write(AT91_AIC5_IDCR, 1); | ||
200 | /* Update ISR cache */ | ||
201 | clear_backup(d->hwirq); | ||
202 | } | ||
203 | |||
204 | static void at91_aic_unmask_irq(struct irq_data *d) | 139 | static void at91_aic_unmask_irq(struct irq_data *d) |
205 | { | 140 | { |
206 | /* Enable interrupt on AIC */ | 141 | /* Enable interrupt on AIC */ |
@@ -209,15 +144,6 @@ static void at91_aic_unmask_irq(struct irq_data *d) | |||
209 | set_backup(d->hwirq); | 144 | set_backup(d->hwirq); |
210 | } | 145 | } |
211 | 146 | ||
212 | static void __maybe_unused at91_aic5_unmask_irq(struct irq_data *d) | ||
213 | { | ||
214 | /* Enable interrupt on AIC5 */ | ||
215 | at91_aic_write(AT91_AIC5_SSR, d->hwirq & AT91_AIC5_INTSEL_MSK); | ||
216 | at91_aic_write(AT91_AIC5_IECR, 1); | ||
217 | /* Update ISR cache */ | ||
218 | set_backup(d->hwirq); | ||
219 | } | ||
220 | |||
221 | static void at91_aic_eoi(struct irq_data *d) | 147 | static void at91_aic_eoi(struct irq_data *d) |
222 | { | 148 | { |
223 | /* | 149 | /* |
@@ -227,11 +153,6 @@ static void at91_aic_eoi(struct irq_data *d) | |||
227 | at91_aic_write(AT91_AIC_EOICR, 0); | 153 | at91_aic_write(AT91_AIC_EOICR, 0); |
228 | } | 154 | } |
229 | 155 | ||
230 | static void __maybe_unused at91_aic5_eoi(struct irq_data *d) | ||
231 | { | ||
232 | at91_aic_write(AT91_AIC5_EOICR, 0); | ||
233 | } | ||
234 | |||
235 | static unsigned long *at91_extern_irq; | 156 | static unsigned long *at91_extern_irq; |
236 | 157 | ||
237 | u32 at91_get_extern_irq(void) | 158 | u32 at91_get_extern_irq(void) |
@@ -282,16 +203,8 @@ static int at91_aic_set_type(struct irq_data *d, unsigned type) | |||
282 | if (srctype < 0) | 203 | if (srctype < 0) |
283 | return srctype; | 204 | return srctype; |
284 | 205 | ||
285 | if (has_aic5()) { | 206 | smr = at91_aic_read(AT91_AIC_SMR(d->hwirq)) & ~AT91_AIC_SRCTYPE; |
286 | at91_aic_write(AT91_AIC5_SSR, | 207 | at91_aic_write(AT91_AIC_SMR(d->hwirq), smr | srctype); |
287 | d->hwirq & AT91_AIC5_INTSEL_MSK); | ||
288 | smr = at91_aic_read(AT91_AIC5_SMR) & ~AT91_AIC_SRCTYPE; | ||
289 | at91_aic_write(AT91_AIC5_SMR, smr | srctype); | ||
290 | } else { | ||
291 | smr = at91_aic_read(AT91_AIC_SMR(d->hwirq)) | ||
292 | & ~AT91_AIC_SRCTYPE; | ||
293 | at91_aic_write(AT91_AIC_SMR(d->hwirq), smr | srctype); | ||
294 | } | ||
295 | 208 | ||
296 | return 0; | 209 | return 0; |
297 | } | 210 | } |
@@ -331,177 +244,6 @@ static void __init at91_aic_hw_init(unsigned int spu_vector) | |||
331 | at91_aic_write(AT91_AIC_ICCR, 0xFFFFFFFF); | 244 | at91_aic_write(AT91_AIC_ICCR, 0xFFFFFFFF); |
332 | } | 245 | } |
333 | 246 | ||
334 | static void __init __maybe_unused at91_aic5_hw_init(unsigned int spu_vector) | ||
335 | { | ||
336 | int i; | ||
337 | |||
338 | /* | ||
339 | * Perform 8 End Of Interrupt Command to make sure AIC | ||
340 | * will not Lock out nIRQ | ||
341 | */ | ||
342 | for (i = 0; i < 8; i++) | ||
343 | at91_aic_write(AT91_AIC5_EOICR, 0); | ||
344 | |||
345 | /* | ||
346 | * Spurious Interrupt ID in Spurious Vector Register. | ||
347 | * When there is no current interrupt, the IRQ Vector Register | ||
348 | * reads the value stored in AIC_SPU | ||
349 | */ | ||
350 | at91_aic_write(AT91_AIC5_SPU, spu_vector); | ||
351 | |||
352 | /* No debugging in AIC: Debug (Protect) Control Register */ | ||
353 | at91_aic_write(AT91_AIC5_DCR, 0); | ||
354 | |||
355 | /* Disable and clear all interrupts initially */ | ||
356 | for (i = 0; i < n_irqs; i++) { | ||
357 | at91_aic_write(AT91_AIC5_SSR, i & AT91_AIC5_INTSEL_MSK); | ||
358 | at91_aic_write(AT91_AIC5_IDCR, 1); | ||
359 | at91_aic_write(AT91_AIC5_ICCR, 1); | ||
360 | } | ||
361 | } | ||
362 | |||
363 | #if defined(CONFIG_OF) | ||
364 | static unsigned int *at91_aic_irq_priorities; | ||
365 | |||
366 | static int at91_aic_irq_map(struct irq_domain *h, unsigned int virq, | ||
367 | irq_hw_number_t hw) | ||
368 | { | ||
369 | /* Put virq number in Source Vector Register */ | ||
370 | at91_aic_write(AT91_AIC_SVR(hw), virq); | ||
371 | |||
372 | /* Active Low interrupt, with priority */ | ||
373 | at91_aic_write(AT91_AIC_SMR(hw), | ||
374 | AT91_AIC_SRCTYPE_LOW | at91_aic_irq_priorities[hw]); | ||
375 | |||
376 | irq_set_chip_and_handler(virq, &at91_aic_chip, handle_fasteoi_irq); | ||
377 | set_irq_flags(virq, IRQF_VALID | IRQF_PROBE); | ||
378 | |||
379 | return 0; | ||
380 | } | ||
381 | |||
382 | static int at91_aic5_irq_map(struct irq_domain *h, unsigned int virq, | ||
383 | irq_hw_number_t hw) | ||
384 | { | ||
385 | at91_aic_write(AT91_AIC5_SSR, hw & AT91_AIC5_INTSEL_MSK); | ||
386 | |||
387 | /* Put virq number in Source Vector Register */ | ||
388 | at91_aic_write(AT91_AIC5_SVR, virq); | ||
389 | |||
390 | /* Active Low interrupt, with priority */ | ||
391 | at91_aic_write(AT91_AIC5_SMR, | ||
392 | AT91_AIC_SRCTYPE_LOW | at91_aic_irq_priorities[hw]); | ||
393 | |||
394 | irq_set_chip_and_handler(virq, &at91_aic_chip, handle_fasteoi_irq); | ||
395 | set_irq_flags(virq, IRQF_VALID | IRQF_PROBE); | ||
396 | |||
397 | return 0; | ||
398 | } | ||
399 | |||
400 | static int at91_aic_irq_domain_xlate(struct irq_domain *d, struct device_node *ctrlr, | ||
401 | const u32 *intspec, unsigned int intsize, | ||
402 | irq_hw_number_t *out_hwirq, unsigned int *out_type) | ||
403 | { | ||
404 | if (WARN_ON(intsize < 3)) | ||
405 | return -EINVAL; | ||
406 | if (WARN_ON(intspec[0] >= n_irqs)) | ||
407 | return -EINVAL; | ||
408 | if (WARN_ON((intspec[2] < AT91_AIC_IRQ_MIN_PRIORITY) | ||
409 | || (intspec[2] > AT91_AIC_IRQ_MAX_PRIORITY))) | ||
410 | return -EINVAL; | ||
411 | |||
412 | *out_hwirq = intspec[0]; | ||
413 | *out_type = intspec[1] & IRQ_TYPE_SENSE_MASK; | ||
414 | at91_aic_irq_priorities[*out_hwirq] = intspec[2]; | ||
415 | |||
416 | return 0; | ||
417 | } | ||
418 | |||
419 | static struct irq_domain_ops at91_aic_irq_ops = { | ||
420 | .map = at91_aic_irq_map, | ||
421 | .xlate = at91_aic_irq_domain_xlate, | ||
422 | }; | ||
423 | |||
424 | int __init at91_aic_of_common_init(struct device_node *node, | ||
425 | struct device_node *parent) | ||
426 | { | ||
427 | struct property *prop; | ||
428 | const __be32 *p; | ||
429 | u32 val; | ||
430 | |||
431 | at91_extern_irq = kzalloc(BITS_TO_LONGS(n_irqs) | ||
432 | * sizeof(*at91_extern_irq), GFP_KERNEL); | ||
433 | if (!at91_extern_irq) | ||
434 | return -ENOMEM; | ||
435 | |||
436 | if (at91_aic_pm_init()) { | ||
437 | kfree(at91_extern_irq); | ||
438 | return -ENOMEM; | ||
439 | } | ||
440 | |||
441 | at91_aic_irq_priorities = kzalloc(n_irqs | ||
442 | * sizeof(*at91_aic_irq_priorities), | ||
443 | GFP_KERNEL); | ||
444 | if (!at91_aic_irq_priorities) | ||
445 | return -ENOMEM; | ||
446 | |||
447 | at91_aic_base = of_iomap(node, 0); | ||
448 | at91_aic_np = node; | ||
449 | |||
450 | at91_aic_domain = irq_domain_add_linear(at91_aic_np, n_irqs, | ||
451 | &at91_aic_irq_ops, NULL); | ||
452 | if (!at91_aic_domain) | ||
453 | panic("Unable to add AIC irq domain (DT)\n"); | ||
454 | |||
455 | of_property_for_each_u32(node, "atmel,external-irqs", prop, p, val) { | ||
456 | if (val >= n_irqs) | ||
457 | pr_warn("AIC: external irq %d >= %d skip it\n", | ||
458 | val, n_irqs); | ||
459 | else | ||
460 | set_bit(val, at91_extern_irq); | ||
461 | } | ||
462 | |||
463 | irq_set_default_host(at91_aic_domain); | ||
464 | |||
465 | return 0; | ||
466 | } | ||
467 | |||
468 | int __init at91_aic_of_init(struct device_node *node, | ||
469 | struct device_node *parent) | ||
470 | { | ||
471 | int err; | ||
472 | |||
473 | err = at91_aic_of_common_init(node, parent); | ||
474 | if (err) | ||
475 | return err; | ||
476 | |||
477 | at91_aic_hw_init(n_irqs); | ||
478 | |||
479 | return 0; | ||
480 | } | ||
481 | |||
482 | int __init at91_aic5_of_init(struct device_node *node, | ||
483 | struct device_node *parent) | ||
484 | { | ||
485 | int err; | ||
486 | |||
487 | at91_aic_caps |= AT91_AIC_CAP_AIC5; | ||
488 | n_irqs = NR_AIC5_IRQS; | ||
489 | at91_aic_chip.irq_ack = at91_aic5_mask_irq; | ||
490 | at91_aic_chip.irq_mask = at91_aic5_mask_irq; | ||
491 | at91_aic_chip.irq_unmask = at91_aic5_unmask_irq; | ||
492 | at91_aic_chip.irq_eoi = at91_aic5_eoi; | ||
493 | at91_aic_irq_ops.map = at91_aic5_irq_map; | ||
494 | |||
495 | err = at91_aic_of_common_init(node, parent); | ||
496 | if (err) | ||
497 | return err; | ||
498 | |||
499 | at91_aic5_hw_init(n_irqs); | ||
500 | |||
501 | return 0; | ||
502 | } | ||
503 | #endif | ||
504 | |||
505 | /* | 247 | /* |
506 | * Initialize the AIC interrupt controller. | 248 | * Initialize the AIC interrupt controller. |
507 | */ | 249 | */ |
diff --git a/arch/arm/mach-at91/pm.c b/arch/arm/mach-at91/pm.c index e95554532987..5920373809c5 100644 --- a/arch/arm/mach-at91/pm.c +++ b/arch/arm/mach-at91/pm.c | |||
@@ -206,16 +206,19 @@ static int at91_pm_enter(suspend_state_t state) | |||
206 | at91_pinctrl_gpio_suspend(); | 206 | at91_pinctrl_gpio_suspend(); |
207 | else | 207 | else |
208 | at91_gpio_suspend(); | 208 | at91_gpio_suspend(); |
209 | at91_irq_suspend(); | ||
210 | 209 | ||
211 | pr_debug("AT91: PM - wake mask %08x, pm state %d\n", | 210 | if (IS_ENABLED(CONFIG_OLD_IRQ_AT91) && at91_aic_base) { |
212 | /* remember all the always-wake irqs */ | 211 | at91_irq_suspend(); |
213 | (at91_pmc_read(AT91_PMC_PCSR) | 212 | |
214 | | (1 << AT91_ID_FIQ) | 213 | pr_debug("AT91: PM - wake mask %08x, pm state %d\n", |
215 | | (1 << AT91_ID_SYS) | 214 | /* remember all the always-wake irqs */ |
216 | | (at91_get_extern_irq())) | 215 | (at91_pmc_read(AT91_PMC_PCSR) |
217 | & at91_aic_read(AT91_AIC_IMR), | 216 | | (1 << AT91_ID_FIQ) |
218 | state); | 217 | | (1 << AT91_ID_SYS) |
218 | | (at91_get_extern_irq())) | ||
219 | & at91_aic_read(AT91_AIC_IMR), | ||
220 | state); | ||
221 | } | ||
219 | 222 | ||
220 | switch (state) { | 223 | switch (state) { |
221 | /* | 224 | /* |
@@ -280,12 +283,17 @@ static int at91_pm_enter(suspend_state_t state) | |||
280 | goto error; | 283 | goto error; |
281 | } | 284 | } |
282 | 285 | ||
283 | pr_debug("AT91: PM - wakeup %08x\n", | 286 | if (IS_ENABLED(CONFIG_OLD_IRQ_AT91) && at91_aic_base) |
284 | at91_aic_read(AT91_AIC_IPR) & at91_aic_read(AT91_AIC_IMR)); | 287 | pr_debug("AT91: PM - wakeup %08x\n", |
288 | at91_aic_read(AT91_AIC_IPR) & | ||
289 | at91_aic_read(AT91_AIC_IMR)); | ||
285 | 290 | ||
286 | error: | 291 | error: |
287 | target_state = PM_SUSPEND_ON; | 292 | target_state = PM_SUSPEND_ON; |
288 | at91_irq_resume(); | 293 | |
294 | if (IS_ENABLED(CONFIG_OLD_IRQ_AT91) && at91_aic_base) | ||
295 | at91_irq_resume(); | ||
296 | |||
289 | if (of_have_populated_dt()) | 297 | if (of_have_populated_dt()) |
290 | at91_pinctrl_gpio_resume(); | 298 | at91_pinctrl_gpio_resume(); |
291 | else | 299 | else |
diff --git a/arch/arm/mach-at91/setup.c b/arch/arm/mach-at91/setup.c index f7a07a58ebb6..0bf893a574f9 100644 --- a/arch/arm/mach-at91/setup.c +++ b/arch/arm/mach-at91/setup.c | |||
@@ -49,7 +49,8 @@ void __init at91_init_irq_default(void) | |||
49 | void __init at91_init_interrupts(unsigned int *priority) | 49 | void __init at91_init_interrupts(unsigned int *priority) |
50 | { | 50 | { |
51 | /* Initialize the AIC interrupt controller */ | 51 | /* Initialize the AIC interrupt controller */ |
52 | at91_aic_init(priority, at91_boot_soc.extern_irq); | 52 | if (IS_ENABLED(CONFIG_OLD_IRQ_AT91)) |
53 | at91_aic_init(priority, at91_boot_soc.extern_irq); | ||
53 | 54 | ||
54 | /* Enable GPIO interrupts */ | 55 | /* Enable GPIO interrupts */ |
55 | at91_gpio_irq_setup(); | 56 | at91_gpio_irq_setup(); |