nsa310s.c 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. /*
  2. * Copyright (C) 2015
  3. * Gerald Kerma <dreagle@doukki.net>
  4. * Tony Dinh <mibodhi@gmail.com>
  5. *
  6. * SPDX-License-Identifier: GPL-2.0+
  7. */
  8. #include <common.h>
  9. #include <miiphy.h>
  10. #include <asm/arch/cpu.h>
  11. #include <asm/arch/soc.h>
  12. #include <asm/arch/mpp.h>
  13. #include <asm/io.h>
  14. #include "nsa310s.h"
  15. DECLARE_GLOBAL_DATA_PTR;
  16. int board_early_init_f(void)
  17. {
  18. /*
  19. * default gpio configuration
  20. * There are maximum 64 gpios controlled through 2 sets of registers
  21. * the below configuration configures mainly initial LED status
  22. */
  23. mvebu_config_gpio(NSA310S_VAL_LOW, NSA310S_VAL_HIGH,
  24. NSA310S_OE_LOW, NSA310S_OE_HIGH);
  25. /* (all LEDs & power off active high) */
  26. /* Multi-Purpose Pins Functionality configuration */
  27. static const u32 kwmpp_config[] = {
  28. MPP0_NF_IO2,
  29. MPP1_NF_IO3,
  30. MPP2_NF_IO4,
  31. MPP3_NF_IO5,
  32. MPP4_NF_IO6,
  33. MPP5_NF_IO7,
  34. MPP6_SYSRST_OUTn,
  35. MPP7_GPO,
  36. MPP8_TW_SDA,
  37. MPP9_TW_SCK,
  38. MPP10_UART0_TXD,
  39. MPP11_UART0_RXD,
  40. MPP12_GPO,
  41. MPP13_GPIO,
  42. MPP14_GPIO,
  43. MPP15_GPIO,
  44. MPP16_GPIO,
  45. MPP17_GPIO,
  46. MPP18_NF_IO0,
  47. MPP19_NF_IO1,
  48. MPP20_GPIO,
  49. MPP21_GPIO,
  50. MPP22_GPIO,
  51. MPP23_GPIO,
  52. MPP24_GPIO,
  53. MPP25_GPIO,
  54. MPP26_GPIO,
  55. MPP27_GPIO,
  56. MPP28_GPIO,
  57. MPP29_GPIO,
  58. MPP30_GPIO,
  59. MPP31_GPIO,
  60. MPP32_GPIO,
  61. MPP33_GPIO,
  62. MPP34_GPIO,
  63. MPP35_GPIO,
  64. 0
  65. };
  66. kirkwood_mpp_conf(kwmpp_config, NULL);
  67. return 0;
  68. }
  69. int board_init(void)
  70. {
  71. /* address of boot parameters */
  72. gd->bd->bi_boot_params = mvebu_sdram_bar(0) + 0x100;
  73. return 0;
  74. }
  75. #ifdef CONFIG_RESET_PHY_R
  76. void reset_phy(void)
  77. {
  78. u16 reg;
  79. u16 phyaddr;
  80. char *name = "egiga0";
  81. if (miiphy_set_current_dev(name))
  82. return;
  83. /* read PHY dev address */
  84. if (miiphy_read(name, 0xee, 0xee, (u16 *) &phyaddr)) {
  85. printf("could not read PHY dev address\n");
  86. return;
  87. }
  88. /* set RGMII delay */
  89. miiphy_write(name, phyaddr, MV88E1318_PGADR_REG, MV88E1318_MAC_CTRL_PG);
  90. miiphy_read(name, phyaddr, MV88E1318_MAC_CTRL_REG, &reg);
  91. reg |= (MV88E1318_RGMII_RX_CTRL | MV88E1318_RGMII_TX_CTRL);
  92. miiphy_write(name, phyaddr, MV88E1318_MAC_CTRL_REG, reg);
  93. miiphy_write(name, phyaddr, MV88E1318_PGADR_REG, 0);
  94. /* reset PHY */
  95. if (miiphy_reset(name, phyaddr))
  96. return;
  97. /*
  98. * ZyXEL NSA310S uses the 88E1310S Alaska (interface identical to 88E1318)
  99. * and has an MCU attached to the LED[2] via tristate interrupt
  100. */
  101. /* switch to LED register page */
  102. miiphy_write(name, phyaddr, MV88E1318_PGADR_REG, MV88E1318_LED_PG);
  103. /* read out LED polarity register */
  104. miiphy_read(name, phyaddr, MV88E1318_LED_POL_REG, &reg);
  105. /* clear 4, set 5 - LED2 low, tri-state */
  106. reg &= ~(MV88E1318_LED2_4);
  107. reg |= (MV88E1318_LED2_5);
  108. /* write back LED polarity register */
  109. miiphy_write(name, phyaddr, MV88E1318_LED_POL_REG, reg);
  110. /* jump back to page 0, per the PHY chip documenation. */
  111. miiphy_write(name, phyaddr, MV88E1318_PGADR_REG, 0);
  112. /* set PHY back to auto-negotiation mode */
  113. miiphy_write(name, phyaddr, 0x4, 0x1e1);
  114. miiphy_write(name, phyaddr, 0x9, 0x300);
  115. /* downshift */
  116. miiphy_write(name, phyaddr, 0x10, 0x3860);
  117. miiphy_write(name, phyaddr, 0x0, 0x9140);
  118. }
  119. #endif /* CONFIG_RESET_PHY_R */