devices-db8500.h 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. /*
  2. * Copyright (C) ST-Ericsson SA 2010
  3. *
  4. * Author: Rabin Vincent <rabin.vincent@stericsson.com> for ST-Ericsson
  5. * License terms: GNU General Public License (GPL), version 2.
  6. */
  7. #ifndef __DEVICES_DB8500_H
  8. #define __DEVICES_DB8500_H
  9. #include <linux/platform_data/usb-musb-ux500.h>
  10. #include "irqs.h"
  11. #include "db8500-regs.h"
  12. #include "devices-common.h"
  13. struct ske_keypad_platform_data;
  14. struct pl022_ssp_controller;
  15. struct platform_device;
  16. extern struct ab8500_platform_data ab8500_platdata;
  17. extern struct prcmu_pdata db8500_prcmu_pdata;
  18. extern struct platform_device db8500_prcmu_device;
  19. static inline struct platform_device *
  20. db8500_add_ske_keypad(struct device *parent,
  21. struct ske_keypad_platform_data *pdata,
  22. size_t size)
  23. {
  24. struct resource resources[] = {
  25. DEFINE_RES_MEM(U8500_SKE_BASE, SZ_4K),
  26. DEFINE_RES_IRQ(IRQ_DB8500_KB),
  27. };
  28. return platform_device_register_resndata(parent, "nmk-ske-keypad", -1,
  29. resources, 2, pdata, size);
  30. }
  31. static inline struct amba_device *
  32. db8500_add_ssp(struct device *parent, const char *name, resource_size_t base,
  33. int irq, struct pl022_ssp_controller *pdata)
  34. {
  35. return amba_ahb_device_add(parent, name, base, SZ_4K, irq, 0, pdata, 0);
  36. }
  37. #define db8500_add_i2c0(parent, pdata) \
  38. dbx500_add_i2c(parent, 0, U8500_I2C0_BASE, IRQ_DB8500_I2C0, pdata)
  39. #define db8500_add_i2c1(parent, pdata) \
  40. dbx500_add_i2c(parent, 1, U8500_I2C1_BASE, IRQ_DB8500_I2C1, pdata)
  41. #define db8500_add_i2c2(parent, pdata) \
  42. dbx500_add_i2c(parent, 2, U8500_I2C2_BASE, IRQ_DB8500_I2C2, pdata)
  43. #define db8500_add_i2c3(parent, pdata) \
  44. dbx500_add_i2c(parent, 3, U8500_I2C3_BASE, IRQ_DB8500_I2C3, pdata)
  45. #define db8500_add_i2c4(parent, pdata) \
  46. dbx500_add_i2c(parent, 4, U8500_I2C4_BASE, IRQ_DB8500_I2C4, pdata)
  47. #define db8500_add_msp0_spi(parent, pdata) \
  48. dbx500_add_msp_spi(parent, "msp0", U8500_MSP0_BASE, \
  49. IRQ_DB8500_MSP0, pdata)
  50. #define db8500_add_msp1_spi(parent, pdata) \
  51. dbx500_add_msp_spi(parent, "msp1", U8500_MSP1_BASE, \
  52. IRQ_DB8500_MSP1, pdata)
  53. #define db8500_add_msp2_spi(parent, pdata) \
  54. dbx500_add_msp_spi(parent, "msp2", U8500_MSP2_BASE, \
  55. IRQ_DB8500_MSP2, pdata)
  56. #define db8500_add_msp3_spi(parent, pdata) \
  57. dbx500_add_msp_spi(parent, "msp3", U8500_MSP3_BASE, \
  58. IRQ_DB8500_MSP1, pdata)
  59. #define db8500_add_rtc(parent) \
  60. dbx500_add_rtc(parent, U8500_RTC_BASE, IRQ_DB8500_RTC);
  61. #define db8500_add_usb(parent, rx_cfg, tx_cfg) \
  62. ux500_add_usb(parent, U8500_USBOTG_BASE, \
  63. IRQ_DB8500_USBOTG, rx_cfg, tx_cfg)
  64. #define db8500_add_sdi0(parent, pdata, pid) \
  65. dbx500_add_sdi(parent, "sdi0", U8500_SDI0_BASE, \
  66. IRQ_DB8500_SDMMC0, pdata, pid)
  67. #define db8500_add_sdi1(parent, pdata, pid) \
  68. dbx500_add_sdi(parent, "sdi1", U8500_SDI1_BASE, \
  69. IRQ_DB8500_SDMMC1, pdata, pid)
  70. #define db8500_add_sdi2(parent, pdata, pid) \
  71. dbx500_add_sdi(parent, "sdi2", U8500_SDI2_BASE, \
  72. IRQ_DB8500_SDMMC2, pdata, pid)
  73. #define db8500_add_sdi3(parent, pdata, pid) \
  74. dbx500_add_sdi(parent, "sdi3", U8500_SDI3_BASE, \
  75. IRQ_DB8500_SDMMC3, pdata, pid)
  76. #define db8500_add_sdi4(parent, pdata, pid) \
  77. dbx500_add_sdi(parent, "sdi4", U8500_SDI4_BASE, \
  78. IRQ_DB8500_SDMMC4, pdata, pid)
  79. #define db8500_add_sdi5(parent, pdata, pid) \
  80. dbx500_add_sdi(parent, "sdi5", U8500_SDI5_BASE, \
  81. IRQ_DB8500_SDMMC5, pdata, pid)
  82. #define db8500_add_ssp0(parent, pdata) \
  83. db8500_add_ssp(parent, "ssp0", U8500_SSP0_BASE, \
  84. IRQ_DB8500_SSP0, pdata)
  85. #define db8500_add_ssp1(parent, pdata) \
  86. db8500_add_ssp(parent, "ssp1", U8500_SSP1_BASE, \
  87. IRQ_DB8500_SSP1, pdata)
  88. #define db8500_add_spi0(parent, pdata) \
  89. dbx500_add_spi(parent, "spi0", U8500_SPI0_BASE, \
  90. IRQ_DB8500_SPI0, pdata, 0)
  91. #define db8500_add_spi1(parent, pdata) \
  92. dbx500_add_spi(parent, "spi1", U8500_SPI1_BASE, \
  93. IRQ_DB8500_SPI1, pdata, 0)
  94. #define db8500_add_spi2(parent, pdata) \
  95. dbx500_add_spi(parent, "spi2", U8500_SPI2_BASE, \
  96. IRQ_DB8500_SPI2, pdata, 0)
  97. #define db8500_add_spi3(parent, pdata) \
  98. dbx500_add_spi(parent, "spi3", U8500_SPI3_BASE, \
  99. IRQ_DB8500_SPI3, pdata, 0)
  100. #define db8500_add_uart0(parent, pdata) \
  101. dbx500_add_uart(parent, "uart0", U8500_UART0_BASE, \
  102. IRQ_DB8500_UART0, pdata)
  103. #define db8500_add_uart1(parent, pdata) \
  104. dbx500_add_uart(parent, "uart1", U8500_UART1_BASE, \
  105. IRQ_DB8500_UART1, pdata)
  106. #define db8500_add_uart2(parent, pdata) \
  107. dbx500_add_uart(parent, "uart2", U8500_UART2_BASE, \
  108. IRQ_DB8500_UART2, pdata)
  109. #define db8500_add_cryp1(parent, pdata) \
  110. dbx500_add_cryp1(parent, -1, U8500_CRYP1_BASE, IRQ_DB8500_CRYP1, pdata)
  111. #define db8500_add_hash1(parent, pdata) \
  112. dbx500_add_hash1(parent, -1, U8500_HASH1_BASE, pdata)
  113. #endif