Freescale i.MX25 PDK (3ds) board support
authorSascha Hauer <s.hauer@pengutronix.de>
Thu, 4 Jun 2009 09:32:46 +0000 (11:32 +0200)
committerSascha Hauer <s.hauer@pengutronix.de>
Fri, 14 Aug 2009 10:40:43 +0000 (12:40 +0200)
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
arch/arm/mach-mx25/Kconfig
arch/arm/mach-mx25/Makefile
arch/arm/mach-mx25/mx25pdk.c [new file with mode: 0644]
arch/arm/plat-mxc/include/mach/uncompress.h

index 14c918bad52ad45331571b962ec7283fbb64aa3c..cc28f56eae80ad5f8b7ba0c6d068cc481a6b96d0 100644 (file)
@@ -2,4 +2,8 @@ if ARCH_MX25
 
 comment "MX25 platforms:"
 
+config MACH_MX25_3DS
+       select ARCH_MXC_IOMUX_V3
+       bool "Support MX25PDK (3DS) Platform"
+
 endif
index 5471086d5e13fb1a0bba1933e1bbd30faf9312b0..fe23836a9f3d85adbe6f8874d1201ab4983ccf69 100644 (file)
@@ -1,2 +1,3 @@
 obj-y                          := mm.o devices.o
 obj-$(CONFIG_ARCH_MX25)                += clock.o
+obj-$(CONFIG_MACH_MX25_3DS)    += mx25pdk.o
diff --git a/arch/arm/mach-mx25/mx25pdk.c b/arch/arm/mach-mx25/mx25pdk.c
new file mode 100644 (file)
index 0000000..92aa4fd
--- /dev/null
@@ -0,0 +1,58 @@
+#include <linux/types.h>
+#include <linux/init.h>
+#include <linux/clk.h>
+#include <linux/irq.h>
+#include <linux/gpio.h>
+#include <linux/smsc911x.h>
+#include <linux/platform_device.h>
+
+#include <mach/hardware.h>
+#include <asm/mach-types.h>
+#include <asm/mach/arch.h>
+#include <asm/mach/time.h>
+#include <asm/memory.h>
+#include <asm/mach/map.h>
+#include <mach/common.h>
+#include <mach/imx-uart.h>
+#include <mach/mx25.h>
+#include <mach/mxc_nand.h>
+#include "devices.h"
+#include <mach/iomux-v3.h>
+
+static struct imxuart_platform_data uart_pdata = {
+       .flags = IMXUART_HAVE_RTSCTS,
+};
+
+static struct mxc_nand_platform_data nand_board_info = {
+       .width = 1,
+       .hw_ecc = 1,
+};
+
+static void __init mx25pdk_init(void)
+{
+       mxc_register_device(&mxc_uart_device0, &uart_pdata);
+       mxc_register_device(&mxc_usbh2, NULL);
+       mxc_register_device(&mxc_nand_device, &nand_board_info);
+}
+
+
+static void __init mx25pdk_timer_init(void)
+{
+       mx25_clocks_init(26000000);
+}
+
+static struct sys_timer mx25pdk_timer = {
+       .init   = mx25pdk_timer_init,
+};
+
+MACHINE_START(MX25_3DS, "Freescale MX25PDK (3DS)")
+       /* Maintainer: Freescale Semiconductor, Inc. */
+       .phys_io        = MX25_AIPS1_BASE_ADDR,
+       .io_pg_offst    = ((MX25_AIPS1_BASE_ADDR_VIRT) >> 18) & 0xfffc,
+       .boot_params    = PHYS_OFFSET + 0x100,
+       .map_io         = mx25_map_io,
+       .init_irq       = mx25_init_irq,
+       .init_machine   = mx25pdk_init,
+       .timer          = &mx25pdk_timer,
+MACHINE_END
+
index b6650e705e310b705bfe13ae2e9c77c163da37ba..1e24499f20b5ec244550677454c85fd775338b23 100644 (file)
@@ -74,6 +74,9 @@ static __inline__ void __arch_decomp_setup(unsigned long arch_id)
        case MACH_TYPE_SCB9328:
                uart_base = MX1_UART1_BASE_ADDR;
                break;
+       case MACH_TYPE_MX25_3DS:
+               uart_base = MX25_UART1_BASE_ADDR;
+               break;
        case MACH_TYPE_IMX27LITE:
        case MACH_TYPE_MX27_3DS:
        case MACH_TYPE_MX27ADS: