diff options
| -rw-r--r-- | arch/arm/mach-mx3/Kconfig | 8 | ||||
| -rw-r--r-- | arch/arm/mach-mx3/Makefile | 1 | ||||
| -rw-r--r-- | arch/arm/mach-mx3/pcm037.c | 65 | ||||
| -rw-r--r-- | arch/arm/mach-mx3/pcm037.h | 11 | ||||
| -rw-r--r-- | arch/arm/mach-mx3/pcm037_eet.c | 204 |
5 files changed, 283 insertions, 6 deletions
diff --git a/arch/arm/mach-mx3/Kconfig b/arch/arm/mach-mx3/Kconfig index 17a21a291e2f..851f2458bf65 100644 --- a/arch/arm/mach-mx3/Kconfig +++ b/arch/arm/mach-mx3/Kconfig | |||
| @@ -36,6 +36,14 @@ config MACH_PCM037 | |||
| 36 | Include support for Phytec pcm037 platform. This includes | 36 | Include support for Phytec pcm037 platform. This includes |
| 37 | specific configurations for the board and its peripherals. | 37 | specific configurations for the board and its peripherals. |
| 38 | 38 | ||
| 39 | config MACH_PCM037_EET | ||
| 40 | bool "Support pcm037 EET board extensions" | ||
| 41 | depends on MACH_PCM037 | ||
| 42 | help | ||
| 43 | Add support for PCM037 EET baseboard extensions. If you are using the | ||
| 44 | OLED display with EET, use "video=mx3fb:CMEL-OLED" kernel | ||
| 45 | command-line parameter. | ||
| 46 | |||
| 39 | config MACH_MX31LITE | 47 | config MACH_MX31LITE |
| 40 | bool "Support MX31 LITEKIT (LogicPD)" | 48 | bool "Support MX31 LITEKIT (LogicPD)" |
| 41 | select ARCH_MX31 | 49 | select ARCH_MX31 |
diff --git a/arch/arm/mach-mx3/Makefile b/arch/arm/mach-mx3/Makefile index 0322696bd11a..6b9775471be6 100644 --- a/arch/arm/mach-mx3/Makefile +++ b/arch/arm/mach-mx3/Makefile | |||
| @@ -11,6 +11,7 @@ obj-$(CONFIG_MACH_MX31ADS) += mx31ads.o | |||
| 11 | obj-$(CONFIG_MACH_MX31LILLY) += mx31lilly.o mx31lilly-db.o | 11 | obj-$(CONFIG_MACH_MX31LILLY) += mx31lilly.o mx31lilly-db.o |
| 12 | obj-$(CONFIG_MACH_MX31LITE) += mx31lite.o | 12 | obj-$(CONFIG_MACH_MX31LITE) += mx31lite.o |
| 13 | obj-$(CONFIG_MACH_PCM037) += pcm037.o | 13 | obj-$(CONFIG_MACH_PCM037) += pcm037.o |
| 14 | obj-$(CONFIG_MACH_PCM037_EET) += pcm037_eet.o | ||
| 14 | obj-$(CONFIG_MACH_MX31_3DS) += mx31pdk.o | 15 | obj-$(CONFIG_MACH_MX31_3DS) += mx31pdk.o |
| 15 | obj-$(CONFIG_MACH_MX31MOBOARD) += mx31moboard.o mx31moboard-devboard.o \ | 16 | obj-$(CONFIG_MACH_MX31MOBOARD) += mx31moboard.o mx31moboard-devboard.o \ |
| 16 | mx31moboard-marxbot.o | 17 | mx31moboard-marxbot.o |
diff --git a/arch/arm/mach-mx3/pcm037.c b/arch/arm/mach-mx3/pcm037.c index d7b29b724a61..840cfda341d0 100644 --- a/arch/arm/mach-mx3/pcm037.c +++ b/arch/arm/mach-mx3/pcm037.c | |||
| @@ -52,6 +52,41 @@ | |||
| 52 | #include <mach/mxc_nand.h> | 52 | #include <mach/mxc_nand.h> |
| 53 | 53 | ||
| 54 | #include "devices.h" | 54 | #include "devices.h" |
| 55 | #include "pcm037.h" | ||
| 56 | |||
| 57 | static enum pcm037_board_variant pcm037_instance = PCM037_PCM970; | ||
| 58 | |||
| 59 | static int __init pcm037_variant_setup(char *str) | ||
| 60 | { | ||
| 61 | if (!strcmp("eet", str)) | ||
| 62 | pcm037_instance = PCM037_EET; | ||
| 63 | else if (strcmp("pcm970", str)) | ||
| 64 | pr_warning("Unknown pcm037 baseboard variant %s\n", str); | ||
| 65 | |||
| 66 | return 1; | ||
| 67 | } | ||
| 68 | |||
| 69 | /* Supported values: "pcm970" (default) and "eet" */ | ||
| 70 | __setup("pcm037_variant=", pcm037_variant_setup); | ||
| 71 | |||
| 72 | enum pcm037_board_variant pcm037_variant(void) | ||
| 73 | { | ||
| 74 | return pcm037_instance; | ||
| 75 | } | ||
| 76 | |||
| 77 | /* UART1 with RTS/CTS handshake signals */ | ||
| 78 | static unsigned int pcm037_uart1_handshake_pins[] = { | ||
| 79 | MX31_PIN_CTS1__CTS1, | ||
| 80 | MX31_PIN_RTS1__RTS1, | ||
| 81 | MX31_PIN_TXD1__TXD1, | ||
| 82 | MX31_PIN_RXD1__RXD1, | ||
| 83 | }; | ||
| 84 | |||
| 85 | /* UART1 without RTS/CTS handshake signals */ | ||
| 86 | static unsigned int pcm037_uart1_pins[] = { | ||
| 87 | MX31_PIN_TXD1__TXD1, | ||
| 88 | MX31_PIN_RXD1__RXD1, | ||
| 89 | }; | ||
| 55 | 90 | ||
| 56 | static unsigned int pcm037_pins[] = { | 91 | static unsigned int pcm037_pins[] = { |
| 57 | /* I2C */ | 92 | /* I2C */ |
| @@ -76,11 +111,6 @@ static unsigned int pcm037_pins[] = { | |||
| 76 | MX31_PIN_CSPI1_SS0__SS0, | 111 | MX31_PIN_CSPI1_SS0__SS0, |
| 77 | MX31_PIN_CSPI1_SS1__SS1, | 112 | MX31_PIN_CSPI1_SS1__SS1, |
| 78 | MX31_PIN_CSPI1_SS2__SS2, | 113 | MX31_PIN_CSPI1_SS2__SS2, |
| 79 | /* UART1 */ | ||
| 80 | MX31_PIN_CTS1__CTS1, | ||
| 81 | MX31_PIN_RTS1__RTS1, | ||
| 82 | MX31_PIN_TXD1__TXD1, | ||
| 83 | MX31_PIN_RXD1__RXD1, | ||
| 84 | /* UART2 */ | 114 | /* UART2 */ |
| 85 | MX31_PIN_TXD2__TXD2, | 115 | MX31_PIN_TXD2__TXD2, |
| 86 | MX31_PIN_RXD2__RXD2, | 116 | MX31_PIN_RXD2__RXD2, |
| @@ -459,6 +489,22 @@ static const struct fb_videomode fb_modedb[] = { | |||
| 459 | .sync = FB_SYNC_VERT_HIGH_ACT | FB_SYNC_OE_ACT_HIGH, | 489 | .sync = FB_SYNC_VERT_HIGH_ACT | FB_SYNC_OE_ACT_HIGH, |
| 460 | .vmode = FB_VMODE_NONINTERLACED, | 490 | .vmode = FB_VMODE_NONINTERLACED, |
| 461 | .flag = 0, | 491 | .flag = 0, |
| 492 | }, { | ||
| 493 | /* 240x320 @ 60 Hz */ | ||
| 494 | .name = "CMEL-OLED", | ||
| 495 | .refresh = 60, | ||
| 496 | .xres = 240, | ||
| 497 | .yres = 320, | ||
| 498 | .pixclock = 185925, | ||
| 499 | .left_margin = 9, | ||
| 500 | .right_margin = 16, | ||
| 501 | .upper_margin = 7, | ||
| 502 | .lower_margin = 9, | ||
| 503 | .hsync_len = 1, | ||
| 504 | .vsync_len = 1, | ||
| 505 | .sync = FB_SYNC_OE_ACT_HIGH | FB_SYNC_CLK_INVERT, | ||
| 506 | .vmode = FB_VMODE_NONINTERLACED, | ||
| 507 | .flag = 0, | ||
| 462 | }, | 508 | }, |
| 463 | }; | 509 | }; |
| 464 | 510 | ||
| @@ -479,6 +525,14 @@ static void __init mxc_board_init(void) | |||
| 479 | mxc_iomux_setup_multiple_pins(pcm037_pins, ARRAY_SIZE(pcm037_pins), | 525 | mxc_iomux_setup_multiple_pins(pcm037_pins, ARRAY_SIZE(pcm037_pins), |
| 480 | "pcm037"); | 526 | "pcm037"); |
| 481 | 527 | ||
| 528 | if (pcm037_variant() == PCM037_EET) | ||
| 529 | mxc_iomux_setup_multiple_pins(pcm037_uart1_pins, | ||
| 530 | ARRAY_SIZE(pcm037_uart1_pins), "pcm037_uart1"); | ||
| 531 | else | ||
| 532 | mxc_iomux_setup_multiple_pins(pcm037_uart1_handshake_pins, | ||
| 533 | ARRAY_SIZE(pcm037_uart1_handshake_pins), | ||
| 534 | "pcm037_uart1"); | ||
| 535 | |||
| 482 | platform_add_devices(devices, ARRAY_SIZE(devices)); | 536 | platform_add_devices(devices, ARRAY_SIZE(devices)); |
| 483 | 537 | ||
| 484 | mxc_register_device(&mxc_uart_device0, &uart_pdata); | 538 | mxc_register_device(&mxc_uart_device0, &uart_pdata); |
| @@ -542,4 +596,3 @@ MACHINE_START(PCM037, "Phytec Phycore pcm037") | |||
| 542 | .init_machine = mxc_board_init, | 596 | .init_machine = mxc_board_init, |
| 543 | .timer = &pcm037_timer, | 597 | .timer = &pcm037_timer, |
| 544 | MACHINE_END | 598 | MACHINE_END |
| 545 | |||
diff --git a/arch/arm/mach-mx3/pcm037.h b/arch/arm/mach-mx3/pcm037.h new file mode 100644 index 000000000000..d6929721a5fd --- /dev/null +++ b/arch/arm/mach-mx3/pcm037.h | |||
| @@ -0,0 +1,11 @@ | |||
| 1 | #ifndef __PCM037_H__ | ||
| 2 | #define __PCM037_H__ | ||
| 3 | |||
| 4 | enum pcm037_board_variant { | ||
| 5 | PCM037_PCM970, | ||
| 6 | PCM037_EET, | ||
| 7 | }; | ||
| 8 | |||
| 9 | extern enum pcm037_board_variant pcm037_variant(void); | ||
| 10 | |||
| 11 | #endif | ||
diff --git a/arch/arm/mach-mx3/pcm037_eet.c b/arch/arm/mach-mx3/pcm037_eet.c new file mode 100644 index 000000000000..fe52fb1bb8b7 --- /dev/null +++ b/arch/arm/mach-mx3/pcm037_eet.c | |||
| @@ -0,0 +1,204 @@ | |||
| 1 | /* | ||
| 2 | * Copyright (C) 2009 | ||
| 3 | * Guennadi Liakhovetski, DENX Software Engineering, <lg@denx.de> | ||
| 4 | * | ||
| 5 | * This program is free software; you can redistribute it and/or modify | ||
| 6 | * it under the terms of the GNU General Public License version 2 as | ||
| 7 | * published by the Free Software Foundation. | ||
| 8 | */ | ||
| 9 | #include <linux/gpio.h> | ||
| 10 | #include <linux/gpio_keys.h> | ||
| 11 | #include <linux/input.h> | ||
| 12 | #include <linux/platform_device.h> | ||
| 13 | #include <linux/spi/spi.h> | ||
| 14 | |||
| 15 | #include <mach/common.h> | ||
| 16 | #if defined(CONFIG_SPI_IMX) || defined(CONFIG_SPI_IMX_MODULE) | ||
| 17 | #include <mach/spi.h> | ||
| 18 | #endif | ||
| 19 | #include <mach/iomux-mx3.h> | ||
| 20 | |||
| 21 | #include <asm/mach-types.h> | ||
| 22 | |||
| 23 | #include "pcm037.h" | ||
| 24 | #include "devices.h" | ||
| 25 | |||
| 26 | static unsigned int pcm037_eet_pins[] = { | ||
| 27 | /* SPI #1 */ | ||
| 28 | MX31_PIN_CSPI1_MISO__MISO, | ||
| 29 | MX31_PIN_CSPI1_MOSI__MOSI, | ||
| 30 | MX31_PIN_CSPI1_SCLK__SCLK, | ||
| 31 | MX31_PIN_CSPI1_SPI_RDY__SPI_RDY, | ||
| 32 | MX31_PIN_CSPI1_SS0__SS0, | ||
| 33 | MX31_PIN_CSPI1_SS1__SS1, | ||
| 34 | MX31_PIN_CSPI1_SS2__SS2, | ||
| 35 | |||
| 36 | /* Reserve and hardwire GPIO 57 high - S6E63D6 chipselect */ | ||
| 37 | IOMUX_MODE(MX31_PIN_KEY_COL7, IOMUX_CONFIG_GPIO), | ||
| 38 | /* GPIO keys */ | ||
| 39 | IOMUX_MODE(MX31_PIN_GPIO1_0, IOMUX_CONFIG_GPIO), /* 0 */ | ||
| 40 | IOMUX_MODE(MX31_PIN_GPIO1_1, IOMUX_CONFIG_GPIO), /* 1 */ | ||
| 41 | IOMUX_MODE(MX31_PIN_GPIO1_2, IOMUX_CONFIG_GPIO), /* 2 */ | ||
| 42 | IOMUX_MODE(MX31_PIN_GPIO1_3, IOMUX_CONFIG_GPIO), /* 3 */ | ||
| 43 | IOMUX_MODE(MX31_PIN_SVEN0, IOMUX_CONFIG_GPIO), /* 32 */ | ||
| 44 | IOMUX_MODE(MX31_PIN_STX0, IOMUX_CONFIG_GPIO), /* 33 */ | ||
| 45 | IOMUX_MODE(MX31_PIN_SRX0, IOMUX_CONFIG_GPIO), /* 34 */ | ||
| 46 | IOMUX_MODE(MX31_PIN_SIMPD0, IOMUX_CONFIG_GPIO), /* 35 */ | ||
| 47 | IOMUX_MODE(MX31_PIN_RTS1, IOMUX_CONFIG_GPIO), /* 38 */ | ||
| 48 | IOMUX_MODE(MX31_PIN_CTS1, IOMUX_CONFIG_GPIO), /* 39 */ | ||
| 49 | IOMUX_MODE(MX31_PIN_KEY_ROW4, IOMUX_CONFIG_GPIO), /* 50 */ | ||
| 50 | IOMUX_MODE(MX31_PIN_KEY_ROW5, IOMUX_CONFIG_GPIO), /* 51 */ | ||
| 51 | IOMUX_MODE(MX31_PIN_KEY_ROW6, IOMUX_CONFIG_GPIO), /* 52 */ | ||
| 52 | IOMUX_MODE(MX31_PIN_KEY_ROW7, IOMUX_CONFIG_GPIO), /* 53 */ | ||
| 53 | |||
| 54 | /* LEDs */ | ||
| 55 | IOMUX_MODE(MX31_PIN_DTR_DTE1, IOMUX_CONFIG_GPIO), /* 44 */ | ||
| 56 | IOMUX_MODE(MX31_PIN_DSR_DTE1, IOMUX_CONFIG_GPIO), /* 45 */ | ||
| 57 | IOMUX_MODE(MX31_PIN_KEY_COL5, IOMUX_CONFIG_GPIO), /* 55 */ | ||
| 58 | IOMUX_MODE(MX31_PIN_KEY_COL6, IOMUX_CONFIG_GPIO), /* 56 */ | ||
| 59 | }; | ||
| 60 | |||
| 61 | /* SPI */ | ||
| 62 | static struct spi_board_info pcm037_spi_dev[] = { | ||
| 63 | { | ||
| 64 | .modalias = "dac124s085", | ||
| 65 | .max_speed_hz = 400000, | ||
| 66 | .bus_num = 0, | ||
| 67 | .chip_select = 0, /* Index in pcm037_spi1_cs[] */ | ||
| 68 | .mode = SPI_CPHA, | ||
| 69 | }, | ||
| 70 | }; | ||
| 71 | |||
| 72 | /* Platform Data for MXC CSPI */ | ||
| 73 | #if defined(CONFIG_SPI_IMX) || defined(CONFIG_SPI_IMX_MODULE) | ||
| 74 | static int pcm037_spi1_cs[] = {MXC_SPI_CS(1), IOMUX_TO_GPIO(MX31_PIN_KEY_COL7)}; | ||
| 75 | |||
| 76 | struct spi_imx_master pcm037_spi1_master = { | ||
| 77 | .chipselect = pcm037_spi1_cs, | ||
| 78 | .num_chipselect = ARRAY_SIZE(pcm037_spi1_cs), | ||
| 79 | }; | ||
| 80 | #endif | ||
| 81 | |||
| 82 | /* GPIO-keys input device */ | ||
| 83 | static struct gpio_keys_button pcm037_gpio_keys[] = { | ||
| 84 | { | ||
| 85 | .type = EV_KEY, | ||
| 86 | .code = KEY_L, | ||
| 87 | .gpio = 0, | ||
| 88 | .desc = "Wheel Manual", | ||
| 89 | .wakeup = 0, | ||
| 90 | }, { | ||
| 91 | .type = EV_KEY, | ||
| 92 | .code = KEY_A, | ||
| 93 | .gpio = 1, | ||
| 94 | .desc = "Wheel AF", | ||
| 95 | .wakeup = 0, | ||
| 96 | }, { | ||
| 97 | .type = EV_KEY, | ||
| 98 | .code = KEY_V, | ||
| 99 | .gpio = 2, | ||
| 100 | .desc = "Wheel View", | ||
| 101 | .wakeup = 0, | ||
| 102 | }, { | ||
| 103 | .type = EV_KEY, | ||
| 104 | .code = KEY_M, | ||
| 105 | .gpio = 3, | ||
| 106 | .desc = "Wheel Menu", | ||
| 107 | .wakeup = 0, | ||
| 108 | }, { | ||
| 109 | .type = EV_KEY, | ||
| 110 | .code = KEY_UP, | ||
| 111 | .gpio = 32, | ||
| 112 | .desc = "Nav Pad Up", | ||
| 113 | .wakeup = 0, | ||
| 114 | }, { | ||
| 115 | .type = EV_KEY, | ||
| 116 | .code = KEY_RIGHT, | ||
| 117 | .gpio = 33, | ||
| 118 | .desc = "Nav Pad Right", | ||
| 119 | .wakeup = 0, | ||
| 120 | }, { | ||
| 121 | .type = EV_KEY, | ||
| 122 | .code = KEY_DOWN, | ||
| 123 | .gpio = 34, | ||
| 124 | .desc = "Nav Pad Down", | ||
| 125 | .wakeup = 0, | ||
| 126 | }, { | ||
| 127 | .type = EV_KEY, | ||
| 128 | .code = KEY_LEFT, | ||
| 129 | .gpio = 35, | ||
| 130 | .desc = "Nav Pad Left", | ||
| 131 | .wakeup = 0, | ||
| 132 | }, { | ||
| 133 | .type = EV_KEY, | ||
| 134 | .code = KEY_ENTER, | ||
| 135 | .gpio = 38, | ||
| 136 | .desc = "Nav Pad Ok", | ||
| 137 | .wakeup = 0, | ||
| 138 | }, { | ||
| 139 | .type = EV_KEY, | ||
| 140 | .code = KEY_O, | ||
| 141 | .gpio = 39, | ||
| 142 | .desc = "Wheel Off", | ||
| 143 | .wakeup = 0, | ||
| 144 | }, { | ||
| 145 | .type = EV_KEY, | ||
| 146 | .code = BTN_FORWARD, | ||
| 147 | .gpio = 50, | ||
| 148 | .desc = "Focus Forward", | ||
| 149 | .wakeup = 0, | ||
| 150 | }, { | ||
| 151 | .type = EV_KEY, | ||
| 152 | .code = BTN_BACK, | ||
| 153 | .gpio = 51, | ||
| 154 | .desc = "Focus Backward", | ||
| 155 | .wakeup = 0, | ||
| 156 | }, { | ||
| 157 | .type = EV_KEY, | ||
| 158 | .code = BTN_MIDDLE, | ||
| 159 | .gpio = 52, | ||
| 160 | .desc = "Release Half", | ||
| 161 | .wakeup = 0, | ||
| 162 | }, { | ||
| 163 | .type = EV_KEY, | ||
| 164 | .code = BTN_EXTRA, | ||
| 165 | .gpio = 53, | ||
| 166 | .desc = "Release Full", | ||
| 167 | .wakeup = 0, | ||
| 168 | }, | ||
| 169 | }; | ||
| 170 | |||
| 171 | static struct gpio_keys_platform_data pcm037_gpio_keys_platform_data = { | ||
| 172 | .buttons = pcm037_gpio_keys, | ||
| 173 | .nbuttons = ARRAY_SIZE(pcm037_gpio_keys), | ||
| 174 | .rep = 0, /* No auto-repeat */ | ||
| 175 | }; | ||
| 176 | |||
| 177 | static struct platform_device pcm037_gpio_keys_device = { | ||
| 178 | .name = "gpio-keys", | ||
| 179 | .id = -1, | ||
| 180 | .dev = { | ||
| 181 | .platform_data = &pcm037_gpio_keys_platform_data, | ||
| 182 | }, | ||
| 183 | }; | ||
| 184 | |||
| 185 | static int eet_init_devices(void) | ||
| 186 | { | ||
| 187 | if (!machine_is_pcm037() || pcm037_variant() != PCM037_EET) | ||
| 188 | return 0; | ||
| 189 | |||
| 190 | mxc_iomux_setup_multiple_pins(pcm037_eet_pins, | ||
| 191 | ARRAY_SIZE(pcm037_eet_pins), "pcm037_eet"); | ||
| 192 | |||
| 193 | /* SPI */ | ||
| 194 | spi_register_board_info(pcm037_spi_dev, ARRAY_SIZE(pcm037_spi_dev)); | ||
| 195 | #if defined(CONFIG_SPI_IMX) || defined(CONFIG_SPI_IMX_MODULE) | ||
| 196 | mxc_register_device(&mxc_spi_device0, &pcm037_spi1_master); | ||
| 197 | #endif | ||
| 198 | |||
| 199 | platform_device_register(&pcm037_gpio_keys_device); | ||
| 200 | |||
| 201 | return 0; | ||
| 202 | } | ||
| 203 | |||
| 204 | late_initcall(eet_init_devices); | ||
