board-cm-t3517.c 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249
  1. /*
  2. * linux/arch/arm/mach-omap2/board-cm-t3517.c
  3. *
  4. * Support for the CompuLab CM-T3517 modules
  5. *
  6. * Copyright (C) 2010 CompuLab, Ltd.
  7. * Author: Igor Grinberg <grinberg@compulab.co.il>
  8. *
  9. * This program is free software; you can redistribute it and/or
  10. * modify it under the terms of the GNU General Public License
  11. * version 2 as published by the Free Software Foundation.
  12. *
  13. * This program is distributed in the hope that it will be useful, but
  14. * WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  16. * General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program; if not, write to the Free Software
  20. * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
  21. * 02110-1301 USA
  22. *
  23. */
  24. #include <linux/kernel.h>
  25. #include <linux/init.h>
  26. #include <linux/platform_device.h>
  27. #include <linux/delay.h>
  28. #include <linux/gpio.h>
  29. #include <linux/leds.h>
  30. #include <linux/rtc-v3020.h>
  31. #include <linux/mtd/mtd.h>
  32. #include <linux/mtd/nand.h>
  33. #include <linux/mtd/partitions.h>
  34. #include <asm/mach-types.h>
  35. #include <asm/mach/arch.h>
  36. #include <asm/mach/map.h>
  37. #include <plat/board.h>
  38. #include <plat/common.h>
  39. #include <plat/control.h>
  40. #include <plat/usb.h>
  41. #include <plat/nand.h>
  42. #include <plat/gpmc.h>
  43. #include "mux.h"
  44. #if defined(CONFIG_LEDS_GPIO) || defined(CONFIG_LEDS_GPIO_MODULE)
  45. static struct gpio_led cm_t3517_leds[] = {
  46. [0] = {
  47. .gpio = 186,
  48. .name = "cm-t3517:green",
  49. .default_trigger = "heartbeat",
  50. .active_low = 0,
  51. },
  52. };
  53. static struct gpio_led_platform_data cm_t3517_led_pdata = {
  54. .num_leds = ARRAY_SIZE(cm_t3517_leds),
  55. .leds = cm_t3517_leds,
  56. };
  57. static struct platform_device cm_t3517_led_device = {
  58. .name = "leds-gpio",
  59. .id = -1,
  60. .dev = {
  61. .platform_data = &cm_t3517_led_pdata,
  62. },
  63. };
  64. static void __init cm_t3517_init_leds(void)
  65. {
  66. platform_device_register(&cm_t3517_led_device);
  67. }
  68. #else
  69. static inline void cm_t3517_init_leds(void) {}
  70. #endif
  71. #if defined(CONFIG_RTC_DRV_V3020) || defined(CONFIG_RTC_DRV_V3020_MODULE)
  72. #define RTC_IO_GPIO (153)
  73. #define RTC_WR_GPIO (154)
  74. #define RTC_RD_GPIO (160)
  75. #define RTC_CS_GPIO (163)
  76. struct v3020_platform_data cm_t3517_v3020_pdata = {
  77. .use_gpio = 1,
  78. .gpio_cs = RTC_CS_GPIO,
  79. .gpio_wr = RTC_WR_GPIO,
  80. .gpio_rd = RTC_RD_GPIO,
  81. .gpio_io = RTC_IO_GPIO,
  82. };
  83. static struct platform_device cm_t3517_rtc_device = {
  84. .name = "v3020",
  85. .id = -1,
  86. .dev = {
  87. .platform_data = &cm_t3517_v3020_pdata,
  88. }
  89. };
  90. static void __init cm_t3517_init_rtc(void)
  91. {
  92. platform_device_register(&cm_t3517_rtc_device);
  93. }
  94. #else
  95. static inline void cm_t3517_init_rtc(void) {}
  96. #endif
  97. #if defined(CONFIG_USB_EHCI_HCD) || defined(CONFIG_USB_EHCI_HCD_MODULE)
  98. #define HSUSB1_RESET_GPIO (146)
  99. #define HSUSB2_RESET_GPIO (147)
  100. #define USB_HUB_RESET_GPIO (152)
  101. static struct ehci_hcd_omap_platform_data cm_t3517_ehci_pdata __initdata = {
  102. .port_mode[0] = EHCI_HCD_OMAP_MODE_PHY,
  103. .port_mode[1] = EHCI_HCD_OMAP_MODE_PHY,
  104. .port_mode[2] = EHCI_HCD_OMAP_MODE_UNKNOWN,
  105. .phy_reset = true,
  106. .reset_gpio_port[0] = HSUSB1_RESET_GPIO,
  107. .reset_gpio_port[1] = HSUSB2_RESET_GPIO,
  108. .reset_gpio_port[2] = -EINVAL,
  109. };
  110. static int cm_t3517_init_usbh(void)
  111. {
  112. int err;
  113. err = gpio_request(USB_HUB_RESET_GPIO, "usb hub rst");
  114. if (err) {
  115. pr_err("CM-T3517: usb hub rst gpio request failed: %d\n", err);
  116. } else {
  117. gpio_direction_output(USB_HUB_RESET_GPIO, 0);
  118. udelay(10);
  119. gpio_set_value(USB_HUB_RESET_GPIO, 1);
  120. msleep(1);
  121. }
  122. usb_ehci_init(&cm_t3517_ehci_pdata);
  123. return 0;
  124. }
  125. #else
  126. static inline int cm_t3517_init_usbh(void)
  127. {
  128. return 0;
  129. }
  130. #endif
  131. #if defined(CONFIG_MTD_NAND_OMAP2) || defined(CONFIG_MTD_NAND_OMAP2_MODULE)
  132. #define NAND_BLOCK_SIZE SZ_128K
  133. static struct mtd_partition cm_t3517_nand_partitions[] = {
  134. {
  135. .name = "xloader",
  136. .offset = 0, /* Offset = 0x00000 */
  137. .size = 4 * NAND_BLOCK_SIZE,
  138. .mask_flags = MTD_WRITEABLE
  139. },
  140. {
  141. .name = "uboot",
  142. .offset = MTDPART_OFS_APPEND, /* Offset = 0x80000 */
  143. .size = 15 * NAND_BLOCK_SIZE,
  144. },
  145. {
  146. .name = "uboot environment",
  147. .offset = MTDPART_OFS_APPEND, /* Offset = 0x260000 */
  148. .size = 2 * NAND_BLOCK_SIZE,
  149. },
  150. {
  151. .name = "linux",
  152. .offset = MTDPART_OFS_APPEND, /* Offset = 0x280000 */
  153. .size = 32 * NAND_BLOCK_SIZE,
  154. },
  155. {
  156. .name = "rootfs",
  157. .offset = MTDPART_OFS_APPEND, /* Offset = 0x680000 */
  158. .size = MTDPART_SIZ_FULL,
  159. },
  160. };
  161. static struct omap_nand_platform_data cm_t3517_nand_data = {
  162. .parts = cm_t3517_nand_partitions,
  163. .nr_parts = ARRAY_SIZE(cm_t3517_nand_partitions),
  164. .dma_channel = -1, /* disable DMA in OMAP NAND driver */
  165. .cs = 0,
  166. };
  167. static void __init cm_t3517_init_nand(void)
  168. {
  169. if (gpmc_nand_init(&cm_t3517_nand_data) < 0)
  170. pr_err("CM-T3517: NAND initialization failed\n");
  171. }
  172. #else
  173. static inline void cm_t3517_init_nand(void) {}
  174. #endif
  175. static struct omap_board_config_kernel cm_t3517_config[] __initdata = {
  176. };
  177. static void __init cm_t3517_init_irq(void)
  178. {
  179. omap_board_config = cm_t3517_config;
  180. omap_board_config_size = ARRAY_SIZE(cm_t3517_config);
  181. omap2_init_common_hw(NULL, NULL);
  182. omap_init_irq();
  183. omap_gpio_init();
  184. }
  185. static struct omap_board_mux board_mux[] __initdata = {
  186. /* GPIO186 - Green LED */
  187. OMAP3_MUX(SYS_CLKOUT2, OMAP_MUX_MODE4 | OMAP_PIN_OUTPUT),
  188. /* RTC GPIOs: IO, WR#, RD#, CS# */
  189. OMAP3_MUX(MCBSP4_DR, OMAP_MUX_MODE4 | OMAP_PIN_INPUT),
  190. OMAP3_MUX(MCBSP4_DX, OMAP_MUX_MODE4 | OMAP_PIN_INPUT),
  191. OMAP3_MUX(MCBSP_CLKS, OMAP_MUX_MODE4 | OMAP_PIN_INPUT),
  192. OMAP3_MUX(UART3_CTS_RCTX, OMAP_MUX_MODE4 | OMAP_PIN_INPUT),
  193. /* HSUSB1 RESET */
  194. OMAP3_MUX(UART2_TX, OMAP_MUX_MODE4 | OMAP_PIN_OUTPUT),
  195. /* HSUSB2 RESET */
  196. OMAP3_MUX(UART2_RX, OMAP_MUX_MODE4 | OMAP_PIN_OUTPUT),
  197. /* CM-T3517 USB HUB nRESET */
  198. OMAP3_MUX(MCBSP4_CLKX, OMAP_MUX_MODE4 | OMAP_PIN_OUTPUT),
  199. { .reg_offset = OMAP_MUX_TERMINATOR },
  200. };
  201. static void __init cm_t3517_init(void)
  202. {
  203. omap3_mux_init(board_mux, OMAP_PACKAGE_CBB);
  204. omap_serial_init();
  205. cm_t3517_init_leds();
  206. cm_t3517_init_nand();
  207. cm_t3517_init_rtc();
  208. cm_t3517_init_usbh();
  209. }
  210. MACHINE_START(CM_T3517, "Compulab CM-T3517")
  211. .phys_io = 0x48000000,
  212. .io_pg_offst = ((0xd8000000) >> 18) & 0xfffc,
  213. .boot_params = 0x80000100,
  214. .map_io = omap3_map_io,
  215. .reserve = omap_reserve,
  216. .init_irq = cm_t3517_init_irq,
  217. .init_machine = cm_t3517_init,
  218. .timer = &omap_timer,
  219. MACHINE_END