board-da830-evm.c 4.0 KB

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