blob: bc44c07c71a99a6fcf4f66ba7b3193f1ac0dc911 [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 */
11#include <mach/irqs.h>
12
Linus Walleij017beaa2011-11-11 18:48:52 +010013/* Snowball specific GPIO assignments, this board has no GPIO expander */
14#define SNOWBALL_ACCEL_INT1_GPIO 163
15#define SNOWBALL_ACCEL_INT2_GPIO 164
16#define SNOWBALL_MAGNET_DRDY_GPIO 165
17#define SNOWBALL_SDMMC_EN_GPIO 217
18#define SNOWBALL_SDMMC_1V8_3V_GPIO 228
19#define SNOWBALL_SDMMC_CD_GPIO 218
Mathieu J. Poirier885d0fe2011-03-25 09:28:58 -060020
Linus Walleij4b4f7572011-02-15 15:01:35 +010021/* HREFv60-specific GPIO assignments, this board has no GPIO expander */
Linus Walleij4b4f7572011-02-15 15:01:35 +010022#define HREFV60_SDMMC_1V8_3V_GPIO 5
Linus Walleij017beaa2011-11-11 18:48:52 +010023#define HREFV60_CAMERA_FLASH_ENABLE 21
Linus Walleij4b4f7572011-02-15 15:01:35 +010024#define HREFV60_MAGNET_DRDY_GPIO 32
25#define HREFV60_DISP1_RST_GPIO 65
26#define HREFV60_DISP2_RST_GPIO 66
Linus Walleij017beaa2011-11-11 18:48:52 +010027#define HREFV60_ACCEL_INT1_GPIO 82
28#define HREFV60_ACCEL_INT2_GPIO 83
29#define HREFV60_SDMMC_CD_GPIO 95
30#define HREFV60_XSHUTDOWN_SECONDARY_SENSOR 140
31#define HREFV60_TOUCH_RST_GPIO 143
32#define HREFV60_HAL_SW_GPIO 145
33#define HREFV60_SDMMC_EN_GPIO 169
34#define HREFV60_MMIO_XENON_CHARGE 170
35#define HREFV60_PROX_SENSE_GPIO 217
36
37/* MOP500 generic GPIOs */
38#define CAMERA_FLASH_INT_PIN 7
39#define CYPRESS_TOUCH_INT_PIN 84
40#define XSHUTDOWN_PRIMARY_SENSOR 141
41#define XSHUTDOWN_SECONDARY_SENSOR 142
42#define CYPRESS_TOUCH_RST_GPIO 143
43#define MOP500_HDMI_RST_GPIO 196
44#define CYPRESS_SLAVE_SELECT_GPIO 216
Rabin Vincentb8410a12010-08-09 19:18:17 +053045
46/* GPIOs on the TC35892 expander */
Linus Walleij4b4f7572011-02-15 15:01:35 +010047#define MOP500_EGPIO(x) (NOMADIK_NR_GPIO + (x))
Linus Walleij017beaa2011-11-11 18:48:52 +010048#define GPIO_MAGNET_DRDY MOP500_EGPIO(1)
Rabin Vincentb8410a12010-08-09 19:18:17 +053049#define GPIO_SDMMC_CD MOP500_EGPIO(3)
Linus Walleij017beaa2011-11-11 18:48:52 +010050#define GPIO_CAMERA_FLASH_ENABLE MOP500_EGPIO(4)
51#define GPIO_MMIO_XENON_CHARGE MOP500_EGPIO(5)
Philippe Langlaisa71b8192011-01-14 10:53:59 +010052#define GPIO_PROX_SENSOR MOP500_EGPIO(7)
Linus Walleij017beaa2011-11-11 18:48:52 +010053#define GPIO_HAL_SENSOR MOP500_EGPIO(8)
54#define GPIO_ACCEL_INT1 MOP500_EGPIO(10)
55#define GPIO_ACCEL_INT2 MOP500_EGPIO(11)
Sundar Iyer0c243522011-01-21 10:56:17 +053056#define GPIO_BU21013_CS MOP500_EGPIO(13)
Linus Walleij017beaa2011-11-11 18:48:52 +010057#define MOP500_DISP2_RST_GPIO MOP500_EGPIO(14)
58#define MOP500_DISP1_RST_GPIO MOP500_EGPIO(15)
Rabin Vincentb8410a12010-08-09 19:18:17 +053059#define GPIO_SDMMC_EN MOP500_EGPIO(17)
60#define GPIO_SDMMC_1V8_3V_SEL MOP500_EGPIO(18)
Bibek Basu3ef374a2011-02-15 12:56:16 +053061#define MOP500_EGPIO_END MOP500_EGPIO(24)
62
Linus Walleij017beaa2011-11-11 18:48:52 +010063/*
64 * GPIOs on the AB8500 mixed-signals circuit
65 * Notice that we subtract 1 from the number passed into the macro, this is
66 * because the AB8500 GPIO pins are enumbered starting from 1, so the value in
67 * parens matches the GPIO pin number in the data sheet.
68 */
Philippe Langlaisa1524ee2012-02-13 10:52:25 +010069#define MOP500_AB8500_PIN_GPIO(x) (MOP500_EGPIO_END + (x) - 1)
Linus Walleij017beaa2011-11-11 18:48:52 +010070/*Snowball AB8500 GPIO */
71#define SNOWBALL_VSMPS2_1V8_GPIO MOP500_AB8500_PIN_GPIO(1) /* SYSCLKREQ2/GPIO1 */
72#define SNOWBALL_PM_GPIO1_GPIO MOP500_AB8500_PIN_GPIO(2) /* SYSCLKREQ3/GPIO2 */
73#define SNOWBALL_WLAN_CLK_REQ_GPIO MOP500_AB8500_PIN_GPIO(3) /* SYSCLKREQ4/GPIO3 */
74#define SNOWBALL_PM_GPIO4_GPIO MOP500_AB8500_PIN_GPIO(4) /* SYSCLKREQ6/GPIO4 */
75#define SNOWBALL_EN_3V6_GPIO MOP500_AB8500_PIN_GPIO(16) /* PWMOUT3/GPIO16 */
76#define SNOWBALL_PME_ETH_GPIO MOP500_AB8500_PIN_GPIO(24) /* SYSCLKREQ7/GPIO24 */
77#define SNOWBALL_EN_3V3_ETH_GPIO MOP500_AB8500_PIN_GPIO(26) /* GPIO26 */
Rabin Vincentb8410a12010-08-09 19:18:17 +053078
Linus Walleij1baa5742012-04-19 18:27:38 +020079struct device;
Rabin Vincent705e0982011-01-21 10:56:16 +053080struct i2c_board_info;
81
Lee Jones18403422012-02-06 11:22:21 -080082extern void mop500_sdi_init(struct device *parent);
83extern void snowball_sdi_init(struct device *parent);
84extern void hrefv60_sdi_init(struct device *parent);
85extern void mop500_sdi_tc35892_init(struct device *parent);
Rabin Vincent705e0982011-01-21 10:56:16 +053086void __init mop500_u8500uib_init(void);
87void __init mop500_stuib_init(void);
Linus Walleijed781d392012-05-03 00:44:52 +020088void __init mop500_pinmaps_init(void);
89void __init snowball_pinmaps_init(void);
90void __init hrefv60_pinmaps_init(void);
Rabin Vincent705e0982011-01-21 10:56:16 +053091
92void mop500_uib_i2c_add(int busnum, struct i2c_board_info *info,
93 unsigned n);
Hanumath Prasad008f8a22010-08-19 12:06:32 +010094
95#endif