board-da830-evm.c 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  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/da8xx.h>
  24. #include <mach/asp.h>
  25. #define DA830_EVM_PHY_MASK 0x0
  26. #define DA830_EVM_MDIO_FREQUENCY 2200000 /* PHY bus frequency */
  27. static struct at24_platform_data da830_evm_i2c_eeprom_info = {
  28. .byte_len = SZ_256K / 8,
  29. .page_size = 64,
  30. .flags = AT24_FLAG_ADDR16,
  31. .setup = davinci_get_mac_addr,
  32. .context = (void *)0x7f00,
  33. };
  34. static struct i2c_board_info __initdata da830_evm_i2c_devices[] = {
  35. {
  36. I2C_BOARD_INFO("24c256", 0x50),
  37. .platform_data = &da830_evm_i2c_eeprom_info,
  38. },
  39. {
  40. I2C_BOARD_INFO("tlv320aic3x", 0x18),
  41. }
  42. };
  43. static struct davinci_i2c_platform_data da830_evm_i2c_0_pdata = {
  44. .bus_freq = 100, /* kHz */
  45. .bus_delay = 0, /* usec */
  46. };
  47. static struct davinci_uart_config da830_evm_uart_config __initdata = {
  48. .enabled_uarts = 0x7,
  49. };
  50. static u8 da830_iis_serializer_direction[] = {
  51. RX_MODE, INACTIVE_MODE, INACTIVE_MODE, INACTIVE_MODE,
  52. INACTIVE_MODE, TX_MODE, INACTIVE_MODE, INACTIVE_MODE,
  53. INACTIVE_MODE, INACTIVE_MODE, INACTIVE_MODE, INACTIVE_MODE,
  54. };
  55. static struct snd_platform_data da830_evm_snd_data = {
  56. .tx_dma_offset = 0x2000,
  57. .rx_dma_offset = 0x2000,
  58. .op_mode = DAVINCI_MCASP_IIS_MODE,
  59. .num_serializer = ARRAY_SIZE(da830_iis_serializer_direction),
  60. .tdm_slots = 2,
  61. .serial_dir = da830_iis_serializer_direction,
  62. .eventq_no = EVENTQ_0,
  63. .version = MCASP_VERSION_2,
  64. .txnumevt = 1,
  65. .rxnumevt = 1,
  66. };
  67. static __init void da830_evm_init(void)
  68. {
  69. struct davinci_soc_info *soc_info = &davinci_soc_info;
  70. int ret;
  71. ret = da8xx_register_edma();
  72. if (ret)
  73. pr_warning("da830_evm_init: edma registration failed: %d\n",
  74. ret);
  75. ret = da8xx_pinmux_setup(da830_i2c0_pins);
  76. if (ret)
  77. pr_warning("da830_evm_init: i2c0 mux setup failed: %d\n",
  78. ret);
  79. ret = da8xx_register_i2c(0, &da830_evm_i2c_0_pdata);
  80. if (ret)
  81. pr_warning("da830_evm_init: i2c0 registration failed: %d\n",
  82. ret);
  83. soc_info->emac_pdata->phy_mask = DA830_EVM_PHY_MASK;
  84. soc_info->emac_pdata->mdio_max_freq = DA830_EVM_MDIO_FREQUENCY;
  85. soc_info->emac_pdata->rmii_en = 1;
  86. ret = da8xx_pinmux_setup(da830_cpgmac_pins);
  87. if (ret)
  88. pr_warning("da830_evm_init: cpgmac mux setup failed: %d\n",
  89. ret);
  90. ret = da8xx_register_emac();
  91. if (ret)
  92. pr_warning("da830_evm_init: emac registration failed: %d\n",
  93. ret);
  94. ret = da8xx_register_watchdog();
  95. if (ret)
  96. pr_warning("da830_evm_init: watchdog registration failed: %d\n",
  97. ret);
  98. davinci_serial_init(&da830_evm_uart_config);
  99. i2c_register_board_info(1, da830_evm_i2c_devices,
  100. ARRAY_SIZE(da830_evm_i2c_devices));
  101. ret = da8xx_pinmux_setup(da830_mcasp1_pins);
  102. if (ret)
  103. pr_warning("da830_evm_init: mcasp1 mux setup failed: %d\n",
  104. ret);
  105. da8xx_init_mcasp(1, &da830_evm_snd_data);
  106. }
  107. #ifdef CONFIG_SERIAL_8250_CONSOLE
  108. static int __init da830_evm_console_init(void)
  109. {
  110. return add_preferred_console("ttyS", 2, "115200");
  111. }
  112. console_initcall(da830_evm_console_init);
  113. #endif
  114. static __init void da830_evm_irq_init(void)
  115. {
  116. struct davinci_soc_info *soc_info = &davinci_soc_info;
  117. cp_intc_init((void __iomem *)DA8XX_CP_INTC_VIRT, DA830_N_CP_INTC_IRQ,
  118. soc_info->intc_irq_prios);
  119. }
  120. static void __init da830_evm_map_io(void)
  121. {
  122. da830_init();
  123. }
  124. MACHINE_START(DAVINCI_DA830_EVM, "DaVinci DA830/OMAP L137 EVM")
  125. .phys_io = IO_PHYS,
  126. .io_pg_offst = (__IO_ADDRESS(IO_PHYS) >> 18) & 0xfffc,
  127. .boot_params = (DA8XX_DDR_BASE + 0x100),
  128. .map_io = da830_evm_map_io,
  129. .init_irq = da830_evm_irq_init,
  130. .timer = &davinci_timer,
  131. .init_machine = da830_evm_init,
  132. MACHINE_END