From mboxrd@z Thu Jan 1 00:00:00 1970 From: u.kleine-koenig@pengutronix.de (Uwe =?iso-8859-1?Q?Kleine-K=F6nig?=) Date: Tue, 10 May 2011 10:13:42 +0200 Subject: [PATCH v6] [ARM] MX1: Add ARMadeus Systems APF9328 board support In-Reply-To: <1304054499-42526-1-git-send-email-gwenhael.goavec-merou@armadeus.com> References: <1304054499-42526-1-git-send-email-gwenhael.goavec-merou@armadeus.com> Message-ID: <20110510081342.GG29089@pengutronix.de> To: linux-arm-kernel@lists.infradead.org List-Id: linux-arm-kernel.lists.infradead.org On Fri, Apr 29, 2011 at 05:21:39AM +0000, Gwenhael Goavec-Merou wrote: > APF9328 is an i.MXL based SOM (System On Module) that can be plugged on > several docking/development boards. Here only basic module support > is added (Ethernet, Serial, NOR Flash). > > Signed-off-by: Gwenhael Goavec-Merou > Signed-off-by: Eric Jarrige > Signed-off-by: Nicolas Colombain > Signed-off-by: Julien Boibessot Acked-by: Uwe Kleine-K?nig > --- > > Changes since v5: > - suppress array index for struct resource > > Changes since v4: > - use constant instead of multiplications > - change maintainer description > > Changes since v3: > - suppress const and __initconst attributes for platform_data and > resource, > - add SOC_IMX1 in Kconfig > > Changes since v2: > - add const and __initconst attributes for platform_data and resource, > - suppress boot_params. > > Changes since v1: > - merge pins tables for UART > - suppress init/exit driver callbacks for UART > > arch/arm/configs/mx1_defconfig | 1 + > arch/arm/mach-imx/Kconfig | 7 ++ > arch/arm/mach-imx/Makefile | 1 + > arch/arm/mach-imx/mach-apf9328.c | 144 ++++++++++++++++++++++++++++++++++++++ > 4 files changed, 153 insertions(+), 0 deletions(-) > create mode 100644 arch/arm/mach-imx/mach-apf9328.c > > diff --git a/arch/arm/configs/mx1_defconfig b/arch/arm/configs/mx1_defconfig > index ff96e8f..e6f6579 100644 > --- a/arch/arm/configs/mx1_defconfig > +++ b/arch/arm/configs/mx1_defconfig > @@ -14,6 +14,7 @@ CONFIG_ARCH_MXC=y > CONFIG_ARCH_MX1=y > CONFIG_ARCH_MX1ADS=y > CONFIG_MACH_SCB9328=y > +CONFIG_MACH_APF9328=y > CONFIG_MXC_IRQ_PRIOR=y > CONFIG_MXC_PWM=y > CONFIG_NO_HZ=y > diff --git a/arch/arm/mach-imx/Kconfig b/arch/arm/mach-imx/Kconfig > index 0382301..4f556ee 100644 > --- a/arch/arm/mach-imx/Kconfig > +++ b/arch/arm/mach-imx/Kconfig > @@ -86,6 +86,13 @@ config MACH_SCB9328 > help > Say Y here if you are using a Synertronixx scb9328 board > > +config MACH_APF9328 > + bool "APF9328" > + select SOC_IMX1 > + select IMX_HAVE_PLATFORM_IMX_UART > + help > + Say Yes here if you are using the Armadeus APF9328 development board > + > endif > > if MACH_MX21 > diff --git a/arch/arm/mach-imx/Makefile b/arch/arm/mach-imx/Makefile > index 6d51e65..e9eb36d 100644 > --- a/arch/arm/mach-imx/Makefile > +++ b/arch/arm/mach-imx/Makefile > @@ -18,6 +18,7 @@ obj-$(CONFIG_MX1_VIDEO) += mx1-camera-fiq.o mx1-camera-fiq-ksym.o > # i.MX1 based machines > obj-$(CONFIG_ARCH_MX1ADS) += mach-mx1ads.o > obj-$(CONFIG_MACH_SCB9328) += mach-scb9328.o > +obj-$(CONFIG_MACH_APF9328) += mach-apf9328.o > > # i.MX21 based machines > obj-$(CONFIG_MACH_MX21ADS) += mach-mx21ads.o > diff --git a/arch/arm/mach-imx/mach-apf9328.c b/arch/arm/mach-imx/mach-apf9328.c > new file mode 100644 > index 0000000..15e45c8 > --- /dev/null > +++ b/arch/arm/mach-imx/mach-apf9328.c > @@ -0,0 +1,144 @@ > +/* > + * linux/arch/arm/mach-imx/mach-apf9328.c > + * > + * Copyright (c) 2005-2011 ARMadeus systems > + * > + * This work is based on mach-scb9328.c which is: > + * Copyright (c) 2004 Sascha Hauer > + * Copyright (c) 2006-2008 Juergen Beisert > + * > + * This program is free software; you can redistribute it and/or modify > + * it under the terms of the GNU General Public License version 2 as > + * published by the Free Software Foundation. > + * > + */ > + > +#include > +#include > +#include > +#include > +#include > + > +#include > +#include > +#include > + > +#include > +#include > +#include > +#include > + > +#include "devices-imx1.h" > + > +static const int apf9328_pins[] __initconst = { > + /* UART1 */ > + PC9_PF_UART1_CTS, > + PC10_PF_UART1_RTS, > + PC11_PF_UART1_TXD, > + PC12_PF_UART1_RXD, > + /* UART2 */ > + PB28_PF_UART2_CTS, > + PB29_PF_UART2_RTS, > + PB30_PF_UART2_TXD, > + PB31_PF_UART2_RXD, > +}; > + > +/* > + * The APF9328 can have up to 32MB NOR Flash > + */ > +static struct resource flash_resource = { > + .start = MX1_CS0_PHYS, > + .end = MX1_CS0_PHYS + SZ_32M - 1, > + .flags = IORESOURCE_MEM, > +}; > + > +static struct physmap_flash_data apf9328_flash_data = { > + .width = 2, > +}; > + > +static struct platform_device apf9328_flash_device = { > + .name = "physmap-flash", > + .id = 0, > + .dev = { > + .platform_data = &apf9328_flash_data, > + }, > + .resource = &flash_resource, > + .num_resources = 1, > +}; > + > +/* > + * APF9328 has a DM9000 Ethernet controller > + */ > +static struct dm9000_plat_data dm9000_setup = { > + .flags = DM9000_PLATF_16BITONLY > +}; > + > +static struct resource dm9000_resources[] = { > + { > + .start = MX1_CS4_PHYS + 0x00C00000, > + .end = MX1_CS4_PHYS + 0x00C00001, > + .flags = IORESOURCE_MEM, > + }, { > + .start = MX1_CS4_PHYS + 0x00C00002, > + .end = MX1_CS4_PHYS + 0x00C00003, > + .flags = IORESOURCE_MEM, > + }, { > + .start = IRQ_GPIOB(14), > + .end = IRQ_GPIOB(14), > + .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_LOWLEVEL, > + }, > +}; > + > +static struct platform_device dm9000x_device = { > + .name = "dm9000", > + .id = 0, > + .num_resources = ARRAY_SIZE(dm9000_resources), > + .resource = dm9000_resources, > + .dev = { > + .platform_data = &dm9000_setup, > + } > +}; > + > +/* --- SERIAL RESSOURCE --- */ > +static const struct imxuart_platform_data uart0_pdata __initconst = { > + .flags = 0, > +}; > + > +static const struct imxuart_platform_data uart1_pdata __initconst = { > + .flags = IMXUART_HAVE_RTSCTS, > +}; > + > +static struct platform_device *devices[] __initdata = { > + &apf9328_flash_device, > + &dm9000x_device, > +}; > + > +static void __init apf9328_init(void) > +{ > + mxc_gpio_setup_multiple_pins(apf9328_pins, > + ARRAY_SIZE(apf9328_pins), > + "APF9328"); > + > + imx1_add_imx_uart0(&uart0_pdata); > + imx1_add_imx_uart1(&uart1_pdata); > + > + platform_add_devices(devices, ARRAY_SIZE(devices)); > +} > + > +static void __init apf9328_timer_init(void) > +{ > + mx1_clocks_init(32768); > +} > + > +static struct sys_timer apf9328_timer = { > + .init = apf9328_timer_init, > +}; > + > +MACHINE_START(APF9328, "Armadeus APF9328") > + /* Maintainer: Gwenhael Goavec-Merou, ARMadeus Systems */ > + .map_io = mx1_map_io, > + .init_early = imx1_init_early, > + .init_irq = mx1_init_irq, > + .timer = &apf9328_timer, > + .init_machine = apf9328_init, > +MACHINE_END > -- > 1.7.3.4 > > > _______________________________________________ > linux-arm-kernel mailing list > linux-arm-kernel at lists.infradead.org > http://lists.infradead.org/mailman/listinfo/linux-arm-kernel > -- Pengutronix e.K. | Uwe Kleine-K?nig | Industrial Linux Solutions | http://www.pengutronix.de/ |