board-da830-evm.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  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. #define DA830_EVM_PHY_MASK 0x0
  25. #define DA830_EVM_MDIO_FREQUENCY 2200000 /* PHY bus frequency */
  26. static struct at24_platform_data da830_evm_i2c_eeprom_info = {
  27. .byte_len = SZ_256K / 8,
  28. .page_size = 64,
  29. .flags = AT24_FLAG_ADDR16,
  30. .setup = davinci_get_mac_addr,
  31. .context = (void *)0x7f00,
  32. };
  33. static struct i2c_board_info __initdata da830_evm_i2c_devices[] = {
  34. {
  35. I2C_BOARD_INFO("24c256", 0x50),
  36. .platform_data = &da830_evm_i2c_eeprom_info,
  37. },
  38. };
  39. static struct davinci_i2c_platform_data da830_evm_i2c_0_pdata = {
  40. .bus_freq = 100, /* kHz */
  41. .bus_delay = 0, /* usec */
  42. };
  43. static struct davinci_uart_config da830_evm_uart_config __initdata = {
  44. .enabled_uarts = 0x7,
  45. };
  46. static __init void da830_evm_init(void)
  47. {
  48. struct davinci_soc_info *soc_info = &davinci_soc_info;
  49. int ret;
  50. ret = da8xx_register_edma();
  51. if (ret)
  52. pr_warning("da830_evm_init: edma registration failed: %d\n",
  53. ret);
  54. ret = da830_pinmux_setup(da830_i2c0_pins);
  55. if (ret)
  56. pr_warning("da830_evm_init: i2c0 mux setup failed: %d\n",
  57. ret);
  58. ret = da8xx_register_i2c(0, &da830_evm_i2c_0_pdata);
  59. if (ret)
  60. pr_warning("da830_evm_init: i2c0 registration failed: %d\n",
  61. ret);
  62. soc_info->emac_pdata->phy_mask = DA830_EVM_PHY_MASK;
  63. soc_info->emac_pdata->mdio_max_freq = DA830_EVM_MDIO_FREQUENCY;
  64. soc_info->emac_pdata->rmii_en = 1;
  65. ret = da830_pinmux_setup(da830_cpgmac_pins);
  66. if (ret)
  67. pr_warning("da830_evm_init: cpgmac mux setup failed: %d\n",
  68. ret);
  69. ret = da8xx_register_emac();
  70. if (ret)
  71. pr_warning("da830_evm_init: emac registration failed: %d\n",
  72. ret);
  73. ret = da8xx_register_watchdog();
  74. if (ret)
  75. pr_warning("da830_evm_init: watchdog registration failed: %d\n",
  76. ret);
  77. davinci_serial_init(&da830_evm_uart_config);
  78. i2c_register_board_info(1, da830_evm_i2c_devices,
  79. ARRAY_SIZE(da830_evm_i2c_devices));
  80. }
  81. #ifdef CONFIG_SERIAL_8250_CONSOLE
  82. static int __init da830_evm_console_init(void)
  83. {
  84. return add_preferred_console("ttyS", 2, "115200");
  85. }
  86. console_initcall(da830_evm_console_init);
  87. #endif
  88. static __init void da830_evm_irq_init(void)
  89. {
  90. struct davinci_soc_info *soc_info = &davinci_soc_info;
  91. cp_intc_init((void __iomem *)DA8XX_CP_INTC_VIRT, DA830_N_CP_INTC_IRQ,
  92. soc_info->intc_irq_prios);
  93. }
  94. static void __init da830_evm_map_io(void)
  95. {
  96. da830_init();
  97. }
  98. MACHINE_START(DAVINCI_DA8XX_EVM, "DaVinci DA830/OMAP L137 EVM")
  99. .phys_io = IO_PHYS,
  100. .io_pg_offst = (__IO_ADDRESS(IO_PHYS) >> 18) & 0xfffc,
  101. .boot_params = (DA8XX_DDR_BASE + 0x100),
  102. .map_io = da830_evm_map_io,
  103. .init_irq = da830_evm_irq_init,
  104. .timer = &davinci_timer,
  105. .init_machine = da830_evm_init,
  106. MACHINE_END