cmd_vcma9.c 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. /*
  2. * (C) Copyright 2002
  3. * Denis Peter, MPL AG Switzerland, d.peter@mpl.ch
  4. *
  5. * adapted for VCMA9
  6. * David Mueller, ELSOFT AG, d.mueller@elsoft.ch
  7. *
  8. * See file CREDITS for list of people who contributed to this
  9. * project.
  10. *
  11. * This program is free software; you can redistribute it and/or
  12. * modify it under the terms of the GNU General Public License as
  13. * published by the Free Software Foundation; either version 2 of
  14. * the License, or (at your option) any later version.
  15. *
  16. * This program is distributed in the hope that it will be useful,
  17. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  18. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  19. * GNU General Public License for more details.
  20. *
  21. * You should have received a copy of the GNU General Public License
  22. * along with this program; if not, write to the Free Software
  23. * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  24. * MA 02111-1307 USA
  25. *
  26. */
  27. #include <common.h>
  28. #include <command.h>
  29. #include "vcma9.h"
  30. #include "../common/common_util.h"
  31. #if defined(CONFIG_DRIVER_CS8900)
  32. #include <../drivers/cs8900.h>
  33. static uchar cs8900_chksum(ushort data)
  34. {
  35. return((data >> 8) & 0x00FF) + (data & 0x00FF);
  36. }
  37. #endif
  38. extern void print_vcma9_info(void);
  39. extern int vcma9_cantest(int);
  40. extern int vcma9_nandtest(void);
  41. extern int vcma9_nanderase(void);
  42. extern int vcma9_nandread(ulong);
  43. extern int vcma9_nandwrite(ulong);
  44. extern int vcma9_dactest(int);
  45. extern int do_mplcommon(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]);
  46. /* ------------------------------------------------------------------------- */
  47. int do_vcma9(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
  48. {
  49. DECLARE_GLOBAL_DATA_PTR;
  50. if (strcmp(argv[1], "info") == 0)
  51. {
  52. print_vcma9_info();
  53. return 0;
  54. }
  55. #if defined(CONFIG_DRIVER_CS8900)
  56. if (strcmp(argv[1], "cs8900_eeprom") == 0) {
  57. if (strcmp(argv[2], "read") == 0) {
  58. uchar addr; ushort data;
  59. addr = simple_strtoul(argv[3], NULL, 16);
  60. cs8900_e2prom_read(addr, &data);
  61. printf("0x%2.2X: 0x%4.4X\n", addr, data);
  62. } else if (strcmp(argv[2], "write") == 0) {
  63. uchar addr; ushort data;
  64. addr = simple_strtoul(argv[3], NULL, 16);
  65. data = simple_strtoul(argv[4], NULL, 16);
  66. cs8900_e2prom_write(addr, data);
  67. } else if (strcmp(argv[2], "setaddr") == 0) {
  68. uchar addr, i, csum; ushort data;
  69. /* check for valid ethaddr */
  70. for (i = 0; i < 6; i++)
  71. if (gd->bd->bi_enetaddr[i] != 0)
  72. break;
  73. if (i < 6) {
  74. addr = 1;
  75. data = 0x2158;
  76. cs8900_e2prom_write(addr, data);
  77. csum = cs8900_chksum(data);
  78. addr++;
  79. for (i = 0; i < 6; i+=2) {
  80. data = gd->bd->bi_enetaddr[i+1] << 8 |
  81. gd->bd->bi_enetaddr[i];
  82. cs8900_e2prom_write(addr, data);
  83. csum += cs8900_chksum(data);
  84. addr++;
  85. }
  86. /* calculate header link byte */
  87. data = 0xA100 | (addr * 2);
  88. cs8900_e2prom_write(0, data);
  89. csum += cs8900_chksum(data);
  90. /* write checksum word */
  91. cs8900_e2prom_write(addr, (0 - csum) << 8);
  92. } else {
  93. printf("\nplease defined 'ethaddr'\n");
  94. }
  95. } else if (strcmp(argv[2], "dump") == 0) {
  96. uchar addr = 0, endaddr, csum; ushort data;
  97. printf("Dump of CS8900 config device: ");
  98. cs8900_e2prom_read(addr, &data);
  99. if ((data & 0xE000) == 0xA000) {
  100. endaddr = (data & 0x00FF) / 2;
  101. csum = cs8900_chksum(data);
  102. for (addr = 1; addr <= endaddr; addr++) {
  103. cs8900_e2prom_read(addr, &data);
  104. printf("\n0x%2.2X: 0x%4.4X", addr, data);
  105. csum += cs8900_chksum(data);
  106. }
  107. printf("\nChecksum: %s", (csum == 0) ? "ok" : "wrong");
  108. } else {
  109. printf("no valid config found");
  110. }
  111. printf("\n");
  112. }
  113. return 0;
  114. }
  115. #endif
  116. #if 0
  117. if (strcmp(argv[1], "cantest") == 0) {
  118. if (argc >= 3)
  119. vcma9_cantest(strcmp(argv[2], "s") ? 0 : 1);
  120. else
  121. vcma9_cantest(0);
  122. return 0;
  123. }
  124. if (strcmp(argv[1], "nandtest") == 0) {
  125. vcma9_nandtest();
  126. return 0;
  127. }
  128. if (strcmp(argv[1], "nanderase") == 0) {
  129. vcma9_nanderase();
  130. return 0;
  131. }
  132. if (strcmp(argv[1], "nandread") == 0) {
  133. ulong offset = 0;
  134. if (argc >= 3)
  135. offset = simple_strtoul(argv[2], NULL, 16);
  136. vcma9_nandread(offset);
  137. return 0;
  138. }
  139. if (strcmp(argv[1], "nandwrite") == 0) {
  140. ulong offset = 0;
  141. if (argc >= 3)
  142. offset = simple_strtoul(argv[2], NULL, 16);
  143. vcma9_nandwrite(offset);
  144. return 0;
  145. }
  146. if (strcmp(argv[1], "dactest") == 0) {
  147. if (argc >= 3)
  148. vcma9_dactest(strcmp(argv[2], "s") ? 0 : 1);
  149. else
  150. vcma9_dactest(0);
  151. return 0;
  152. }
  153. #endif
  154. return (do_mplcommon(cmdtp, flag, argc, argv));
  155. }
  156. U_BOOT_CMD(
  157. vcma9, 6, 1, do_vcma9,
  158. "vcma9 - VCMA9 specific commands\n",
  159. "flash mem [SrcAddr]\n - updates U-Boot with image in memory\n"
  160. );