blob: 85279d5e7b828cd8994502535c57ac905146abb1 [file] [log] [blame]
wdenk57b2d802003-06-27 21:31:46 +00001/*
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>
Mike Frysinger1a8d6582011-12-04 17:45:22 +000029#include <linux/compiler.h>
wdenk57b2d802003-06-27 21:31:46 +000030
Wolfgang Denk6405a152006-03-31 18:32:53 +020031DECLARE_GLOBAL_DATA_PTR;
wdenk57b2d802003-06-27 21:31:46 +000032
Mike Frysinger1a8d6582011-12-04 17:45:22 +000033__maybe_unused
34static void print_num(const char *name, ulong value)
35{
36 printf("%-12s= 0x%08lX\n", name, value);
37}
wdenk57b2d802003-06-27 21:31:46 +000038
Simon Glass1a0f81d2011-12-06 13:37:17 +000039__maybe_unused
Mike Frysinger1a8d6582011-12-04 17:45:22 +000040static void print_eth(int idx)
41{
42 char name[10], *val;
43 if (idx)
44 sprintf(name, "eth%iaddr", idx);
45 else
46 strcpy(name, "ethaddr");
47 val = getenv(name);
48 if (!val)
49 val = "(not set)";
50 printf("%-12s= %s\n", name, val);
51}
Mike Frysinger9335cc72009-02-11 18:50:10 -050052
Mike Frysinger1a8d6582011-12-04 17:45:22 +000053__maybe_unused
Michal Simekc4c248f2013-01-23 12:21:18 +010054static void print_eths(void)
55{
56 struct eth_device *dev;
57 int i = 0;
58
59 do {
60 dev = eth_get_dev_by_index(i);
61 if (dev) {
62 printf("eth%dname = %s\n", i, dev->name);
63 print_eth(i);
64 i++;
65 }
66 } while (dev);
67
68 printf("current eth = %s\n", eth_get_name());
69 printf("ip_addr = %s\n", getenv("ipaddr"));
70}
71
72__maybe_unused
Daniel Schwierzeck0fdcf1d2012-10-03 08:36:11 +000073static void print_lnum(const char *name, unsigned long long value)
Mike Frysinger1a8d6582011-12-04 17:45:22 +000074{
75 printf("%-12s= 0x%.8llX\n", name, value);
76}
77
78__maybe_unused
79static void print_mhz(const char *name, unsigned long hz)
80{
81 char buf[32];
82
83 printf("%-12s= %6s MHz\n", name, strmhz(buf, hz));
84}
wdenk57b2d802003-06-27 21:31:46 +000085
Reinhard Meyer0f8337b2010-06-06 19:01:59 +020086#if defined(CONFIG_PPC)
wdenk57b2d802003-06-27 21:31:46 +000087
Macpaul Lindfd70642011-04-27 16:28:35 +000088int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
wdenk57b2d802003-06-27 21:31:46 +000089{
wdenk57b2d802003-06-27 21:31:46 +000090 bd_t *bd = gd->bd;
wdenk57b2d802003-06-27 21:31:46 +000091
92#ifdef DEBUG
Macpaul Lindfd70642011-04-27 16:28:35 +000093 print_num("bd address", (ulong)bd);
wdenk57b2d802003-06-27 21:31:46 +000094#endif
Macpaul Lindfd70642011-04-27 16:28:35 +000095 print_num("memstart", bd->bi_memstart);
96 print_lnum("memsize", bd->bi_memsize);
97 print_num("flashstart", bd->bi_flashstart);
98 print_num("flashsize", bd->bi_flashsize);
99 print_num("flashoffset", bd->bi_flashoffset);
100 print_num("sramstart", bd->bi_sramstart);
101 print_num("sramsize", bd->bi_sramsize);
102#if defined(CONFIG_5xx) || defined(CONFIG_8xx) || \
103 defined(CONFIG_8260) || defined(CONFIG_E500)
104 print_num("immr_base", bd->bi_immr_base);
wdenk57b2d802003-06-27 21:31:46 +0000105#endif
Macpaul Lindfd70642011-04-27 16:28:35 +0000106 print_num("bootflags", bd->bi_bootflags);
107#if defined(CONFIG_405CR) || defined(CONFIG_405EP) || \
108 defined(CONFIG_405GP) || \
109 defined(CONFIG_440EP) || defined(CONFIG_440EPX) || \
110 defined(CONFIG_440GR) || defined(CONFIG_440GRX) || \
111 defined(CONFIG_440SP) || defined(CONFIG_440SPE) || \
112 defined(CONFIG_XILINX_405)
Timur Tabi7b480702011-10-05 17:08:07 -0500113 print_mhz("procfreq", bd->bi_procfreq);
114 print_mhz("plb_busfreq", bd->bi_plb_busfreq);
Macpaul Lindfd70642011-04-27 16:28:35 +0000115#if defined(CONFIG_405EP) || defined(CONFIG_405GP) || \
116 defined(CONFIG_440EP) || defined(CONFIG_440EPX) || \
117 defined(CONFIG_440GR) || defined(CONFIG_440GRX) || \
118 defined(CONFIG_440SPE) || defined(CONFIG_XILINX_405)
Timur Tabi7b480702011-10-05 17:08:07 -0500119 print_mhz("pci_busfreq", bd->bi_pci_busfreq);
wdenk57b2d802003-06-27 21:31:46 +0000120#endif
Michal Simek594c7b52008-06-24 09:54:09 +0200121#else /* ! CONFIG_405GP, CONFIG_405CR, CONFIG_405EP, CONFIG_XILINX_405, CONFIG_440EP CONFIG_440GR */
Jon Loeligerf5ad3782005-07-23 10:37:35 -0500122#if defined(CONFIG_CPM2)
Timur Tabi7b480702011-10-05 17:08:07 -0500123 print_mhz("vco", bd->bi_vco);
124 print_mhz("sccfreq", bd->bi_sccfreq);
125 print_mhz("brgfreq", bd->bi_brgfreq);
wdenk57b2d802003-06-27 21:31:46 +0000126#endif
Timur Tabi7b480702011-10-05 17:08:07 -0500127 print_mhz("intfreq", bd->bi_intfreq);
Jon Loeligerf5ad3782005-07-23 10:37:35 -0500128#if defined(CONFIG_CPM2)
Timur Tabi7b480702011-10-05 17:08:07 -0500129 print_mhz("cpmfreq", bd->bi_cpmfreq);
wdenk57b2d802003-06-27 21:31:46 +0000130#endif
Timur Tabi7b480702011-10-05 17:08:07 -0500131 print_mhz("busfreq", bd->bi_busfreq);
Michal Simek594c7b52008-06-24 09:54:09 +0200132#endif /* CONFIG_405GP, CONFIG_405CR, CONFIG_405EP, CONFIG_XILINX_405, CONFIG_440EP CONFIG_440GR */
wdenk337f5652004-10-28 00:09:35 +0000133#if defined(CONFIG_MPC8220)
Timur Tabi7b480702011-10-05 17:08:07 -0500134 print_mhz("inpfreq", bd->bi_inpfreq);
135 print_mhz("flbfreq", bd->bi_flbfreq);
136 print_mhz("pcifreq", bd->bi_pcifreq);
137 print_mhz("vcofreq", bd->bi_vcofreq);
138 print_mhz("pevfreq", bd->bi_pevfreq);
wdenk337f5652004-10-28 00:09:35 +0000139#endif
wdenk0aeb8532004-10-10 21:21:55 +0000140
Timur Tabi1587daa2012-03-15 11:42:26 +0000141#ifdef CONFIG_ENABLE_36BIT_PHYS
142#ifdef CONFIG_PHYS_64BIT
143 puts("addressing = 36-bit\n");
144#else
145 puts("addressing = 32-bit\n");
146#endif
147#endif
148
Mike Frysinger9335cc72009-02-11 18:50:10 -0500149 print_eth(0);
wdenk54070ab2004-12-31 09:32:47 +0000150#if defined(CONFIG_HAS_ETH1)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500151 print_eth(1);
wdenk0aeb8532004-10-10 21:21:55 +0000152#endif
wdenk54070ab2004-12-31 09:32:47 +0000153#if defined(CONFIG_HAS_ETH2)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500154 print_eth(2);
wdenk9c53f402003-10-15 23:53:47 +0000155#endif
wdenk54070ab2004-12-31 09:32:47 +0000156#if defined(CONFIG_HAS_ETH3)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500157 print_eth(3);
wdenk0aeb8532004-10-10 21:21:55 +0000158#endif
richardretanubune5167f12008-09-29 18:28:23 -0400159#if defined(CONFIG_HAS_ETH4)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500160 print_eth(4);
richardretanubune5167f12008-09-29 18:28:23 -0400161#endif
richardretanubune5167f12008-09-29 18:28:23 -0400162#if defined(CONFIG_HAS_ETH5)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500163 print_eth(5);
richardretanubune5167f12008-09-29 18:28:23 -0400164#endif
165
wdenk57b2d802003-06-27 21:31:46 +0000166#ifdef CONFIG_HERMES
Timur Tabi7b480702011-10-05 17:08:07 -0500167 print_mhz("ethspeed", bd->bi_ethspeed);
wdenk57b2d802003-06-27 21:31:46 +0000168#endif
Mike Frysinger04b63f22012-04-04 18:53:40 +0000169 printf("IP addr = %s\n", getenv("ipaddr"));
Simon Glass3a7de0b2012-10-12 14:21:14 +0000170 printf("baudrate = %6u bps\n", bd->bi_baudrate);
Macpaul Lindfd70642011-04-27 16:28:35 +0000171 print_num("relocaddr", gd->relocaddr);
wdenk57b2d802003-06-27 21:31:46 +0000172 return 0;
173}
174
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200175#elif defined(CONFIG_NIOS2)
wdenkef3386f2004-10-10 21:27:30 +0000176
Macpaul Lindfd70642011-04-27 16:28:35 +0000177int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
wdenkef3386f2004-10-10 21:27:30 +0000178{
wdenkef3386f2004-10-10 21:27:30 +0000179 bd_t *bd = gd->bd;
180
Macpaul Lindfd70642011-04-27 16:28:35 +0000181 print_num("mem start", (ulong)bd->bi_memstart);
182 print_lnum("mem size", (u64)bd->bi_memsize);
183 print_num("flash start", (ulong)bd->bi_flashstart);
184 print_num("flash size", (ulong)bd->bi_flashsize);
185 print_num("flash offset", (ulong)bd->bi_flashoffset);
wdenkef3386f2004-10-10 21:27:30 +0000186
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200187#if defined(CONFIG_SYS_SRAM_BASE)
wdenkef3386f2004-10-10 21:27:30 +0000188 print_num ("sram start", (ulong)bd->bi_sramstart);
189 print_num ("sram size", (ulong)bd->bi_sramsize);
190#endif
191
Jon Loeligerd704d912007-07-10 11:02:44 -0500192#if defined(CONFIG_CMD_NET)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500193 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000194 printf("ip_addr = %s\n", getenv("ipaddr"));
wdenkef3386f2004-10-10 21:27:30 +0000195#endif
196
Simon Glasse335e3c2012-10-12 14:21:12 +0000197 printf("baudrate = %u bps\n", bd->bi_baudrate);
wdenkef3386f2004-10-10 21:27:30 +0000198
199 return 0;
200}
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200201
202#elif defined(CONFIG_MICROBLAZE)
Michal Simek922ce202007-03-11 13:48:24 +0100203
Macpaul Lindfd70642011-04-27 16:28:35 +0000204int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
Michal Simek922ce202007-03-11 13:48:24 +0100205{
Michal Simek922ce202007-03-11 13:48:24 +0100206 bd_t *bd = gd->bd;
Macpaul Lindfd70642011-04-27 16:28:35 +0000207 print_num("mem start ", (ulong)bd->bi_memstart);
208 print_lnum("mem size ", (u64)bd->bi_memsize);
209 print_num("flash start ", (ulong)bd->bi_flashstart);
210 print_num("flash size ", (ulong)bd->bi_flashsize);
211 print_num("flash offset ", (ulong)bd->bi_flashoffset);
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200212#if defined(CONFIG_SYS_SRAM_BASE)
Macpaul Lindfd70642011-04-27 16:28:35 +0000213 print_num("sram start ", (ulong)bd->bi_sramstart);
214 print_num("sram size ", (ulong)bd->bi_sramsize);
Michal Simek922ce202007-03-11 13:48:24 +0100215#endif
Jon Loeligerd704d912007-07-10 11:02:44 -0500216#if defined(CONFIG_CMD_NET)
Michal Simekc4c248f2013-01-23 12:21:18 +0100217 print_eths();
Michal Simek922ce202007-03-11 13:48:24 +0100218#endif
Michal Simek971eb342013-01-23 14:15:35 +0100219 printf("baudrate = %u bps\n", bd->bi_baudrate);
Michal Simek922ce202007-03-11 13:48:24 +0100220 return 0;
221}
wdenk60164a82003-10-08 23:26:14 +0000222
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200223#elif defined(CONFIG_SPARC)
224
Wolfgang Denk6262d0212010-06-28 22:00:46 +0200225int do_bdinfo(cmd_tbl_t * cmdtp, int flag, int argc, char * const argv[])
Daniel Hellstrom83eb3cc2008-03-26 22:36:03 +0100226{
227 bd_t *bd = gd->bd;
Daniel Hellstrom83eb3cc2008-03-26 22:36:03 +0100228
229#ifdef DEBUG
230 print_num("bd address ", (ulong) bd);
231#endif
232 print_num("memstart ", bd->bi_memstart);
Becky Brucea36601e2008-06-09 20:37:16 -0500233 print_lnum("memsize ", bd->bi_memsize);
Daniel Hellstrom83eb3cc2008-03-26 22:36:03 +0100234 print_num("flashstart ", bd->bi_flashstart);
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200235 print_num("CONFIG_SYS_MONITOR_BASE ", CONFIG_SYS_MONITOR_BASE);
Jean-Christophe PLAGNIOL-VILLARD7e1cda62008-09-10 22:48:06 +0200236 print_num("CONFIG_ENV_ADDR ", CONFIG_ENV_ADDR);
Marek Vasut292af862012-07-27 08:04:33 +0000237 printf("CONFIG_SYS_RELOC_MONITOR_BASE = 0x%x (%d)\n", CONFIG_SYS_RELOC_MONITOR_BASE,
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200238 CONFIG_SYS_MONITOR_LEN);
Marek Vasut292af862012-07-27 08:04:33 +0000239 printf("CONFIG_SYS_MALLOC_BASE = 0x%x (%d)\n", CONFIG_SYS_MALLOC_BASE,
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200240 CONFIG_SYS_MALLOC_LEN);
Marek Vasut292af862012-07-27 08:04:33 +0000241 printf("CONFIG_SYS_INIT_SP_OFFSET = 0x%x (%d)\n", CONFIG_SYS_INIT_SP_OFFSET,
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200242 CONFIG_SYS_STACK_SIZE);
Marek Vasut292af862012-07-27 08:04:33 +0000243 printf("CONFIG_SYS_PROM_OFFSET = 0x%x (%d)\n", CONFIG_SYS_PROM_OFFSET,
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200244 CONFIG_SYS_PROM_SIZE);
Marek Vasut292af862012-07-27 08:04:33 +0000245 printf("CONFIG_SYS_GBL_DATA_OFFSET = 0x%x (%d)\n", CONFIG_SYS_GBL_DATA_OFFSET,
Wolfgang Denk0191e472010-10-26 14:34:52 +0200246 GENERATED_GBL_DATA_SIZE);
Daniel Hellstrom83eb3cc2008-03-26 22:36:03 +0100247
248#if defined(CONFIG_CMD_NET)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500249 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000250 printf("ip_addr = %s\n", getenv("ipaddr"));
Daniel Hellstrom83eb3cc2008-03-26 22:36:03 +0100251#endif
Simon Glass78be0022012-10-12 14:21:15 +0000252 printf("baudrate = %6u bps\n", bd->bi_baudrate);
Daniel Hellstrom83eb3cc2008-03-26 22:36:03 +0100253 return 0;
254}
255
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200256#elif defined(CONFIG_M68K)
257
Macpaul Lindfd70642011-04-27 16:28:35 +0000258int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
TsiChung Liewf6afe722007-06-18 13:50:13 -0500259{
TsiChung Liewf6afe722007-06-18 13:50:13 -0500260 bd_t *bd = gd->bd;
TsiChungLiewfc3ca3b2007-08-16 15:05:11 -0500261
Macpaul Lindfd70642011-04-27 16:28:35 +0000262 print_num("memstart", (ulong)bd->bi_memstart);
263 print_lnum("memsize", (u64)bd->bi_memsize);
264 print_num("flashstart", (ulong)bd->bi_flashstart);
265 print_num("flashsize", (ulong)bd->bi_flashsize);
266 print_num("flashoffset", (ulong)bd->bi_flashoffset);
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200267#if defined(CONFIG_SYS_INIT_RAM_ADDR)
Macpaul Lindfd70642011-04-27 16:28:35 +0000268 print_num("sramstart", (ulong)bd->bi_sramstart);
269 print_num("sramsize", (ulong)bd->bi_sramsize);
TsiChung Liewf6afe722007-06-18 13:50:13 -0500270#endif
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200271#if defined(CONFIG_SYS_MBAR)
Macpaul Lindfd70642011-04-27 16:28:35 +0000272 print_num("mbar", bd->bi_mbar_base);
TsiChungLiewfc3ca3b2007-08-16 15:05:11 -0500273#endif
Timur Tabi7b480702011-10-05 17:08:07 -0500274 print_mhz("cpufreq", bd->bi_intfreq);
275 print_mhz("busfreq", bd->bi_busfreq);
TsiChungLiewfc3ca3b2007-08-16 15:05:11 -0500276#ifdef CONFIG_PCI
Timur Tabi7b480702011-10-05 17:08:07 -0500277 print_mhz("pcifreq", bd->bi_pcifreq);
TsiChung Liewf6afe722007-06-18 13:50:13 -0500278#endif
TsiChungLiewfc3ca3b2007-08-16 15:05:11 -0500279#ifdef CONFIG_EXTRA_CLOCK
Timur Tabi7b480702011-10-05 17:08:07 -0500280 print_mhz("flbfreq", bd->bi_flbfreq);
281 print_mhz("inpfreq", bd->bi_inpfreq);
282 print_mhz("vcofreq", bd->bi_vcofreq);
TsiChungLiewfc3ca3b2007-08-16 15:05:11 -0500283#endif
Stefan Roeseaddc4472007-08-18 14:37:52 +0200284#if defined(CONFIG_CMD_NET)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500285 print_eth(0);
TsiChung Liewf6afe722007-06-18 13:50:13 -0500286#if defined(CONFIG_HAS_ETH1)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500287 print_eth(1);
TsiChung Liewf6afe722007-06-18 13:50:13 -0500288#endif
TsiChung Liewf6afe722007-06-18 13:50:13 -0500289#if defined(CONFIG_HAS_ETH2)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500290 print_eth(2);
TsiChung Liewf6afe722007-06-18 13:50:13 -0500291#endif
TsiChung Liewf6afe722007-06-18 13:50:13 -0500292#if defined(CONFIG_HAS_ETH3)
Mike Frysinger9335cc72009-02-11 18:50:10 -0500293 print_eth(3);
TsiChung Liewf6afe722007-06-18 13:50:13 -0500294#endif
295
Mike Frysinger04b63f22012-04-04 18:53:40 +0000296 printf("ip_addr = %s\n", getenv("ipaddr"));
Stefan Roeseaddc4472007-08-18 14:37:52 +0200297#endif
Simon Glassb9b4d222012-10-12 14:21:10 +0000298 printf("baudrate = %u bps\n", bd->bi_baudrate);
TsiChung Liewf6afe722007-06-18 13:50:13 -0500299
300 return 0;
301}
302
Mike Frysingerf443d3c2008-02-04 19:26:55 -0500303#elif defined(CONFIG_BLACKFIN)
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200304
Wolfgang Denk6262d0212010-06-28 22:00:46 +0200305int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
Mike Frysingerf443d3c2008-02-04 19:26:55 -0500306{
Mike Frysingerf443d3c2008-02-04 19:26:55 -0500307 bd_t *bd = gd->bd;
308
309 printf("U-Boot = %s\n", bd->bi_r_version);
310 printf("CPU = %s\n", bd->bi_cpu);
311 printf("Board = %s\n", bd->bi_board_name);
Timur Tabi7b480702011-10-05 17:08:07 -0500312 print_mhz("VCO", bd->bi_vco);
313 print_mhz("CCLK", bd->bi_cclk);
314 print_mhz("SCLK", bd->bi_sclk);
Mike Frysingerf443d3c2008-02-04 19:26:55 -0500315
Macpaul Lindfd70642011-04-27 16:28:35 +0000316 print_num("boot_params", (ulong)bd->bi_boot_params);
317 print_num("memstart", (ulong)bd->bi_memstart);
318 print_lnum("memsize", (u64)bd->bi_memsize);
319 print_num("flashstart", (ulong)bd->bi_flashstart);
320 print_num("flashsize", (ulong)bd->bi_flashsize);
321 print_num("flashoffset", (ulong)bd->bi_flashoffset);
Mike Frysingerf443d3c2008-02-04 19:26:55 -0500322
Mike Frysinger9335cc72009-02-11 18:50:10 -0500323 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000324 printf("ip_addr = %s\n", getenv("ipaddr"));
Simon Glass25c2bad2012-10-12 14:21:17 +0000325 printf("baudrate = %u bps\n", bd->bi_baudrate);
Mike Frysingerf443d3c2008-02-04 19:26:55 -0500326
327 return 0;
328}
329
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200330#elif defined(CONFIG_MIPS)
wdenk57b2d802003-06-27 21:31:46 +0000331
Macpaul Lindfd70642011-04-27 16:28:35 +0000332int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
wdenk57b2d802003-06-27 21:31:46 +0000333{
wdenk57b2d802003-06-27 21:31:46 +0000334 bd_t *bd = gd->bd;
335
Macpaul Lindfd70642011-04-27 16:28:35 +0000336 print_num("boot_params", (ulong)bd->bi_boot_params);
337 print_num("memstart", (ulong)bd->bi_memstart);
338 print_lnum("memsize", (u64)bd->bi_memsize);
339 print_num("flashstart", (ulong)bd->bi_flashstart);
340 print_num("flashsize", (ulong)bd->bi_flashsize);
341 print_num("flashoffset", (ulong)bd->bi_flashoffset);
wdenk57b2d802003-06-27 21:31:46 +0000342
Mike Frysinger9335cc72009-02-11 18:50:10 -0500343 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000344 printf("ip_addr = %s\n", getenv("ipaddr"));
Simon Glassc81b6902012-10-12 14:21:18 +0000345 printf("baudrate = %u bps\n", bd->bi_baudrate);
wdenk57b2d802003-06-27 21:31:46 +0000346
347 return 0;
348}
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200349
350#elif defined(CONFIG_AVR32)
351
Macpaul Lindfd70642011-04-27 16:28:35 +0000352int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200353{
354 bd_t *bd = gd->bd;
355
Macpaul Lindfd70642011-04-27 16:28:35 +0000356 print_num("boot_params", (ulong)bd->bi_boot_params);
357 print_num("memstart", (ulong)bd->bi_memstart);
358 print_lnum("memsize", (u64)bd->bi_memsize);
359 print_num("flashstart", (ulong)bd->bi_flashstart);
360 print_num("flashsize", (ulong)bd->bi_flashsize);
361 print_num("flashoffset", (ulong)bd->bi_flashoffset);
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200362
363 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000364 printf("ip_addr = %s\n", getenv("ipaddr"));
Simon Glassf7cd60a2012-10-12 14:21:09 +0000365 printf("baudrate = %u bps\n", bd->bi_baudrate);
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200366
367 return 0;
368}
wdenk57b2d802003-06-27 21:31:46 +0000369
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200370#elif defined(CONFIG_ARM)
wdenk57b2d802003-06-27 21:31:46 +0000371
Macpaul Lindfd70642011-04-27 16:28:35 +0000372int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
wdenk57b2d802003-06-27 21:31:46 +0000373{
wdenk57b2d802003-06-27 21:31:46 +0000374 int i;
375 bd_t *bd = gd->bd;
376
Macpaul Lindfd70642011-04-27 16:28:35 +0000377 print_num("arch_number", bd->bi_arch_number);
378 print_num("boot_params", (ulong)bd->bi_boot_params);
wdenk57b2d802003-06-27 21:31:46 +0000379
Macpaul Lindfd70642011-04-27 16:28:35 +0000380 for (i = 0; i < CONFIG_NR_DRAM_BANKS; ++i) {
wdenk57b2d802003-06-27 21:31:46 +0000381 print_num("DRAM bank", i);
382 print_num("-> start", bd->bi_dram[i].start);
383 print_num("-> size", bd->bi_dram[i].size);
384 }
385
Hebbare6c85282007-12-18 16:03:07 -0800386#if defined(CONFIG_CMD_NET)
Michal Simekc4c248f2013-01-23 12:21:18 +0100387 print_eths();
Hebbare6c85282007-12-18 16:03:07 -0800388#endif
Simon Glassc3b324e2012-10-12 14:21:16 +0000389 printf("baudrate = %u bps\n", bd->bi_baudrate);
Aneesh Vecee9c82011-06-16 23:30:48 +0000390#if !(defined(CONFIG_SYS_ICACHE_OFF) && defined(CONFIG_SYS_DCACHE_OFF))
Simon Glass6b4ee152012-12-13 20:48:39 +0000391 print_num("TLB addr", gd->arch.tlb_addr);
Heiko Schocheraeb29912010-09-17 13:10:39 +0200392#endif
Macpaul Lindfd70642011-04-27 16:28:35 +0000393 print_num("relocaddr", gd->relocaddr);
394 print_num("reloc off", gd->reloc_off);
395 print_num("irq_sp", gd->irq_sp); /* irq stack pointer */
396 print_num("sp start ", gd->start_addr_sp);
Simon Glass66d6e632012-12-13 20:49:13 +0000397#if defined(CONFIG_LCD) || defined(CONFIG_VIDEO)
Macpaul Lindfd70642011-04-27 16:28:35 +0000398 print_num("FB base ", gd->fb_base);
Simon Glass66d6e632012-12-13 20:49:13 +0000399#endif
Hadli, Manjunath0dfccbe2012-02-06 00:30:44 +0000400 /*
401 * TODO: Currently only support for davinci SOC's is added.
402 * Remove this check once all the board implement this.
403 */
404#ifdef CONFIG_CLOCKS
405 printf("ARM frequency = %ld MHz\n", gd->bd->bi_arm_freq);
406 printf("DSP frequency = %ld MHz\n", gd->bd->bi_dsp_freq);
407 printf("DDR frequency = %ld MHz\n", gd->bd->bi_ddr_freq);
408#endif
wdenk57b2d802003-06-27 21:31:46 +0000409 return 0;
410}
411
Nobuhiro Iwamatsu3da00e62010-07-22 16:05:32 +0900412#elif defined(CONFIG_SH)
413
Macpaul Lindfd70642011-04-27 16:28:35 +0000414int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
Nobuhiro Iwamatsu3da00e62010-07-22 16:05:32 +0900415{
416 bd_t *bd = gd->bd;
Macpaul Lindfd70642011-04-27 16:28:35 +0000417 print_num("mem start ", (ulong)bd->bi_memstart);
418 print_lnum("mem size ", (u64)bd->bi_memsize);
419 print_num("flash start ", (ulong)bd->bi_flashstart);
420 print_num("flash size ", (ulong)bd->bi_flashsize);
421 print_num("flash offset ", (ulong)bd->bi_flashoffset);
Nobuhiro Iwamatsu3da00e62010-07-22 16:05:32 +0900422
423#if defined(CONFIG_CMD_NET)
424 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000425 printf("ip_addr = %s\n", getenv("ipaddr"));
Nobuhiro Iwamatsu3da00e62010-07-22 16:05:32 +0900426#endif
Simon Glassd9a44622012-10-12 14:21:08 +0000427 printf("baudrate = %u bps\n", bd->bi_baudrate);
Nobuhiro Iwamatsu3da00e62010-07-22 16:05:32 +0900428 return 0;
429}
430
Graeme Russ14917a92010-08-22 16:25:58 +1000431#elif defined(CONFIG_X86)
432
Macpaul Lindfd70642011-04-27 16:28:35 +0000433int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
Graeme Russ14917a92010-08-22 16:25:58 +1000434{
435 int i;
436 bd_t *bd = gd->bd;
Graeme Russ14917a92010-08-22 16:25:58 +1000437
Macpaul Lindfd70642011-04-27 16:28:35 +0000438 print_num("boot_params", (ulong)bd->bi_boot_params);
439 print_num("bi_memstart", bd->bi_memstart);
440 print_num("bi_memsize", bd->bi_memsize);
441 print_num("bi_flashstart", bd->bi_flashstart);
442 print_num("bi_flashsize", bd->bi_flashsize);
443 print_num("bi_flashoffset", bd->bi_flashoffset);
444 print_num("bi_sramstart", bd->bi_sramstart);
445 print_num("bi_sramsize", bd->bi_sramsize);
446 print_num("bi_bootflags", bd->bi_bootflags);
Timur Tabi7b480702011-10-05 17:08:07 -0500447 print_mhz("cpufreq", bd->bi_intfreq);
448 print_mhz("busfreq", bd->bi_busfreq);
Graeme Russ14917a92010-08-22 16:25:58 +1000449
Macpaul Lindfd70642011-04-27 16:28:35 +0000450 for (i = 0; i < CONFIG_NR_DRAM_BANKS; ++i) {
Graeme Russ14917a92010-08-22 16:25:58 +1000451 print_num("DRAM bank", i);
452 print_num("-> start", bd->bi_dram[i].start);
453 print_num("-> size", bd->bi_dram[i].size);
454 }
455
456#if defined(CONFIG_CMD_NET)
457 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000458 printf("ip_addr = %s\n", getenv("ipaddr"));
Timur Tabi7b480702011-10-05 17:08:07 -0500459 print_mhz("ethspeed", bd->bi_ethspeed);
Graeme Russ14917a92010-08-22 16:25:58 +1000460#endif
Simon Glass11aca5f2012-10-12 14:21:20 +0000461 printf("baudrate = %u bps\n", bd->bi_baudrate);
Graeme Russ14917a92010-08-22 16:25:58 +1000462
463 return 0;
464}
465
Simon Glass4413ed32011-09-17 06:48:47 +0000466#elif defined(CONFIG_SANDBOX)
467
468int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
469{
470 int i;
471 bd_t *bd = gd->bd;
472
473 print_num("boot_params", (ulong)bd->bi_boot_params);
474
475 for (i = 0; i < CONFIG_NR_DRAM_BANKS; ++i) {
476 print_num("DRAM bank", i);
477 print_num("-> start", bd->bi_dram[i].start);
478 print_num("-> size", bd->bi_dram[i].size);
479 }
480
481#if defined(CONFIG_CMD_NET)
482 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000483 printf("ip_addr = %s\n", getenv("ipaddr"));
Simon Glass4413ed32011-09-17 06:48:47 +0000484#endif
Simon Glass66d6e632012-12-13 20:49:13 +0000485#if defined(CONFIG_LCD) || defined(CONFIG_VIDEO)
Simon Glass4413ed32011-09-17 06:48:47 +0000486 print_num("FB base ", gd->fb_base);
Simon Glass66d6e632012-12-13 20:49:13 +0000487#endif
Simon Glass4413ed32011-09-17 06:48:47 +0000488 return 0;
489}
490
Macpaul Lin354b4e32011-10-19 20:41:09 +0000491#elif defined(CONFIG_NDS32)
492
493int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
494{
495 int i;
496 bd_t *bd = gd->bd;
497
498 print_num("arch_number", bd->bi_arch_number);
499 print_num("boot_params", (ulong)bd->bi_boot_params);
500
501 for (i = 0; i < CONFIG_NR_DRAM_BANKS; ++i) {
502 print_num("DRAM bank", i);
503 print_num("-> start", bd->bi_dram[i].start);
504 print_num("-> size", bd->bi_dram[i].size);
505 }
506
507#if defined(CONFIG_CMD_NET)
508 print_eth(0);
Mike Frysinger04b63f22012-04-04 18:53:40 +0000509 printf("ip_addr = %s\n", getenv("ipaddr"));
Macpaul Lin354b4e32011-10-19 20:41:09 +0000510#endif
Simon Glassf4baef02012-10-12 14:21:19 +0000511 printf("baudrate = %u bps\n", bd->bi_baudrate);
Macpaul Lin354b4e32011-10-19 20:41:09 +0000512
513 return 0;
514}
515
Stefan Kristianssona646fa62011-11-18 19:21:34 +0000516#elif defined(CONFIG_OPENRISC)
517
518int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
519{
520 bd_t *bd = gd->bd;
521
522 print_num("mem start", (ulong)bd->bi_memstart);
523 print_lnum("mem size", (u64)bd->bi_memsize);
524 print_num("flash start", (ulong)bd->bi_flashstart);
525 print_num("flash size", (ulong)bd->bi_flashsize);
526 print_num("flash offset", (ulong)bd->bi_flashoffset);
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"));
Stefan Kristianssona646fa62011-11-18 19:21:34 +0000531#endif
532
Simon Glass00322d92012-10-12 14:21:13 +0000533 printf("baudrate = %u bps\n", bd->bi_baudrate);
Stefan Kristianssona646fa62011-11-18 19:21:34 +0000534
535 return 0;
536}
537
Reinhard Meyer0f8337b2010-06-06 19:01:59 +0200538#else
539 #error "a case for this architecture does not exist!"
540#endif
wdenk57b2d802003-06-27 21:31:46 +0000541
wdenk57b2d802003-06-27 21:31:46 +0000542/* -------------------------------------------------------------------- */
543
wdenkf287a242003-07-01 21:06:45 +0000544U_BOOT_CMD(
545 bdinfo, 1, 1, do_bdinfo,
Peter Tyserdfb72b82009-01-27 18:03:12 -0600546 "print Board Info structure",
Wolfgang Denkc54781c2009-05-24 17:06:54 +0200547 ""
wdenk57b2d802003-06-27 21:31:46 +0000548);