]>
Commit | Line | Data |
---|---|---|
8bde7f77 WD |
1 | /* |
2 | * (C) Copyright 2003 | |
3 | * Wolfgang Denk, DENX Software Engineering, wd@denx.de. | |
4 | * | |
5 | * See file CREDITS for list of people who contributed to this | |
6 | * project. | |
7 | * | |
8 | * This program is free software; you can redistribute it and/or | |
9 | * modify it under the terms of the GNU General Public License as | |
10 | * published by the Free Software Foundation; either version 2 of | |
11 | * the License, or (at your option) any later version. | |
12 | * | |
13 | * This program is distributed in the hope that it will be useful, | |
14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
16 | * GNU General Public License for more details. | |
17 | * | |
18 | * You should have received a copy of the GNU General Public License | |
19 | * along with this program; if not, write to the Free Software | |
20 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, | |
21 | * MA 02111-1307 USA | |
22 | */ | |
23 | ||
24 | /* | |
25 | * Boot support | |
26 | */ | |
27 | #include <common.h> | |
28 | #include <command.h> | |
9d2b18a0 | 29 | #include <net.h> /* for print_IPaddr */ |
8bde7f77 | 30 | |
d87080b7 | 31 | DECLARE_GLOBAL_DATA_PTR; |
8bde7f77 | 32 | |
8bde7f77 WD |
33 | static void print_num(const char *, ulong); |
34 | ||
35 | #ifndef CONFIG_ARM /* PowerPC and other */ | |
36 | ||
37 | #ifdef CONFIG_PPC | |
38 | static void print_str(const char *, const char *); | |
39 | ||
40 | int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) | |
41 | { | |
8bde7f77 WD |
42 | int i; |
43 | bd_t *bd = gd->bd; | |
44 | char buf[32]; | |
45 | ||
46 | #ifdef DEBUG | |
47 | print_num ("bd address", (ulong)bd ); | |
48 | #endif | |
49 | print_num ("memstart", bd->bi_memstart ); | |
50 | print_num ("memsize", bd->bi_memsize ); | |
51 | print_num ("flashstart", bd->bi_flashstart ); | |
52 | print_num ("flashsize", bd->bi_flashsize ); | |
53 | print_num ("flashoffset", bd->bi_flashoffset ); | |
54 | print_num ("sramstart", bd->bi_sramstart ); | |
55 | print_num ("sramsize", bd->bi_sramsize ); | |
97d80fc3 WD |
56 | #if defined(CONFIG_5xx) || defined(CONFIG_8xx) || \ |
57 | defined(CONFIG_8260) || defined(CONFIG_E500) | |
8bde7f77 WD |
58 | print_num ("immr_base", bd->bi_immr_base ); |
59 | #endif | |
60 | print_num ("bootflags", bd->bi_bootflags ); | |
97d80fc3 | 61 | #if defined(CONFIG_405GP) || defined(CONFIG_405CR) || \ |
c157d8e2 | 62 | defined(CONFIG_405EP) || defined(CONFIG_XILINX_ML300) || \ |
6c5879f3 | 63 | defined(CONFIG_440EP) || defined(CONFIG_440GR) || \ |
887e2ec9 SR |
64 | defined(CONFIG_440EPX) || defined(CONFIG_440GRX) || \ |
65 | defined(CONFIG_440SP) || defined(CONFIG_440SPE) | |
8bde7f77 | 66 | print_str ("procfreq", strmhz(buf, bd->bi_procfreq)); |
983fda83 | 67 | print_str ("plb_busfreq", strmhz(buf, bd->bi_plb_busfreq)); |
c157d8e2 | 68 | #if defined(CONFIG_405GP) || defined(CONFIG_405EP) || defined(CONFIG_XILINX_ML300) || \ |
887e2ec9 SR |
69 | defined(CONFIG_440EP) || defined(CONFIG_440GR) || defined(CONFIG_440SPE) || \ |
70 | defined(CONFIG_440EPX) || defined(CONFIG_440GRX) | |
983fda83 | 71 | print_str ("pci_busfreq", strmhz(buf, bd->bi_pci_busfreq)); |
8bde7f77 | 72 | #endif |
846b0dd2 | 73 | #else /* ! CONFIG_405GP, CONFIG_405CR, CONFIG_405EP, CONFIG_XILINX_ML300, CONFIG_440EP CONFIG_440GR */ |
9c4c5ae3 | 74 | #if defined(CONFIG_CPM2) |
8bde7f77 WD |
75 | print_str ("vco", strmhz(buf, bd->bi_vco)); |
76 | print_str ("sccfreq", strmhz(buf, bd->bi_sccfreq)); | |
77 | print_str ("brgfreq", strmhz(buf, bd->bi_brgfreq)); | |
78 | #endif | |
79 | print_str ("intfreq", strmhz(buf, bd->bi_intfreq)); | |
9c4c5ae3 | 80 | #if defined(CONFIG_CPM2) |
8bde7f77 WD |
81 | print_str ("cpmfreq", strmhz(buf, bd->bi_cpmfreq)); |
82 | #endif | |
83 | print_str ("busfreq", strmhz(buf, bd->bi_busfreq)); | |
846b0dd2 | 84 | #endif /* CONFIG_405GP, CONFIG_405CR, CONFIG_405EP, CONFIG_XILINX_ML300, CONFIG_440EP CONFIG_440GR */ |
983fda83 WD |
85 | #if defined(CONFIG_MPC8220) |
86 | print_str ("inpfreq", strmhz(buf, bd->bi_inpfreq)); | |
87 | print_str ("flbfreq", strmhz(buf, bd->bi_flbfreq)); | |
88 | print_str ("pcifreq", strmhz(buf, bd->bi_pcifreq)); | |
89 | print_str ("vcofreq", strmhz(buf, bd->bi_vcofreq)); | |
90 | print_str ("pevfreq", strmhz(buf, bd->bi_pevfreq)); | |
91 | #endif | |
03f5c550 | 92 | |
4b9206ed | 93 | puts ("ethaddr ="); |
8bde7f77 WD |
94 | for (i=0; i<6; ++i) { |
95 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]); | |
96 | } | |
03f5c550 | 97 | |
e2ffd59b | 98 | #if defined(CONFIG_HAS_ETH1) |
4b9206ed | 99 | puts ("\neth1addr ="); |
8bde7f77 WD |
100 | for (i=0; i<6; ++i) { |
101 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enet1addr[i]); | |
102 | } | |
03f5c550 WD |
103 | #endif |
104 | ||
e2ffd59b | 105 | #if defined(CONFIG_HAS_ETH2) |
4b9206ed | 106 | puts ("\neth2addr ="); |
42d1f039 WD |
107 | for (i=0; i<6; ++i) { |
108 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enet2addr[i]); | |
109 | } | |
110 | #endif | |
03f5c550 | 111 | |
e2ffd59b | 112 | #if defined(CONFIG_HAS_ETH3) |
03f5c550 WD |
113 | puts ("\neth3addr ="); |
114 | for (i=0; i<6; ++i) { | |
115 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enet3addr[i]); | |
116 | } | |
117 | #endif | |
118 | ||
8bde7f77 WD |
119 | #ifdef CONFIG_HERMES |
120 | print_str ("ethspeed", strmhz(buf, bd->bi_ethspeed)); | |
121 | #endif | |
4b9206ed | 122 | puts ("\nIP addr = "); print_IPaddr (bd->bi_ip_addr); |
8bde7f77 WD |
123 | printf ("\nbaudrate = %6ld bps\n", bd->bi_baudrate ); |
124 | return 0; | |
125 | } | |
126 | ||
4a551709 WD |
127 | #elif defined(CONFIG_NIOS) /* NIOS*/ |
128 | ||
129 | int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) | |
130 | { | |
4a551709 WD |
131 | int i; |
132 | bd_t *bd = gd->bd; | |
133 | ||
134 | print_num ("memstart", (ulong)bd->bi_memstart); | |
135 | print_num ("memsize", (ulong)bd->bi_memsize); | |
136 | print_num ("flashstart", (ulong)bd->bi_flashstart); | |
137 | print_num ("flashsize", (ulong)bd->bi_flashsize); | |
138 | print_num ("flashoffset", (ulong)bd->bi_flashoffset); | |
139 | ||
4b9206ed | 140 | puts ("ethaddr ="); |
4a551709 WD |
141 | for (i=0; i<6; ++i) { |
142 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]); | |
143 | } | |
4b9206ed | 144 | puts ("\nip_addr = "); |
4a551709 WD |
145 | print_IPaddr (bd->bi_ip_addr); |
146 | printf ("\nbaudrate = %ld bps\n", bd->bi_baudrate); | |
147 | ||
148 | return 0; | |
149 | } | |
150 | ||
5c952cf0 WD |
151 | #elif defined(CONFIG_NIOS2) /* Nios-II */ |
152 | ||
153 | int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) | |
154 | { | |
252f60b0 | 155 | #if defined(CONFIG_CMD_NET) |
5c952cf0 | 156 | int i; |
252f60b0 | 157 | #endif |
5c952cf0 WD |
158 | bd_t *bd = gd->bd; |
159 | ||
160 | print_num ("mem start", (ulong)bd->bi_memstart); | |
161 | print_num ("mem size", (ulong)bd->bi_memsize); | |
162 | print_num ("flash start", (ulong)bd->bi_flashstart); | |
163 | print_num ("flash size", (ulong)bd->bi_flashsize); | |
164 | print_num ("flash offset", (ulong)bd->bi_flashoffset); | |
165 | ||
166 | #if defined(CFG_SRAM_BASE) | |
167 | print_num ("sram start", (ulong)bd->bi_sramstart); | |
168 | print_num ("sram size", (ulong)bd->bi_sramsize); | |
169 | #endif | |
170 | ||
90253178 | 171 | #if defined(CONFIG_CMD_NET) |
5c952cf0 WD |
172 | puts ("ethaddr ="); |
173 | for (i=0; i<6; ++i) { | |
174 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]); | |
175 | } | |
176 | puts ("\nip_addr = "); | |
177 | print_IPaddr (bd->bi_ip_addr); | |
178 | #endif | |
179 | ||
180 | printf ("\nbaudrate = %ld bps\n", bd->bi_baudrate); | |
181 | ||
182 | return 0; | |
183 | } | |
cfc67116 MS |
184 | #elif defined(CONFIG_MICROBLAZE) /* ! PPC, which leaves Microblaze */ |
185 | ||
186 | int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) | |
187 | { | |
188 | int i; | |
189 | bd_t *bd = gd->bd; | |
190 | print_num ("mem start ", (ulong)bd->bi_memstart); | |
191 | print_num ("mem size ", (ulong)bd->bi_memsize); | |
192 | print_num ("flash start ", (ulong)bd->bi_flashstart); | |
193 | print_num ("flash size ", (ulong)bd->bi_flashsize); | |
194 | print_num ("flash offset ", (ulong)bd->bi_flashoffset); | |
195 | #if defined(CFG_SRAM_BASE) | |
196 | print_num ("sram start ", (ulong)bd->bi_sramstart); | |
197 | print_num ("sram size ", (ulong)bd->bi_sramsize); | |
198 | #endif | |
90253178 | 199 | #if defined(CONFIG_CMD_NET) |
cfc67116 MS |
200 | puts ("ethaddr ="); |
201 | for (i=0; i<6; ++i) { | |
202 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]); | |
203 | } | |
204 | puts ("\nip_addr = "); | |
205 | print_IPaddr (bd->bi_ip_addr); | |
206 | #endif | |
207 | printf ("\nbaudrate = %d bps\n", (ulong)bd->bi_baudrate); | |
208 | return 0; | |
209 | } | |
4a551709 | 210 | |
00ab32c8 DH |
211 | #elif defined(CONFIG_SPARC) /* SPARC */ |
212 | int do_bdinfo(cmd_tbl_t * cmdtp, int flag, int argc, char *argv[]) | |
213 | { | |
214 | bd_t *bd = gd->bd; | |
215 | #if defined(CONFIG_CMD_NET) | |
216 | int i; | |
217 | #endif | |
218 | ||
219 | #ifdef DEBUG | |
220 | print_num("bd address ", (ulong) bd); | |
221 | #endif | |
222 | print_num("memstart ", bd->bi_memstart); | |
223 | print_num("memsize ", bd->bi_memsize); | |
224 | print_num("flashstart ", bd->bi_flashstart); | |
225 | print_num("CFG_MONITOR_BASE ", CFG_MONITOR_BASE); | |
226 | print_num("CFG_ENV_ADDR ", CFG_ENV_ADDR); | |
227 | printf("CFG_RELOC_MONITOR_BASE = 0x%lx (%d)\n", CFG_RELOC_MONITOR_BASE, | |
228 | CFG_MONITOR_LEN); | |
229 | printf("CFG_MALLOC_BASE = 0x%lx (%d)\n", CFG_MALLOC_BASE, | |
230 | CFG_MALLOC_LEN); | |
231 | printf("CFG_INIT_SP_OFFSET = 0x%lx (%d)\n", CFG_INIT_SP_OFFSET, | |
232 | CFG_STACK_SIZE); | |
233 | printf("CFG_PROM_OFFSET = 0x%lx (%d)\n", CFG_PROM_OFFSET, | |
234 | CFG_PROM_SIZE); | |
235 | printf("CFG_GBL_DATA_OFFSET = 0x%lx (%d)\n", CFG_GBL_DATA_OFFSET, | |
236 | CFG_GBL_DATA_SIZE); | |
237 | ||
238 | #if defined(CONFIG_CMD_NET) | |
239 | puts("ethaddr ="); | |
240 | for (i = 0; i < 6; ++i) { | |
241 | printf("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]); | |
242 | } | |
243 | puts("\nIP addr = "); | |
244 | print_IPaddr(bd->bi_ip_addr); | |
245 | #endif | |
246 | printf("\nbaudrate = %6ld bps\n", bd->bi_baudrate); | |
247 | return 0; | |
248 | } | |
249 | ||
8e585f02 | 250 | #elif defined(CONFIG_M68K) /* M68K */ |
8ae158cd | 251 | static void print_str(const char *, const char *); |
8e585f02 TL |
252 | |
253 | int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) | |
254 | { | |
255 | int i; | |
256 | bd_t *bd = gd->bd; | |
8ae158cd TL |
257 | char buf[32]; |
258 | ||
8e585f02 TL |
259 | print_num ("memstart", (ulong)bd->bi_memstart); |
260 | print_num ("memsize", (ulong)bd->bi_memsize); | |
261 | print_num ("flashstart", (ulong)bd->bi_flashstart); | |
262 | print_num ("flashsize", (ulong)bd->bi_flashsize); | |
263 | print_num ("flashoffset", (ulong)bd->bi_flashoffset); | |
264 | #if defined(CFG_INIT_RAM_ADDR) | |
8ae158cd TL |
265 | print_num ("sramstart", (ulong)bd->bi_sramstart); |
266 | print_num ("sramsize", (ulong)bd->bi_sramsize); | |
8e585f02 TL |
267 | #endif |
268 | #if defined(CFG_MBAR) | |
8ae158cd | 269 | print_num ("mbar", bd->bi_mbar_base); |
8e585f02 | 270 | #endif |
8ae158cd TL |
271 | print_str ("busfreq", strmhz(buf, bd->bi_busfreq)); |
272 | #ifdef CONFIG_PCI | |
273 | print_str ("pcifreq", strmhz(buf, bd->bi_pcifreq)); | |
274 | #endif | |
275 | #ifdef CONFIG_EXTRA_CLOCK | |
276 | print_str ("flbfreq", strmhz(buf, bd->bi_flbfreq)); | |
277 | print_str ("inpfreq", strmhz(buf, bd->bi_inpfreq)); | |
278 | print_str ("vcofreq", strmhz(buf, bd->bi_vcofreq)); | |
279 | #endif | |
26667b7f | 280 | #if defined(CONFIG_CMD_NET) |
8e585f02 TL |
281 | puts ("ethaddr ="); |
282 | for (i=0; i<6; ++i) { | |
283 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]); | |
284 | } | |
285 | ||
286 | #if defined(CONFIG_HAS_ETH1) | |
287 | puts ("\neth1addr ="); | |
288 | for (i=0; i<6; ++i) { | |
289 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enet1addr[i]); | |
290 | } | |
291 | #endif | |
292 | ||
293 | #if defined(CONFIG_HAS_ETH2) | |
ab77bc54 TL |
294 | puts ("\neth2addr ="); |
295 | for (i=0; i<6; ++i) { | |
8e585f02 TL |
296 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enet2addr[i]); |
297 | } | |
298 | #endif | |
299 | ||
300 | #if defined(CONFIG_HAS_ETH3) | |
ab77bc54 TL |
301 | puts ("\neth3addr ="); |
302 | for (i=0; i<6; ++i) { | |
8e585f02 TL |
303 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enet3addr[i]); |
304 | } | |
305 | #endif | |
306 | ||
307 | puts ("\nip_addr = "); | |
308 | print_IPaddr (bd->bi_ip_addr); | |
26667b7f | 309 | #endif |
8e585f02 TL |
310 | printf ("\nbaudrate = %d bps\n", bd->bi_baudrate); |
311 | ||
312 | return 0; | |
313 | } | |
314 | ||
8dc48d71 MF |
315 | #elif defined(CONFIG_BLACKFIN) |
316 | ||
317 | int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) | |
318 | { | |
319 | int i; | |
320 | bd_t *bd = gd->bd; | |
321 | ||
322 | printf("U-Boot = %s\n", bd->bi_r_version); | |
323 | printf("CPU = %s\n", bd->bi_cpu); | |
324 | printf("Board = %s\n", bd->bi_board_name); | |
325 | printf("VCO = %lu MHz\n", bd->bi_vco / 1000000); | |
326 | printf("CCLK = %lu MHz\n", bd->bi_cclk / 1000000); | |
327 | printf("SCLK = %lu MHz\n", bd->bi_sclk / 1000000); | |
328 | ||
329 | print_num("boot_params", (ulong)bd->bi_boot_params); | |
330 | print_num("memstart", (ulong)bd->bi_memstart); | |
331 | print_num("memsize", (ulong)bd->bi_memsize); | |
332 | print_num("flashstart", (ulong)bd->bi_flashstart); | |
333 | print_num("flashsize", (ulong)bd->bi_flashsize); | |
334 | print_num("flashoffset", (ulong)bd->bi_flashoffset); | |
335 | ||
336 | puts("ethaddr ="); | |
337 | for (i = 0; i < 6; ++i) | |
338 | printf("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]); | |
339 | puts("\nip_addr = "); | |
340 | print_IPaddr(bd->bi_ip_addr); | |
341 | printf("\nbaudrate = %d bps\n", bd->bi_baudrate); | |
342 | ||
343 | return 0; | |
344 | } | |
345 | ||
8bde7f77 WD |
346 | #else /* ! PPC, which leaves MIPS */ |
347 | ||
348 | int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) | |
349 | { | |
8bde7f77 WD |
350 | int i; |
351 | bd_t *bd = gd->bd; | |
352 | ||
353 | print_num ("boot_params", (ulong)bd->bi_boot_params); | |
354 | print_num ("memstart", (ulong)bd->bi_memstart); | |
355 | print_num ("memsize", (ulong)bd->bi_memsize); | |
356 | print_num ("flashstart", (ulong)bd->bi_flashstart); | |
357 | print_num ("flashsize", (ulong)bd->bi_flashsize); | |
358 | print_num ("flashoffset", (ulong)bd->bi_flashoffset); | |
359 | ||
4b9206ed | 360 | puts ("ethaddr ="); |
8bde7f77 WD |
361 | for (i=0; i<6; ++i) { |
362 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]); | |
363 | } | |
4b9206ed | 364 | puts ("\nip_addr = "); |
8bde7f77 WD |
365 | print_IPaddr (bd->bi_ip_addr); |
366 | printf ("\nbaudrate = %d bps\n", bd->bi_baudrate); | |
367 | ||
368 | return 0; | |
369 | } | |
370 | #endif /* MIPS */ | |
371 | ||
372 | #else /* ARM */ | |
373 | ||
374 | int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) | |
375 | { | |
8bde7f77 WD |
376 | int i; |
377 | bd_t *bd = gd->bd; | |
378 | ||
379 | print_num ("arch_number", bd->bi_arch_number); | |
380 | print_num ("env_t", (ulong)bd->bi_env); | |
381 | print_num ("boot_params", (ulong)bd->bi_boot_params); | |
382 | ||
383 | for (i=0; i<CONFIG_NR_DRAM_BANKS; ++i) { | |
384 | print_num("DRAM bank", i); | |
385 | print_num("-> start", bd->bi_dram[i].start); | |
386 | print_num("-> size", bd->bi_dram[i].size); | |
387 | } | |
388 | ||
a41dbbd9 | 389 | #if defined(CONFIG_CMD_NET) |
4b9206ed | 390 | puts ("ethaddr ="); |
8bde7f77 WD |
391 | for (i=0; i<6; ++i) { |
392 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]); | |
393 | } | |
4b9206ed | 394 | puts ( "\n" |
8bde7f77 WD |
395 | "ip_addr = "); |
396 | print_IPaddr (bd->bi_ip_addr); | |
a41dbbd9 | 397 | #endif |
b79a11cc | 398 | printf ("\n" |
8bde7f77 WD |
399 | "baudrate = %d bps\n", bd->bi_baudrate); |
400 | ||
401 | return 0; | |
402 | } | |
403 | ||
404 | #endif /* CONFIG_ARM XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX */ | |
405 | ||
406 | static void print_num(const char *name, ulong value) | |
407 | { | |
408 | printf ("%-12s= 0x%08lX\n", name, value); | |
409 | } | |
410 | ||
8ae158cd | 411 | #if defined(CONFIG_PPC) || defined(CONFIG_M68K) |
8bde7f77 WD |
412 | static void print_str(const char *name, const char *str) |
413 | { | |
414 | printf ("%-12s= %6s MHz\n", name, str); | |
415 | } | |
416 | #endif /* CONFIG_PPC */ | |
417 | ||
418 | ||
419 | /* -------------------------------------------------------------------- */ | |
420 | ||
0d498393 WD |
421 | U_BOOT_CMD( |
422 | bdinfo, 1, 1, do_bdinfo, | |
8bde7f77 WD |
423 | "bdinfo - print Board Info structure\n", |
424 | NULL | |
425 | ); |