]> git.ipfire.org Git - people/ms/u-boot.git/blame - common/cmd_bdinfo.c
cmd_i2c.c: reworked subcommand handling
[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>
29
d87080b7 30DECLARE_GLOBAL_DATA_PTR;
8bde7f77 31
8bde7f77
WD
32static void print_num(const char *, ulong);
33
26e42cbd 34#if !defined(CONFIG_ARM) || defined(CONFIG_CMD_NET)
de2dff6f 35static void print_eth(int idx);
26e42cbd 36#endif
de2dff6f 37
8bde7f77 38#ifndef CONFIG_ARM /* PowerPC and other */
b57ca3e1 39static void print_lnum(const char *, u64);
8bde7f77
WD
40
41#ifdef CONFIG_PPC
42static void print_str(const char *, const char *);
43
44int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
45{
8bde7f77
WD
46 bd_t *bd = gd->bd;
47 char buf[32];
48
49#ifdef DEBUG
50 print_num ("bd address", (ulong)bd );
51#endif
52 print_num ("memstart", bd->bi_memstart );
b57ca3e1 53 print_lnum ("memsize", bd->bi_memsize );
8bde7f77
WD
54 print_num ("flashstart", bd->bi_flashstart );
55 print_num ("flashsize", bd->bi_flashsize );
56 print_num ("flashoffset", bd->bi_flashoffset );
57 print_num ("sramstart", bd->bi_sramstart );
58 print_num ("sramsize", bd->bi_sramsize );
97d80fc3
WD
59#if defined(CONFIG_5xx) || defined(CONFIG_8xx) || \
60 defined(CONFIG_8260) || defined(CONFIG_E500)
8bde7f77
WD
61 print_num ("immr_base", bd->bi_immr_base );
62#endif
63 print_num ("bootflags", bd->bi_bootflags );
97d80fc3 64#if defined(CONFIG_405GP) || defined(CONFIG_405CR) || \
9fea65a6 65 defined(CONFIG_405EP) || defined(CONFIG_XILINX_405) || \
6c5879f3 66 defined(CONFIG_440EP) || defined(CONFIG_440GR) || \
887e2ec9
SR
67 defined(CONFIG_440EPX) || defined(CONFIG_440GRX) || \
68 defined(CONFIG_440SP) || defined(CONFIG_440SPE)
8bde7f77 69 print_str ("procfreq", strmhz(buf, bd->bi_procfreq));
983fda83 70 print_str ("plb_busfreq", strmhz(buf, bd->bi_plb_busfreq));
9fea65a6 71#if defined(CONFIG_405GP) || defined(CONFIG_405EP) || defined(CONFIG_XILINX_405) || \
887e2ec9
SR
72 defined(CONFIG_440EP) || defined(CONFIG_440GR) || defined(CONFIG_440SPE) || \
73 defined(CONFIG_440EPX) || defined(CONFIG_440GRX)
983fda83 74 print_str ("pci_busfreq", strmhz(buf, bd->bi_pci_busfreq));
8bde7f77 75#endif
9fea65a6 76#else /* ! CONFIG_405GP, CONFIG_405CR, CONFIG_405EP, CONFIG_XILINX_405, CONFIG_440EP CONFIG_440GR */
9c4c5ae3 77#if defined(CONFIG_CPM2)
8bde7f77
WD
78 print_str ("vco", strmhz(buf, bd->bi_vco));
79 print_str ("sccfreq", strmhz(buf, bd->bi_sccfreq));
80 print_str ("brgfreq", strmhz(buf, bd->bi_brgfreq));
81#endif
82 print_str ("intfreq", strmhz(buf, bd->bi_intfreq));
9c4c5ae3 83#if defined(CONFIG_CPM2)
8bde7f77
WD
84 print_str ("cpmfreq", strmhz(buf, bd->bi_cpmfreq));
85#endif
86 print_str ("busfreq", strmhz(buf, bd->bi_busfreq));
9fea65a6 87#endif /* CONFIG_405GP, CONFIG_405CR, CONFIG_405EP, CONFIG_XILINX_405, CONFIG_440EP CONFIG_440GR */
983fda83
WD
88#if defined(CONFIG_MPC8220)
89 print_str ("inpfreq", strmhz(buf, bd->bi_inpfreq));
90 print_str ("flbfreq", strmhz(buf, bd->bi_flbfreq));
91 print_str ("pcifreq", strmhz(buf, bd->bi_pcifreq));
92 print_str ("vcofreq", strmhz(buf, bd->bi_vcofreq));
93 print_str ("pevfreq", strmhz(buf, bd->bi_pevfreq));
94#endif
03f5c550 95
de2dff6f 96 print_eth(0);
e2ffd59b 97#if defined(CONFIG_HAS_ETH1)
de2dff6f 98 print_eth(1);
03f5c550 99#endif
e2ffd59b 100#if defined(CONFIG_HAS_ETH2)
de2dff6f 101 print_eth(2);
42d1f039 102#endif
e2ffd59b 103#if defined(CONFIG_HAS_ETH3)
de2dff6f 104 print_eth(3);
03f5c550 105#endif
c68a05fe 106#if defined(CONFIG_HAS_ETH4)
de2dff6f 107 print_eth(4);
c68a05fe 108#endif
c68a05fe 109#if defined(CONFIG_HAS_ETH5)
de2dff6f 110 print_eth(5);
c68a05fe 111#endif
112
8bde7f77
WD
113#ifdef CONFIG_HERMES
114 print_str ("ethspeed", strmhz(buf, bd->bi_ethspeed));
115#endif
b6446b67
MF
116 printf ("IP addr = %pI4\n", &bd->bi_ip_addr);
117 printf ("baudrate = %6ld bps\n", bd->bi_baudrate );
4b99327a 118 print_num ("relocaddr", gd->relocaddr);
8bde7f77
WD
119 return 0;
120}
121
4a551709
WD
122#elif defined(CONFIG_NIOS) /* NIOS*/
123
124int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
125{
4a551709
WD
126 bd_t *bd = gd->bd;
127
128 print_num ("memstart", (ulong)bd->bi_memstart);
b57ca3e1 129 print_lnum ("memsize", (u64)bd->bi_memsize);
4a551709
WD
130 print_num ("flashstart", (ulong)bd->bi_flashstart);
131 print_num ("flashsize", (ulong)bd->bi_flashsize);
132 print_num ("flashoffset", (ulong)bd->bi_flashoffset);
133
de2dff6f 134 print_eth(0);
b6446b67
MF
135 printf ("ip_addr = %pI4\n", &bd->bi_ip_addr);
136 printf ("baudrate = %ld bps\n", bd->bi_baudrate);
4a551709
WD
137
138 return 0;
139}
140
5c952cf0
WD
141#elif defined(CONFIG_NIOS2) /* Nios-II */
142
143int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
144{
5c952cf0
WD
145 bd_t *bd = gd->bd;
146
147 print_num ("mem start", (ulong)bd->bi_memstart);
b57ca3e1 148 print_lnum ("mem size", (u64)bd->bi_memsize);
5c952cf0
WD
149 print_num ("flash start", (ulong)bd->bi_flashstart);
150 print_num ("flash size", (ulong)bd->bi_flashsize);
151 print_num ("flash offset", (ulong)bd->bi_flashoffset);
152
6d0f6bcf 153#if defined(CONFIG_SYS_SRAM_BASE)
5c952cf0
WD
154 print_num ("sram start", (ulong)bd->bi_sramstart);
155 print_num ("sram size", (ulong)bd->bi_sramsize);
156#endif
157
90253178 158#if defined(CONFIG_CMD_NET)
de2dff6f 159 print_eth(0);
b6446b67 160 printf ("ip_addr = %pI4\n", &bd->bi_ip_addr);
5c952cf0
WD
161#endif
162
b6446b67 163 printf ("baudrate = %ld bps\n", bd->bi_baudrate);
5c952cf0
WD
164
165 return 0;
166}
cfc67116
MS
167#elif defined(CONFIG_MICROBLAZE) /* ! PPC, which leaves Microblaze */
168
169int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
170{
cfc67116
MS
171 bd_t *bd = gd->bd;
172 print_num ("mem start ", (ulong)bd->bi_memstart);
b57ca3e1 173 print_lnum ("mem size ", (u64)bd->bi_memsize);
cfc67116
MS
174 print_num ("flash start ", (ulong)bd->bi_flashstart);
175 print_num ("flash size ", (ulong)bd->bi_flashsize);
176 print_num ("flash offset ", (ulong)bd->bi_flashoffset);
6d0f6bcf 177#if defined(CONFIG_SYS_SRAM_BASE)
cfc67116
MS
178 print_num ("sram start ", (ulong)bd->bi_sramstart);
179 print_num ("sram size ", (ulong)bd->bi_sramsize);
180#endif
90253178 181#if defined(CONFIG_CMD_NET)
de2dff6f 182 print_eth(0);
b6446b67 183 printf ("ip_addr = %pI4\n", &bd->bi_ip_addr);
cfc67116 184#endif
b6446b67 185 printf ("baudrate = %ld bps\n", (ulong)bd->bi_baudrate);
cfc67116
MS
186 return 0;
187}
4a551709 188
00ab32c8
DH
189#elif defined(CONFIG_SPARC) /* SPARC */
190int do_bdinfo(cmd_tbl_t * cmdtp, int flag, int argc, char *argv[])
191{
192 bd_t *bd = gd->bd;
00ab32c8
DH
193
194#ifdef DEBUG
195 print_num("bd address ", (ulong) bd);
196#endif
197 print_num("memstart ", bd->bi_memstart);
b57ca3e1 198 print_lnum("memsize ", bd->bi_memsize);
00ab32c8 199 print_num("flashstart ", bd->bi_flashstart);
6d0f6bcf 200 print_num("CONFIG_SYS_MONITOR_BASE ", CONFIG_SYS_MONITOR_BASE);
0e8d1586 201 print_num("CONFIG_ENV_ADDR ", CONFIG_ENV_ADDR);
6d0f6bcf
JCPV
202 printf("CONFIG_SYS_RELOC_MONITOR_BASE = 0x%lx (%d)\n", CONFIG_SYS_RELOC_MONITOR_BASE,
203 CONFIG_SYS_MONITOR_LEN);
204 printf("CONFIG_SYS_MALLOC_BASE = 0x%lx (%d)\n", CONFIG_SYS_MALLOC_BASE,
205 CONFIG_SYS_MALLOC_LEN);
206 printf("CONFIG_SYS_INIT_SP_OFFSET = 0x%lx (%d)\n", CONFIG_SYS_INIT_SP_OFFSET,
207 CONFIG_SYS_STACK_SIZE);
208 printf("CONFIG_SYS_PROM_OFFSET = 0x%lx (%d)\n", CONFIG_SYS_PROM_OFFSET,
209 CONFIG_SYS_PROM_SIZE);
210 printf("CONFIG_SYS_GBL_DATA_OFFSET = 0x%lx (%d)\n", CONFIG_SYS_GBL_DATA_OFFSET,
211 CONFIG_SYS_GBL_DATA_SIZE);
00ab32c8
DH
212
213#if defined(CONFIG_CMD_NET)
de2dff6f 214 print_eth(0);
b6446b67 215 printf("ip_addr = %pI4\n", &bd->bi_ip_addr);
00ab32c8 216#endif
b6446b67 217 printf("baudrate = %6ld bps\n", bd->bi_baudrate);
00ab32c8
DH
218 return 0;
219}
220
8e585f02 221#elif defined(CONFIG_M68K) /* M68K */
8ae158cd 222static void print_str(const char *, const char *);
8e585f02
TL
223
224int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
225{
8e585f02 226 bd_t *bd = gd->bd;
8ae158cd
TL
227 char buf[32];
228
8e585f02 229 print_num ("memstart", (ulong)bd->bi_memstart);
b57ca3e1 230 print_lnum ("memsize", (u64)bd->bi_memsize);
8e585f02
TL
231 print_num ("flashstart", (ulong)bd->bi_flashstart);
232 print_num ("flashsize", (ulong)bd->bi_flashsize);
233 print_num ("flashoffset", (ulong)bd->bi_flashoffset);
6d0f6bcf 234#if defined(CONFIG_SYS_INIT_RAM_ADDR)
8ae158cd
TL
235 print_num ("sramstart", (ulong)bd->bi_sramstart);
236 print_num ("sramsize", (ulong)bd->bi_sramsize);
8e585f02 237#endif
6d0f6bcf 238#if defined(CONFIG_SYS_MBAR)
8ae158cd 239 print_num ("mbar", bd->bi_mbar_base);
8e585f02 240#endif
ee73cc59 241 print_str ("cpufreq", strmhz(buf, bd->bi_intfreq));
8ae158cd
TL
242 print_str ("busfreq", strmhz(buf, bd->bi_busfreq));
243#ifdef CONFIG_PCI
244 print_str ("pcifreq", strmhz(buf, bd->bi_pcifreq));
245#endif
246#ifdef CONFIG_EXTRA_CLOCK
247 print_str ("flbfreq", strmhz(buf, bd->bi_flbfreq));
248 print_str ("inpfreq", strmhz(buf, bd->bi_inpfreq));
249 print_str ("vcofreq", strmhz(buf, bd->bi_vcofreq));
250#endif
26667b7f 251#if defined(CONFIG_CMD_NET)
de2dff6f 252 print_eth(0);
8e585f02 253#if defined(CONFIG_HAS_ETH1)
de2dff6f 254 print_eth(1);
8e585f02 255#endif
8e585f02 256#if defined(CONFIG_HAS_ETH2)
de2dff6f 257 print_eth(2);
8e585f02 258#endif
8e585f02 259#if defined(CONFIG_HAS_ETH3)
de2dff6f 260 print_eth(3);
8e585f02
TL
261#endif
262
b6446b67 263 printf ("ip_addr = %pI4\n", &bd->bi_ip_addr);
26667b7f 264#endif
b6446b67 265 printf ("baudrate = %ld bps\n", bd->bi_baudrate);
8e585f02
TL
266
267 return 0;
268}
269
8dc48d71 270#elif defined(CONFIG_BLACKFIN)
6dadc919 271static void print_str(const char *, const char *);
8dc48d71
MF
272
273int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
274{
8dc48d71 275 bd_t *bd = gd->bd;
6dadc919 276 char buf[32];
8dc48d71
MF
277
278 printf("U-Boot = %s\n", bd->bi_r_version);
279 printf("CPU = %s\n", bd->bi_cpu);
280 printf("Board = %s\n", bd->bi_board_name);
6dadc919
MF
281 print_str("VCO", strmhz(buf, bd->bi_vco));
282 print_str("CCLK", strmhz(buf, bd->bi_cclk));
283 print_str("SCLK", strmhz(buf, bd->bi_sclk));
8dc48d71
MF
284
285 print_num("boot_params", (ulong)bd->bi_boot_params);
286 print_num("memstart", (ulong)bd->bi_memstart);
b57ca3e1 287 print_lnum("memsize", (u64)bd->bi_memsize);
8dc48d71
MF
288 print_num("flashstart", (ulong)bd->bi_flashstart);
289 print_num("flashsize", (ulong)bd->bi_flashsize);
290 print_num("flashoffset", (ulong)bd->bi_flashoffset);
291
de2dff6f 292 print_eth(0);
b6446b67
MF
293 printf("ip_addr = %pI4\n", &bd->bi_ip_addr);
294 printf("baudrate = %d bps\n", bd->bi_baudrate);
8dc48d71
MF
295
296 return 0;
297}
298
8bde7f77
WD
299#else /* ! PPC, which leaves MIPS */
300
301int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
302{
8bde7f77
WD
303 bd_t *bd = gd->bd;
304
305 print_num ("boot_params", (ulong)bd->bi_boot_params);
306 print_num ("memstart", (ulong)bd->bi_memstart);
b57ca3e1 307 print_lnum ("memsize", (u64)bd->bi_memsize);
8bde7f77
WD
308 print_num ("flashstart", (ulong)bd->bi_flashstart);
309 print_num ("flashsize", (ulong)bd->bi_flashsize);
310 print_num ("flashoffset", (ulong)bd->bi_flashoffset);
311
de2dff6f 312 print_eth(0);
b6446b67
MF
313 printf ("ip_addr = %pI4\n", &bd->bi_ip_addr);
314 printf ("baudrate = %d bps\n", bd->bi_baudrate);
8bde7f77
WD
315
316 return 0;
317}
318#endif /* MIPS */
319
320#else /* ARM */
321
322int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
323{
8bde7f77
WD
324 int i;
325 bd_t *bd = gd->bd;
326
327 print_num ("arch_number", bd->bi_arch_number);
328 print_num ("env_t", (ulong)bd->bi_env);
329 print_num ("boot_params", (ulong)bd->bi_boot_params);
330
331 for (i=0; i<CONFIG_NR_DRAM_BANKS; ++i) {
332 print_num("DRAM bank", i);
333 print_num("-> start", bd->bi_dram[i].start);
334 print_num("-> size", bd->bi_dram[i].size);
335 }
336
a41dbbd9 337#if defined(CONFIG_CMD_NET)
de2dff6f 338 print_eth(0);
b6446b67 339 printf ("ip_addr = %pI4\n", &bd->bi_ip_addr);
a41dbbd9 340#endif
b6446b67 341 printf ("baudrate = %d bps\n", bd->bi_baudrate);
8bde7f77
WD
342
343 return 0;
344}
345
346#endif /* CONFIG_ARM XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX */
347
348static void print_num(const char *name, ulong value)
349{
350 printf ("%-12s= 0x%08lX\n", name, value);
351}
352
26e42cbd 353#if !defined(CONFIG_ARM) || defined(CONFIG_CMD_NET)
de2dff6f
MF
354static void print_eth(int idx)
355{
356 char name[10], *val;
357 if (idx)
358 sprintf(name, "eth%iaddr", idx);
359 else
360 strcpy(name, "ethaddr");
361 val = getenv(name);
362 if (!val)
363 val = "(not set)";
364 printf("%-12s= %s\n", name, val);
365}
26e42cbd 366#endif
de2dff6f 367
b57ca3e1
BB
368#ifndef CONFIG_ARM
369static void print_lnum(const char *name, u64 value)
370{
371 printf ("%-12s= 0x%.8llX\n", name, value);
372}
373#endif
374
6dadc919 375#if defined(CONFIG_PPC) || defined(CONFIG_M68K) || defined(CONFIG_BLACKFIN)
8bde7f77
WD
376static void print_str(const char *name, const char *str)
377{
378 printf ("%-12s= %6s MHz\n", name, str);
379}
380#endif /* CONFIG_PPC */
381
382
383/* -------------------------------------------------------------------- */
384
0d498393
WD
385U_BOOT_CMD(
386 bdinfo, 1, 1, do_bdinfo,
2fb2604d 387 "print Board Info structure",
a89c33db 388 ""
8bde7f77 389);