nsa310s.c 3.0 KB

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