]> git.ipfire.org Git - people/ms/u-boot.git/blob - board/mpl/vcma9/cmd_vcma9.c
Make sure that argv[] argument pointers are not modified.
[people/ms/u-boot.git] / board / mpl / vcma9 / cmd_vcma9.c
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
28 #include <common.h>
29 #include <command.h>
30 #include <net.h>
31 #include "vcma9.h"
32 #include "../common/common_util.h"
33
34 #if defined(CONFIG_CS8900)
35 #include <../drivers/net/cs8900.h>
36
37 static uchar cs8900_chksum(ushort data)
38 {
39 return((data >> 8) & 0x00FF) + (data & 0x00FF);
40 }
41
42 #endif
43
44 DECLARE_GLOBAL_DATA_PTR;
45
46 extern void print_vcma9_info(void);
47 extern int vcma9_cantest(int);
48 extern int vcma9_nandtest(void);
49 extern int vcma9_nanderase(void);
50 extern int vcma9_nandread(ulong);
51 extern int vcma9_nandwrite(ulong);
52 extern int vcma9_dactest(int);
53 extern int do_mplcommon(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]);
54
55 /* ------------------------------------------------------------------------- */
56
57 int do_vcma9(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
58 {
59 struct eth_device *dev;
60 char cs8900_name[10];
61 if (strcmp(argv[1], "info") == 0)
62 {
63 print_vcma9_info();
64 return 0;
65 }
66 #if defined(CONFIG_CS8900)
67 if (strcmp(argv[1], "cs8900") == 0) {
68 sprintf(cs8900_name, "%s-0", CS8900_DRIVERNAME);
69 dev = eth_get_dev_by_name(cs8900_name);
70 if (!dev) {
71 printf("Couldn't find CS8900 driver");
72 return 0;
73 }
74 if (strcmp(argv[2], "read") == 0) {
75 uchar addr; ushort data;
76
77 addr = simple_strtoul(argv[3], NULL, 16);
78 cs8900_e2prom_read(dev, addr, &data);
79 printf("0x%2.2X: 0x%4.4X\n", addr, data);
80 } else if (strcmp(argv[2], "write") == 0) {
81 uchar addr; ushort data;
82
83 addr = simple_strtoul(argv[3], NULL, 16);
84 data = simple_strtoul(argv[4], NULL, 16);
85 cs8900_e2prom_write(dev, addr, data);
86 } else if (strcmp(argv[2], "setaddr") == 0) {
87 uchar addr, i, csum; ushort data;
88 uchar ethaddr[6];
89
90 /* check for valid ethaddr */
91 if (eth_getenv_enetaddr("ethaddr", ethaddr)) {
92 addr = 1;
93 data = 0x2158;
94 cs8900_e2prom_write(dev, addr, data);
95 csum = cs8900_chksum(data);
96 addr++;
97 for (i = 0; i < 6; i+=2) {
98 data = ethaddr[i+1] << 8 |
99 ethaddr[i];
100 cs8900_e2prom_write(dev, addr, data);
101 csum += cs8900_chksum(data);
102 addr++;
103 }
104 /* calculate header link byte */
105 data = 0xA100 | (addr * 2);
106 cs8900_e2prom_write(dev, 0, data);
107 csum += cs8900_chksum(data);
108 /* write checksum word */
109 cs8900_e2prom_write(dev, addr, (0 - csum) << 8);
110 } else {
111 puts("\nplease defined 'ethaddr'\n");
112 }
113 } else if (strcmp(argv[2], "dump") == 0) {
114 uchar addr = 0, endaddr, csum; ushort data;
115
116 puts("Dump of CS8900 config device: ");
117 cs8900_e2prom_read(dev, addr, &data);
118 if ((data & 0xE000) == 0xA000) {
119 endaddr = (data & 0x00FF) / 2;
120 csum = cs8900_chksum(data);
121 for (addr = 1; addr <= endaddr; addr++) {
122 cs8900_e2prom_read(dev, addr, &data);
123 printf("\n0x%2.2X: 0x%4.4X", addr, data);
124 csum += cs8900_chksum(data);
125 }
126 printf("\nChecksum: %s", (csum == 0) ? "ok" : "wrong");
127 } else {
128 puts("no valid config found");
129 }
130 puts("\n");
131 }
132
133 return 0;
134 }
135 #endif
136 #if 0
137 if (strcmp(argv[1], "cantest") == 0) {
138 if (argc >= 3)
139 vcma9_cantest(strcmp(argv[2], "s") ? 0 : 1);
140 else
141 vcma9_cantest(0);
142 return 0;
143 }
144 if (strcmp(argv[1], "nandtest") == 0) {
145 vcma9_nandtest();
146 return 0;
147 }
148 if (strcmp(argv[1], "nanderase") == 0) {
149 vcma9_nanderase();
150 return 0;
151 }
152 if (strcmp(argv[1], "nandread") == 0) {
153 ulong offset = 0;
154
155 if (argc >= 3)
156 offset = simple_strtoul(argv[2], NULL, 16);
157
158 vcma9_nandread(offset);
159 return 0;
160 }
161 if (strcmp(argv[1], "nandwrite") == 0) {
162 ulong offset = 0;
163
164 if (argc >= 3)
165 offset = simple_strtoul(argv[2], NULL, 16);
166
167 vcma9_nandwrite(offset);
168 return 0;
169 }
170 if (strcmp(argv[1], "dactest") == 0) {
171 if (argc >= 3)
172 vcma9_dactest(strcmp(argv[2], "s") ? 0 : 1);
173 else
174 vcma9_dactest(0);
175 return 0;
176 }
177 #endif
178
179 return (do_mplcommon(cmdtp, flag, argc, argv));
180 }
181
182 U_BOOT_CMD(
183 vcma9, 6, 1, do_vcma9,
184 "VCMA9 specific commands",
185 "flash mem [SrcAddr]\n - updates U-Boot with image in memory"
186 );