devices.c 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  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. static struct resource imx_csi_resources[] = {
  28. [0] = {
  29. .start = 0x00224000,
  30. .end = 0x00224010,
  31. .flags = IORESOURCE_MEM,
  32. },
  33. [1] = {
  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 = "imx-csi",
  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. [0] = {
  52. .start = 0x00217000,
  53. .end = 0x00217010,
  54. .flags = IORESOURCE_MEM,
  55. },
  56. [1] = {
  57. .start = I2C_INT,
  58. .end = I2C_INT,
  59. .flags = IORESOURCE_IRQ,
  60. },
  61. };
  62. struct platform_device imx_i2c_device = {
  63. .name = "imx-i2c",
  64. .id = 0,
  65. .resource = imx_i2c_resources,
  66. .num_resources = ARRAY_SIZE(imx_i2c_resources),
  67. };
  68. static struct resource imx_uart1_resources[] = {
  69. [0] = {
  70. .start = UART1_BASE_ADDR,
  71. .end = UART1_BASE_ADDR + 0xD0,
  72. .flags = IORESOURCE_MEM,
  73. },
  74. [1] = {
  75. .start = UART1_MINT_RX,
  76. .end = UART1_MINT_RX,
  77. .flags = IORESOURCE_IRQ,
  78. },
  79. [2] = {
  80. .start = UART1_MINT_TX,
  81. .end = UART1_MINT_TX,
  82. .flags = IORESOURCE_IRQ,
  83. },
  84. [3] = {
  85. .start = UART1_MINT_RTS,
  86. .end = UART1_MINT_RTS,
  87. .flags = IORESOURCE_IRQ,
  88. },
  89. };
  90. struct platform_device imx_uart1_device = {
  91. .name = "imx-uart",
  92. .id = 0,
  93. .num_resources = ARRAY_SIZE(imx_uart1_resources),
  94. .resource = imx_uart1_resources,
  95. };
  96. static struct resource imx_uart2_resources[] = {
  97. [0] = {
  98. .start = UART2_BASE_ADDR,
  99. .end = UART2_BASE_ADDR + 0xD0,
  100. .flags = IORESOURCE_MEM,
  101. },
  102. [1] = {
  103. .start = UART2_MINT_RX,
  104. .end = UART2_MINT_RX,
  105. .flags = IORESOURCE_IRQ,
  106. },
  107. [2] = {
  108. .start = UART2_MINT_TX,
  109. .end = UART2_MINT_TX,
  110. .flags = IORESOURCE_IRQ,
  111. },
  112. [3] = {
  113. .start = UART2_MINT_RTS,
  114. .end = UART2_MINT_RTS,
  115. .flags = IORESOURCE_IRQ,
  116. },
  117. };
  118. struct platform_device imx_uart2_device = {
  119. .name = "imx-uart",
  120. .id = 1,
  121. .num_resources = ARRAY_SIZE(imx_uart2_resources),
  122. .resource = imx_uart2_resources,
  123. };
  124. static struct resource imx_rtc_resources[] = {
  125. [0] = {
  126. .start = 0x00204000,
  127. .end = 0x00204024,
  128. .flags = IORESOURCE_MEM,
  129. },
  130. [1] = {
  131. .start = RTC_INT,
  132. .end = RTC_INT,
  133. .flags = IORESOURCE_IRQ,
  134. },
  135. [2] = {
  136. .start = RTC_SAMINT,
  137. .end = RTC_SAMINT,
  138. .flags = IORESOURCE_IRQ,
  139. },
  140. };
  141. struct platform_device imx_rtc_device = {
  142. .name = "rtc-imx",
  143. .id = 0,
  144. .resource = imx_rtc_resources,
  145. .num_resources = ARRAY_SIZE(imx_rtc_resources),
  146. };
  147. static struct resource imx_wdt_resources[] = {
  148. [0] = {
  149. .start = 0x00201000,
  150. .end = 0x00201008,
  151. .flags = IORESOURCE_MEM,
  152. },
  153. [1] = {
  154. .start = WDT_INT,
  155. .end = WDT_INT,
  156. .flags = IORESOURCE_IRQ,
  157. },
  158. };
  159. struct platform_device imx_wdt_device = {
  160. .name = "imx-wdt",
  161. .id = 0,
  162. .resource = imx_wdt_resources,
  163. .num_resources = ARRAY_SIZE(imx_wdt_resources),
  164. };
  165. static struct resource imx_usb_resources[] = {
  166. [0] = {
  167. .start = 0x00212000,
  168. .end = 0x00212148,
  169. .flags = IORESOURCE_MEM,
  170. },
  171. [1] = {
  172. .start = USBD_INT0,
  173. .end = USBD_INT0,
  174. .flags = IORESOURCE_IRQ,
  175. },
  176. [2] = {
  177. .start = USBD_INT1,
  178. .end = USBD_INT1,
  179. .flags = IORESOURCE_IRQ,
  180. },
  181. [3] = {
  182. .start = USBD_INT2,
  183. .end = USBD_INT2,
  184. .flags = IORESOURCE_IRQ,
  185. },
  186. [4] = {
  187. .start = USBD_INT3,
  188. .end = USBD_INT3,
  189. .flags = IORESOURCE_IRQ,
  190. },
  191. [5] = {
  192. .start = USBD_INT4,
  193. .end = USBD_INT4,
  194. .flags = IORESOURCE_IRQ,
  195. },
  196. [6] = {
  197. .start = USBD_INT5,
  198. .end = USBD_INT5,
  199. .flags = IORESOURCE_IRQ,
  200. },
  201. [7] = {
  202. .start = USBD_INT6,
  203. .end = USBD_INT6,
  204. .flags = IORESOURCE_IRQ,
  205. },
  206. };
  207. struct platform_device imx_usb_device = {
  208. .name = "imx_udc",
  209. .id = 0,
  210. .num_resources = ARRAY_SIZE(imx_usb_resources),
  211. .resource = imx_usb_resources,
  212. };
  213. /* GPIO port description */
  214. static struct mxc_gpio_port imx_gpio_ports[] = {
  215. [0] = {
  216. .chip.label = "gpio-0",
  217. .base = (void __iomem *)IO_ADDRESS(GPIO_BASE_ADDR),
  218. .irq = GPIO_INT_PORTA,
  219. .virtual_irq_start = MXC_GPIO_IRQ_START
  220. },
  221. [1] = {
  222. .chip.label = "gpio-1",
  223. .base = (void __iomem *)IO_ADDRESS(GPIO_BASE_ADDR + 0x100),
  224. .irq = GPIO_INT_PORTB,
  225. .virtual_irq_start = MXC_GPIO_IRQ_START + 32
  226. },
  227. [2] = {
  228. .chip.label = "gpio-2",
  229. .base = (void __iomem *)IO_ADDRESS(GPIO_BASE_ADDR + 0x200),
  230. .irq = GPIO_INT_PORTC,
  231. .virtual_irq_start = MXC_GPIO_IRQ_START + 64
  232. },
  233. [3] = {
  234. .chip.label = "gpio-3",
  235. .base = (void __iomem *)IO_ADDRESS(GPIO_BASE_ADDR + 0x300),
  236. .irq = GPIO_INT_PORTD,
  237. .virtual_irq_start = MXC_GPIO_IRQ_START + 96
  238. }
  239. };
  240. int __init mxc_register_gpios(void)
  241. {
  242. return mxc_gpio_init(imx_gpio_ports, ARRAY_SIZE(imx_gpio_ports));
  243. }