]> git.ipfire.org Git - people/ms/u-boot.git/blame - common/cmd_bdinfo.c
Merge branch 'master' of git://www.denx.de/git/u-boot-mpc85xx
[people/ms/u-boot.git] / common / cmd_bdinfo.c
CommitLineData
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 31DECLARE_GLOBAL_DATA_PTR;
8bde7f77 32
8bde7f77
WD
33static void print_num(const char *, ulong);
34
35#ifndef CONFIG_ARM /* PowerPC and other */
36
37#ifdef CONFIG_PPC
38static void print_str(const char *, const char *);
39
40int 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
129int 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
153int 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
186int 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
8e585f02 211#elif defined(CONFIG_M68K) /* M68K */
8ae158cd 212static void print_str(const char *, const char *);
8e585f02
TL
213
214int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
215{
216 int i;
217 bd_t *bd = gd->bd;
8ae158cd
TL
218 char buf[32];
219
8e585f02
TL
220 print_num ("memstart", (ulong)bd->bi_memstart);
221 print_num ("memsize", (ulong)bd->bi_memsize);
222 print_num ("flashstart", (ulong)bd->bi_flashstart);
223 print_num ("flashsize", (ulong)bd->bi_flashsize);
224 print_num ("flashoffset", (ulong)bd->bi_flashoffset);
225#if defined(CFG_INIT_RAM_ADDR)
8ae158cd
TL
226 print_num ("sramstart", (ulong)bd->bi_sramstart);
227 print_num ("sramsize", (ulong)bd->bi_sramsize);
8e585f02
TL
228#endif
229#if defined(CFG_MBAR)
8ae158cd 230 print_num ("mbar", bd->bi_mbar_base);
8e585f02 231#endif
8ae158cd
TL
232 print_str ("busfreq", strmhz(buf, bd->bi_busfreq));
233#ifdef CONFIG_PCI
234 print_str ("pcifreq", strmhz(buf, bd->bi_pcifreq));
235#endif
236#ifdef CONFIG_EXTRA_CLOCK
237 print_str ("flbfreq", strmhz(buf, bd->bi_flbfreq));
238 print_str ("inpfreq", strmhz(buf, bd->bi_inpfreq));
239 print_str ("vcofreq", strmhz(buf, bd->bi_vcofreq));
240#endif
26667b7f 241#if defined(CONFIG_CMD_NET)
8e585f02
TL
242 puts ("ethaddr =");
243 for (i=0; i<6; ++i) {
244 printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]);
245 }
246
247#if defined(CONFIG_HAS_ETH1)
248 puts ("\neth1addr =");
249 for (i=0; i<6; ++i) {
250 printf ("%c%02X", i ? ':' : ' ', bd->bi_enet1addr[i]);
251 }
252#endif
253
254#if defined(CONFIG_HAS_ETH2)
ab77bc54
TL
255 puts ("\neth2addr =");
256 for (i=0; i<6; ++i) {
8e585f02
TL
257 printf ("%c%02X", i ? ':' : ' ', bd->bi_enet2addr[i]);
258 }
259#endif
260
261#if defined(CONFIG_HAS_ETH3)
ab77bc54
TL
262 puts ("\neth3addr =");
263 for (i=0; i<6; ++i) {
8e585f02
TL
264 printf ("%c%02X", i ? ':' : ' ', bd->bi_enet3addr[i]);
265 }
266#endif
267
268 puts ("\nip_addr = ");
269 print_IPaddr (bd->bi_ip_addr);
26667b7f 270#endif
8e585f02
TL
271 printf ("\nbaudrate = %d bps\n", bd->bi_baudrate);
272
273 return 0;
274}
275
8dc48d71
MF
276#elif defined(CONFIG_BLACKFIN)
277
278int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
279{
280 int i;
281 bd_t *bd = gd->bd;
282
283 printf("U-Boot = %s\n", bd->bi_r_version);
284 printf("CPU = %s\n", bd->bi_cpu);
285 printf("Board = %s\n", bd->bi_board_name);
286 printf("VCO = %lu MHz\n", bd->bi_vco / 1000000);
287 printf("CCLK = %lu MHz\n", bd->bi_cclk / 1000000);
288 printf("SCLK = %lu MHz\n", bd->bi_sclk / 1000000);
289
290 print_num("boot_params", (ulong)bd->bi_boot_params);
291 print_num("memstart", (ulong)bd->bi_memstart);
292 print_num("memsize", (ulong)bd->bi_memsize);
293 print_num("flashstart", (ulong)bd->bi_flashstart);
294 print_num("flashsize", (ulong)bd->bi_flashsize);
295 print_num("flashoffset", (ulong)bd->bi_flashoffset);
296
297 puts("ethaddr =");
298 for (i = 0; i < 6; ++i)
299 printf("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]);
300 puts("\nip_addr = ");
301 print_IPaddr(bd->bi_ip_addr);
302 printf("\nbaudrate = %d bps\n", bd->bi_baudrate);
303
304 return 0;
305}
306
8bde7f77
WD
307#else /* ! PPC, which leaves MIPS */
308
309int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
310{
8bde7f77
WD
311 int i;
312 bd_t *bd = gd->bd;
313
314 print_num ("boot_params", (ulong)bd->bi_boot_params);
315 print_num ("memstart", (ulong)bd->bi_memstart);
316 print_num ("memsize", (ulong)bd->bi_memsize);
317 print_num ("flashstart", (ulong)bd->bi_flashstart);
318 print_num ("flashsize", (ulong)bd->bi_flashsize);
319 print_num ("flashoffset", (ulong)bd->bi_flashoffset);
320
4b9206ed 321 puts ("ethaddr =");
8bde7f77
WD
322 for (i=0; i<6; ++i) {
323 printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]);
324 }
4b9206ed 325 puts ("\nip_addr = ");
8bde7f77
WD
326 print_IPaddr (bd->bi_ip_addr);
327 printf ("\nbaudrate = %d bps\n", bd->bi_baudrate);
328
329 return 0;
330}
331#endif /* MIPS */
332
333#else /* ARM */
334
335int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
336{
8bde7f77
WD
337 int i;
338 bd_t *bd = gd->bd;
339
340 print_num ("arch_number", bd->bi_arch_number);
341 print_num ("env_t", (ulong)bd->bi_env);
342 print_num ("boot_params", (ulong)bd->bi_boot_params);
343
344 for (i=0; i<CONFIG_NR_DRAM_BANKS; ++i) {
345 print_num("DRAM bank", i);
346 print_num("-> start", bd->bi_dram[i].start);
347 print_num("-> size", bd->bi_dram[i].size);
348 }
349
a41dbbd9 350#if defined(CONFIG_CMD_NET)
4b9206ed 351 puts ("ethaddr =");
8bde7f77
WD
352 for (i=0; i<6; ++i) {
353 printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]);
354 }
4b9206ed 355 puts ( "\n"
8bde7f77
WD
356 "ip_addr = ");
357 print_IPaddr (bd->bi_ip_addr);
a41dbbd9 358#endif
b79a11cc 359 printf ("\n"
8bde7f77
WD
360 "baudrate = %d bps\n", bd->bi_baudrate);
361
362 return 0;
363}
364
365#endif /* CONFIG_ARM XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX */
366
367static void print_num(const char *name, ulong value)
368{
369 printf ("%-12s= 0x%08lX\n", name, value);
370}
371
8ae158cd 372#if defined(CONFIG_PPC) || defined(CONFIG_M68K)
8bde7f77
WD
373static void print_str(const char *name, const char *str)
374{
375 printf ("%-12s= %6s MHz\n", name, str);
376}
377#endif /* CONFIG_PPC */
378
379
380/* -------------------------------------------------------------------- */
381
0d498393
WD
382U_BOOT_CMD(
383 bdinfo, 1, 1, do_bdinfo,
8bde7f77
WD
384 "bdinfo - print Board Info structure\n",
385 NULL
386);