diff options
Diffstat (limited to 'arch/arm/mach-at91')
| -rw-r--r-- | arch/arm/mach-at91/Kconfig | 1 | ||||
| -rw-r--r-- | arch/arm/mach-at91/Kconfig.non_dt | 169 | ||||
| -rw-r--r-- | arch/arm/mach-at91/Makefile | 6 | ||||
| -rw-r--r-- | arch/arm/mach-at91/at91rm9200.c | 11 | ||||
| -rw-r--r-- | arch/arm/mach-at91/at91sam9260.c | 4 | ||||
| -rw-r--r-- | arch/arm/mach-at91/at91sam9261.c | 4 | ||||
| -rw-r--r-- | arch/arm/mach-at91/at91sam9263.c | 2 | ||||
| -rw-r--r-- | arch/arm/mach-at91/at91sam9g45.c | 4 | ||||
| -rw-r--r-- | arch/arm/mach-at91/at91sam9rl.c | 2 | ||||
| -rw-r--r-- | arch/arm/mach-at91/at91sam9x5.c | 2 | ||||
| -rw-r--r-- | arch/arm/mach-at91/at91x40.c | 7 | ||||
| -rw-r--r-- | arch/arm/mach-at91/board-dt-sama5.c | 3 | ||||
| -rw-r--r-- | arch/arm/mach-at91/board-rm9200dk.c | 228 | ||||
| -rw-r--r-- | arch/arm/mach-at91/board-sam9261ek.c | 28 | ||||
| -rw-r--r-- | arch/arm/mach-at91/board-usb-a926x.c | 384 | ||||
| -rw-r--r-- | arch/arm/mach-at91/clock.c | 30 | ||||
| -rw-r--r-- | arch/arm/mach-at91/cpuidle.c | 2 | ||||
| -rw-r--r-- | arch/arm/mach-at91/generic.h | 7 | ||||
| -rw-r--r-- | arch/arm/mach-at91/include/mach/at91_pmc.h | 3 | ||||
| -rw-r--r-- | arch/arm/mach-at91/irq.c | 9 | ||||
| -rw-r--r-- | arch/arm/mach-at91/pm.c | 2 | ||||
| -rw-r--r-- | arch/arm/mach-at91/setup.c | 4 | ||||
| -rw-r--r-- | arch/arm/mach-at91/soc.h | 1 | 
23 files changed, 143 insertions, 770 deletions
| diff --git a/arch/arm/mach-at91/Kconfig b/arch/arm/mach-at91/Kconfig index 02802386b89..699b71e7f7e 100644 --- a/arch/arm/mach-at91/Kconfig +++ b/arch/arm/mach-at91/Kconfig @@ -163,6 +163,7 @@ config MACH_SAMA5_DT  	bool "Atmel SAMA5 Evaluation Kits with device-tree support"  	depends on SOC_SAMA5  	select USE_OF +	select PHYLIB if NETDEVICES  	help  	  Select this if you want to experiment device-tree with  	  an Atmel Evaluation Kit. diff --git a/arch/arm/mach-at91/Kconfig.non_dt b/arch/arm/mach-at91/Kconfig.non_dt index 6c24985515a..ca900be144c 100644 --- a/arch/arm/mach-at91/Kconfig.non_dt +++ b/arch/arm/mach-at91/Kconfig.non_dt @@ -14,15 +14,11 @@ config ARCH_AT91RM9200  	select SOC_AT91RM9200  config ARCH_AT91SAM9260 -	bool "AT91SAM9260 or AT91SAM9XE" +	bool "AT91SAM9260 or AT91SAM9XE or AT91SAM9G20"  	select SOC_AT91SAM9260  config ARCH_AT91SAM9261 -	bool "AT91SAM9261" -	select SOC_AT91SAM9261 - -config ARCH_AT91SAM9G10 -	bool "AT91SAM9G10" +	bool "AT91SAM9261 or AT91SAM9G10"  	select SOC_AT91SAM9261  config ARCH_AT91SAM9263 @@ -33,10 +29,6 @@ config ARCH_AT91SAM9RL  	bool "AT91SAM9RL"  	select SOC_AT91SAM9RL -config ARCH_AT91SAM9G20 -	bool "AT91SAM9G20" -	select SOC_AT91SAM9260 -  config ARCH_AT91SAM9G45  	bool "AT91SAM9G45"  	select SOC_AT91SAM9G45 @@ -50,6 +42,14 @@ config ARCH_AT91X40  endchoice +config ARCH_AT91SAM9G20 +	bool +	select ARCH_AT91SAM9260 + +config ARCH_AT91SAM9G10 +	bool +	select ARCH_AT91SAM9261 +  # ----------------------------------------------------------  if ARCH_AT91RM9200 @@ -62,13 +62,6 @@ config MACH_ONEARM  	  Select this if you are using Ajeco's 1ARM Single Board Computer.  	  <http://www.ajeco.fi/> -config ARCH_AT91RM9200DK -	bool "Atmel AT91RM9200-DK Development board" -	select HAVE_AT91_DATAFLASH_CARD -	help -	  Select this if you are using Atmel's AT91RM9200-DK Development board. -	  (Discontinued) -  config MACH_AT91RM9200EK  	bool "Atmel AT91RM9200-EK Evaluation Kit"  	select HAVE_AT91_DATAFLASH_CARD @@ -183,12 +176,6 @@ config MACH_AFEB9260  	  <svn://194.85.238.22/home/users/george/svn/arm9eb>  	  <http://groups.google.com/group/arm9fpga-evolution-board> -config MACH_USB_A9260 -	bool "CALAO USB-A9260" -	help -	  Select this if you are using a Calao Systems USB-A9260. -	  <http://www.calao-systems.com> -  config MACH_QIL_A9260  	bool "CALAO QIL-A9260 board"  	help @@ -207,76 +194,6 @@ config MACH_FLEXIBITY  	  Select this if you are using Flexibity Connect board  	  <http://www.flexibity.com> -endif - -# ---------------------------------------------------------- - -if ARCH_AT91SAM9261 - -comment "AT91SAM9261 Board Type" - -config MACH_AT91SAM9261EK -	bool "Atmel AT91SAM9261-EK Evaluation Kit" -	select HAVE_AT91_DATAFLASH_CARD -	help -	  Select this if you are using Atmel's AT91SAM9261-EK Evaluation Kit. -	  <http://www.atmel.com/dyn/products/tools_card.asp?tool_id=3820> - -endif - -# ---------------------------------------------------------- - -if ARCH_AT91SAM9G10 - -comment "AT91SAM9G10 Board Type" - -config MACH_AT91SAM9G10EK -	bool "Atmel AT91SAM9G10-EK Evaluation Kit" -	select HAVE_AT91_DATAFLASH_CARD -	help -	  Select this if you are using Atmel's AT91SAM9G10-EK Evaluation Kit. -	  <http://www.atmel.com/dyn/products/tools_card.asp?tool_id=4588> - -endif - -# ---------------------------------------------------------- - -if ARCH_AT91SAM9263 - -comment "AT91SAM9263 Board Type" - -config MACH_AT91SAM9263EK -	bool "Atmel AT91SAM9263-EK Evaluation Kit" -	select HAVE_AT91_DATAFLASH_CARD -	help -	  Select this if you are using Atmel's AT91SAM9263-EK Evaluation Kit. -	  <http://www.atmel.com/dyn/products/tools_card.asp?tool_id=4057> - -config MACH_USB_A9263 -	bool "CALAO USB-A9263" -	help -	  Select this if you are using a Calao Systems USB-A9263. -	  <http://www.calao-systems.com> - -endif - -# ---------------------------------------------------------- - -if ARCH_AT91SAM9RL - -comment "AT91SAM9RL Board Type" - -config MACH_AT91SAM9RLEK -	bool "Atmel AT91SAM9RL-EK Evaluation Kit" -	help -	  Select this if you are using Atmel's AT91SAM9RL-EK Evaluation Kit. - -endif - -# ---------------------------------------------------------- - -if ARCH_AT91SAM9G20 -  comment "AT91SAM9G20 Board Type"  config MACH_AT91SAM9G20EK @@ -334,24 +251,64 @@ config MACH_GSIA18S  	  produced by GeoSIG Ltd company. This is an internet accelerograph.  	  <http://www.geosig.com> -config MACH_USB_A9G20 -	bool "CALAO USB-A9G20" -	depends on ARCH_AT91SAM9G20 +config MACH_SNAPPER_9260 +	bool "Bluewater Systems Snapper 9260/9G20 module" +	help +	  Select this if you are using the Bluewater Systems Snapper 9260 or +	  Snapper 9G20 modules. +	  <http://www.bluewatersys.com/> +endif + +# ---------------------------------------------------------- + +if ARCH_AT91SAM9261 + +comment "AT91SAM9261 Board Type" + +config MACH_AT91SAM9261EK +	bool "Atmel AT91SAM9261-EK Evaluation Kit" +	select HAVE_AT91_DATAFLASH_CARD  	help -	  Select this if you are using a Calao Systems USB-A9G20. -	  <http://www.calao-systems.com> +	  Select this if you are using Atmel's AT91SAM9261-EK Evaluation Kit. +	  <http://www.atmel.com/dyn/products/tools_card.asp?tool_id=3820> + +comment "AT91SAM9G10 Board Type" + +config MACH_AT91SAM9G10EK +	bool "Atmel AT91SAM9G10-EK Evaluation Kit" +	select HAVE_AT91_DATAFLASH_CARD +	help +	  Select this if you are using Atmel's AT91SAM9G10-EK Evaluation Kit. +	  <http://www.atmel.com/dyn/products/tools_card.asp?tool_id=4588>  endif -if (ARCH_AT91SAM9260 || ARCH_AT91SAM9G20) -comment "AT91SAM9260/AT91SAM9G20 boards" +# ---------------------------------------------------------- + +if ARCH_AT91SAM9263 + +comment "AT91SAM9263 Board Type" + +config MACH_AT91SAM9263EK +	bool "Atmel AT91SAM9263-EK Evaluation Kit" +	select HAVE_AT91_DATAFLASH_CARD +	help +	  Select this if you are using Atmel's AT91SAM9263-EK Evaluation Kit. +	  <http://www.atmel.com/dyn/products/tools_card.asp?tool_id=4057> + +endif + +# ---------------------------------------------------------- + +if ARCH_AT91SAM9RL + +comment "AT91SAM9RL Board Type" + +config MACH_AT91SAM9RLEK +	bool "Atmel AT91SAM9RL-EK Evaluation Kit" +	help +	  Select this if you are using Atmel's AT91SAM9RL-EK Evaluation Kit. -config MACH_SNAPPER_9260 -        bool "Bluewater Systems Snapper 9260/9G20 module" -        help -          Select this if you are using the Bluewater Systems Snapper 9260 or -          Snapper 9G20 modules. -          <http://www.bluewatersys.com/>  endif  # ---------------------------------------------------------- diff --git a/arch/arm/mach-at91/Makefile b/arch/arm/mach-at91/Makefile index 788562dccb4..3b0a9538093 100644 --- a/arch/arm/mach-at91/Makefile +++ b/arch/arm/mach-at91/Makefile @@ -27,16 +27,13 @@ obj-$(CONFIG_SOC_SAMA5D3)	+= sama5d3.o  obj-$(CONFIG_ARCH_AT91RM9200)	+= at91rm9200_devices.o  obj-$(CONFIG_ARCH_AT91SAM9260)	+= at91sam9260_devices.o  obj-$(CONFIG_ARCH_AT91SAM9261)	+= at91sam9261_devices.o -obj-$(CONFIG_ARCH_AT91SAM9G10)	+= at91sam9261_devices.o  obj-$(CONFIG_ARCH_AT91SAM9263)	+= at91sam9263_devices.o  obj-$(CONFIG_ARCH_AT91SAM9RL)	+= at91sam9rl_devices.o -obj-$(CONFIG_ARCH_AT91SAM9G20)	+= at91sam9260_devices.o  obj-$(CONFIG_ARCH_AT91SAM9G45)	+= at91sam9g45_devices.o  obj-$(CONFIG_ARCH_AT91X40)	+= at91x40.o at91x40_time.o  # AT91RM9200 board-specific support  obj-$(CONFIG_MACH_ONEARM)	+= board-1arm.o -obj-$(CONFIG_ARCH_AT91RM9200DK)	+= board-rm9200dk.o  obj-$(CONFIG_MACH_AT91RM9200EK)	+= board-rm9200ek.o  obj-$(CONFIG_MACH_CSB337)	+= board-csb337.o  obj-$(CONFIG_MACH_CSB637)	+= board-csb637.o @@ -55,7 +52,6 @@ obj-$(CONFIG_MACH_RSI_EWS)	+= board-rsi-ews.o  obj-$(CONFIG_MACH_AT91SAM9260EK) += board-sam9260ek.o  obj-$(CONFIG_MACH_CAM60)	+= board-cam60.o  obj-$(CONFIG_MACH_SAM9_L9260)	+= board-sam9-l9260.o -obj-$(CONFIG_MACH_USB_A9260)	+= board-usb-a926x.o  obj-$(CONFIG_MACH_QIL_A9260)	+= board-qil-a9260.o  obj-$(CONFIG_MACH_AFEB9260)	+= board-afeb-9260v1.o  obj-$(CONFIG_MACH_CPU9260)	+= board-cpu9krea.o @@ -67,7 +63,6 @@ obj-$(CONFIG_MACH_AT91SAM9G10EK) += board-sam9261ek.o  # AT91SAM9263 board-specific support  obj-$(CONFIG_MACH_AT91SAM9263EK) += board-sam9263ek.o -obj-$(CONFIG_MACH_USB_A9263)	+= board-usb-a926x.o  # AT91SAM9RL board-specific support  obj-$(CONFIG_MACH_AT91SAM9RLEK)	+= board-sam9rlek.o @@ -80,7 +75,6 @@ obj-$(CONFIG_MACH_STAMP9G20)	+= board-stamp9g20.o  obj-$(CONFIG_MACH_PORTUXG20)	+= board-stamp9g20.o  obj-$(CONFIG_MACH_PCONTROL_G20)	+= board-pcontrol-g20.o board-stamp9g20.o  obj-$(CONFIG_MACH_GSIA18S)	+= board-gsia18s.o board-stamp9g20.o -obj-$(CONFIG_MACH_USB_A9G20)	+= board-usb-a926x.o  # AT91SAM9260/AT91SAM9G20 board-specific support  obj-$(CONFIG_MACH_SNAPPER_9260)	+= board-snapper9260.o diff --git a/arch/arm/mach-at91/at91rm9200.c b/arch/arm/mach-at91/at91rm9200.c index d193a409bc4..4aad93d54d6 100644 --- a/arch/arm/mach-at91/at91rm9200.c +++ b/arch/arm/mach-at91/at91rm9200.c @@ -11,6 +11,7 @@   */  #include <linux/module.h> +#include <linux/reboot.h>  #include <asm/irq.h>  #include <asm/mach/arch.h> @@ -304,7 +305,7 @@ static void at91rm9200_idle(void)  	at91_pmc_write(AT91_PMC_SCDR, AT91_PMC_PCK);  } -static void at91rm9200_restart(char mode, const char *cmd) +static void at91rm9200_restart(enum reboot_mode reboot_mode, const char *cmd)  {  	/*  	 * Perform a hardware reset with the use of the Watchdog timer. @@ -332,10 +333,6 @@ static void __init at91rm9200_initialize(void)  {  	arm_pm_idle = at91rm9200_idle;  	arm_pm_restart = at91rm9200_restart; -	at91_extern_irq = (1 << AT91RM9200_ID_IRQ0) | (1 << AT91RM9200_ID_IRQ1) -			| (1 << AT91RM9200_ID_IRQ2) | (1 << AT91RM9200_ID_IRQ3) -			| (1 << AT91RM9200_ID_IRQ4) | (1 << AT91RM9200_ID_IRQ5) -			| (1 << AT91RM9200_ID_IRQ6);  	/* Initialize GPIO subsystem */  	at91_gpio_init(at91rm9200_gpio, @@ -388,6 +385,10 @@ static unsigned int at91rm9200_default_irq_priority[NR_AIC_IRQS] __initdata = {  AT91_SOC_START(at91rm9200)  	.map_io = at91rm9200_map_io,  	.default_irq_priority = at91rm9200_default_irq_priority, +	.extern_irq = (1 << AT91RM9200_ID_IRQ0) | (1 << AT91RM9200_ID_IRQ1) +		    | (1 << AT91RM9200_ID_IRQ2) | (1 << AT91RM9200_ID_IRQ3) +		    | (1 << AT91RM9200_ID_IRQ4) | (1 << AT91RM9200_ID_IRQ5) +		    | (1 << AT91RM9200_ID_IRQ6),  	.ioremap_registers = at91rm9200_ioremap_registers,  	.register_clocks = at91rm9200_register_clocks,  	.init = at91rm9200_initialize, diff --git a/arch/arm/mach-at91/at91sam9260.c b/arch/arm/mach-at91/at91sam9260.c index a8ce24538da..5de6074b4f4 100644 --- a/arch/arm/mach-at91/at91sam9260.c +++ b/arch/arm/mach-at91/at91sam9260.c @@ -348,8 +348,6 @@ static void __init at91sam9260_initialize(void)  {  	arm_pm_idle = at91sam9_idle;  	arm_pm_restart = at91sam9_alt_restart; -	at91_extern_irq = (1 << AT91SAM9260_ID_IRQ0) | (1 << AT91SAM9260_ID_IRQ1) -			| (1 << AT91SAM9260_ID_IRQ2);  	/* Register GPIO subsystem */  	at91_gpio_init(at91sam9260_gpio, 3); @@ -400,6 +398,8 @@ static unsigned int at91sam9260_default_irq_priority[NR_AIC_IRQS] __initdata = {  AT91_SOC_START(at91sam9260)  	.map_io = at91sam9260_map_io,  	.default_irq_priority = at91sam9260_default_irq_priority, +	.extern_irq = (1 << AT91SAM9260_ID_IRQ0) | (1 << AT91SAM9260_ID_IRQ1) +		    | (1 << AT91SAM9260_ID_IRQ2),  	.ioremap_registers = at91sam9260_ioremap_registers,  	.register_clocks = at91sam9260_register_clocks,  	.init = at91sam9260_initialize, diff --git a/arch/arm/mach-at91/at91sam9261.c b/arch/arm/mach-at91/at91sam9261.c index 25efb5ac30f..0e0793241ab 100644 --- a/arch/arm/mach-at91/at91sam9261.c +++ b/arch/arm/mach-at91/at91sam9261.c @@ -290,8 +290,6 @@ static void __init at91sam9261_initialize(void)  {  	arm_pm_idle = at91sam9_idle;  	arm_pm_restart = at91sam9_alt_restart; -	at91_extern_irq = (1 << AT91SAM9261_ID_IRQ0) | (1 << AT91SAM9261_ID_IRQ1) -			| (1 << AT91SAM9261_ID_IRQ2);  	/* Register GPIO subsystem */  	at91_gpio_init(at91sam9261_gpio, 3); @@ -342,6 +340,8 @@ static unsigned int at91sam9261_default_irq_priority[NR_AIC_IRQS] __initdata = {  AT91_SOC_START(at91sam9261)  	.map_io = at91sam9261_map_io,  	.default_irq_priority = at91sam9261_default_irq_priority, +	.extern_irq = (1 << AT91SAM9261_ID_IRQ0) | (1 << AT91SAM9261_ID_IRQ1) +		    | (1 << AT91SAM9261_ID_IRQ2),  	.ioremap_registers = at91sam9261_ioremap_registers,  	.register_clocks = at91sam9261_register_clocks,  	.init = at91sam9261_initialize, diff --git a/arch/arm/mach-at91/at91sam9263.c b/arch/arm/mach-at91/at91sam9263.c index f44ffd2105a..6ce7d185089 100644 --- a/arch/arm/mach-at91/at91sam9263.c +++ b/arch/arm/mach-at91/at91sam9263.c @@ -327,7 +327,6 @@ static void __init at91sam9263_initialize(void)  {  	arm_pm_idle = at91sam9_idle;  	arm_pm_restart = at91sam9_alt_restart; -	at91_extern_irq = (1 << AT91SAM9263_ID_IRQ0) | (1 << AT91SAM9263_ID_IRQ1);  	/* Register GPIO subsystem */  	at91_gpio_init(at91sam9263_gpio, 5); @@ -378,6 +377,7 @@ static unsigned int at91sam9263_default_irq_priority[NR_AIC_IRQS] __initdata = {  AT91_SOC_START(at91sam9263)  	.map_io = at91sam9263_map_io,  	.default_irq_priority = at91sam9263_default_irq_priority, +	.extern_irq = (1 << AT91SAM9263_ID_IRQ0) | (1 << AT91SAM9263_ID_IRQ1),  	.ioremap_registers = at91sam9263_ioremap_registers,  	.register_clocks = at91sam9263_register_clocks,  	.init = at91sam9263_initialize, diff --git a/arch/arm/mach-at91/at91sam9g45.c b/arch/arm/mach-at91/at91sam9g45.c index 8b7fce06765..474ee04d24b 100644 --- a/arch/arm/mach-at91/at91sam9g45.c +++ b/arch/arm/mach-at91/at91sam9g45.c @@ -266,6 +266,8 @@ static struct clk_lookup periph_clocks_lookups[] = {  	CLKDEV_CON_DEV_ID(NULL, "fff88000.i2c", &twi1_clk),  	CLKDEV_CON_DEV_ID("spi_clk", "fffa4000.spi", &spi0_clk),  	CLKDEV_CON_DEV_ID("spi_clk", "fffa8000.spi", &spi1_clk), +	CLKDEV_CON_DEV_ID("hclk", "600000.gadget", &utmi_clk), +	CLKDEV_CON_DEV_ID("pclk", "600000.gadget", &udphs_clk),  	/* fake hclk clock */  	CLKDEV_CON_DEV_ID("hclk", "at91_ohci", &uhphs_clk),  	CLKDEV_CON_DEV_ID(NULL, "fffff200.gpio", &pioA_clk), @@ -374,7 +376,6 @@ static void __init at91sam9g45_initialize(void)  {  	arm_pm_idle = at91sam9_idle;  	arm_pm_restart = at91sam9g45_restart; -	at91_extern_irq = (1 << AT91SAM9G45_ID_IRQ0);  	/* Register GPIO subsystem */  	at91_gpio_init(at91sam9g45_gpio, 5); @@ -425,6 +426,7 @@ static unsigned int at91sam9g45_default_irq_priority[NR_AIC_IRQS] __initdata = {  AT91_SOC_START(at91sam9g45)  	.map_io = at91sam9g45_map_io,  	.default_irq_priority = at91sam9g45_default_irq_priority, +	.extern_irq = (1 << AT91SAM9G45_ID_IRQ0),  	.ioremap_registers = at91sam9g45_ioremap_registers,  	.register_clocks = at91sam9g45_register_clocks,  	.init = at91sam9g45_initialize, diff --git a/arch/arm/mach-at91/at91sam9rl.c b/arch/arm/mach-at91/at91sam9rl.c index f77fae5591b..d4ec0d9a987 100644 --- a/arch/arm/mach-at91/at91sam9rl.c +++ b/arch/arm/mach-at91/at91sam9rl.c @@ -293,7 +293,6 @@ static void __init at91sam9rl_initialize(void)  {  	arm_pm_idle = at91sam9_idle;  	arm_pm_restart = at91sam9_alt_restart; -	at91_extern_irq = (1 << AT91SAM9RL_ID_IRQ0);  	/* Register GPIO subsystem */  	at91_gpio_init(at91sam9rl_gpio, 4); @@ -344,6 +343,7 @@ static unsigned int at91sam9rl_default_irq_priority[NR_AIC_IRQS] __initdata = {  AT91_SOC_START(at91sam9rl)  	.map_io = at91sam9rl_map_io,  	.default_irq_priority = at91sam9rl_default_irq_priority, +	.extern_irq = (1 << AT91SAM9RL_ID_IRQ0),  	.ioremap_registers = at91sam9rl_ioremap_registers,  	.register_clocks = at91sam9rl_register_clocks,  	.init = at91sam9rl_initialize, diff --git a/arch/arm/mach-at91/at91sam9x5.c b/arch/arm/mach-at91/at91sam9x5.c index e631fec040c..2abee6626aa 100644 --- a/arch/arm/mach-at91/at91sam9x5.c +++ b/arch/arm/mach-at91/at91sam9x5.c @@ -249,6 +249,8 @@ static struct clk_lookup periph_clocks_lookups[] = {  	CLKDEV_CON_DEV_ID("hclk", "600000.ohci", &uhphs_clk),  	CLKDEV_CON_DEV_ID("ohci_clk", "600000.ohci", &uhphs_clk),  	CLKDEV_CON_DEV_ID("ehci_clk", "700000.ehci", &uhphs_clk), +	CLKDEV_CON_DEV_ID("hclk", "500000.gadget", &utmi_clk), +	CLKDEV_CON_DEV_ID("pclk", "500000.gadget", &udphs_clk),  };  /* diff --git a/arch/arm/mach-at91/at91x40.c b/arch/arm/mach-at91/at91x40.c index 19ca7939690..bad94b84a46 100644 --- a/arch/arm/mach-at91/at91x40.c +++ b/arch/arm/mach-at91/at91x40.c @@ -55,8 +55,6 @@ static void at91x40_idle(void)  void __init at91x40_initialize(unsigned long main_clock)  {  	arm_pm_idle = at91x40_idle; -	at91_extern_irq = (1 << AT91X40_ID_IRQ0) | (1 << AT91X40_ID_IRQ1) -			| (1 << AT91X40_ID_IRQ2);  }  /* @@ -86,9 +84,10 @@ static unsigned int at91x40_default_irq_priority[NR_AIC_IRQS] __initdata = {  void __init at91x40_init_interrupts(unsigned int priority[NR_AIC_IRQS])  { +	u32  extern_irq = (1 << AT91X40_ID_IRQ0) | (1 << AT91X40_ID_IRQ1) +			| (1 << AT91X40_ID_IRQ2);  	if (!priority)  		priority = at91x40_default_irq_priority; -	at91_aic_init(priority, at91_extern_irq); +	at91_aic_init(priority, extern_irq);  } - diff --git a/arch/arm/mach-at91/board-dt-sama5.c b/arch/arm/mach-at91/board-dt-sama5.c index 705305e62bb..ad95f6a23a2 100644 --- a/arch/arm/mach-at91/board-dt-sama5.c +++ b/arch/arm/mach-at91/board-dt-sama5.c @@ -62,7 +62,8 @@ static int ksz9021rn_phy_fixup(struct phy_device *phy)  static void __init sama5_dt_device_init(void)  { -	if (of_machine_is_compatible("atmel,sama5d3xcm")) +	if (of_machine_is_compatible("atmel,sama5d3xcm") && +	    IS_ENABLED(CONFIG_PHYLIB))  		phy_register_fixup_for_uid(PHY_ID_KSZ9021, MICREL_PHY_ID_MASK,  			ksz9021rn_phy_fixup); diff --git a/arch/arm/mach-at91/board-rm9200dk.c b/arch/arm/mach-at91/board-rm9200dk.c deleted file mode 100644 index 690541b18cb..00000000000 --- a/arch/arm/mach-at91/board-rm9200dk.c +++ /dev/null @@ -1,228 +0,0 @@ -/* - * linux/arch/arm/mach-at91/board-rm9200dk.c - * - *  Copyright (C) 2005 SAN People - * - *  Epson S1D framebuffer glue code is: - *     Copyright (C) 2005 Thibaut VARENE <varenet@parisc-linux.org> - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA - */ - -#include <linux/types.h> -#include <linux/gpio.h> -#include <linux/init.h> -#include <linux/mm.h> -#include <linux/module.h> -#include <linux/platform_device.h> -#include <linux/spi/spi.h> -#include <linux/mtd/physmap.h> - -#include <asm/setup.h> -#include <asm/mach-types.h> -#include <asm/irq.h> - -#include <asm/mach/arch.h> -#include <asm/mach/map.h> -#include <asm/mach/irq.h> - -#include <mach/hardware.h> -#include <mach/at91rm9200_mc.h> -#include <mach/at91_ramc.h> - -#include "at91_aic.h" -#include "board.h" -#include "generic.h" - - -static void __init dk_init_early(void) -{ -	/* Initialize processor: 18.432 MHz crystal */ -	at91_initialize(18432000); -} - -static struct macb_platform_data __initdata dk_eth_data = { -	.phy_irq_pin	= AT91_PIN_PC4, -	.is_rmii	= 1, -}; - -static struct at91_usbh_data __initdata dk_usbh_data = { -	.ports		= 2, -	.vbus_pin	= {-EINVAL, -EINVAL}, -	.overcurrent_pin= {-EINVAL, -EINVAL}, -}; - -static struct at91_udc_data __initdata dk_udc_data = { -	.vbus_pin	= AT91_PIN_PD4, -	.pullup_pin	= AT91_PIN_PD5, -}; - -static struct at91_cf_data __initdata dk_cf_data = { -	.irq_pin	= -EINVAL, -	.det_pin	= AT91_PIN_PB0, -	.vcc_pin	= -EINVAL, -	.rst_pin	= AT91_PIN_PC5, -}; - -#ifndef CONFIG_MTD_AT91_DATAFLASH_CARD -static struct mci_platform_data __initdata dk_mci0_data = { -	.slot[0] = { -		.bus_width	= 4, -		.detect_pin	= -EINVAL, -		.wp_pin		= -EINVAL, -	}, -}; -#endif - -static struct spi_board_info dk_spi_devices[] = { -	{	/* DataFlash chip */ -		.modalias	= "mtd_dataflash", -		.chip_select	= 0, -		.max_speed_hz	= 15 * 1000 * 1000, -	}, -	{	/* UR6HCPS2-SP40 PS2-to-SPI adapter */ -		.modalias	= "ur6hcps2", -		.chip_select	= 1, -		.max_speed_hz	= 250 *  1000, -	}, -	{	/* TLV1504 ADC, 4 channels, 10 bits; one is a temp sensor */ -		.modalias	= "tlv1504", -		.chip_select	= 2, -		.max_speed_hz	= 20 * 1000 * 1000, -	}, -#ifdef CONFIG_MTD_AT91_DATAFLASH_CARD -	{	/* DataFlash card */ -		.modalias	= "mtd_dataflash", -		.chip_select	= 3, -		.max_speed_hz	= 15 * 1000 * 1000, -	} -#endif -}; - -static struct i2c_board_info __initdata dk_i2c_devices[] = { -	{ -		I2C_BOARD_INFO("ics1523", 0x26), -	}, -	{ -		I2C_BOARD_INFO("x9429", 0x28), -	}, -	{ -		I2C_BOARD_INFO("24c1024", 0x50), -	} -}; - -static struct mtd_partition __initdata dk_nand_partition[] = { -	{ -		.name	= "NAND Partition 1", -		.offset	= 0, -		.size	= MTDPART_SIZ_FULL, -	}, -}; - -static struct atmel_nand_data __initdata dk_nand_data = { -	.ale		= 22, -	.cle		= 21, -	.det_pin	= AT91_PIN_PB1, -	.rdy_pin	= AT91_PIN_PC2, -	.enable_pin	= -EINVAL, -	.ecc_mode	= NAND_ECC_SOFT, -	.on_flash_bbt	= 1, -	.parts		= dk_nand_partition, -	.num_parts	= ARRAY_SIZE(dk_nand_partition), -}; - -#define DK_FLASH_BASE	AT91_CHIPSELECT_0 -#define DK_FLASH_SIZE	SZ_2M - -static struct physmap_flash_data dk_flash_data = { -	.width		= 2, -}; - -static struct resource dk_flash_resource = { -	.start		= DK_FLASH_BASE, -	.end		= DK_FLASH_BASE + DK_FLASH_SIZE - 1, -	.flags		= IORESOURCE_MEM, -}; - -static struct platform_device dk_flash = { -	.name		= "physmap-flash", -	.id		= 0, -	.dev		= { -				.platform_data	= &dk_flash_data, -			}, -	.resource	= &dk_flash_resource, -	.num_resources	= 1, -}; - -static struct gpio_led dk_leds[] = { -	{ -		.name			= "led0", -		.gpio			= AT91_PIN_PB2, -		.active_low		= 1, -		.default_trigger	= "heartbeat", -	} -}; - -static void __init dk_board_init(void) -{ -	/* Serial */ -	/* DBGU on ttyS0. (Rx & Tx only) */ -	at91_register_uart(0, 0, 0); - -	/* USART1 on ttyS1. (Rx, Tx, CTS, RTS, DTR, DSR, DCD, RI) */ -	at91_register_uart(AT91RM9200_ID_US1, 1, ATMEL_UART_CTS | ATMEL_UART_RTS -			   | ATMEL_UART_DTR | ATMEL_UART_DSR | ATMEL_UART_DCD -			   | ATMEL_UART_RI); -	at91_add_device_serial(); -	/* Ethernet */ -	at91_add_device_eth(&dk_eth_data); -	/* USB Host */ -	at91_add_device_usbh(&dk_usbh_data); -	/* USB Device */ -	at91_add_device_udc(&dk_udc_data); -	at91_set_multi_drive(dk_udc_data.pullup_pin, 1);	/* pullup_pin is connected to reset */ -	/* Compact Flash */ -	at91_add_device_cf(&dk_cf_data); -	/* I2C */ -	at91_add_device_i2c(dk_i2c_devices, ARRAY_SIZE(dk_i2c_devices)); -	/* SPI */ -	at91_add_device_spi(dk_spi_devices, ARRAY_SIZE(dk_spi_devices)); -#ifdef CONFIG_MTD_AT91_DATAFLASH_CARD -	/* DataFlash card */ -	at91_set_gpio_output(AT91_PIN_PB7, 0); -#else -	/* MMC */ -	at91_set_gpio_output(AT91_PIN_PB7, 1);	/* this MMC card slot can optionally use SPI signaling (CS3). */ -	at91_add_device_mci(0, &dk_mci0_data); -#endif -	/* NAND */ -	at91_add_device_nand(&dk_nand_data); -	/* NOR Flash */ -	platform_device_register(&dk_flash); -	/* LEDs */ -	at91_gpio_leds(dk_leds, ARRAY_SIZE(dk_leds)); -	/* VGA */ -//	dk_add_device_video(); -} - -MACHINE_START(AT91RM9200DK, "Atmel AT91RM9200-DK") -	/* Maintainer: SAN People/Atmel */ -	.init_time	= at91rm9200_timer_init, -	.map_io		= at91_map_io, -	.handle_irq	= at91_aic_handle_irq, -	.init_early	= dk_init_early, -	.init_irq	= at91_init_irq_default, -	.init_machine	= dk_board_init, -MACHINE_END diff --git a/arch/arm/mach-at91/board-sam9261ek.c b/arch/arm/mach-at91/board-sam9261ek.c index b446645c772..d3437624ca4 100644 --- a/arch/arm/mach-at91/board-sam9261ek.c +++ b/arch/arm/mach-at91/board-sam9261ek.c @@ -264,11 +264,7 @@ static void __init ek_add_device_ts(void) {}   */  static struct at73c213_board_info at73c213_data = {  	.ssc_id		= 1, -#if defined(CONFIG_MACH_AT91SAM9261EK) -	.shortname	= "AT91SAM9261-EK external DAC", -#else -	.shortname	= "AT91SAM9G10-EK external DAC", -#endif +	.shortname	= "AT91SAM9261/9G10-EK external DAC",  };  #if defined(CONFIG_SND_AT73C213) || defined(CONFIG_SND_AT73C213_MODULE) @@ -412,9 +408,6 @@ static struct atmel_lcdfb_info __initdata ek_lcdc_data = {  	.default_monspecs		= &at91fb_default_stn_monspecs,  	.atmel_lcdfb_power_control	= at91_lcdc_stn_power_control,  	.guard_time			= 1, -#if defined(CONFIG_MACH_AT91SAM9G10EK) -	.lcd_wiring_mode		= ATMEL_LCDC_WIRING_RGB, -#endif  };  #else @@ -468,9 +461,6 @@ static struct atmel_lcdfb_info __initdata ek_lcdc_data = {  	.default_monspecs		= &at91fb_default_tft_monspecs,  	.atmel_lcdfb_power_control	= at91_lcdc_tft_power_control,  	.guard_time			= 1, -#if defined(CONFIG_MACH_AT91SAM9G10EK) -	.lcd_wiring_mode		= ATMEL_LCDC_WIRING_RGB, -#endif  };  #endif @@ -574,6 +564,10 @@ static void __init ek_board_init(void)  	/* DBGU on ttyS0. (Rx & Tx only) */  	at91_register_uart(0, 0, 0);  	at91_add_device_serial(); + +	if (cpu_is_at91sam9g10()) +		ek_lcdc_data.lcd_wiring_mode = ATMEL_LCDC_WIRING_RGB; +  	/* USB Host */  	at91_add_device_usbh(&ek_usbh_data);  	/* USB Device */ @@ -606,11 +600,17 @@ static void __init ek_board_init(void)  	at91_gpio_leds(ek_leds, ARRAY_SIZE(ek_leds));  } -#if defined(CONFIG_MACH_AT91SAM9261EK)  MACHINE_START(AT91SAM9261EK, "Atmel AT91SAM9261-EK") -#else +	/* Maintainer: Atmel */ +	.init_time	= at91sam926x_pit_init, +	.map_io		= at91_map_io, +	.handle_irq	= at91_aic_handle_irq, +	.init_early	= ek_init_early, +	.init_irq	= at91_init_irq_default, +	.init_machine	= ek_board_init, +MACHINE_END +  MACHINE_START(AT91SAM9G10EK, "Atmel AT91SAM9G10-EK") -#endif  	/* Maintainer: Atmel */  	.init_time	= at91sam926x_pit_init,  	.map_io		= at91_map_io, diff --git a/arch/arm/mach-at91/board-usb-a926x.c b/arch/arm/mach-at91/board-usb-a926x.c deleted file mode 100644 index 2487d944a1b..00000000000 --- a/arch/arm/mach-at91/board-usb-a926x.c +++ /dev/null @@ -1,384 +0,0 @@ -/* - * linux/arch/arm/mach-at91/board-usb-a926x.c - * - *  Copyright (C) 2005 SAN People - *  Copyright (C) 2007 Atmel Corporation. - *  Copyright (C) 2007 Calao-systems - *  Copyright (C) 2011 Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com> - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA - */ - -#include <linux/types.h> -#include <linux/init.h> -#include <linux/mm.h> -#include <linux/module.h> -#include <linux/platform_device.h> -#include <linux/spi/spi.h> -#include <linux/gpio_keys.h> -#include <linux/gpio.h> -#include <linux/input.h> -#include <linux/spi/mmc_spi.h> - -#include <asm/setup.h> -#include <asm/mach-types.h> -#include <asm/irq.h> - -#include <asm/mach/arch.h> -#include <asm/mach/map.h> -#include <asm/mach/irq.h> - -#include <mach/hardware.h> -#include <mach/at91sam9_smc.h> - -#include "at91_aic.h" -#include "at91_shdwc.h" -#include "board.h" -#include "sam9_smc.h" -#include "generic.h" - - -static void __init ek_init_early(void) -{ -	/* Initialize processor: 12.00 MHz crystal */ -	at91_initialize(12000000); -} - -/* - * USB Host port - */ -static struct at91_usbh_data __initdata ek_usbh_data = { -	.ports		= 2, -	.vbus_pin	= {-EINVAL, -EINVAL}, -	.overcurrent_pin= {-EINVAL, -EINVAL}, -}; - -/* - * USB Device port - */ -static struct at91_udc_data __initdata ek_udc_data = { -	.vbus_pin	= AT91_PIN_PB11, -	.pullup_pin	= -EINVAL,		/* pull-up driven by UDC */ -}; - -static void __init ek_add_device_udc(void) -{ -	if (machine_is_usb_a9260() || machine_is_usb_a9g20()) -		ek_udc_data.vbus_pin = AT91_PIN_PC5; - -	at91_add_device_udc(&ek_udc_data); -} - -#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE) -#define MMC_SPI_CARD_DETECT_INT AT91_PIN_PC4 -static int at91_mmc_spi_init(struct device *dev, -	irqreturn_t (*detect_int)(int, void *), void *data) -{ -	/* Configure Interrupt pin as input, no pull-up */ -	at91_set_gpio_input(MMC_SPI_CARD_DETECT_INT, 0); -	return request_irq(gpio_to_irq(MMC_SPI_CARD_DETECT_INT), detect_int, -		IRQF_TRIGGER_FALLING | IRQF_TRIGGER_RISING, -		"mmc-spi-detect", data); -} - -static void at91_mmc_spi_exit(struct device *dev, void *data) -{ -	free_irq(gpio_to_irq(MMC_SPI_CARD_DETECT_INT), data); -} - -static struct mmc_spi_platform_data at91_mmc_spi_pdata = { -	.init = at91_mmc_spi_init, -	.exit = at91_mmc_spi_exit, -	.detect_delay = 100, /* msecs */ -}; -#endif - -/* - * SPI devices. - */ -static struct spi_board_info usb_a9263_spi_devices[] = { -	{	/* DataFlash chip */ -		.modalias	= "mtd_dataflash", -		.chip_select	= 0, -		.max_speed_hz	= 15 * 1000 * 1000, -		.bus_num	= 0, -	} -}; - -static struct spi_board_info usb_a9g20_spi_devices[] = { -#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE) -	{ -		.modalias = "mmc_spi", -		.max_speed_hz = 20000000,	/* max spi clock (SCK) speed in HZ */ -		.bus_num = 1, -		.chip_select = 0, -		.platform_data = &at91_mmc_spi_pdata, -		.mode = SPI_MODE_3, -	}, -#endif -}; - -static void __init ek_add_device_spi(void) -{ -	if (machine_is_usb_a9263()) -		at91_add_device_spi(usb_a9263_spi_devices, ARRAY_SIZE(usb_a9263_spi_devices)); -	else if (machine_is_usb_a9g20()) -		at91_add_device_spi(usb_a9g20_spi_devices, ARRAY_SIZE(usb_a9g20_spi_devices)); -} - -/* - * MACB Ethernet device - */ -static struct macb_platform_data __initdata ek_macb_data = { -	.phy_irq_pin	= AT91_PIN_PE31, -	.is_rmii	= 1, -}; - -static void __init ek_add_device_eth(void) -{ -	if (machine_is_usb_a9260() || machine_is_usb_a9g20()) -		ek_macb_data.phy_irq_pin = AT91_PIN_PA31; - -	at91_add_device_eth(&ek_macb_data); -} - -/* - * NAND flash - */ -static struct mtd_partition __initdata ek_nand_partition[] = { -	{ -		.name	= "barebox", -		.offset	= 0, -		.size	= 3 * SZ_128K, -	}, { -		.name	= "bareboxenv", -		.offset	= MTDPART_OFS_NXTBLK, -		.size	= SZ_128K, -	}, { -		.name	= "bareboxenv2", -		.offset	= MTDPART_OFS_NXTBLK, -		.size	= SZ_128K, -	}, { -		.name	= "oftree", -		.offset	= MTDPART_OFS_NXTBLK, -		.size	= SZ_128K, -	}, { -		.name	= "kernel", -		.offset	= MTDPART_OFS_NXTBLK, -		.size	= 4 * SZ_1M, -	}, { -		.name	= "rootfs", -		.offset	= MTDPART_OFS_NXTBLK, -		.size	= 120 * SZ_1M, -	}, { -		.name	= "data", -		.offset	= MTDPART_OFS_NXTBLK, -		.size	= MTDPART_SIZ_FULL, -	} -}; - -static struct atmel_nand_data __initdata ek_nand_data = { -	.ale		= 21, -	.cle		= 22, -	.det_pin	= -EINVAL, -	.rdy_pin	= AT91_PIN_PA22, -	.enable_pin	= AT91_PIN_PD15, -	.ecc_mode	= NAND_ECC_SOFT, -	.on_flash_bbt	= 1, -	.parts		= ek_nand_partition, -	.num_parts	= ARRAY_SIZE(ek_nand_partition), -}; - -static struct sam9_smc_config __initdata usb_a9260_nand_smc_config = { -	.ncs_read_setup		= 0, -	.nrd_setup		= 1, -	.ncs_write_setup	= 0, -	.nwe_setup		= 1, - -	.ncs_read_pulse		= 3, -	.nrd_pulse		= 3, -	.ncs_write_pulse	= 3, -	.nwe_pulse		= 3, - -	.read_cycle		= 5, -	.write_cycle		= 5, - -	.mode			= AT91_SMC_READMODE | AT91_SMC_WRITEMODE | AT91_SMC_EXNWMODE_DISABLE | AT91_SMC_DBW_8, -	.tdf_cycles		= 2, -}; - -static struct sam9_smc_config __initdata usb_a9g20_nand_smc_config = { -	.ncs_read_setup		= 0, -	.nrd_setup		= 2, -	.ncs_write_setup	= 0, -	.nwe_setup		= 2, - -	.ncs_read_pulse		= 4, -	.nrd_pulse		= 4, -	.ncs_write_pulse	= 4, -	.nwe_pulse		= 4, - -	.read_cycle		= 7, -	.write_cycle		= 7, - -	.mode			= AT91_SMC_READMODE | AT91_SMC_WRITEMODE | AT91_SMC_EXNWMODE_DISABLE | AT91_SMC_DBW_8, -	.tdf_cycles		= 3, -}; - -static void __init ek_add_device_nand(void) -{ -	if (machine_is_usb_a9260() || machine_is_usb_a9g20()) { -		ek_nand_data.rdy_pin	= AT91_PIN_PC13; -		ek_nand_data.enable_pin	= AT91_PIN_PC14; -	} - -	/* configure chip-select 3 (NAND) */ -	if (machine_is_usb_a9g20()) -		sam9_smc_configure(0, 3, &usb_a9g20_nand_smc_config); -	else -		sam9_smc_configure(0, 3, &usb_a9260_nand_smc_config); - -	at91_add_device_nand(&ek_nand_data); -} - - -/* - * GPIO Buttons - */ -#if defined(CONFIG_KEYBOARD_GPIO) || defined(CONFIG_KEYBOARD_GPIO_MODULE) -static struct gpio_keys_button ek_buttons[] = { -	{	/* USER PUSH BUTTON */ -		.code		= KEY_ENTER, -		.gpio		= AT91_PIN_PB10, -		.active_low	= 1, -		.desc		= "user_pb", -		.wakeup		= 1, -	} -}; - -static struct gpio_keys_platform_data ek_button_data = { -	.buttons	= ek_buttons, -	.nbuttons	= ARRAY_SIZE(ek_buttons), -}; - -static struct platform_device ek_button_device = { -	.name		= "gpio-keys", -	.id		= -1, -	.num_resources	= 0, -	.dev		= { -		.platform_data	= &ek_button_data, -	} -}; - -static void __init ek_add_device_buttons(void) -{ -	at91_set_GPIO_periph(AT91_PIN_PB10, 1);	/* user push button, pull up enabled */ -	at91_set_deglitch(AT91_PIN_PB10, 1); - -	platform_device_register(&ek_button_device); -} -#else -static void __init ek_add_device_buttons(void) {} -#endif - -/* - * LEDs - */ -static struct gpio_led ek_leds[] = { -	{	/* user_led (green) */ -		.name			= "user_led", -		.gpio			= AT91_PIN_PB21, -		.active_low		= 1, -		.default_trigger	= "heartbeat", -	} -}; - -static struct i2c_board_info __initdata ek_i2c_devices[] = { -	{ -		I2C_BOARD_INFO("rv3029c2", 0x56), -	}, -}; - -static void __init ek_add_device_leds(void) -{ -	if (machine_is_usb_a9260() || machine_is_usb_a9g20()) -		ek_leds[0].active_low = 0; - -	at91_gpio_leds(ek_leds, ARRAY_SIZE(ek_leds)); -} - -static void __init ek_board_init(void) -{ -	/* Serial */ -	/* DBGU on ttyS0. (Rx & Tx only) */ -	at91_register_uart(0, 0, 0); -	at91_add_device_serial(); -	/* USB Host */ -	at91_add_device_usbh(&ek_usbh_data); -	/* USB Device */ -	ek_add_device_udc(); -	/* SPI */ -	ek_add_device_spi(); -	/* Ethernet */ -	ek_add_device_eth(); -	/* NAND */ -	ek_add_device_nand(); -	/* Push Buttons */ -	ek_add_device_buttons(); -	/* LEDs */ -	ek_add_device_leds(); - -	if (machine_is_usb_a9g20()) { -		/* I2C */ -		at91_add_device_i2c(ek_i2c_devices, ARRAY_SIZE(ek_i2c_devices)); -	} else { -		/* I2C */ -		at91_add_device_i2c(NULL, 0); -		/* shutdown controller, wakeup button (5 msec low) */ -		at91_shdwc_write(AT91_SHDW_MR, AT91_SHDW_CPTWK0_(10) -				| AT91_SHDW_WKMODE0_LOW -				| AT91_SHDW_RTTWKEN); -	} -} - -MACHINE_START(USB_A9263, "CALAO USB_A9263") -	/* Maintainer: calao-systems */ -	.init_time	= at91sam926x_pit_init, -	.map_io		= at91_map_io, -	.handle_irq	= at91_aic_handle_irq, -	.init_early	= ek_init_early, -	.init_irq	= at91_init_irq_default, -	.init_machine	= ek_board_init, -MACHINE_END - -MACHINE_START(USB_A9260, "CALAO USB_A9260") -	/* Maintainer: calao-systems */ -	.init_time	= at91sam926x_pit_init, -	.map_io		= at91_map_io, -	.handle_irq	= at91_aic_handle_irq, -	.init_early	= ek_init_early, -	.init_irq	= at91_init_irq_default, -	.init_machine	= ek_board_init, -MACHINE_END - -MACHINE_START(USB_A9G20, "CALAO USB_A92G0") -	/* Maintainer: Jean-Christophe PLAGNIOL-VILLARD */ -	.init_time	= at91sam926x_pit_init, -	.map_io		= at91_map_io, -	.handle_irq	= at91_aic_handle_irq, -	.init_early	= ek_init_early, -	.init_irq	= at91_init_irq_default, -	.init_machine	= ek_board_init, -MACHINE_END diff --git a/arch/arm/mach-at91/clock.c b/arch/arm/mach-at91/clock.c index da841885d01..6b2630a92f7 100644 --- a/arch/arm/mach-at91/clock.c +++ b/arch/arm/mach-at91/clock.c @@ -75,7 +75,7 @@ EXPORT_SYMBOL_GPL(at91_pmc_base);  #define cpu_has_pllb()		(!(cpu_is_at91sam9rl() \  				|| cpu_is_at91sam9g45() \  				|| cpu_is_at91sam9x5() \ -				|| cpu_is_at91sam9n12())) +				|| cpu_is_sama5d3()))  #define cpu_has_upll()		(cpu_is_at91sam9g45() \  				|| cpu_is_at91sam9x5() \ @@ -489,7 +489,7 @@ static int at91_clk_show(struct seq_file *s, void *unused)  		seq_printf(s, "UCKR = %8x\n", uckr);  	}  	seq_printf(s, "MCKR = %8x\n", at91_pmc_read(AT91_PMC_MCKR)); -	if (cpu_has_upll()) +	if (cpu_has_upll() || cpu_is_at91sam9n12())  		seq_printf(s, "USB  = %8x\n", at91_pmc_read(AT91_PMC_USB));  	seq_printf(s, "SR   = %8x\n", sr); @@ -614,6 +614,8 @@ static u32 __init at91_usb_rate(struct clk *pll, u32 freq, u32 reg)  {  	if (pll == &pllb && (reg & AT91_PMC_USB96M))  		return freq / 2; +	else if (pll == &utmi_clk || cpu_is_at91sam9n12()) +		return freq / (1 + ((reg & AT91_PMC_OHCIUSBDIV) >> 8));  	else  		return freq;  } @@ -683,6 +685,8 @@ static struct clk *const standard_pmc_clocks[] __initconst = {  /* PLLB generated USB full speed clock init */  static void __init at91_pllb_usbfs_clock_init(unsigned long main_clock)  { +	unsigned int reg; +  	/*  	 * USB clock init:  choose 48 MHz PLLB value,  	 * disable 48MHz clock during usb peripheral suspend. @@ -691,22 +695,35 @@ static void __init at91_pllb_usbfs_clock_init(unsigned long main_clock)  	 */  	uhpck.parent = &pllb; -	at91_pllb_usb_init = at91_pll_calc(main_clock, 48000000 * 2) | AT91_PMC_USB96M; +	reg = at91_pllb_usb_init = at91_pll_calc(main_clock, 48000000 * 2);  	pllb.rate_hz = at91_pll_rate(&pllb, main_clock, at91_pllb_usb_init);  	if (cpu_is_at91rm9200()) { +		reg = at91_pllb_usb_init |= AT91_PMC_USB96M;  		uhpck.pmc_mask = AT91RM9200_PMC_UHP;  		udpck.pmc_mask = AT91RM9200_PMC_UDP;  		at91_pmc_write(AT91_PMC_SCER, AT91RM9200_PMC_MCKUDP);  	} else if (cpu_is_at91sam9260() || cpu_is_at91sam9261() ||  		   cpu_is_at91sam9263() || cpu_is_at91sam9g20() ||  		   cpu_is_at91sam9g10()) { +		reg = at91_pllb_usb_init |= AT91_PMC_USB96M; +		uhpck.pmc_mask = AT91SAM926x_PMC_UHP; +		udpck.pmc_mask = AT91SAM926x_PMC_UDP; +	} else if (cpu_is_at91sam9n12()) { +		/* Divider for USB clock is in USB clock register for 9n12 */ +		reg = AT91_PMC_USBS_PLLB; + +		/* For PLLB output 96M, set usb divider 2 (USBDIV + 1) */ +		reg |= AT91_PMC_OHCIUSBDIV_2; +		at91_pmc_write(AT91_PMC_USB, reg); + +		/* Still setup masks */  		uhpck.pmc_mask = AT91SAM926x_PMC_UHP;  		udpck.pmc_mask = AT91SAM926x_PMC_UDP;  	}  	at91_pmc_write(AT91_CKGR_PLLBR, 0); -	udpck.rate_hz = at91_usb_rate(&pllb, pllb.rate_hz, at91_pllb_usb_init); -	uhpck.rate_hz = at91_usb_rate(&pllb, pllb.rate_hz, at91_pllb_usb_init); +	udpck.rate_hz = at91_usb_rate(&pllb, pllb.rate_hz, reg); +	uhpck.rate_hz = at91_usb_rate(&pllb, pllb.rate_hz, reg);  }  /* UPLL generated USB full speed clock init */ @@ -725,8 +742,7 @@ static void __init at91_upll_usbfs_clock_init(unsigned long main_clock)  	/* Now set uhpck values */  	uhpck.parent = &utmi_clk;  	uhpck.pmc_mask = AT91SAM926x_PMC_UHP; -	uhpck.rate_hz = utmi_clk.rate_hz; -	uhpck.rate_hz /= 1 + ((at91_pmc_read(AT91_PMC_USB) & AT91_PMC_OHCIUSBDIV) >> 8); +	uhpck.rate_hz = at91_usb_rate(&utmi_clk, utmi_clk.rate_hz, usbr);  }  static int __init at91_pmc_init(unsigned long main_clock) diff --git a/arch/arm/mach-at91/cpuidle.c b/arch/arm/mach-at91/cpuidle.c index 69f9e3bbf4e..4ec6a6d9b9b 100644 --- a/arch/arm/mach-at91/cpuidle.c +++ b/arch/arm/mach-at91/cpuidle.c @@ -51,7 +51,7 @@ static struct cpuidle_driver at91_idle_driver = {  	.states[1]		= {  		.enter			= at91_enter_idle,  		.exit_latency		= 10, -		.target_residency	= 100000, +		.target_residency	= 10000,  		.flags			= CPUIDLE_FLAG_TIME_VALID,  		.name			= "RAM_SR",  		.desc			= "WFI and DDR Self Refresh", diff --git a/arch/arm/mach-at91/generic.h b/arch/arm/mach-at91/generic.h index 78ab0654865..dc6e2f5f804 100644 --- a/arch/arm/mach-at91/generic.h +++ b/arch/arm/mach-at91/generic.h @@ -10,6 +10,7 @@  #include <linux/clkdev.h>  #include <linux/of.h> +#include <linux/reboot.h>   /* Map io */  extern void __init at91_map_io(void); @@ -60,8 +61,8 @@ extern void at91sam9_idle(void);  /* reset */  extern void at91_ioremap_rstc(u32 base_addr); -extern void at91sam9_alt_restart(char, const char *); -extern void at91sam9g45_restart(char, const char *); +extern void at91sam9_alt_restart(enum reboot_mode, const char *); +extern void at91sam9g45_restart(enum reboot_mode, const char *);  /* shutdown */  extern void at91_ioremap_shdwc(u32 base_addr); @@ -85,4 +86,4 @@ extern void __init at91_gpio_irq_setup(void);  extern int  __init at91_gpio_of_irq_setup(struct device_node *node,  					  struct device_node *parent); -extern int at91_extern_irq; +extern u32 at91_get_extern_irq(void); diff --git a/arch/arm/mach-at91/include/mach/at91_pmc.h b/arch/arm/mach-at91/include/mach/at91_pmc.h index 2bd7f51b0b8..c604cc69acb 100644 --- a/arch/arm/mach-at91/include/mach/at91_pmc.h +++ b/arch/arm/mach-at91/include/mach/at91_pmc.h @@ -130,7 +130,10 @@ extern void __iomem *at91_pmc_base;  #define		AT91_PMC_USBS		(0x1 <<  0)		/* USB OHCI Input clock selection */  #define			AT91_PMC_USBS_PLLA		(0 << 0)  #define			AT91_PMC_USBS_UPLL		(1 << 0) +#define			AT91_PMC_USBS_PLLB		(1 << 0)	/* [AT91SAMN12 only] */  #define		AT91_PMC_OHCIUSBDIV	(0xF <<  8)		/* Divider for USB OHCI Clock */ +#define			AT91_PMC_OHCIUSBDIV_1	(0x0 <<  8) +#define			AT91_PMC_OHCIUSBDIV_2	(0x1 <<  8)  #define	AT91_PMC_SMD		0x3c			/* Soft Modem Clock Register [some SAM9 only] */  #define		AT91_PMC_SMDS		(0x1  <<  0)		/* SMD input clock selection */ diff --git a/arch/arm/mach-at91/irq.c b/arch/arm/mach-at91/irq.c index e0ca5917102..3d192c5aee6 100644 --- a/arch/arm/mach-at91/irq.c +++ b/arch/arm/mach-at91/irq.c @@ -232,7 +232,14 @@ static void __maybe_unused at91_aic5_eoi(struct irq_data *d)  	at91_aic_write(AT91_AIC5_EOICR, 0);  } -unsigned long *at91_extern_irq; +static unsigned long *at91_extern_irq; + +u32 at91_get_extern_irq(void) +{ +	if (!at91_extern_irq) +		return 0; +	return *at91_extern_irq; +}  #define is_extern_irq(hwirq) test_bit(hwirq, at91_extern_irq) diff --git a/arch/arm/mach-at91/pm.c b/arch/arm/mach-at91/pm.c index 530db304ec5..15afb5d9271 100644 --- a/arch/arm/mach-at91/pm.c +++ b/arch/arm/mach-at91/pm.c @@ -212,7 +212,7 @@ static int at91_pm_enter(suspend_state_t state)  			(at91_pmc_read(AT91_PMC_PCSR)  					| (1 << AT91_ID_FIQ)  					| (1 << AT91_ID_SYS) -					| (at91_extern_irq)) +					| (at91_get_extern_irq()))  				& at91_aic_read(AT91_AIC_IMR),  			state); diff --git a/arch/arm/mach-at91/setup.c b/arch/arm/mach-at91/setup.c index e2f4bdd146d..b17fbcf4d9e 100644 --- a/arch/arm/mach-at91/setup.c +++ b/arch/arm/mach-at91/setup.c @@ -48,7 +48,7 @@ void __init at91_init_irq_default(void)  void __init at91_init_interrupts(unsigned int *priority)  {  	/* Initialize the AIC interrupt controller */ -	at91_aic_init(priority, at91_extern_irq); +	at91_aic_init(priority, at91_boot_soc.extern_irq);  	/* Enable GPIO interrupts */  	at91_gpio_irq_setup(); @@ -80,7 +80,7 @@ void __init at91_init_sram(int bank, unsigned long base, unsigned int length)  	desc->pfn = __phys_to_pfn(base);  	desc->length = length; -	desc->type = MT_DEVICE; +	desc->type = MT_MEMORY_NONCACHED;  	pr_info("AT91: sram at 0x%lx of 0x%x mapped at 0x%lx\n",  		base, length, desc->virtual); diff --git a/arch/arm/mach-at91/soc.h b/arch/arm/mach-at91/soc.h index 43a225f9e71..a1e1482c6da 100644 --- a/arch/arm/mach-at91/soc.h +++ b/arch/arm/mach-at91/soc.h @@ -6,6 +6,7 @@  struct at91_init_soc {  	int builtin; +	u32 extern_irq;  	unsigned int *default_irq_priority;  	void (*map_io)(void);  	void (*ioremap_registers)(void); | 
