ax88796.c 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * (c) 2007 Nobuhiro Iwamatsu <iwamatsu@nigauri.org>
  4. */
  5. #include <common.h>
  6. #include "ax88796.h"
  7. /*
  8. * Set 1 bit data
  9. */
  10. static void ax88796_bitset(u32 bit)
  11. {
  12. /* DATA1 */
  13. if( bit )
  14. EEDI_HIGH;
  15. else
  16. EEDI_LOW;
  17. EECLK_LOW;
  18. udelay(1000);
  19. EECLK_HIGH;
  20. udelay(1000);
  21. EEDI_LOW;
  22. }
  23. /*
  24. * Get 1 bit data
  25. */
  26. static u8 ax88796_bitget(void)
  27. {
  28. u8 bit;
  29. EECLK_LOW;
  30. udelay(1000);
  31. /* DATA */
  32. bit = EEDO;
  33. EECLK_HIGH;
  34. udelay(1000);
  35. return bit;
  36. }
  37. /*
  38. * Send COMMAND to EEPROM
  39. */
  40. static void ax88796_eep_cmd(u8 cmd)
  41. {
  42. ax88796_bitset(BIT_DUMMY);
  43. switch(cmd){
  44. case MAC_EEP_READ:
  45. ax88796_bitset(1);
  46. ax88796_bitset(1);
  47. ax88796_bitset(0);
  48. break;
  49. case MAC_EEP_WRITE:
  50. ax88796_bitset(1);
  51. ax88796_bitset(0);
  52. ax88796_bitset(1);
  53. break;
  54. case MAC_EEP_ERACE:
  55. ax88796_bitset(1);
  56. ax88796_bitset(1);
  57. ax88796_bitset(1);
  58. break;
  59. case MAC_EEP_EWEN:
  60. ax88796_bitset(1);
  61. ax88796_bitset(0);
  62. ax88796_bitset(0);
  63. break;
  64. case MAC_EEP_EWDS:
  65. ax88796_bitset(1);
  66. ax88796_bitset(0);
  67. ax88796_bitset(0);
  68. break;
  69. default:
  70. break;
  71. }
  72. }
  73. static void ax88796_eep_setaddr(u16 addr)
  74. {
  75. int i ;
  76. for( i = 7 ; i >= 0 ; i-- )
  77. ax88796_bitset(addr & (1 << i));
  78. }
  79. /*
  80. * Get data from EEPROM
  81. */
  82. static u16 ax88796_eep_getdata(void)
  83. {
  84. ushort data = 0;
  85. int i;
  86. ax88796_bitget(); /* DUMMY */
  87. for( i = 0 ; i < 16 ; i++ ){
  88. data <<= 1;
  89. data |= ax88796_bitget();
  90. }
  91. return data;
  92. }
  93. static void ax88796_mac_read(u8 *buff)
  94. {
  95. int i ;
  96. u16 data;
  97. u16 addr = 0;
  98. for( i = 0 ; i < 3; i++ )
  99. {
  100. EECS_HIGH;
  101. EEDI_LOW;
  102. udelay(1000);
  103. /* READ COMMAND */
  104. ax88796_eep_cmd(MAC_EEP_READ);
  105. /* ADDRESS */
  106. ax88796_eep_setaddr(addr++);
  107. /* GET DATA */
  108. data = ax88796_eep_getdata();
  109. *buff++ = (uchar)(data & 0xff);
  110. *buff++ = (uchar)((data >> 8) & 0xff);
  111. EECLK_LOW;
  112. EEDI_LOW;
  113. EECS_LOW;
  114. }
  115. }
  116. int get_prom(u8* mac_addr, u8* base_addr)
  117. {
  118. u8 prom[32];
  119. int i;
  120. ax88796_mac_read(prom);
  121. for (i = 0; i < 6; i++){
  122. mac_addr[i] = prom[i];
  123. }
  124. return 1;
  125. }