diff options
author | Denis 'GNUtoo' Carikli <GNUtoo@no-log.org> | 2011-02-18 16:22:23 -0500 |
---|---|---|
committer | Sascha Hauer <s.hauer@pengutronix.de> | 2011-02-28 03:28:46 -0500 |
commit | ea7ee4cae4db6630b388f39c3abe4f86f67211f9 (patch) | |
tree | 461887cc537338617ac3c2208becd2dde9051ffa /arch | |
parent | b03b2a7a2007e4122ec105b54580327d4126e000 (diff) |
mx31: add support for the bugbase 1.3 from buglabs
Note that the hardware schematics and documentations can be obtained
here: http://www.bugcommunity.com/wiki/index.php/BUGbase
Signed-off-by: Denis 'GNUtoo' Carikli <GNUtoo@no-log.org>
Acked-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/arm/mach-mx3/Kconfig | 9 | ||||
-rw-r--r-- | arch/arm/mach-mx3/Makefile | 1 | ||||
-rw-r--r-- | arch/arm/mach-mx3/mach-bug.c | 66 | ||||
-rw-r--r-- | arch/arm/plat-mxc/include/mach/uncompress.h | 4 |
4 files changed, 80 insertions, 0 deletions
diff --git a/arch/arm/mach-mx3/Kconfig b/arch/arm/mach-mx3/Kconfig index de80d980fe63..4f57f13c028c 100644 --- a/arch/arm/mach-mx3/Kconfig +++ b/arch/arm/mach-mx3/Kconfig | |||
@@ -199,6 +199,15 @@ config MACH_KZM_ARM11_01 | |||
199 | Include support for KZM-ARM11-01. This includes specific | 199 | Include support for KZM-ARM11-01. This includes specific |
200 | configurations for the board and its peripherals. | 200 | configurations for the board and its peripherals. |
201 | 201 | ||
202 | config MACH_BUG | ||
203 | bool "Support Buglabs BUGBase platform" | ||
204 | select SOC_IMX31 | ||
205 | select IMX_HAVE_PLATFORM_IMX_UART | ||
206 | default y | ||
207 | help | ||
208 | Include support for BUGBase 1.3 platform. This includes specific | ||
209 | configurations for the board and its peripherals. | ||
210 | |||
202 | config MACH_EUKREA_CPUIMX35 | 211 | config MACH_EUKREA_CPUIMX35 |
203 | bool "Support Eukrea CPUIMX35 Platform" | 212 | bool "Support Eukrea CPUIMX35 Platform" |
204 | select SOC_IMX35 | 213 | select SOC_IMX35 |
diff --git a/arch/arm/mach-mx3/Makefile b/arch/arm/mach-mx3/Makefile index 224d07a79d7e..a54faf2cf5fa 100644 --- a/arch/arm/mach-mx3/Makefile +++ b/arch/arm/mach-mx3/Makefile | |||
@@ -20,6 +20,7 @@ obj-$(CONFIG_MACH_PCM043) += mach-pcm043.o | |||
20 | obj-$(CONFIG_MACH_ARMADILLO5X0) += mach-armadillo5x0.o | 20 | obj-$(CONFIG_MACH_ARMADILLO5X0) += mach-armadillo5x0.o |
21 | obj-$(CONFIG_MACH_MX35_3DS) += mach-mx35_3ds.o | 21 | obj-$(CONFIG_MACH_MX35_3DS) += mach-mx35_3ds.o |
22 | obj-$(CONFIG_MACH_KZM_ARM11_01) += mach-kzm_arm11_01.o | 22 | obj-$(CONFIG_MACH_KZM_ARM11_01) += mach-kzm_arm11_01.o |
23 | obj-$(CONFIG_MACH_BUG) += mach-bug.o | ||
23 | obj-$(CONFIG_MACH_EUKREA_CPUIMX35) += mach-cpuimx35.o | 24 | obj-$(CONFIG_MACH_EUKREA_CPUIMX35) += mach-cpuimx35.o |
24 | obj-$(CONFIG_MACH_EUKREA_MBIMXSD35_BASEBOARD) += eukrea_mbimxsd-baseboard.o | 25 | obj-$(CONFIG_MACH_EUKREA_MBIMXSD35_BASEBOARD) += eukrea_mbimxsd-baseboard.o |
25 | obj-$(CONFIG_MACH_VPR200) += mach-vpr200.o | 26 | obj-$(CONFIG_MACH_VPR200) += mach-vpr200.o |
diff --git a/arch/arm/mach-mx3/mach-bug.c b/arch/arm/mach-mx3/mach-bug.c new file mode 100644 index 000000000000..d137d7078ee9 --- /dev/null +++ b/arch/arm/mach-mx3/mach-bug.c | |||
@@ -0,0 +1,66 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2000 Deep Blue Solutions Ltd | ||
3 | * Copyright (C) 2002 Shane Nay (shane@minirl.com) | ||
4 | * Copyright 2005-2007 Freescale Semiconductor, Inc. All Rights Reserved. | ||
5 | * Copyright 2011 Denis 'GNUtoo' Carikli <GNUtoo@no-log.org> | ||
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 | |||
18 | #include <linux/kernel.h> | ||
19 | #include <linux/init.h> | ||
20 | #include <linux/platform_device.h> | ||
21 | |||
22 | #include <mach/iomux-mx3.h> | ||
23 | #include <mach/imx-uart.h> | ||
24 | #include <mach/hardware.h> | ||
25 | #include <mach/common.h> | ||
26 | |||
27 | #include <asm/mach/time.h> | ||
28 | #include <asm/mach/arch.h> | ||
29 | #include <asm/mach-types.h> | ||
30 | |||
31 | #include "devices-imx31.h" | ||
32 | |||
33 | static const struct imxuart_platform_data uart_pdata __initconst = { | ||
34 | .flags = IMXUART_HAVE_RTSCTS, | ||
35 | }; | ||
36 | |||
37 | static const unsigned int bug_pins[] __initconst = { | ||
38 | MX31_PIN_PC_RST__CTS5, | ||
39 | MX31_PIN_PC_VS2__RTS5, | ||
40 | MX31_PIN_PC_BVD2__TXD5, | ||
41 | MX31_PIN_PC_BVD1__RXD5, | ||
42 | }; | ||
43 | |||
44 | static void __init bug_board_init(void) | ||
45 | { | ||
46 | mxc_iomux_setup_multiple_pins(bug_pins, | ||
47 | ARRAY_SIZE(bug_pins), "uart-4"); | ||
48 | imx31_add_imx_uart4(&uart_pdata); | ||
49 | } | ||
50 | |||
51 | static void __init bug_timer_init(void) | ||
52 | { | ||
53 | mx31_clocks_init(26000000); | ||
54 | } | ||
55 | |||
56 | static struct sys_timer bug_timer = { | ||
57 | .init = bug_timer_init, | ||
58 | }; | ||
59 | |||
60 | MACHINE_START(BUG, "BugLabs BUGBase") | ||
61 | .map_io = mx31_map_io, | ||
62 | .init_early = imx31_init_early, | ||
63 | .init_irq = mx31_init_irq, | ||
64 | .timer = &bug_timer, | ||
65 | .init_machine = bug_board_init, | ||
66 | MACHINE_END | ||
diff --git a/arch/arm/plat-mxc/include/mach/uncompress.h b/arch/arm/plat-mxc/include/mach/uncompress.h index 741255886214..4864b0afd440 100644 --- a/arch/arm/plat-mxc/include/mach/uncompress.h +++ b/arch/arm/plat-mxc/include/mach/uncompress.h | |||
@@ -62,6 +62,7 @@ static inline void flush(void) | |||
62 | #define MX2X_UART1_BASE_ADDR 0x1000a000 | 62 | #define MX2X_UART1_BASE_ADDR 0x1000a000 |
63 | #define MX3X_UART1_BASE_ADDR 0x43F90000 | 63 | #define MX3X_UART1_BASE_ADDR 0x43F90000 |
64 | #define MX3X_UART2_BASE_ADDR 0x43F94000 | 64 | #define MX3X_UART2_BASE_ADDR 0x43F94000 |
65 | #define MX3X_UART5_BASE_ADDR 0x43FB4000 | ||
65 | #define MX51_UART1_BASE_ADDR 0x73fbc000 | 66 | #define MX51_UART1_BASE_ADDR 0x73fbc000 |
66 | #define MX50_UART1_BASE_ADDR 0x53fbc000 | 67 | #define MX50_UART1_BASE_ADDR 0x53fbc000 |
67 | #define MX53_UART1_BASE_ADDR 0x53fbc000 | 68 | #define MX53_UART1_BASE_ADDR 0x53fbc000 |
@@ -102,6 +103,9 @@ static __inline__ void __arch_decomp_setup(unsigned long arch_id) | |||
102 | case MACH_TYPE_MAGX_ZN5: | 103 | case MACH_TYPE_MAGX_ZN5: |
103 | uart_base = MX3X_UART2_BASE_ADDR; | 104 | uart_base = MX3X_UART2_BASE_ADDR; |
104 | break; | 105 | break; |
106 | case MACH_TYPE_BUG: | ||
107 | uart_base = MX3X_UART5_BASE_ADDR; | ||
108 | break; | ||
105 | case MACH_TYPE_MX51_BABBAGE: | 109 | case MACH_TYPE_MX51_BABBAGE: |
106 | case MACH_TYPE_EUKREA_CPUIMX51SD: | 110 | case MACH_TYPE_EUKREA_CPUIMX51SD: |
107 | case MACH_TYPE_MX51_3DS: | 111 | case MACH_TYPE_MX51_3DS: |