blob: f0cdaf302260f3a0b5301f545ee941c61af043d0 [file] [log] [blame]
wdenk57b2d802003-06-27 21:31:46 +00001/*
2 * (C) Copyright 2003
3 * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4 *
Wolfgang Denkd79de1d2013-07-08 09:37:19 +02005 * SPDX-License-Identifier: GPL-2.0+
wdenk57b2d802003-06-27 21:31:46 +00006 */
7
8/*
9 * Boot support
10 */
11#include <common.h>
12#include <command.h>
Mike Frysinger1a8d6582011-12-04 17:45:22 +000013#include <linux/compiler.h>
wdenk57b2d802003-06-27 21:31:46 +000014
Wolfgang Denk6405a152006-03-31 18:32:53 +020015DECLARE_GLOBAL_DATA_PTR;
wdenk57b2d802003-06-27 21:31:46 +000016
Mike Frysinger1a8d6582011-12-04 17:45:22 +000017__maybe_unused
18static void print_num(const char *name, ulong value)
19{
20 printf("%-12s= 0x%08lX\n", name, value);
21}
wdenk57b2d802003-06-27 21:31:46 +000022
Simon Glass1a0f81d2011-12-06 13:37:17 +000023__maybe_unused
Mike Frysinger1a8d6582011-12-04 17:45:22 +000024static void print_eth(int idx)
25{
26 char name[10], *val;
27 if (idx)
28 sprintf(name, "eth%iaddr", idx);
29 else
30 strcpy(name, "ethaddr");
31 val = getenv(name);
32 if (!val)
33 val = "(not set)";
34 printf("%-12s= %s\n", name, val);
35}
Mike Frysinger9335cc72009-02-11 18:50:10 -050036
Joe Hershbergerc7eceaf2015-03-22 17:09:10 -050037#ifndef CONFIG_DM_ETH
Mike Frysinger1a8d6582011-12-04 17:45:22 +000038__maybe_unused
Michal Simekc4c248f2013-01-23 12:21:18 +010039static void print_eths(void)
40{
41 struct eth_device *dev;
42 int i = 0;
43
44 do {
45 dev = eth_get_dev_by_index(i);
46 if (dev) {
47 printf("eth%dname = %s\n", i, dev->name);
48 print_eth(i);
49 i++;
50 }
51 } while (dev);
52
53 printf("current eth = %s\n", eth_get_name());
54 printf("ip_addr = %s\n", getenv("ipaddr"));
55}
Joe Hershbergerc7eceaf2015-03-22 17:09:10 -050056#endif
Michal Simekc4c248f2013-01-23 12:21:18 +010057
58__maybe_unused
Daniel Schwierzeck0fdcf1d2012-10-03 08:36:11 +000059static void print_lnum(const char *name, unsigned long long value)
Mike Frysinger1a8d6582011-12-04 17:45:22 +000060{
61 printf("%-12s= 0x%.8llX\n", name, value);
62}
63
64__maybe_unused
65static void print_mhz(const char *name, unsigned long hz)
66{
67 char buf[32];
68
69 printf("%-12s= %6s MHz\n", name, strmhz(buf, hz));
70}
wdenk57b2d802003-06-27 21:31:46 +000071
Max Filippoved8b0672016-07-28 03:57:18 +030072
73static inline void print_bi_boot_params(const bd_t *bd)
74{
75 print_num("boot_params", (ulong)bd->bi_boot_params);
76}
77
Reinhard Meyer0f8337b2010-06-06 19:01:59 +020078#if defined(CONFIG_PPC)
York Sunb0f347c2013-05-14 08:06:39 +000079void __weak board_detail(void)
80{
81 /* Please define boot_detail() for your platform */
82}
wdenk57b2d802003-06-27 21:31:46 +000083
Macpaul Lindfd70642011-04-27 16:28:35 +000084int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
wdenk57b2d802003-06-27 21:31:46 +000085{
wdenk57b2d802003-06-27 21:31:46 +000086 bd_t *bd = gd->bd;
wdenk57b2d802003-06-27 21:31:46 +000087
88#ifdef DEBUG
Macpaul Lindfd70642011-04-27 16:28:35 +000089 print_num("bd address", (ulong)bd);
wdenk57b2d802003-06-27 21:31:46 +000090#endif
Macpaul Lindfd70642011-04-27 16:28:35 +000091 print_num("memstart", bd->bi_memstart);
92 print_lnum("memsize", bd->bi_memsize);
93 print_num("flashstart", bd->bi_flashstart);
94 print_num("flashsize", bd->bi_flashsize);
95 print_num("flashoffset", bd->bi_flashoffset);
96 print_num("sramstart", bd->bi_sramstart);
97 print_num("sramsize", bd->bi_sramsize);
98#if defined(CONFIG_5xx) || defined(CONFIG_8xx) || \
Masahiro Yamada5a2bf982014-03-05 17:40:10 +090099 defined(CONFIG_MPC8260) || defined(CONFIG_E500)
Macpaul Lindfd70642011-04-27 16:28:35 +0000100 print_num("immr_base", bd->bi_immr_base);
wdenk57b2d802003-06-27 21:31:46 +0000101#endif
Macpaul Lindfd70642011-04-27 16:28:35 +0000102 print_num("bootflags", bd->bi_bootflags);
Matthias Fuchse54a67f2013-08-07 12:10:38 +0200103#if defined(CONFIG_405EP) || \
Macpaul Lindfd70642011-04-27 16:28:35 +0000104 defined(CONFIG_405GP) || \
105 defined(CONFIG_440EP) || defined(CONFIG_440EPX) || \
106 defined(CONFIG_440GR) || defined(CONFIG_440GRX) || \
107 defined(CONFIG_440SP) || defined(CONFIG_440SPE) || \
108 defined(CONFIG_XILINX_405)
Timur Tabi7b480702011-10-05 17:08:07 -0500109 print_mhz("procfreq", bd->bi_procfreq);
110 print_mhz("plb_busfreq", bd->bi_plb_busfreq);
Macpaul Lindfd70642011-04-27 16:28:35 +0000111#if defined(CONFIG_405EP) || defined(CONFIG_405GP) || \
112 defined(CONFIG_440EP) || defined(CONFIG_440EPX) || \
113 defined(CONFIG_440GR) || defined(CONFIG_440GRX) || \
114 defined(CONFIG_440SPE) || defined(CONFIG_XILINX_405)
Timur Tabi7b480702011-10-05 17:08:07 -0500115 print_mhz("pci_busfreq", bd->bi_pci_busfreq);
wdenk57b2d802003-06-27 21:31:46 +0000116#endif
Matthias Fuchse54a67f2013-08-07 12:10:38 +0200117#else /* ! CONFIG_405GP, CONFIG_405EP, CONFIG_XILINX_405, CONFIG_440EP CONFIG_440GR */
Jon Loeligerf5ad3782005-07-23 10:37:35 -0500118#if defined(CONFIG_CPM2)
Timur Tabi7b480702011-10-05 17:08:07 -0500119 print_mhz("vco", bd->bi_vco);
120 print_mhz("sccfreq", bd->bi_sccfreq);
121 print_mhz("brgfreq", bd->bi_brgfreq);
wdenk57b2d802003-06-27 21:31:46 +0000122#endif
Timur Tabi7b480702011-10-05 17:08:07 -0500123 print_mhz("intfreq", bd->bi_intfreq);
Jon Loeligerf5ad3782005-07-23 10:37:35 -0500124#if defined(CONFIG_CPM2)
Timur Tabi7b480702011-10-05 17:08:07 -0500125 print_mhz("cpmfreq", bd->bi_cpmfreq);
wdenk57b2d802003-06-27 21:31:46 +0000126#endif
Timur Tabi7b480702011-10-05 17:08:07 -0500127 print_mhz("busfreq", bd->bi_busfreq);
Matthias Fuchse54a67f2013-08-07 12:10:38 +0200128#endif /* CONFIG_405GP, CONFIG_405EP, CONFIG_XILINX_405, CONFIG_440EP CONFIG_440GR */
wdenk0aeb8532004-10-10 21:21:55 +0000129
Timur Tabi1587daa2012-03-15 11:42:26 +0000130#ifdef CONFIG_ENABLE_36BIT_PHYS
131#ifdef CONFIG_PHYS_64BIT
132 puts("addressing = 36-bit\n");
133#else
134 puts("addressing = 32-bit\n");
135#endif
136#endif
137
Mike Frysinger9335cc72009-02-11 18:50:10 -0500138 print_eth(0);
wdenk54070ab2004-12-31 09:32:47 +0000139#if defined(CONFIG_HAS_ETH1)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500140 print_eth(1);
wdenk0aeb8532004-10-10 21:21:55 +0000141#endif
wdenk54070ab2004-12-31 09:32:47 +0000142#if defined(CONFIG_HAS_ETH2)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500143 print_eth(2);
wdenk9c53f402003-10-15 23:53:47 +0000144#endif
wdenk54070ab2004-12-31 09:32:47 +0000145#if defined(CONFIG_HAS_ETH3)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500146 print_eth(3);
wdenk0aeb8532004-10-10 21:21:55 +0000147#endif
richardretanubune5167f12008-09-29 18:28:23 -0400148#if defined(CONFIG_HAS_ETH4)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500149 print_eth(4);
richardretanubune5167f12008-09-29 18:28:23 -0400150#endif
richardretanubune5167f12008-09-29 18:28:23 -0400151#if defined(CONFIG_HAS_ETH5)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500152 print_eth(5);
richardretanubune5167f12008-09-29 18:28:23 -0400153#endif
154
Mike Frysinger04b63f22012-04-04 18:53:40 +0000155 printf("IP addr = %s\n", getenv("ipaddr"));
Masahiro Yamada197c7202014-04-04 20:09:58 +0900156 printf("baudrate = %6u bps\n", gd->baudrate);
Macpaul Lindfd70642011-04-27 16:28:35 +0000157 print_num("relocaddr", gd->relocaddr);
York Sunb0f347c2013-05-14 08:06:39 +0000158 board_detail();
wdenk57b2d802003-06-27 21:31:46 +0000159 return 0;
160}
161
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200162#elif defined(CONFIG_NIOS2)
wdenkef3386f2004-10-10 21:27:30 +0000163
Macpaul Lindfd70642011-04-27 16:28:35 +0000164int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
wdenkef3386f2004-10-10 21:27:30 +0000165{
Thomas Chou41d02bb2015-10-27 10:21:06 +0800166 int i;
wdenkef3386f2004-10-10 21:27:30 +0000167 bd_t *bd = gd->bd;
168
Thomas Chou41d02bb2015-10-27 10:21:06 +0800169 for (i = 0; i < CONFIG_NR_DRAM_BANKS; ++i) {
170 print_num("DRAM bank", i);
171 print_num("-> start", bd->bi_dram[i].start);
172 print_num("-> size", bd->bi_dram[i].size);
173 }
174
Macpaul Lindfd70642011-04-27 16:28:35 +0000175 print_num("flash start", (ulong)bd->bi_flashstart);
176 print_num("flash size", (ulong)bd->bi_flashsize);
177 print_num("flash offset", (ulong)bd->bi_flashoffset);
wdenkef3386f2004-10-10 21:27:30 +0000178
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200179#if defined(CONFIG_SYS_SRAM_BASE)
wdenkef3386f2004-10-10 21:27:30 +0000180 print_num ("sram start", (ulong)bd->bi_sramstart);
181 print_num ("sram size", (ulong)bd->bi_sramsize);
182#endif
183
Jon Loeligerd704d912007-07-10 11:02:44 -0500184#if defined(CONFIG_CMD_NET)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500185 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000186 printf("ip_addr = %s\n", getenv("ipaddr"));
wdenkef3386f2004-10-10 21:27:30 +0000187#endif
188
Masahiro Yamada197c7202014-04-04 20:09:58 +0900189 printf("baudrate = %u bps\n", gd->baudrate);
wdenkef3386f2004-10-10 21:27:30 +0000190
191 return 0;
192}
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200193
194#elif defined(CONFIG_MICROBLAZE)
Michal Simek922ce202007-03-11 13:48:24 +0100195
Macpaul Lindfd70642011-04-27 16:28:35 +0000196int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
Michal Simek922ce202007-03-11 13:48:24 +0100197{
Michal Simek922ce202007-03-11 13:48:24 +0100198 bd_t *bd = gd->bd;
Michal Simek65e915c2014-05-08 16:08:44 +0200199 int i;
200
201 for (i = 0; i < CONFIG_NR_DRAM_BANKS; ++i) {
202 print_num("DRAM bank", i);
203 print_num("-> start", bd->bi_dram[i].start);
204 print_num("-> size", bd->bi_dram[i].size);
205 }
206
Macpaul Lindfd70642011-04-27 16:28:35 +0000207 print_num("flash start ", (ulong)bd->bi_flashstart);
208 print_num("flash size ", (ulong)bd->bi_flashsize);
209 print_num("flash offset ", (ulong)bd->bi_flashoffset);
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200210#if defined(CONFIG_SYS_SRAM_BASE)
Macpaul Lindfd70642011-04-27 16:28:35 +0000211 print_num("sram start ", (ulong)bd->bi_sramstart);
212 print_num("sram size ", (ulong)bd->bi_sramsize);
Michal Simek922ce202007-03-11 13:48:24 +0100213#endif
Michal Simekf2c06d42015-12-08 15:39:24 +0100214#if defined(CONFIG_CMD_NET) && !defined(CONFIG_DM_ETH)
Michal Simekc4c248f2013-01-23 12:21:18 +0100215 print_eths();
Michal Simek922ce202007-03-11 13:48:24 +0100216#endif
Masahiro Yamada197c7202014-04-04 20:09:58 +0900217 printf("baudrate = %u bps\n", gd->baudrate);
Michal Simek65e915c2014-05-08 16:08:44 +0200218 print_num("relocaddr", gd->relocaddr);
219 print_num("reloc off", gd->reloc_off);
Michal Simek04244642015-01-27 15:41:08 +0100220 print_num("fdt_blob", (ulong)gd->fdt_blob);
221 print_num("new_fdt", (ulong)gd->new_fdt);
222 print_num("fdt_size", (ulong)gd->fdt_size);
Michal Simek65e915c2014-05-08 16:08:44 +0200223
Michal Simek922ce202007-03-11 13:48:24 +0100224 return 0;
225}
wdenk60164a82003-10-08 23:26:14 +0000226
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200227#elif defined(CONFIG_SPARC)
228
Wolfgang Denk6262d0212010-06-28 22:00:46 +0200229int do_bdinfo(cmd_tbl_t * cmdtp, int flag, int argc, char * const argv[])
Daniel Hellstrom83eb3cc2008-03-26 22:36:03 +0100230{
231 bd_t *bd = gd->bd;
Daniel Hellstrom83eb3cc2008-03-26 22:36:03 +0100232
233#ifdef DEBUG
234 print_num("bd address ", (ulong) bd);
235#endif
236 print_num("memstart ", bd->bi_memstart);
Becky Brucea36601e2008-06-09 20:37:16 -0500237 print_lnum("memsize ", bd->bi_memsize);
Daniel Hellstrom83eb3cc2008-03-26 22:36:03 +0100238 print_num("flashstart ", bd->bi_flashstart);
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200239 print_num("CONFIG_SYS_MONITOR_BASE ", CONFIG_SYS_MONITOR_BASE);
Jean-Christophe PLAGNIOL-VILLARD7e1cda62008-09-10 22:48:06 +0200240 print_num("CONFIG_ENV_ADDR ", CONFIG_ENV_ADDR);
Marek Vasut292af862012-07-27 08:04:33 +0000241 printf("CONFIG_SYS_RELOC_MONITOR_BASE = 0x%x (%d)\n", CONFIG_SYS_RELOC_MONITOR_BASE,
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200242 CONFIG_SYS_MONITOR_LEN);
Marek Vasut292af862012-07-27 08:04:33 +0000243 printf("CONFIG_SYS_MALLOC_BASE = 0x%x (%d)\n", CONFIG_SYS_MALLOC_BASE,
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200244 CONFIG_SYS_MALLOC_LEN);
Marek Vasut292af862012-07-27 08:04:33 +0000245 printf("CONFIG_SYS_INIT_SP_OFFSET = 0x%x (%d)\n", CONFIG_SYS_INIT_SP_OFFSET,
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200246 CONFIG_SYS_STACK_SIZE);
Marek Vasut292af862012-07-27 08:04:33 +0000247 printf("CONFIG_SYS_PROM_OFFSET = 0x%x (%d)\n", CONFIG_SYS_PROM_OFFSET,
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200248 CONFIG_SYS_PROM_SIZE);
Marek Vasut292af862012-07-27 08:04:33 +0000249 printf("CONFIG_SYS_GBL_DATA_OFFSET = 0x%x (%d)\n", CONFIG_SYS_GBL_DATA_OFFSET,
Wolfgang Denk0191e472010-10-26 14:34:52 +0200250 GENERATED_GBL_DATA_SIZE);
Daniel Hellstrom83eb3cc2008-03-26 22:36:03 +0100251
252#if defined(CONFIG_CMD_NET)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500253 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000254 printf("ip_addr = %s\n", getenv("ipaddr"));
Daniel Hellstrom83eb3cc2008-03-26 22:36:03 +0100255#endif
Masahiro Yamada197c7202014-04-04 20:09:58 +0900256 printf("baudrate = %6u bps\n", gd->baudrate);
Daniel Hellstrom83eb3cc2008-03-26 22:36:03 +0100257 return 0;
258}
259
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200260#elif defined(CONFIG_M68K)
261
Macpaul Lindfd70642011-04-27 16:28:35 +0000262int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
TsiChung Liewf6afe722007-06-18 13:50:13 -0500263{
TsiChung Liewf6afe722007-06-18 13:50:13 -0500264 bd_t *bd = gd->bd;
TsiChungLiewfc3ca3b2007-08-16 15:05:11 -0500265
Macpaul Lindfd70642011-04-27 16:28:35 +0000266 print_num("memstart", (ulong)bd->bi_memstart);
267 print_lnum("memsize", (u64)bd->bi_memsize);
268 print_num("flashstart", (ulong)bd->bi_flashstart);
269 print_num("flashsize", (ulong)bd->bi_flashsize);
270 print_num("flashoffset", (ulong)bd->bi_flashoffset);
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200271#if defined(CONFIG_SYS_INIT_RAM_ADDR)
Macpaul Lindfd70642011-04-27 16:28:35 +0000272 print_num("sramstart", (ulong)bd->bi_sramstart);
273 print_num("sramsize", (ulong)bd->bi_sramsize);
TsiChung Liewf6afe722007-06-18 13:50:13 -0500274#endif
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200275#if defined(CONFIG_SYS_MBAR)
Macpaul Lindfd70642011-04-27 16:28:35 +0000276 print_num("mbar", bd->bi_mbar_base);
TsiChungLiewfc3ca3b2007-08-16 15:05:11 -0500277#endif
Timur Tabi7b480702011-10-05 17:08:07 -0500278 print_mhz("cpufreq", bd->bi_intfreq);
279 print_mhz("busfreq", bd->bi_busfreq);
TsiChungLiewfc3ca3b2007-08-16 15:05:11 -0500280#ifdef CONFIG_PCI
Timur Tabi7b480702011-10-05 17:08:07 -0500281 print_mhz("pcifreq", bd->bi_pcifreq);
TsiChung Liewf6afe722007-06-18 13:50:13 -0500282#endif
TsiChungLiewfc3ca3b2007-08-16 15:05:11 -0500283#ifdef CONFIG_EXTRA_CLOCK
Timur Tabi7b480702011-10-05 17:08:07 -0500284 print_mhz("flbfreq", bd->bi_flbfreq);
285 print_mhz("inpfreq", bd->bi_inpfreq);
286 print_mhz("vcofreq", bd->bi_vcofreq);
TsiChungLiewfc3ca3b2007-08-16 15:05:11 -0500287#endif
Stefan Roeseaddc4472007-08-18 14:37:52 +0200288#if defined(CONFIG_CMD_NET)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500289 print_eth(0);
TsiChung Liewf6afe722007-06-18 13:50:13 -0500290#if defined(CONFIG_HAS_ETH1)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500291 print_eth(1);
TsiChung Liewf6afe722007-06-18 13:50:13 -0500292#endif
TsiChung Liewf6afe722007-06-18 13:50:13 -0500293#if defined(CONFIG_HAS_ETH2)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500294 print_eth(2);
TsiChung Liewf6afe722007-06-18 13:50:13 -0500295#endif
TsiChung Liewf6afe722007-06-18 13:50:13 -0500296#if defined(CONFIG_HAS_ETH3)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500297 print_eth(3);
TsiChung Liewf6afe722007-06-18 13:50:13 -0500298#endif
299
Mike Frysinger04b63f22012-04-04 18:53:40 +0000300 printf("ip_addr = %s\n", getenv("ipaddr"));
Stefan Roeseaddc4472007-08-18 14:37:52 +0200301#endif
Masahiro Yamada197c7202014-04-04 20:09:58 +0900302 printf("baudrate = %u bps\n", gd->baudrate);
TsiChung Liewf6afe722007-06-18 13:50:13 -0500303
304 return 0;
305}
306
Mike Frysingerf443d3c2008-02-04 19:26:55 -0500307#elif defined(CONFIG_BLACKFIN)
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200308
Wolfgang Denk6262d0212010-06-28 22:00:46 +0200309int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
Mike Frysingerf443d3c2008-02-04 19:26:55 -0500310{
Mike Frysingerf443d3c2008-02-04 19:26:55 -0500311 bd_t *bd = gd->bd;
312
313 printf("U-Boot = %s\n", bd->bi_r_version);
314 printf("CPU = %s\n", bd->bi_cpu);
315 printf("Board = %s\n", bd->bi_board_name);
Timur Tabi7b480702011-10-05 17:08:07 -0500316 print_mhz("VCO", bd->bi_vco);
317 print_mhz("CCLK", bd->bi_cclk);
318 print_mhz("SCLK", bd->bi_sclk);
Mike Frysingerf443d3c2008-02-04 19:26:55 -0500319
Max Filippoved8b0672016-07-28 03:57:18 +0300320 print_bi_boot_params(bd);
Macpaul Lindfd70642011-04-27 16:28:35 +0000321 print_num("memstart", (ulong)bd->bi_memstart);
322 print_lnum("memsize", (u64)bd->bi_memsize);
323 print_num("flashstart", (ulong)bd->bi_flashstart);
324 print_num("flashsize", (ulong)bd->bi_flashsize);
325 print_num("flashoffset", (ulong)bd->bi_flashoffset);
Mike Frysingerf443d3c2008-02-04 19:26:55 -0500326
Mike Frysinger9335cc72009-02-11 18:50:10 -0500327 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000328 printf("ip_addr = %s\n", getenv("ipaddr"));
Masahiro Yamada197c7202014-04-04 20:09:58 +0900329 printf("baudrate = %u bps\n", gd->baudrate);
Mike Frysingerf443d3c2008-02-04 19:26:55 -0500330
331 return 0;
332}
333
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200334#elif defined(CONFIG_MIPS)
wdenk57b2d802003-06-27 21:31:46 +0000335
Macpaul Lindfd70642011-04-27 16:28:35 +0000336int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
wdenk57b2d802003-06-27 21:31:46 +0000337{
wdenk57b2d802003-06-27 21:31:46 +0000338 bd_t *bd = gd->bd;
339
Max Filippoved8b0672016-07-28 03:57:18 +0300340 print_bi_boot_params(bd);
Macpaul Lindfd70642011-04-27 16:28:35 +0000341 print_num("memstart", (ulong)bd->bi_memstart);
342 print_lnum("memsize", (u64)bd->bi_memsize);
343 print_num("flashstart", (ulong)bd->bi_flashstart);
344 print_num("flashsize", (ulong)bd->bi_flashsize);
345 print_num("flashoffset", (ulong)bd->bi_flashoffset);
wdenk57b2d802003-06-27 21:31:46 +0000346
Mike Frysinger9335cc72009-02-11 18:50:10 -0500347 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000348 printf("ip_addr = %s\n", getenv("ipaddr"));
Masahiro Yamada197c7202014-04-04 20:09:58 +0900349 printf("baudrate = %u bps\n", gd->baudrate);
developerc1ca7102016-03-31 12:51:20 +0100350 print_num("relocaddr", gd->relocaddr);
351 print_num("reloc off", gd->reloc_off);
wdenk57b2d802003-06-27 21:31:46 +0000352
353 return 0;
354}
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200355
356#elif defined(CONFIG_AVR32)
357
Macpaul Lindfd70642011-04-27 16:28:35 +0000358int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200359{
360 bd_t *bd = gd->bd;
361
Max Filippoved8b0672016-07-28 03:57:18 +0300362 print_bi_boot_params(bd);
Andreas Bießmannc1d09172015-02-06 23:06:48 +0100363 print_num("memstart", (ulong)bd->bi_dram[0].start);
364 print_lnum("memsize", (u64)bd->bi_dram[0].size);
Macpaul Lindfd70642011-04-27 16:28:35 +0000365 print_num("flashstart", (ulong)bd->bi_flashstart);
366 print_num("flashsize", (ulong)bd->bi_flashsize);
367 print_num("flashoffset", (ulong)bd->bi_flashoffset);
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200368
369 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000370 printf("ip_addr = %s\n", getenv("ipaddr"));
Masahiro Yamada197c7202014-04-04 20:09:58 +0900371 printf("baudrate = %u bps\n", gd->baudrate);
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200372
373 return 0;
374}
wdenk57b2d802003-06-27 21:31:46 +0000375
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200376#elif defined(CONFIG_ARM)
wdenk57b2d802003-06-27 21:31:46 +0000377
Jeroen Hofsteef384fbf2014-06-23 00:22:08 +0200378static int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc,
379 char * const argv[])
wdenk57b2d802003-06-27 21:31:46 +0000380{
wdenk57b2d802003-06-27 21:31:46 +0000381 int i;
382 bd_t *bd = gd->bd;
383
Macpaul Lindfd70642011-04-27 16:28:35 +0000384 print_num("arch_number", bd->bi_arch_number);
Max Filippoved8b0672016-07-28 03:57:18 +0300385 print_bi_boot_params(bd);
wdenk57b2d802003-06-27 21:31:46 +0000386
Macpaul Lindfd70642011-04-27 16:28:35 +0000387 for (i = 0; i < CONFIG_NR_DRAM_BANKS; ++i) {
wdenk57b2d802003-06-27 21:31:46 +0000388 print_num("DRAM bank", i);
389 print_num("-> start", bd->bi_dram[i].start);
390 print_num("-> size", bd->bi_dram[i].size);
391 }
392
York Sun5d286cd2015-12-04 11:57:07 -0800393#ifdef CONFIG_SYS_MEM_RESERVE_SECURE
York Sun1ef95cc2016-06-24 16:46:18 -0700394 if (gd->arch.secure_ram & MEM_RESERVE_SECURE_SECURED) {
York Sun5d286cd2015-12-04 11:57:07 -0800395 print_num("Secure ram",
York Sun1ef95cc2016-06-24 16:46:18 -0700396 gd->arch.secure_ram & MEM_RESERVE_SECURE_ADDR_MASK);
York Sun5d286cd2015-12-04 11:57:07 -0800397 }
398#endif
Simon Glasseb637cd2015-04-05 16:07:38 -0600399#if defined(CONFIG_CMD_NET) && !defined(CONFIG_DM_ETH)
Michal Simekc4c248f2013-01-23 12:21:18 +0100400 print_eths();
Hebbare6c85282007-12-18 16:03:07 -0800401#endif
Masahiro Yamada197c7202014-04-04 20:09:58 +0900402 printf("baudrate = %u bps\n", gd->baudrate);
Aneesh Vecee9c82011-06-16 23:30:48 +0000403#if !(defined(CONFIG_SYS_ICACHE_OFF) && defined(CONFIG_SYS_DCACHE_OFF))
Simon Glass6b4ee152012-12-13 20:48:39 +0000404 print_num("TLB addr", gd->arch.tlb_addr);
Heiko Schocheraeb29912010-09-17 13:10:39 +0200405#endif
Macpaul Lindfd70642011-04-27 16:28:35 +0000406 print_num("relocaddr", gd->relocaddr);
407 print_num("reloc off", gd->reloc_off);
408 print_num("irq_sp", gd->irq_sp); /* irq stack pointer */
409 print_num("sp start ", gd->start_addr_sp);
Simon Glass66d6e632012-12-13 20:49:13 +0000410#if defined(CONFIG_LCD) || defined(CONFIG_VIDEO)
Macpaul Lindfd70642011-04-27 16:28:35 +0000411 print_num("FB base ", gd->fb_base);
Simon Glass66d6e632012-12-13 20:49:13 +0000412#endif
Hadli, Manjunath0dfccbe2012-02-06 00:30:44 +0000413 /*
414 * TODO: Currently only support for davinci SOC's is added.
415 * Remove this check once all the board implement this.
416 */
417#ifdef CONFIG_CLOCKS
418 printf("ARM frequency = %ld MHz\n", gd->bd->bi_arm_freq);
419 printf("DSP frequency = %ld MHz\n", gd->bd->bi_dsp_freq);
420 printf("DDR frequency = %ld MHz\n", gd->bd->bi_ddr_freq);
421#endif
Hannes Schmelzer9ac9ef52015-06-11 12:27:09 +0200422#ifdef CONFIG_BOARD_TYPES
423 printf("Board Type = %ld\n", gd->board_type);
424#endif
Simon Glassf97a7e72016-07-05 17:10:11 -0600425#ifdef CONFIG_SYS_MALLOC_F
426 printf("Early malloc usage: %lx / %x\n", gd->malloc_ptr,
427 CONFIG_SYS_MALLOC_F_LEN);
428#endif
429
wdenk57b2d802003-06-27 21:31:46 +0000430 return 0;
431}
432
Nobuhiro Iwamatsu3da00e62010-07-22 16:05:32 +0900433#elif defined(CONFIG_SH)
434
Macpaul Lindfd70642011-04-27 16:28:35 +0000435int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
Nobuhiro Iwamatsu3da00e62010-07-22 16:05:32 +0900436{
437 bd_t *bd = gd->bd;
Macpaul Lindfd70642011-04-27 16:28:35 +0000438 print_num("mem start ", (ulong)bd->bi_memstart);
439 print_lnum("mem size ", (u64)bd->bi_memsize);
440 print_num("flash start ", (ulong)bd->bi_flashstart);
441 print_num("flash size ", (ulong)bd->bi_flashsize);
442 print_num("flash offset ", (ulong)bd->bi_flashoffset);
Nobuhiro Iwamatsu3da00e62010-07-22 16:05:32 +0900443
444#if defined(CONFIG_CMD_NET)
445 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000446 printf("ip_addr = %s\n", getenv("ipaddr"));
Nobuhiro Iwamatsu3da00e62010-07-22 16:05:32 +0900447#endif
Masahiro Yamada197c7202014-04-04 20:09:58 +0900448 printf("baudrate = %u bps\n", gd->baudrate);
Nobuhiro Iwamatsu3da00e62010-07-22 16:05:32 +0900449 return 0;
450}
451
Graeme Russ14917a92010-08-22 16:25:58 +1000452#elif defined(CONFIG_X86)
453
Macpaul Lindfd70642011-04-27 16:28:35 +0000454int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
Graeme Russ14917a92010-08-22 16:25:58 +1000455{
456 int i;
457 bd_t *bd = gd->bd;
Graeme Russ14917a92010-08-22 16:25:58 +1000458
Max Filippoved8b0672016-07-28 03:57:18 +0300459 print_bi_boot_params(bd);
Macpaul Lindfd70642011-04-27 16:28:35 +0000460 print_num("bi_memstart", bd->bi_memstart);
461 print_num("bi_memsize", bd->bi_memsize);
462 print_num("bi_flashstart", bd->bi_flashstart);
463 print_num("bi_flashsize", bd->bi_flashsize);
464 print_num("bi_flashoffset", bd->bi_flashoffset);
465 print_num("bi_sramstart", bd->bi_sramstart);
466 print_num("bi_sramsize", bd->bi_sramsize);
467 print_num("bi_bootflags", bd->bi_bootflags);
Timur Tabi7b480702011-10-05 17:08:07 -0500468 print_mhz("cpufreq", bd->bi_intfreq);
469 print_mhz("busfreq", bd->bi_busfreq);
Graeme Russ14917a92010-08-22 16:25:58 +1000470
Macpaul Lindfd70642011-04-27 16:28:35 +0000471 for (i = 0; i < CONFIG_NR_DRAM_BANKS; ++i) {
Graeme Russ14917a92010-08-22 16:25:58 +1000472 print_num("DRAM bank", i);
473 print_num("-> start", bd->bi_dram[i].start);
474 print_num("-> size", bd->bi_dram[i].size);
475 }
476
477#if defined(CONFIG_CMD_NET)
478 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000479 printf("ip_addr = %s\n", getenv("ipaddr"));
Timur Tabi7b480702011-10-05 17:08:07 -0500480 print_mhz("ethspeed", bd->bi_ethspeed);
Graeme Russ14917a92010-08-22 16:25:58 +1000481#endif
Masahiro Yamada197c7202014-04-04 20:09:58 +0900482 printf("baudrate = %u bps\n", gd->baudrate);
Graeme Russ14917a92010-08-22 16:25:58 +1000483
484 return 0;
485}
486
Simon Glass4413ed32011-09-17 06:48:47 +0000487#elif defined(CONFIG_SANDBOX)
488
489int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
490{
491 int i;
492 bd_t *bd = gd->bd;
493
Max Filippoved8b0672016-07-28 03:57:18 +0300494 print_bi_boot_params(bd);
Simon Glass4413ed32011-09-17 06:48:47 +0000495
496 for (i = 0; i < CONFIG_NR_DRAM_BANKS; ++i) {
497 print_num("DRAM bank", i);
498 print_num("-> start", bd->bi_dram[i].start);
499 print_num("-> size", bd->bi_dram[i].size);
500 }
501
502#if defined(CONFIG_CMD_NET)
503 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000504 printf("ip_addr = %s\n", getenv("ipaddr"));
Simon Glass4413ed32011-09-17 06:48:47 +0000505#endif
Simon Glass66d6e632012-12-13 20:49:13 +0000506#if defined(CONFIG_LCD) || defined(CONFIG_VIDEO)
Simon Glass4413ed32011-09-17 06:48:47 +0000507 print_num("FB base ", gd->fb_base);
Simon Glass66d6e632012-12-13 20:49:13 +0000508#endif
Simon Glass4413ed32011-09-17 06:48:47 +0000509 return 0;
510}
511
Macpaul Lin354b4e32011-10-19 20:41:09 +0000512#elif defined(CONFIG_NDS32)
513
514int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
515{
516 int i;
517 bd_t *bd = gd->bd;
518
519 print_num("arch_number", bd->bi_arch_number);
Max Filippoved8b0672016-07-28 03:57:18 +0300520 print_bi_boot_params(bd);
Macpaul Lin354b4e32011-10-19 20:41:09 +0000521
522 for (i = 0; i < CONFIG_NR_DRAM_BANKS; ++i) {
523 print_num("DRAM bank", i);
524 print_num("-> start", bd->bi_dram[i].start);
525 print_num("-> size", bd->bi_dram[i].size);
526 }
527
528#if defined(CONFIG_CMD_NET)
529 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000530 printf("ip_addr = %s\n", getenv("ipaddr"));
Macpaul Lin354b4e32011-10-19 20:41:09 +0000531#endif
Masahiro Yamada197c7202014-04-04 20:09:58 +0900532 printf("baudrate = %u bps\n", gd->baudrate);
Macpaul Lin354b4e32011-10-19 20:41:09 +0000533
534 return 0;
535}
536
Stefan Kristianssona646fa62011-11-18 19:21:34 +0000537#elif defined(CONFIG_OPENRISC)
538
539int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
540{
541 bd_t *bd = gd->bd;
542
543 print_num("mem start", (ulong)bd->bi_memstart);
544 print_lnum("mem size", (u64)bd->bi_memsize);
545 print_num("flash start", (ulong)bd->bi_flashstart);
546 print_num("flash size", (ulong)bd->bi_flashsize);
547 print_num("flash offset", (ulong)bd->bi_flashoffset);
548
549#if defined(CONFIG_CMD_NET)
550 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000551 printf("ip_addr = %s\n", getenv("ipaddr"));
Stefan Kristianssona646fa62011-11-18 19:21:34 +0000552#endif
553
Masahiro Yamada197c7202014-04-04 20:09:58 +0900554 printf("baudrate = %u bps\n", gd->baudrate);
Stefan Kristianssona646fa62011-11-18 19:21:34 +0000555
556 return 0;
557}
558
Alexey Brodkinecaafd52014-12-26 11:03:15 +0300559#elif defined(CONFIG_ARC)
Alexey Brodkin78bc86f2014-02-04 12:56:16 +0400560
561int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
562{
563 bd_t *bd = gd->bd;
564
565 print_num("mem start", bd->bi_memstart);
566 print_lnum("mem size", bd->bi_memsize);
567
568#if defined(CONFIG_CMD_NET)
569 print_eth(0);
570 printf("ip_addr = %s\n", getenv("ipaddr"));
571#endif
Masahiro Yamada197c7202014-04-04 20:09:58 +0900572 printf("baudrate = %d bps\n", gd->baudrate);
Alexey Brodkin78bc86f2014-02-04 12:56:16 +0400573
574 return 0;
575}
576
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200577#else
578 #error "a case for this architecture does not exist!"
579#endif
wdenk57b2d802003-06-27 21:31:46 +0000580
wdenk57b2d802003-06-27 21:31:46 +0000581/* -------------------------------------------------------------------- */
582
wdenkf287a242003-07-01 21:06:45 +0000583U_BOOT_CMD(
584 bdinfo, 1, 1, do_bdinfo,
Peter Tyserdfb72b82009-01-27 18:03:12 -0600585 "print Board Info structure",
Wolfgang Denkc54781c2009-05-24 17:06:54 +0200586 ""
wdenk57b2d802003-06-27 21:31:46 +0000587);