board-mop500.h 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. /*
  2. * Copyright (C) ST-Ericsson SA 2010
  3. *
  4. * License terms: GNU General Public License (GPL) version 2
  5. */
  6. #ifndef __BOARD_MOP500_H
  7. #define __BOARD_MOP500_H
  8. /* For NOMADIK_NR_GPIO */
  9. #include <mach/irqs.h>
  10. #include <mach/msp.h>
  11. #include <linux/amba/mmci.h>
  12. /* Snowball specific GPIO assignments, this board has no GPIO expander */
  13. #define SNOWBALL_ACCEL_INT1_GPIO 163
  14. #define SNOWBALL_ACCEL_INT2_GPIO 164
  15. #define SNOWBALL_MAGNET_DRDY_GPIO 165
  16. #define SNOWBALL_SDMMC_EN_GPIO 217
  17. #define SNOWBALL_SDMMC_1V8_3V_GPIO 228
  18. #define SNOWBALL_SDMMC_CD_GPIO 218
  19. /* HREFv60-specific GPIO assignments, this board has no GPIO expander */
  20. #define HREFV60_SDMMC_1V8_3V_GPIO 5
  21. #define HREFV60_CAMERA_FLASH_ENABLE 21
  22. #define HREFV60_MAGNET_DRDY_GPIO 32
  23. #define HREFV60_DISP1_RST_GPIO 65
  24. #define HREFV60_DISP2_RST_GPIO 66
  25. #define HREFV60_ACCEL_INT1_GPIO 82
  26. #define HREFV60_ACCEL_INT2_GPIO 83
  27. #define HREFV60_SDMMC_CD_GPIO 95
  28. #define HREFV60_XSHUTDOWN_SECONDARY_SENSOR 140
  29. #define HREFV60_TOUCH_RST_GPIO 143
  30. #define HREFV60_HAL_SW_GPIO 145
  31. #define HREFV60_SDMMC_EN_GPIO 169
  32. #define HREFV60_MMIO_XENON_CHARGE 170
  33. #define HREFV60_PROX_SENSE_GPIO 217
  34. /* MOP500 generic GPIOs */
  35. #define CAMERA_FLASH_INT_PIN 7
  36. #define CYPRESS_TOUCH_INT_PIN 84
  37. #define XSHUTDOWN_PRIMARY_SENSOR 141
  38. #define XSHUTDOWN_SECONDARY_SENSOR 142
  39. #define CYPRESS_TOUCH_RST_GPIO 143
  40. #define MOP500_HDMI_RST_GPIO 196
  41. #define CYPRESS_SLAVE_SELECT_GPIO 216
  42. /* GPIOs on the TC35892 expander */
  43. #define MOP500_EGPIO(x) (NOMADIK_NR_GPIO + (x))
  44. #define GPIO_MAGNET_DRDY MOP500_EGPIO(1)
  45. #define GPIO_SDMMC_CD MOP500_EGPIO(3)
  46. #define GPIO_CAMERA_FLASH_ENABLE MOP500_EGPIO(4)
  47. #define GPIO_MMIO_XENON_CHARGE MOP500_EGPIO(5)
  48. #define GPIO_PROX_SENSOR MOP500_EGPIO(7)
  49. #define GPIO_HAL_SENSOR MOP500_EGPIO(8)
  50. #define GPIO_ACCEL_INT1 MOP500_EGPIO(10)
  51. #define GPIO_ACCEL_INT2 MOP500_EGPIO(11)
  52. #define GPIO_BU21013_CS MOP500_EGPIO(13)
  53. #define MOP500_DISP2_RST_GPIO MOP500_EGPIO(14)
  54. #define MOP500_DISP1_RST_GPIO MOP500_EGPIO(15)
  55. #define GPIO_SDMMC_EN MOP500_EGPIO(17)
  56. #define GPIO_SDMMC_1V8_3V_SEL MOP500_EGPIO(18)
  57. #define MOP500_EGPIO_END MOP500_EGPIO(24)
  58. /*
  59. * GPIOs on the AB8500 mixed-signals circuit
  60. * Notice that we subtract 1 from the number passed into the macro, this is
  61. * because the AB8500 GPIO pins are enumbered starting from 1, so the value in
  62. * parens matches the GPIO pin number in the data sheet.
  63. */
  64. #define MOP500_AB8500_PIN_GPIO(x) (MOP500_EGPIO_END + (x) - 1)
  65. /*Snowball AB8500 GPIO */
  66. #define SNOWBALL_VSMPS2_1V8_GPIO MOP500_AB8500_PIN_GPIO(1) /* SYSCLKREQ2/GPIO1 */
  67. #define SNOWBALL_PM_GPIO1_GPIO MOP500_AB8500_PIN_GPIO(2) /* SYSCLKREQ3/GPIO2 */
  68. #define SNOWBALL_WLAN_CLK_REQ_GPIO MOP500_AB8500_PIN_GPIO(3) /* SYSCLKREQ4/GPIO3 */
  69. #define SNOWBALL_PM_GPIO4_GPIO MOP500_AB8500_PIN_GPIO(4) /* SYSCLKREQ6/GPIO4 */
  70. #define SNOWBALL_EN_3V6_GPIO MOP500_AB8500_PIN_GPIO(16) /* PWMOUT3/GPIO16 */
  71. #define SNOWBALL_PME_ETH_GPIO MOP500_AB8500_PIN_GPIO(24) /* SYSCLKREQ7/GPIO24 */
  72. #define SNOWBALL_EN_3V3_ETH_GPIO MOP500_AB8500_PIN_GPIO(26) /* GPIO26 */
  73. struct device;
  74. struct i2c_board_info;
  75. extern struct mmci_platform_data mop500_sdi0_data;
  76. extern struct mmci_platform_data mop500_sdi1_data;
  77. extern struct mmci_platform_data mop500_sdi2_data;
  78. extern struct mmci_platform_data mop500_sdi4_data;
  79. extern struct msp_i2s_platform_data msp0_platform_data;
  80. extern struct msp_i2s_platform_data msp1_platform_data;
  81. extern struct msp_i2s_platform_data msp2_platform_data;
  82. extern struct msp_i2s_platform_data msp3_platform_data;
  83. extern struct arm_pmu_platdata db8500_pmu_platdata;
  84. extern struct amba_pl011_data uart0_plat;
  85. extern struct amba_pl011_data uart1_plat;
  86. extern struct amba_pl011_data uart2_plat;
  87. extern struct pl022_ssp_controller ssp0_plat;
  88. extern void mop500_sdi_init(struct device *parent);
  89. extern void snowball_sdi_init(struct device *parent);
  90. extern void hrefv60_sdi_init(struct device *parent);
  91. extern void mop500_sdi_tc35892_init(struct device *parent);
  92. void __init mop500_u8500uib_init(void);
  93. void __init mop500_stuib_init(void);
  94. void __init mop500_pinmaps_init(void);
  95. void __init snowball_pinmaps_init(void);
  96. void __init hrefv60_pinmaps_init(void);
  97. void mop500_audio_init(struct device *parent);
  98. int __init mop500_uib_init(void);
  99. void mop500_uib_i2c_add(int busnum, struct i2c_board_info *info,
  100. unsigned n);
  101. #endif