board-da830-evm.c 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. /*
  2. * TI DA830/OMAP L137 EVM board
  3. *
  4. * Author: Mark A. Greer <mgreer@mvista.com>
  5. * Derived from: arch/arm/mach-davinci/board-dm644x-evm.c
  6. *
  7. * 2007, 2009 (c) MontaVista Software, Inc. This file is licensed under
  8. * the terms of the GNU General Public License version 2. This program
  9. * is licensed "as is" without any warranty of any kind, whether express
  10. * or implied.
  11. */
  12. #include <linux/kernel.h>
  13. #include <linux/module.h>
  14. #include <linux/init.h>
  15. #include <linux/console.h>
  16. #include <linux/i2c.h>
  17. #include <linux/i2c/at24.h>
  18. #include <asm/mach-types.h>
  19. #include <asm/mach/arch.h>
  20. #include <mach/common.h>
  21. #include <mach/irqs.h>
  22. #include <mach/cp_intc.h>
  23. #include <mach/mux.h>
  24. #include <mach/da8xx.h>
  25. #include <mach/asp.h>
  26. #define DA830_EVM_PHY_MASK 0x0
  27. #define DA830_EVM_MDIO_FREQUENCY 2200000 /* PHY bus frequency */
  28. static struct at24_platform_data da830_evm_i2c_eeprom_info = {
  29. .byte_len = SZ_256K / 8,
  30. .page_size = 64,
  31. .flags = AT24_FLAG_ADDR16,
  32. .setup = davinci_get_mac_addr,
  33. .context = (void *)0x7f00,
  34. };
  35. static struct i2c_board_info __initdata da830_evm_i2c_devices[] = {
  36. {
  37. I2C_BOARD_INFO("24c256", 0x50),
  38. .platform_data = &da830_evm_i2c_eeprom_info,
  39. },
  40. {
  41. I2C_BOARD_INFO("tlv320aic3x", 0x18),
  42. }
  43. };
  44. static struct davinci_i2c_platform_data da830_evm_i2c_0_pdata = {
  45. .bus_freq = 100, /* kHz */
  46. .bus_delay = 0, /* usec */
  47. };
  48. static struct davinci_uart_config da830_evm_uart_config __initdata = {
  49. .enabled_uarts = 0x7,
  50. };
  51. static const short da830_evm_mcasp1_pins[] = {
  52. DA830_AHCLKX1, DA830_ACLKX1, DA830_AFSX1, DA830_AHCLKR1, DA830_AFSR1,
  53. DA830_AMUTE1, DA830_AXR1_0, DA830_AXR1_1, DA830_AXR1_2, DA830_AXR1_5,
  54. DA830_ACLKR1, DA830_AXR1_6, DA830_AXR1_7, DA830_AXR1_8, DA830_AXR1_10,
  55. DA830_AXR1_11,
  56. -1
  57. };
  58. static u8 da830_iis_serializer_direction[] = {
  59. RX_MODE, INACTIVE_MODE, INACTIVE_MODE, INACTIVE_MODE,
  60. INACTIVE_MODE, TX_MODE, INACTIVE_MODE, INACTIVE_MODE,
  61. INACTIVE_MODE, INACTIVE_MODE, INACTIVE_MODE, INACTIVE_MODE,
  62. };
  63. static struct snd_platform_data da830_evm_snd_data = {
  64. .tx_dma_offset = 0x2000,
  65. .rx_dma_offset = 0x2000,
  66. .op_mode = DAVINCI_MCASP_IIS_MODE,
  67. .num_serializer = ARRAY_SIZE(da830_iis_serializer_direction),
  68. .tdm_slots = 2,
  69. .serial_dir = da830_iis_serializer_direction,
  70. .eventq_no = EVENTQ_0,
  71. .version = MCASP_VERSION_2,
  72. .txnumevt = 1,
  73. .rxnumevt = 1,
  74. };
  75. static __init void da830_evm_init(void)
  76. {
  77. struct davinci_soc_info *soc_info = &davinci_soc_info;
  78. int ret;
  79. ret = da8xx_register_edma();
  80. if (ret)
  81. pr_warning("da830_evm_init: edma registration failed: %d\n",
  82. ret);
  83. ret = da8xx_pinmux_setup(da830_i2c0_pins);
  84. if (ret)
  85. pr_warning("da830_evm_init: i2c0 mux setup failed: %d\n",
  86. ret);
  87. ret = da8xx_register_i2c(0, &da830_evm_i2c_0_pdata);
  88. if (ret)
  89. pr_warning("da830_evm_init: i2c0 registration failed: %d\n",
  90. ret);
  91. soc_info->emac_pdata->phy_mask = DA830_EVM_PHY_MASK;
  92. soc_info->emac_pdata->mdio_max_freq = DA830_EVM_MDIO_FREQUENCY;
  93. soc_info->emac_pdata->rmii_en = 1;
  94. ret = da8xx_pinmux_setup(da830_cpgmac_pins);
  95. if (ret)
  96. pr_warning("da830_evm_init: cpgmac mux setup failed: %d\n",
  97. ret);
  98. ret = da8xx_register_emac();
  99. if (ret)
  100. pr_warning("da830_evm_init: emac registration failed: %d\n",
  101. ret);
  102. ret = da8xx_register_watchdog();
  103. if (ret)
  104. pr_warning("da830_evm_init: watchdog registration failed: %d\n",
  105. ret);
  106. davinci_serial_init(&da830_evm_uart_config);
  107. i2c_register_board_info(1, da830_evm_i2c_devices,
  108. ARRAY_SIZE(da830_evm_i2c_devices));
  109. ret = da8xx_pinmux_setup(da830_evm_mcasp1_pins);
  110. if (ret)
  111. pr_warning("da830_evm_init: mcasp1 mux setup failed: %d\n",
  112. ret);
  113. da8xx_register_mcasp(1, &da830_evm_snd_data);
  114. }
  115. #ifdef CONFIG_SERIAL_8250_CONSOLE
  116. static int __init da830_evm_console_init(void)
  117. {
  118. return add_preferred_console("ttyS", 2, "115200");
  119. }
  120. console_initcall(da830_evm_console_init);
  121. #endif
  122. static __init void da830_evm_irq_init(void)
  123. {
  124. struct davinci_soc_info *soc_info = &davinci_soc_info;
  125. cp_intc_init((void __iomem *)DA8XX_CP_INTC_VIRT, DA830_N_CP_INTC_IRQ,
  126. soc_info->intc_irq_prios);
  127. }
  128. static void __init da830_evm_map_io(void)
  129. {
  130. da830_init();
  131. }
  132. MACHINE_START(DAVINCI_DA830_EVM, "DaVinci DA830/OMAP L137 EVM")
  133. .phys_io = IO_PHYS,
  134. .io_pg_offst = (__IO_ADDRESS(IO_PHYS) >> 18) & 0xfffc,
  135. .boot_params = (DA8XX_DDR_BASE + 0x100),
  136. .map_io = da830_evm_map_io,
  137. .init_irq = da830_evm_irq_init,
  138. .timer = &davinci_timer,
  139. .init_machine = da830_evm_init,
  140. MACHINE_END