Blame view
arch/arm/mach-imx/mach-pcm037.c
17.4 KB
ce8ffef0b MX31: add basic p... |
1 2 3 4 5 6 7 8 9 10 11 12 |
/* * Copyright (C) 2008 Sascha Hauer, Pengutronix * * 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. |
ce8ffef0b MX31: add basic p... |
13 14 15 16 |
*/ #include <linux/types.h> #include <linux/init.h> |
32c1ad9ab pcm037: add MT9T0... |
17 |
#include <linux/dma-mapping.h> |
ce8ffef0b MX31: add basic p... |
18 19 |
#include <linux/platform_device.h> #include <linux/mtd/physmap.h> |
3dad21a95 [ARM] pcm037: Add... |
20 |
#include <linux/mtd/plat-ram.h> |
ce8ffef0b MX31: add basic p... |
21 |
#include <linux/memory.h> |
ba54b9589 [ARM] pcm037: add... |
22 |
#include <linux/gpio.h> |
4353318ed arm: convert pcm0... |
23 |
#include <linux/smsc911x.h> |
ba54b9589 [ARM] pcm037: add... |
24 |
#include <linux/interrupt.h> |
792067507 [ARM] PCM037 Boar... |
25 26 |
#include <linux/i2c.h> #include <linux/i2c/at24.h> |
dddd4a493 pcm037: add SDHC ... |
27 28 29 |
#include <linux/delay.h> #include <linux/spi/spi.h> #include <linux/irq.h> |
91bf9a256 pcm037: Add suppo... |
30 |
#include <linux/can/platform/sja1000.h> |
ee14373cd i.MX31 pcm037: Ad... |
31 32 |
#include <linux/usb/otg.h> #include <linux/usb/ulpi.h> |
5a0e3ad6a include cleanup: ... |
33 |
#include <linux/gfp.h> |
dca7c0b42 ARM: mx3/pcm037: ... |
34 |
#include <linux/memblock.h> |
ce8ffef0b MX31: add basic p... |
35 |
|
32c1ad9ab pcm037: add MT9T0... |
36 |
#include <media/soc_camera.h> |
ce8ffef0b MX31: add basic p... |
37 38 39 40 |
#include <asm/mach-types.h> #include <asm/mach/arch.h> #include <asm/mach/time.h> #include <asm/mach/map.h> |
716a3dc20 ARM: Add arm_memb... |
41 |
#include <asm/memblock.h> |
a09e64fbc [ARM] Move includ... |
42 |
#include <mach/common.h> |
32c1ad9ab pcm037: add MT9T0... |
43 |
#include <mach/hardware.h> |
a09e64fbc [ARM] Move includ... |
44 |
#include <mach/iomux-mx3.h> |
ee14373cd i.MX31 pcm037: Ad... |
45 |
#include <mach/ulpi.h> |
ce8ffef0b MX31: add basic p... |
46 |
|
a2ceeef59 ARM: imx: Change ... |
47 |
#include "devices-imx31.h" |
574ec547c ARM: add support ... |
48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 |
#include "pcm037.h" static enum pcm037_board_variant pcm037_instance = PCM037_PCM970; static int __init pcm037_variant_setup(char *str) { if (!strcmp("eet", str)) pcm037_instance = PCM037_EET; else if (strcmp("pcm970", str)) pr_warning("Unknown pcm037 baseboard variant %s ", str); return 1; } /* Supported values: "pcm970" (default) and "eet" */ __setup("pcm037_variant=", pcm037_variant_setup); enum pcm037_board_variant pcm037_variant(void) { return pcm037_instance; } /* UART1 with RTS/CTS handshake signals */ static unsigned int pcm037_uart1_handshake_pins[] = { MX31_PIN_CTS1__CTS1, MX31_PIN_RTS1__RTS1, MX31_PIN_TXD1__TXD1, MX31_PIN_RXD1__RXD1, }; /* UART1 without RTS/CTS handshake signals */ static unsigned int pcm037_uart1_pins[] = { MX31_PIN_TXD1__TXD1, MX31_PIN_RXD1__RXD1, }; |
5cf094212 i.MX3: make SoC d... |
84 |
|
01ac7d584 pcm037: setup all... |
85 86 87 88 |
static unsigned int pcm037_pins[] = { /* I2C */ MX31_PIN_CSPI2_MOSI__SCL, MX31_PIN_CSPI2_MISO__SDA, |
32c1ad9ab pcm037: add MT9T0... |
89 90 |
MX31_PIN_CSPI2_SS2__I2C3_SDA, MX31_PIN_CSPI2_SCLK__I2C3_SCL, |
01ac7d584 pcm037: setup all... |
91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 |
/* SDHC1 */ MX31_PIN_SD1_DATA3__SD1_DATA3, MX31_PIN_SD1_DATA2__SD1_DATA2, MX31_PIN_SD1_DATA1__SD1_DATA1, MX31_PIN_SD1_DATA0__SD1_DATA0, MX31_PIN_SD1_CLK__SD1_CLK, MX31_PIN_SD1_CMD__SD1_CMD, IOMUX_MODE(MX31_PIN_SCK6, IOMUX_CONFIG_GPIO), /* card detect */ IOMUX_MODE(MX31_PIN_SFS6, IOMUX_CONFIG_GPIO), /* write protect */ /* SPI1 */ MX31_PIN_CSPI1_MOSI__MOSI, MX31_PIN_CSPI1_MISO__MISO, MX31_PIN_CSPI1_SCLK__SCLK, MX31_PIN_CSPI1_SPI_RDY__SPI_RDY, MX31_PIN_CSPI1_SS0__SS0, MX31_PIN_CSPI1_SS1__SS1, MX31_PIN_CSPI1_SS2__SS2, |
01ac7d584 pcm037: setup all... |
108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 |
/* UART2 */ MX31_PIN_TXD2__TXD2, MX31_PIN_RXD2__RXD2, MX31_PIN_CTS2__CTS2, MX31_PIN_RTS2__RTS2, /* UART3 */ MX31_PIN_CSPI3_MOSI__RXD3, MX31_PIN_CSPI3_MISO__TXD3, MX31_PIN_CSPI3_SCLK__RTS3, MX31_PIN_CSPI3_SPI_RDY__CTS3, /* LAN9217 irq pin */ IOMUX_MODE(MX31_PIN_GPIO3_1, IOMUX_CONFIG_GPIO), /* Onewire */ MX31_PIN_BATT_LINE__OWIRE, /* Framebuffer */ MX31_PIN_LD0__LD0, MX31_PIN_LD1__LD1, MX31_PIN_LD2__LD2, MX31_PIN_LD3__LD3, MX31_PIN_LD4__LD4, MX31_PIN_LD5__LD5, MX31_PIN_LD6__LD6, MX31_PIN_LD7__LD7, MX31_PIN_LD8__LD8, MX31_PIN_LD9__LD9, MX31_PIN_LD10__LD10, MX31_PIN_LD11__LD11, MX31_PIN_LD12__LD12, MX31_PIN_LD13__LD13, MX31_PIN_LD14__LD14, MX31_PIN_LD15__LD15, MX31_PIN_LD16__LD16, MX31_PIN_LD17__LD17, MX31_PIN_VSYNC3__VSYNC3, MX31_PIN_HSYNC__HSYNC, MX31_PIN_FPSHIFT__FPSHIFT, MX31_PIN_DRDY0__DRDY0, MX31_PIN_D3_REV__D3_REV, MX31_PIN_CONTRAST__CONTRAST, MX31_PIN_D3_SPL__D3_SPL, MX31_PIN_D3_CLS__D3_CLS, MX31_PIN_LCS0__GPI03_23, |
32c1ad9ab pcm037: add MT9T0... |
150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 |
/* CSI */ IOMUX_MODE(MX31_PIN_CSI_D5, IOMUX_CONFIG_GPIO), MX31_PIN_CSI_D6__CSI_D6, MX31_PIN_CSI_D7__CSI_D7, MX31_PIN_CSI_D8__CSI_D8, MX31_PIN_CSI_D9__CSI_D9, MX31_PIN_CSI_D10__CSI_D10, MX31_PIN_CSI_D11__CSI_D11, MX31_PIN_CSI_D12__CSI_D12, MX31_PIN_CSI_D13__CSI_D13, MX31_PIN_CSI_D14__CSI_D14, MX31_PIN_CSI_D15__CSI_D15, MX31_PIN_CSI_HSYNC__CSI_HSYNC, MX31_PIN_CSI_MCLK__CSI_MCLK, MX31_PIN_CSI_PIXCLK__CSI_PIXCLK, MX31_PIN_CSI_VSYNC__CSI_VSYNC, |
e0fd4db37 pcm037: mux confi... |
166 167 |
/* GPIO */ IOMUX_MODE(MX31_PIN_ATA_DMACK, IOMUX_CONFIG_GPIO), |
ee14373cd i.MX31 pcm037: Ad... |
168 |
/* OTG */ |
eb05bbeb6 ARM: add USB devi... |
169 170 171 172 173 174 175 176 177 178 179 180 |
MX31_PIN_USBOTG_DATA0__USBOTG_DATA0, MX31_PIN_USBOTG_DATA1__USBOTG_DATA1, MX31_PIN_USBOTG_DATA2__USBOTG_DATA2, MX31_PIN_USBOTG_DATA3__USBOTG_DATA3, MX31_PIN_USBOTG_DATA4__USBOTG_DATA4, MX31_PIN_USBOTG_DATA5__USBOTG_DATA5, MX31_PIN_USBOTG_DATA6__USBOTG_DATA6, MX31_PIN_USBOTG_DATA7__USBOTG_DATA7, MX31_PIN_USBOTG_CLK__USBOTG_CLK, MX31_PIN_USBOTG_DIR__USBOTG_DIR, MX31_PIN_USBOTG_NXT__USBOTG_NXT, MX31_PIN_USBOTG_STP__USBOTG_STP, |
ee14373cd i.MX31 pcm037: Ad... |
181 182 183 184 185 186 187 188 189 190 191 192 193 |
/* USB host 2 */ IOMUX_MODE(MX31_PIN_USBH2_CLK, IOMUX_CONFIG_FUNC), IOMUX_MODE(MX31_PIN_USBH2_DIR, IOMUX_CONFIG_FUNC), IOMUX_MODE(MX31_PIN_USBH2_NXT, IOMUX_CONFIG_FUNC), IOMUX_MODE(MX31_PIN_USBH2_STP, IOMUX_CONFIG_FUNC), IOMUX_MODE(MX31_PIN_USBH2_DATA0, IOMUX_CONFIG_FUNC), IOMUX_MODE(MX31_PIN_USBH2_DATA1, IOMUX_CONFIG_FUNC), IOMUX_MODE(MX31_PIN_STXD3, IOMUX_CONFIG_FUNC), IOMUX_MODE(MX31_PIN_SRXD3, IOMUX_CONFIG_FUNC), IOMUX_MODE(MX31_PIN_SCK3, IOMUX_CONFIG_FUNC), IOMUX_MODE(MX31_PIN_SFS3, IOMUX_CONFIG_FUNC), IOMUX_MODE(MX31_PIN_STXD6, IOMUX_CONFIG_FUNC), IOMUX_MODE(MX31_PIN_SRXD6, IOMUX_CONFIG_FUNC), |
eb05bbeb6 ARM: add USB devi... |
194 |
}; |
ee14373cd i.MX31 pcm037: Ad... |
195 196 197 |
static struct physmap_flash_data pcm037_flash_data = { .width = 2, }; |
eb05bbeb6 ARM: add USB devi... |
198 |
|
ee14373cd i.MX31 pcm037: Ad... |
199 200 201 202 |
static struct resource pcm037_flash_resource = { .start = 0xa0000000, .end = 0xa1ffffff, .flags = IORESOURCE_MEM, |
eb05bbeb6 ARM: add USB devi... |
203 |
}; |
ce8ffef0b MX31: add basic p... |
204 205 206 207 208 209 210 211 212 |
static struct platform_device pcm037_flash = { .name = "physmap-flash", .id = 0, .dev = { .platform_data = &pcm037_flash_data, }, .resource = &pcm037_flash_resource, .num_resources = 1, }; |
16cf5c415 ARM: imx: dynamic... |
213 |
static const struct imxuart_platform_data uart_pdata __initconst = { |
a9b062335 pcm037: add rts/c... |
214 |
.flags = IMXUART_HAVE_RTSCTS, |
ce8ffef0b MX31: add basic p... |
215 |
}; |
4353318ed arm: convert pcm0... |
216 |
static struct resource smsc911x_resources[] = { |
3f4f54b4f mx3: Codingstyle:... |
217 |
{ |
f568dd7f5 imx/mach-mx3: use... |
218 219 |
.start = MX31_CS1_BASE_ADDR + 0x300, .end = MX31_CS1_BASE_ADDR + 0x300 + SZ_64K - 1, |
ba54b9589 [ARM] pcm037: add... |
220 |
.flags = IORESOURCE_MEM, |
3f4f54b4f mx3: Codingstyle:... |
221 |
}, { |
ba54b9589 [ARM] pcm037: add... |
222 223 |
.start = IOMUX_TO_IRQ(MX31_PIN_GPIO3_1), .end = IOMUX_TO_IRQ(MX31_PIN_GPIO3_1), |
4353318ed arm: convert pcm0... |
224 |
.flags = IORESOURCE_IRQ | IORESOURCE_IRQ_LOWLEVEL, |
ba54b9589 [ARM] pcm037: add... |
225 226 |
}, }; |
4353318ed arm: convert pcm0... |
227 228 229 230 231 232 |
static struct smsc911x_platform_config smsc911x_info = { .flags = SMSC911X_USE_32BIT | SMSC911X_FORCE_INTERNAL_PHY | SMSC911X_SAVE_MAC_ADDRESS, .irq_polarity = SMSC911X_IRQ_POLARITY_ACTIVE_LOW, .irq_type = SMSC911X_IRQ_TYPE_OPEN_DRAIN, .phy_interface = PHY_INTERFACE_MODE_MII, |
ba54b9589 [ARM] pcm037: add... |
233 234 235 |
}; static struct platform_device pcm037_eth = { |
4353318ed arm: convert pcm0... |
236 |
.name = "smsc911x", |
ba54b9589 [ARM] pcm037: add... |
237 |
.id = -1, |
4353318ed arm: convert pcm0... |
238 239 |
.num_resources = ARRAY_SIZE(smsc911x_resources), .resource = smsc911x_resources, |
ba54b9589 [ARM] pcm037: add... |
240 |
.dev = { |
4353318ed arm: convert pcm0... |
241 |
.platform_data = &smsc911x_info, |
ba54b9589 [ARM] pcm037: add... |
242 243 |
}, }; |
3dad21a95 [ARM] pcm037: Add... |
244 245 246 247 248 |
static struct platdata_mtd_ram pcm038_sram_data = { .bankwidth = 2, }; static struct resource pcm038_sram_resource = { |
f568dd7f5 imx/mach-mx3: use... |
249 250 |
.start = MX31_CS4_BASE_ADDR, .end = MX31_CS4_BASE_ADDR + 512 * 1024 - 1, |
3dad21a95 [ARM] pcm037: Add... |
251 252 253 254 255 256 257 258 259 260 261 262 |
.flags = IORESOURCE_MEM, }; static struct platform_device pcm037_sram_device = { .name = "mtd-ram", .id = 0, .dev = { .platform_data = &pcm038_sram_data, }, .num_resources = 1, .resource = &pcm038_sram_resource, }; |
a2ceeef59 ARM: imx: Change ... |
263 264 |
static const struct mxc_nand_platform_data pcm037_nand_board_info __initconst = { |
3287abbd7 [ARM] pcm037: add... |
265 266 267 |
.width = 1, .hw_ecc = 1, }; |
4a9b8b0b0 ARM: imx: dynamic... |
268 |
static const struct imxi2c_platform_data pcm037_i2c1_data __initconst = { |
792067507 [ARM] PCM037 Boar... |
269 |
.bitrate = 100000, |
792067507 [ARM] PCM037 Boar... |
270 |
}; |
4a9b8b0b0 ARM: imx: dynamic... |
271 |
static const struct imxi2c_platform_data pcm037_i2c2_data __initconst = { |
32c1ad9ab pcm037: add MT9T0... |
272 273 |
.bitrate = 20000, }; |
792067507 [ARM] PCM037 Boar... |
274 275 276 277 278 |
static struct at24_platform_data board_eeprom = { .byte_len = 4096, .page_size = 32, .flags = AT24_FLAG_ADDR16, }; |
32c1ad9ab pcm037: add MT9T0... |
279 280 281 282 283 284 |
static int pcm037_camera_power(struct device *dev, int on) { /* disable or enable the camera in X7 or X8 PCM970 connector */ gpio_set_value(IOMUX_TO_GPIO(MX31_PIN_CSI_D5), !on); return 0; } |
9d00278d4 mx3: add support ... |
285 |
static struct i2c_board_info pcm037_i2c_camera[] = { |
32c1ad9ab pcm037: add MT9T0... |
286 287 |
{ I2C_BOARD_INFO("mt9t031", 0x5d), |
9d00278d4 mx3: add support ... |
288 289 |
}, { I2C_BOARD_INFO("mt9v022", 0x48), |
32c1ad9ab pcm037: add MT9T0... |
290 291 |
}, }; |
9d00278d4 mx3: add support ... |
292 293 294 295 |
static struct soc_camera_link iclink_mt9v022 = { .bus_id = 0, /* Must match with the camera ID */ .board_info = &pcm037_i2c_camera[1], .i2c_adapter_id = 2, |
9d00278d4 mx3: add support ... |
296 297 298 |
}; static struct soc_camera_link iclink_mt9t031 = { |
32c1ad9ab pcm037: add MT9T0... |
299 300 |
.bus_id = 0, /* Must match with the camera ID */ .power = pcm037_camera_power, |
9d00278d4 mx3: add support ... |
301 |
.board_info = &pcm037_i2c_camera[0], |
32c1ad9ab pcm037: add MT9T0... |
302 |
.i2c_adapter_id = 2, |
32c1ad9ab pcm037: add MT9T0... |
303 |
}; |
792067507 [ARM] PCM037 Boar... |
304 |
static struct i2c_board_info pcm037_i2c_devices[] = { |
32c1ad9ab pcm037: add MT9T0... |
305 |
{ |
792067507 [ARM] PCM037 Boar... |
306 307 308 |
I2C_BOARD_INFO("at24", 0x52), /* E0=0, E1=1, E2=0 */ .platform_data = &board_eeprom, }, { |
cf87a6e2f ARM: mxc: Fix i2c... |
309 |
I2C_BOARD_INFO("pcf8563", 0x51), |
792067507 [ARM] PCM037 Boar... |
310 311 |
} }; |
32c1ad9ab pcm037: add MT9T0... |
312 |
|
9d00278d4 mx3: add support ... |
313 |
static struct platform_device pcm037_mt9t031 = { |
32c1ad9ab pcm037: add MT9T0... |
314 315 316 |
.name = "soc-camera-pdrv", .id = 0, .dev = { |
9d00278d4 mx3: add support ... |
317 318 319 320 321 322 323 324 325 |
.platform_data = &iclink_mt9t031, }, }; static struct platform_device pcm037_mt9v022 = { .name = "soc-camera-pdrv", .id = 1, .dev = { .platform_data = &iclink_mt9v022, |
32c1ad9ab pcm037: add MT9T0... |
326 327 |
}, }; |
792067507 [ARM] PCM037 Boar... |
328 |
|
dddd4a493 pcm037: add SDHC ... |
329 330 331 |
/* Not connected by default */ #ifdef PCM970_SDHC_RW_SWITCH static int pcm970_sdhc1_get_ro(struct device *dev) |
f2cb641f5 pcm037: Add sdhc ... |
332 |
{ |
dddd4a493 pcm037: add SDHC ... |
333 334 335 |
return gpio_get_value(IOMUX_TO_GPIO(MX31_PIN_SFS6)); } #endif |
4f163eb88 mx31: calls to gp... |
336 337 |
#define SDHC1_GPIO_WP IOMUX_TO_GPIO(MX31_PIN_SFS6) #define SDHC1_GPIO_DET IOMUX_TO_GPIO(MX31_PIN_SCK6) |
dddd4a493 pcm037: add SDHC ... |
338 339 340 341 |
static int pcm970_sdhc1_init(struct device *dev, irq_handler_t detect_irq, void *data) { int ret; |
dddd4a493 pcm037: add SDHC ... |
342 |
|
4f163eb88 mx31: calls to gp... |
343 344 345 346 347 |
ret = gpio_request(SDHC1_GPIO_DET, "sdhc-detect"); if (ret) return ret; gpio_direction_input(SDHC1_GPIO_DET); |
dddd4a493 pcm037: add SDHC ... |
348 |
|
4f163eb88 mx31: calls to gp... |
349 350 351 352 353 354 |
#ifdef PCM970_SDHC_RW_SWITCH ret = gpio_request(SDHC1_GPIO_WP, "sdhc-wp"); if (ret) goto err_gpio_free; gpio_direction_input(SDHC1_GPIO_WP); #endif |
dddd4a493 pcm037: add SDHC ... |
355 356 357 358 |
ret = request_irq(IOMUX_TO_IRQ(MX31_PIN_SCK6), detect_irq, IRQF_DISABLED | IRQF_TRIGGER_FALLING, "sdhc-detect", data); |
4f163eb88 mx31: calls to gp... |
359 360 361 362 363 364 365 366 367 368 369 |
if (ret) goto err_gpio_free_2; return 0; err_gpio_free_2: #ifdef PCM970_SDHC_RW_SWITCH gpio_free(SDHC1_GPIO_WP); err_gpio_free: #endif gpio_free(SDHC1_GPIO_DET); |
dddd4a493 pcm037: add SDHC ... |
370 |
return ret; |
f2cb641f5 pcm037: Add sdhc ... |
371 372 373 374 |
} static void pcm970_sdhc1_exit(struct device *dev, void *data) { |
dddd4a493 pcm037: add SDHC ... |
375 |
free_irq(IOMUX_TO_IRQ(MX31_PIN_SCK6), data); |
4f163eb88 mx31: calls to gp... |
376 377 |
gpio_free(SDHC1_GPIO_DET); gpio_free(SDHC1_GPIO_WP); |
f2cb641f5 pcm037: Add sdhc ... |
378 |
} |
6a697e3d3 ARM: mx3: dynamic... |
379 |
static const struct imxmmc_platform_data sdhc_pdata __initconst = { |
dddd4a493 pcm037: add SDHC ... |
380 381 382 |
#ifdef PCM970_SDHC_RW_SWITCH .get_ro = pcm970_sdhc1_get_ro, #endif |
f2cb641f5 pcm037: Add sdhc ... |
383 384 385 |
.init = pcm970_sdhc1_init, .exit = pcm970_sdhc1_exit, }; |
afa77ef30 ARM: mx3: dynamic... |
386 |
struct mx3_camera_pdata camera_pdata __initdata = { |
32c1ad9ab pcm037: add MT9T0... |
387 388 389 |
.flags = MX3_CAMERA_DATAWIDTH_8 | MX3_CAMERA_DATAWIDTH_10, .mclk_10khz = 2000, }; |
dca7c0b42 ARM: mx3/pcm037: ... |
390 391 |
static phys_addr_t mx3_camera_base __initdata; #define MX3_CAMERA_BUF_SIZE SZ_4M |
afa77ef30 ARM: mx3: dynamic... |
392 |
static int __init pcm037_init_camera(void) |
32c1ad9ab pcm037: add MT9T0... |
393 |
{ |
afa77ef30 ARM: mx3: dynamic... |
394 395 |
int dma, ret = -ENOMEM; struct platform_device *pdev = imx31_alloc_mx3_camera(&camera_pdata); |
32c1ad9ab pcm037: add MT9T0... |
396 |
|
afa77ef30 ARM: mx3: dynamic... |
397 398 399 400 |
if (IS_ERR(pdev)) return PTR_ERR(pdev); dma = dma_declare_coherent_memory(&pdev->dev, |
dca7c0b42 ARM: mx3/pcm037: ... |
401 402 |
mx3_camera_base, mx3_camera_base, MX3_CAMERA_BUF_SIZE, |
32c1ad9ab pcm037: add MT9T0... |
403 |
DMA_MEMORY_MAP | DMA_MEMORY_EXCLUSIVE); |
afa77ef30 ARM: mx3: dynamic... |
404 405 406 407 408 409 410 |
if (!(dma & DMA_MEMORY_MAP)) goto err; ret = platform_device_add(pdev); if (ret) err: platform_device_put(pdev); |
32c1ad9ab pcm037: add MT9T0... |
411 |
|
afa77ef30 ARM: mx3: dynamic... |
412 |
return ret; |
32c1ad9ab pcm037: add MT9T0... |
413 |
} |
ce8ffef0b MX31: add basic p... |
414 415 |
static struct platform_device *devices[] __initdata = { &pcm037_flash, |
3dad21a95 [ARM] pcm037: Add... |
416 |
&pcm037_sram_device, |
9d00278d4 mx3: add support ... |
417 418 |
&pcm037_mt9t031, &pcm037_mt9v022, |
ce8ffef0b MX31: add basic p... |
419 |
}; |
afa77ef30 ARM: mx3: dynamic... |
420 |
static const struct ipu_platform_data mx3_ipu_data __initconst = { |
a8df0ee8d ARM: framebuffer ... |
421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 |
.irq_base = MXC_IPU_IRQ_START, }; static const struct fb_videomode fb_modedb[] = { { /* 240x320 @ 60 Hz Sharp */ .name = "Sharp-LQ035Q7DH06-QVGA", .refresh = 60, .xres = 240, .yres = 320, .pixclock = 185925, .left_margin = 9, .right_margin = 16, .upper_margin = 7, .lower_margin = 9, .hsync_len = 1, .vsync_len = 1, .sync = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_SHARP_MODE | FB_SYNC_CLK_INVERT | FB_SYNC_CLK_IDLE_EN, .vmode = FB_VMODE_NONINTERLACED, .flag = 0, }, { /* 240x320 @ 60 Hz */ .name = "TX090", .refresh = 60, .xres = 240, .yres = 320, .pixclock = 38255, .left_margin = 144, .right_margin = 0, .upper_margin = 7, .lower_margin = 40, .hsync_len = 96, .vsync_len = 1, .sync = FB_SYNC_VERT_HIGH_ACT | FB_SYNC_OE_ACT_HIGH, .vmode = FB_VMODE_NONINTERLACED, .flag = 0, |
574ec547c ARM: add support ... |
458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 |
}, { /* 240x320 @ 60 Hz */ .name = "CMEL-OLED", .refresh = 60, .xres = 240, .yres = 320, .pixclock = 185925, .left_margin = 9, .right_margin = 16, .upper_margin = 7, .lower_margin = 9, .hsync_len = 1, .vsync_len = 1, .sync = FB_SYNC_OE_ACT_HIGH | FB_SYNC_CLK_INVERT, .vmode = FB_VMODE_NONINTERLACED, .flag = 0, |
a8df0ee8d ARM: framebuffer ... |
474 475 476 477 |
}, }; static struct mx3fb_platform_data mx3fb_pdata = { |
a8df0ee8d ARM: framebuffer ... |
478 479 480 481 |
.name = "Sharp-LQ035Q7DH06-QVGA", .mode = fb_modedb, .num_modes = ARRAY_SIZE(fb_modedb), }; |
91bf9a256 pcm037: Add suppo... |
482 483 |
static struct resource pcm970_sja1000_resources[] = { { |
f568dd7f5 imx/mach-mx3: use... |
484 485 |
.start = MX31_CS5_BASE_ADDR, .end = MX31_CS5_BASE_ADDR + 0x100 - 1, |
91bf9a256 pcm037: Add suppo... |
486 487 488 489 490 491 492 493 494 |
.flags = IORESOURCE_MEM, }, { .start = IOMUX_TO_IRQ(IOMUX_PIN(48, 105)), .end = IOMUX_TO_IRQ(IOMUX_PIN(48, 105)), .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_LOWEDGE, }, }; struct sja1000_platform_data pcm970_sja1000_platform_data = { |
56e6943b9 can: sja1000 plat... |
495 496 497 |
.osc_freq = 16000000, .ocr = OCR_TX1_PULLDOWN | OCR_TX0_PUSHPULL, .cdr = CDR_CBP, |
91bf9a256 pcm037: Add suppo... |
498 499 500 501 502 503 504 505 506 507 |
}; static struct platform_device pcm970_sja1000 = { .name = "sja1000_platform", .dev = { .platform_data = &pcm970_sja1000_platform_data, }, .resource = pcm970_sja1000_resources, .num_resources = ARRAY_SIZE(pcm970_sja1000_resources), }; |
4bd597b63 ARM i.MX ehci: do... |
508 509 510 511 |
static int pcm037_otg_init(struct platform_device *pdev) { return mx31_initialize_usb_hw(pdev->id, MXC_EHCI_INTERFACE_DIFF_UNI); } |
2d58de280 ARM: mx3: dynamic... |
512 |
static struct mxc_usbh_platform_data otg_pdata __initdata = { |
4bd597b63 ARM i.MX ehci: do... |
513 |
.init = pcm037_otg_init, |
ee14373cd i.MX31 pcm037: Ad... |
514 |
.portsc = MXC_EHCI_MODE_ULPI, |
ee14373cd i.MX31 pcm037: Ad... |
515 |
}; |
4bd597b63 ARM i.MX ehci: do... |
516 517 518 519 |
static int pcm037_usbh2_init(struct platform_device *pdev) { return mx31_initialize_usb_hw(pdev->id, MXC_EHCI_INTERFACE_DIFF_UNI); } |
2d58de280 ARM: mx3: dynamic... |
520 |
static struct mxc_usbh_platform_data usbh2_pdata __initdata = { |
4bd597b63 ARM i.MX ehci: do... |
521 |
.init = pcm037_usbh2_init, |
ee14373cd i.MX31 pcm037: Ad... |
522 |
.portsc = MXC_EHCI_MODE_ULPI, |
ee14373cd i.MX31 pcm037: Ad... |
523 |
}; |
9e1dde338 ARM: mx3: dynamic... |
524 |
static const struct fsl_usb2_platform_data otg_device_pdata __initconst = { |
ee14373cd i.MX31 pcm037: Ad... |
525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 |
.operating_mode = FSL_USB2_DR_DEVICE, .phy_mode = FSL_USB2_PHY_ULPI, }; static int otg_mode_host; static int __init pcm037_otg_mode(char *options) { if (!strcmp(options, "host")) otg_mode_host = 1; else if (!strcmp(options, "device")) otg_mode_host = 0; else pr_info("otg_mode neither \"host\" nor \"device\". " "Defaulting to device "); return 0; } __setup("otg_mode=", pcm037_otg_mode); |
ce8ffef0b MX31: add basic p... |
544 545 546 |
/* * Board specific initialization. */ |
e134fb2b4 ARM: mx3+mx5: ren... |
547 |
static void __init pcm037_init(void) |
ce8ffef0b MX31: add basic p... |
548 |
{ |
4f163eb88 mx31: calls to gp... |
549 |
int ret; |
ee14373cd i.MX31 pcm037: Ad... |
550 |
|
b78d8e59a gpio/mxc: Change ... |
551 |
imx31_soc_init(); |
ee14373cd i.MX31 pcm037: Ad... |
552 |
mxc_iomux_set_gpr(MUX_PGP_UH2, 1); |
4f163eb88 mx31: calls to gp... |
553 |
|
01ac7d584 pcm037: setup all... |
554 555 |
mxc_iomux_setup_multiple_pins(pcm037_pins, ARRAY_SIZE(pcm037_pins), "pcm037"); |
ee14373cd i.MX31 pcm037: Ad... |
556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 |
#define H2_PAD_CFG (PAD_CTL_DRV_MAX | PAD_CTL_SRE_FAST | PAD_CTL_HYS_CMOS \ | PAD_CTL_ODE_CMOS | PAD_CTL_100K_PU) mxc_iomux_set_pad(MX31_PIN_USBH2_CLK, H2_PAD_CFG); mxc_iomux_set_pad(MX31_PIN_USBH2_DIR, H2_PAD_CFG); mxc_iomux_set_pad(MX31_PIN_USBH2_NXT, H2_PAD_CFG); mxc_iomux_set_pad(MX31_PIN_USBH2_STP, H2_PAD_CFG); mxc_iomux_set_pad(MX31_PIN_USBH2_DATA0, H2_PAD_CFG); /* USBH2_DATA0 */ mxc_iomux_set_pad(MX31_PIN_USBH2_DATA1, H2_PAD_CFG); /* USBH2_DATA1 */ mxc_iomux_set_pad(MX31_PIN_SRXD6, H2_PAD_CFG); /* USBH2_DATA2 */ mxc_iomux_set_pad(MX31_PIN_STXD6, H2_PAD_CFG); /* USBH2_DATA3 */ mxc_iomux_set_pad(MX31_PIN_SFS3, H2_PAD_CFG); /* USBH2_DATA4 */ mxc_iomux_set_pad(MX31_PIN_SCK3, H2_PAD_CFG); /* USBH2_DATA5 */ mxc_iomux_set_pad(MX31_PIN_SRXD3, H2_PAD_CFG); /* USBH2_DATA6 */ mxc_iomux_set_pad(MX31_PIN_STXD3, H2_PAD_CFG); /* USBH2_DATA7 */ |
574ec547c ARM: add support ... |
571 572 573 574 575 576 577 |
if (pcm037_variant() == PCM037_EET) mxc_iomux_setup_multiple_pins(pcm037_uart1_pins, ARRAY_SIZE(pcm037_uart1_pins), "pcm037_uart1"); else mxc_iomux_setup_multiple_pins(pcm037_uart1_handshake_pins, ARRAY_SIZE(pcm037_uart1_handshake_pins), "pcm037_uart1"); |
ce8ffef0b MX31: add basic p... |
578 |
platform_add_devices(devices, ARRAY_SIZE(devices)); |
742269e2d ARM: mx3: dynamic... |
579 |
imx31_add_imx2_wdt(NULL); |
16cf5c415 ARM: imx: dynamic... |
580 581 582 583 |
imx31_add_imx_uart0(&uart_pdata); /* XXX: should't this have .flags = 0 (i.e. no RTSCTS) on PCM037_EET? */ imx31_add_imx_uart1(&uart_pdata); imx31_add_imx_uart2(&uart_pdata); |
d517cab1c [ARM] pcm037: add... |
584 |
|
ae71a5622 ARM: imx: dynamic... |
585 |
imx31_add_mxc_w1(NULL); |
ba54b9589 [ARM] pcm037: add... |
586 |
|
f8e5143be pcm037 board supp... |
587 |
/* LAN9217 IRQ pin */ |
4f163eb88 mx31: calls to gp... |
588 589 590 591 592 593 594 595 |
ret = gpio_request(IOMUX_TO_GPIO(MX31_PIN_GPIO3_1), "lan9217-irq"); if (ret) pr_warning("could not get LAN irq gpio "); else { gpio_direction_input(IOMUX_TO_GPIO(MX31_PIN_GPIO3_1)); platform_device_register(&pcm037_eth); } |
3287abbd7 [ARM] pcm037: add... |
596 |
|
32c1ad9ab pcm037: add MT9T0... |
597 |
/* I2C adapters and devices */ |
792067507 [ARM] PCM037 Boar... |
598 599 |
i2c_register_board_info(1, pcm037_i2c_devices, ARRAY_SIZE(pcm037_i2c_devices)); |
4a9b8b0b0 ARM: imx: dynamic... |
600 601 |
imx31_add_imx_i2c1(&pcm037_i2c1_data); imx31_add_imx_i2c2(&pcm037_i2c2_data); |
32c1ad9ab pcm037: add MT9T0... |
602 |
|
a2ceeef59 ARM: imx: Change ... |
603 |
imx31_add_mxc_nand(&pcm037_nand_board_info); |
6a697e3d3 ARM: mx3: dynamic... |
604 |
imx31_add_mxc_mmc(0, &sdhc_pdata); |
afa77ef30 ARM: mx3: dynamic... |
605 606 |
imx31_add_ipu_core(&mx3_ipu_data); imx31_add_mx3_sdc_fb(&mx3fb_pdata); |
32c1ad9ab pcm037: add MT9T0... |
607 608 609 610 611 612 613 |
/* CSI */ /* Camera power: default - off */ ret = gpio_request(IOMUX_TO_GPIO(MX31_PIN_CSI_D5), "mt9t031-power"); if (!ret) gpio_direction_output(IOMUX_TO_GPIO(MX31_PIN_CSI_D5), 1); else |
9d00278d4 mx3: add support ... |
614 |
iclink_mt9t031.power = NULL; |
32c1ad9ab pcm037: add MT9T0... |
615 |
|
afa77ef30 ARM: mx3: dynamic... |
616 |
pcm037_init_camera(); |
91bf9a256 pcm037: Add suppo... |
617 618 |
platform_device_register(&pcm970_sja1000); |
ee14373cd i.MX31 pcm037: Ad... |
619 |
|
ee14373cd i.MX31 pcm037: Ad... |
620 |
if (otg_mode_host) { |
48f6b0999 ARM i.MX: introdu... |
621 622 623 624 |
otg_pdata.otg = imx_otg_ulpi_create(ULPI_OTG_DRVVBUS | ULPI_OTG_DRVVBUS_EXT); if (otg_pdata.otg) imx31_add_mxc_ehci_otg(&otg_pdata); |
ee14373cd i.MX31 pcm037: Ad... |
625 |
} |
48f6b0999 ARM i.MX: introdu... |
626 627 628 629 |
usbh2_pdata.otg = imx_otg_ulpi_create(ULPI_OTG_DRVVBUS | ULPI_OTG_DRVVBUS_EXT); if (usbh2_pdata.otg) imx31_add_mxc_ehci_hs(2, &usbh2_pdata); |
ee14373cd i.MX31 pcm037: Ad... |
630 |
|
ee14373cd i.MX31 pcm037: Ad... |
631 |
if (!otg_mode_host) |
9e1dde338 ARM: mx3: dynamic... |
632 |
imx31_add_fsl_usb2_udc(&otg_device_pdata); |
ee14373cd i.MX31 pcm037: Ad... |
633 |
|
ce8ffef0b MX31: add basic p... |
634 |
} |
ce8ffef0b MX31: add basic p... |
635 636 |
static void __init pcm037_timer_init(void) { |
30c730f8f [ARM] MXC: rework... |
637 |
mx31_clocks_init(26000000); |
ce8ffef0b MX31: add basic p... |
638 639 640 641 642 |
} struct sys_timer pcm037_timer = { .init = pcm037_timer_init, }; |
dca7c0b42 ARM: mx3/pcm037: ... |
643 644 645 |
static void __init pcm037_reserve(void) { /* reserve 4 MiB for mx3-camera */ |
716a3dc20 ARM: Add arm_memb... |
646 |
mx3_camera_base = arm_memblock_steal(MX3_CAMERA_BUF_SIZE, |
dca7c0b42 ARM: mx3/pcm037: ... |
647 |
MX3_CAMERA_BUF_SIZE); |
dca7c0b42 ARM: mx3/pcm037: ... |
648 |
} |
ce8ffef0b MX31: add basic p... |
649 650 |
MACHINE_START(PCM037, "Phytec Phycore pcm037") /* Maintainer: Pengutronix */ |
dc8f19076 ARM: mach-imx: co... |
651 |
.atag_offset = 0x100, |
dca7c0b42 ARM: mx3/pcm037: ... |
652 |
.reserve = pcm037_reserve, |
97976e223 ARM: mx3: use .in... |
653 654 655 |
.map_io = mx31_map_io, .init_early = imx31_init_early, .init_irq = mx31_init_irq, |
ffa2ea3f5 ARM i.MX boards: ... |
656 |
.handle_irq = imx31_handle_irq, |
97976e223 ARM: mx3: use .in... |
657 |
.timer = &pcm037_timer, |
e134fb2b4 ARM: mx3+mx5: ren... |
658 |
.init_machine = pcm037_init, |
65ea7884b ARM: restart: mxc... |
659 |
.restart = mxc_restart, |
ce8ffef0b MX31: add basic p... |
660 |
MACHINE_END |