devices.c 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242
  1. /*
  2. * Copyright 2006-2007 Freescale Semiconductor, Inc. All Rights Reserved.
  3. * Copyright 2008 Sascha Hauer, kernel@pengutronix.de
  4. * Copyright (c) 2008 Paulius Zaleckas <paulius.zaleckas@teltonika.lt>
  5. * Copyright (c) 2008 Darius Augulis <darius.augulis@teltonika.lt>
  6. *
  7. * This program is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU General Public License
  9. * as published by the Free Software Foundation; either version 2
  10. * of the License, or (at your option) any later version.
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program; if not, write to the Free Software
  18. * Foundation, Inc., 51 Franklin Street, Fifth Floor,
  19. * Boston, MA 02110-1301, USA.
  20. */
  21. #include <linux/kernel.h>
  22. #include <linux/init.h>
  23. #include <linux/platform_device.h>
  24. #include <linux/gpio.h>
  25. #include <mach/irqs.h>
  26. #include <mach/hardware.h>
  27. #include "devices.h"
  28. static struct resource imx_csi_resources[] = {
  29. {
  30. .start = 0x00224000,
  31. .end = 0x00224010,
  32. .flags = IORESOURCE_MEM,
  33. }, {
  34. .start = CSI_INT,
  35. .end = CSI_INT,
  36. .flags = IORESOURCE_IRQ,
  37. },
  38. };
  39. static u64 imx_csi_dmamask = 0xffffffffUL;
  40. struct platform_device imx_csi_device = {
  41. .name = "mx1-camera",
  42. .id = 0, /* This is used to put cameras on this interface */
  43. .dev = {
  44. .dma_mask = &imx_csi_dmamask,
  45. .coherent_dma_mask = 0xffffffff,
  46. },
  47. .resource = imx_csi_resources,
  48. .num_resources = ARRAY_SIZE(imx_csi_resources),
  49. };
  50. static struct resource imx_i2c_resources[] = {
  51. {
  52. .start = 0x00217000,
  53. .end = 0x00217010,
  54. .flags = IORESOURCE_MEM,
  55. }, {
  56. .start = I2C_INT,
  57. .end = I2C_INT,
  58. .flags = IORESOURCE_IRQ,
  59. },
  60. };
  61. struct platform_device imx_i2c_device = {
  62. .name = "imx-i2c",
  63. .id = 0,
  64. .resource = imx_i2c_resources,
  65. .num_resources = ARRAY_SIZE(imx_i2c_resources),
  66. };
  67. static struct resource imx_uart1_resources[] = {
  68. {
  69. .start = UART1_BASE_ADDR,
  70. .end = UART1_BASE_ADDR + 0xD0,
  71. .flags = IORESOURCE_MEM,
  72. }, {
  73. .start = UART1_MINT_RX,
  74. .end = UART1_MINT_RX,
  75. .flags = IORESOURCE_IRQ,
  76. }, {
  77. .start = UART1_MINT_TX,
  78. .end = UART1_MINT_TX,
  79. .flags = IORESOURCE_IRQ,
  80. }, {
  81. .start = UART1_MINT_RTS,
  82. .end = UART1_MINT_RTS,
  83. .flags = IORESOURCE_IRQ,
  84. },
  85. };
  86. struct platform_device imx_uart1_device = {
  87. .name = "imx-uart",
  88. .id = 0,
  89. .num_resources = ARRAY_SIZE(imx_uart1_resources),
  90. .resource = imx_uart1_resources,
  91. };
  92. static struct resource imx_uart2_resources[] = {
  93. {
  94. .start = UART2_BASE_ADDR,
  95. .end = UART2_BASE_ADDR + 0xD0,
  96. .flags = IORESOURCE_MEM,
  97. }, {
  98. .start = UART2_MINT_RX,
  99. .end = UART2_MINT_RX,
  100. .flags = IORESOURCE_IRQ,
  101. }, {
  102. .start = UART2_MINT_TX,
  103. .end = UART2_MINT_TX,
  104. .flags = IORESOURCE_IRQ,
  105. }, {
  106. .start = UART2_MINT_RTS,
  107. .end = UART2_MINT_RTS,
  108. .flags = IORESOURCE_IRQ,
  109. },
  110. };
  111. struct platform_device imx_uart2_device = {
  112. .name = "imx-uart",
  113. .id = 1,
  114. .num_resources = ARRAY_SIZE(imx_uart2_resources),
  115. .resource = imx_uart2_resources,
  116. };
  117. static struct resource imx_rtc_resources[] = {
  118. {
  119. .start = 0x00204000,
  120. .end = 0x00204024,
  121. .flags = IORESOURCE_MEM,
  122. }, {
  123. .start = RTC_INT,
  124. .end = RTC_INT,
  125. .flags = IORESOURCE_IRQ,
  126. }, {
  127. .start = RTC_SAMINT,
  128. .end = RTC_SAMINT,
  129. .flags = IORESOURCE_IRQ,
  130. },
  131. };
  132. struct platform_device imx_rtc_device = {
  133. .name = "rtc-imx",
  134. .id = 0,
  135. .resource = imx_rtc_resources,
  136. .num_resources = ARRAY_SIZE(imx_rtc_resources),
  137. };
  138. static struct resource imx_wdt_resources[] = {
  139. {
  140. .start = 0x00201000,
  141. .end = 0x00201008,
  142. .flags = IORESOURCE_MEM,
  143. }, {
  144. .start = WDT_INT,
  145. .end = WDT_INT,
  146. .flags = IORESOURCE_IRQ,
  147. },
  148. };
  149. struct platform_device imx_wdt_device = {
  150. .name = "imx-wdt",
  151. .id = 0,
  152. .resource = imx_wdt_resources,
  153. .num_resources = ARRAY_SIZE(imx_wdt_resources),
  154. };
  155. static struct resource imx_usb_resources[] = {
  156. {
  157. .start = 0x00212000,
  158. .end = 0x00212148,
  159. .flags = IORESOURCE_MEM,
  160. }, {
  161. .start = USBD_INT0,
  162. .end = USBD_INT0,
  163. .flags = IORESOURCE_IRQ,
  164. }, {
  165. .start = USBD_INT1,
  166. .end = USBD_INT1,
  167. .flags = IORESOURCE_IRQ,
  168. }, {
  169. .start = USBD_INT2,
  170. .end = USBD_INT2,
  171. .flags = IORESOURCE_IRQ,
  172. }, {
  173. .start = USBD_INT3,
  174. .end = USBD_INT3,
  175. .flags = IORESOURCE_IRQ,
  176. }, {
  177. .start = USBD_INT4,
  178. .end = USBD_INT4,
  179. .flags = IORESOURCE_IRQ,
  180. }, {
  181. .start = USBD_INT5,
  182. .end = USBD_INT5,
  183. .flags = IORESOURCE_IRQ,
  184. }, {
  185. .start = USBD_INT6,
  186. .end = USBD_INT6,
  187. .flags = IORESOURCE_IRQ,
  188. },
  189. };
  190. struct platform_device imx_usb_device = {
  191. .name = "imx_udc",
  192. .id = 0,
  193. .num_resources = ARRAY_SIZE(imx_usb_resources),
  194. .resource = imx_usb_resources,
  195. };
  196. /* GPIO port description */
  197. static struct mxc_gpio_port imx_gpio_ports[] = {
  198. {
  199. .chip.label = "gpio-0",
  200. .base = (void __iomem *)IO_ADDRESS(GPIO_BASE_ADDR),
  201. .irq = GPIO_INT_PORTA,
  202. .virtual_irq_start = MXC_GPIO_IRQ_START,
  203. }, {
  204. .chip.label = "gpio-1",
  205. .base = (void __iomem *)IO_ADDRESS(GPIO_BASE_ADDR + 0x100),
  206. .irq = GPIO_INT_PORTB,
  207. .virtual_irq_start = MXC_GPIO_IRQ_START + 32,
  208. }, {
  209. .chip.label = "gpio-2",
  210. .base = (void __iomem *)IO_ADDRESS(GPIO_BASE_ADDR + 0x200),
  211. .irq = GPIO_INT_PORTC,
  212. .virtual_irq_start = MXC_GPIO_IRQ_START + 64,
  213. }, {
  214. .chip.label = "gpio-3",
  215. .base = (void __iomem *)IO_ADDRESS(GPIO_BASE_ADDR + 0x300),
  216. .irq = GPIO_INT_PORTD,
  217. .virtual_irq_start = MXC_GPIO_IRQ_START + 96,
  218. }
  219. };
  220. int __init mxc_register_gpios(void)
  221. {
  222. return mxc_gpio_init(imx_gpio_ports, ARRAY_SIZE(imx_gpio_ports));
  223. }