platform-imx-ssi.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. /*
  2. * Copyright (C) 2010 Pengutronix
  3. * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de>
  4. *
  5. * This program is free software; you can redistribute it and/or modify it under
  6. * the terms of the GNU General Public License version 2 as published by the
  7. * Free Software Foundation.
  8. */
  9. #include <mach/hardware.h>
  10. #include <mach/devices-common.h>
  11. #define imx_imx_ssi_data_entry(soc, _id, _hwid, _size) \
  12. [_id] = { \
  13. .id = _id, \
  14. .iobase = soc ## _SSI ## _hwid ## _BASE_ADDR, \
  15. .iosize = _size, \
  16. .irq = soc ## _INT_SSI ## _hwid, \
  17. .dmatx0 = soc ## _DMA_REQ_SSI ## _hwid ## _TX0, \
  18. .dmarx0 = soc ## _DMA_REQ_SSI ## _hwid ## _RX0, \
  19. .dmatx1 = soc ## _DMA_REQ_SSI ## _hwid ## _TX1, \
  20. .dmarx1 = soc ## _DMA_REQ_SSI ## _hwid ## _RX1, \
  21. }
  22. #ifdef CONFIG_SOC_IMX21
  23. const struct imx_imx_ssi_data imx21_imx_ssi_data[] __initconst = {
  24. #define imx21_imx_ssi_data_entry(_id, _hwid) \
  25. imx_imx_ssi_data_entry(MX21, _id, _hwid, SZ_4K)
  26. imx21_imx_ssi_data_entry(0, 1),
  27. imx21_imx_ssi_data_entry(1, 2),
  28. };
  29. #endif /* ifdef CONFIG_SOC_IMX21 */
  30. #ifdef CONFIG_SOC_IMX25
  31. const struct imx_imx_ssi_data imx25_imx_ssi_data[] __initconst = {
  32. #define imx25_imx_ssi_data_entry(_id, _hwid) \
  33. imx_imx_ssi_data_entry(MX25, _id, _hwid, SZ_4K)
  34. imx25_imx_ssi_data_entry(0, 1),
  35. imx25_imx_ssi_data_entry(1, 2),
  36. };
  37. #endif /* ifdef CONFIG_SOC_IMX25 */
  38. #ifdef CONFIG_SOC_IMX27
  39. const struct imx_imx_ssi_data imx27_imx_ssi_data[] __initconst = {
  40. #define imx27_imx_ssi_data_entry(_id, _hwid) \
  41. imx_imx_ssi_data_entry(MX27, _id, _hwid, SZ_4K)
  42. imx27_imx_ssi_data_entry(0, 1),
  43. imx27_imx_ssi_data_entry(1, 2),
  44. };
  45. #endif /* ifdef CONFIG_SOC_IMX27 */
  46. #ifdef CONFIG_SOC_IMX31
  47. const struct imx_imx_ssi_data imx31_imx_ssi_data[] __initconst = {
  48. #define imx31_imx_ssi_data_entry(_id, _hwid) \
  49. imx_imx_ssi_data_entry(MX31, _id, _hwid, SZ_4K)
  50. imx31_imx_ssi_data_entry(0, 1),
  51. imx31_imx_ssi_data_entry(1, 2),
  52. };
  53. #endif /* ifdef CONFIG_SOC_IMX31 */
  54. #ifdef CONFIG_SOC_IMX35
  55. const struct imx_imx_ssi_data imx35_imx_ssi_data[] __initconst = {
  56. #define imx35_imx_ssi_data_entry(_id, _hwid) \
  57. imx_imx_ssi_data_entry(MX35, _id, _hwid, SZ_4K)
  58. imx35_imx_ssi_data_entry(0, 1),
  59. imx35_imx_ssi_data_entry(1, 2),
  60. };
  61. #endif /* ifdef CONFIG_SOC_IMX35 */
  62. #ifdef CONFIG_SOC_IMX51
  63. const struct imx_imx_ssi_data imx51_imx_ssi_data[] __initconst = {
  64. #define imx51_imx_ssi_data_entry(_id, _hwid) \
  65. imx_imx_ssi_data_entry(MX51, _id, _hwid, SZ_4K)
  66. imx51_imx_ssi_data_entry(0, 1),
  67. imx51_imx_ssi_data_entry(1, 2),
  68. imx51_imx_ssi_data_entry(2, 3),
  69. };
  70. #endif /* ifdef CONFIG_SOC_IMX51 */
  71. struct platform_device *__init imx_add_imx_ssi(
  72. const struct imx_imx_ssi_data *data,
  73. const struct imx_ssi_platform_data *pdata)
  74. {
  75. struct resource res[] = {
  76. {
  77. .start = data->iobase,
  78. .end = data->iobase + data->iosize - 1,
  79. .flags = IORESOURCE_MEM,
  80. }, {
  81. .start = data->irq,
  82. .end = data->irq,
  83. .flags = IORESOURCE_IRQ,
  84. },
  85. #define DMARES(_name) { \
  86. .name = #_name, \
  87. .start = data->dma ## _name, \
  88. .end = data->dma ## _name, \
  89. .flags = IORESOURCE_DMA, \
  90. }
  91. DMARES(tx0),
  92. DMARES(rx0),
  93. DMARES(tx1),
  94. DMARES(rx1),
  95. };
  96. return imx_add_platform_device("imx-ssi", data->id,
  97. res, ARRAY_SIZE(res),
  98. pdata, sizeof(*pdata));
  99. }