blob: 511d6febbe9996ac7f4831ba6d878435765c2869 [file] [log] [blame]
Hanumath Prasad008f8a22010-08-19 12:06:32 +01001/*
2 * Copyright (C) ST-Ericsson SA 2010
3 *
4 * License terms: GNU General Public License (GPL) version 2
5 */
6
7#ifndef __BOARD_MOP500_H
8#define __BOARD_MOP500_H
9
Linus Walleij1baa5742012-04-19 18:27:38 +020010/* For NOMADIK_NR_GPIO */
Arnd Bergmanneba52742013-03-21 22:51:08 +010011#include "irqs.h"
Arnd Bergmannab0fc6c2013-03-21 22:51:06 +010012#include <linux/platform_data/asoc-ux500-msp.h>
Lee Jones5e1ac7d2012-05-29 14:40:04 +080013#include <linux/amba/mmci.h>
Linus Walleij1baa5742012-04-19 18:27:38 +020014
Linus Walleij017beaa2011-11-11 18:48:52 +010015/* Snowball specific GPIO assignments, this board has no GPIO expander */
16#define SNOWBALL_ACCEL_INT1_GPIO 163
17#define SNOWBALL_ACCEL_INT2_GPIO 164
18#define SNOWBALL_MAGNET_DRDY_GPIO 165
19#define SNOWBALL_SDMMC_EN_GPIO 217
20#define SNOWBALL_SDMMC_1V8_3V_GPIO 228
21#define SNOWBALL_SDMMC_CD_GPIO 218
Mathieu J. Poirier885d0fe2011-03-25 09:28:58 -060022
Linus Walleij4b4f7572011-02-15 15:01:35 +010023/* HREFv60-specific GPIO assignments, this board has no GPIO expander */
Linus Walleij4b4f7572011-02-15 15:01:35 +010024#define HREFV60_SDMMC_1V8_3V_GPIO 5
Linus Walleij017beaa2011-11-11 18:48:52 +010025#define HREFV60_CAMERA_FLASH_ENABLE 21
Linus Walleij4b4f7572011-02-15 15:01:35 +010026#define HREFV60_MAGNET_DRDY_GPIO 32
27#define HREFV60_DISP1_RST_GPIO 65
28#define HREFV60_DISP2_RST_GPIO 66
Linus Walleij017beaa2011-11-11 18:48:52 +010029#define HREFV60_ACCEL_INT1_GPIO 82
30#define HREFV60_ACCEL_INT2_GPIO 83
31#define HREFV60_SDMMC_CD_GPIO 95
32#define HREFV60_XSHUTDOWN_SECONDARY_SENSOR 140
33#define HREFV60_TOUCH_RST_GPIO 143
34#define HREFV60_HAL_SW_GPIO 145
35#define HREFV60_SDMMC_EN_GPIO 169
36#define HREFV60_MMIO_XENON_CHARGE 170
37#define HREFV60_PROX_SENSE_GPIO 217
38
39/* MOP500 generic GPIOs */
40#define CAMERA_FLASH_INT_PIN 7
41#define CYPRESS_TOUCH_INT_PIN 84
42#define XSHUTDOWN_PRIMARY_SENSOR 141
43#define XSHUTDOWN_SECONDARY_SENSOR 142
44#define CYPRESS_TOUCH_RST_GPIO 143
45#define MOP500_HDMI_RST_GPIO 196
46#define CYPRESS_SLAVE_SELECT_GPIO 216
Rabin Vincentb8410a12010-08-09 19:18:17 +053047
48/* GPIOs on the TC35892 expander */
Linus Walleij4b4f7572011-02-15 15:01:35 +010049#define MOP500_EGPIO(x) (NOMADIK_NR_GPIO + (x))
Linus Walleij017beaa2011-11-11 18:48:52 +010050#define GPIO_MAGNET_DRDY MOP500_EGPIO(1)
Rabin Vincentb8410a12010-08-09 19:18:17 +053051#define GPIO_SDMMC_CD MOP500_EGPIO(3)
Linus Walleij017beaa2011-11-11 18:48:52 +010052#define GPIO_CAMERA_FLASH_ENABLE MOP500_EGPIO(4)
53#define GPIO_MMIO_XENON_CHARGE MOP500_EGPIO(5)
Philippe Langlaisa71b8192011-01-14 10:53:59 +010054#define GPIO_PROX_SENSOR MOP500_EGPIO(7)
Linus Walleij017beaa2011-11-11 18:48:52 +010055#define GPIO_HAL_SENSOR MOP500_EGPIO(8)
56#define GPIO_ACCEL_INT1 MOP500_EGPIO(10)
57#define GPIO_ACCEL_INT2 MOP500_EGPIO(11)
Sundar Iyer0c243522011-01-21 10:56:17 +053058#define GPIO_BU21013_CS MOP500_EGPIO(13)
Linus Walleij017beaa2011-11-11 18:48:52 +010059#define MOP500_DISP2_RST_GPIO MOP500_EGPIO(14)
60#define MOP500_DISP1_RST_GPIO MOP500_EGPIO(15)
Rabin Vincentb8410a12010-08-09 19:18:17 +053061#define GPIO_SDMMC_EN MOP500_EGPIO(17)
62#define GPIO_SDMMC_1V8_3V_SEL MOP500_EGPIO(18)
Bibek Basu3ef374a2011-02-15 12:56:16 +053063#define MOP500_EGPIO_END MOP500_EGPIO(24)
64
Linus Walleij017beaa2011-11-11 18:48:52 +010065/*
66 * GPIOs on the AB8500 mixed-signals circuit
67 * Notice that we subtract 1 from the number passed into the macro, this is
68 * because the AB8500 GPIO pins are enumbered starting from 1, so the value in
69 * parens matches the GPIO pin number in the data sheet.
70 */
Philippe Langlaisa1524ee2012-02-13 10:52:25 +010071#define MOP500_AB8500_PIN_GPIO(x) (MOP500_EGPIO_END + (x) - 1)
Linus Walleij017beaa2011-11-11 18:48:52 +010072/*Snowball AB8500 GPIO */
73#define SNOWBALL_VSMPS2_1V8_GPIO MOP500_AB8500_PIN_GPIO(1) /* SYSCLKREQ2/GPIO1 */
74#define SNOWBALL_PM_GPIO1_GPIO MOP500_AB8500_PIN_GPIO(2) /* SYSCLKREQ3/GPIO2 */
75#define SNOWBALL_WLAN_CLK_REQ_GPIO MOP500_AB8500_PIN_GPIO(3) /* SYSCLKREQ4/GPIO3 */
76#define SNOWBALL_PM_GPIO4_GPIO MOP500_AB8500_PIN_GPIO(4) /* SYSCLKREQ6/GPIO4 */
77#define SNOWBALL_EN_3V6_GPIO MOP500_AB8500_PIN_GPIO(16) /* PWMOUT3/GPIO16 */
78#define SNOWBALL_PME_ETH_GPIO MOP500_AB8500_PIN_GPIO(24) /* SYSCLKREQ7/GPIO24 */
79#define SNOWBALL_EN_3V3_ETH_GPIO MOP500_AB8500_PIN_GPIO(26) /* GPIO26 */
Rabin Vincentb8410a12010-08-09 19:18:17 +053080
Linus Walleij1baa5742012-04-19 18:27:38 +020081struct device;
Lee Jones5e1ac7d2012-05-29 14:40:04 +080082extern struct mmci_platform_data mop500_sdi0_data;
Lee Jones9cf24b12012-08-30 16:11:08 +010083extern struct mmci_platform_data mop500_sdi1_data;
84extern struct mmci_platform_data mop500_sdi2_data;
Lee Jones5e1ac7d2012-05-29 14:40:04 +080085extern struct mmci_platform_data mop500_sdi4_data;
Lee Jones724ebbf2012-07-25 13:58:36 +010086extern struct msp_i2s_platform_data msp0_platform_data;
87extern struct msp_i2s_platform_data msp1_platform_data;
88extern struct msp_i2s_platform_data msp2_platform_data;
89extern struct msp_i2s_platform_data msp3_platform_data;
Lee Jonesfa86a762012-09-27 10:17:36 +010090extern struct pl022_ssp_controller ssp0_plat;
Rabin Vincent705e0982011-01-21 10:56:16 +053091
Linus Walleijed781d392012-05-03 00:44:52 +020092void __init mop500_pinmaps_init(void);
93void __init snowball_pinmaps_init(void);
94void __init hrefv60_pinmaps_init(void);
Rabin Vincent705e0982011-01-21 10:56:16 +053095
Hanumath Prasad008f8a22010-08-19 12:06:32 +010096#endif