xref: /openbmc/u-boot/cmd/bdinfo.c (revision b37483c4)
12e192b24SSimon Glass /*
22e192b24SSimon Glass  * (C) Copyright 2003
32e192b24SSimon Glass  * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
42e192b24SSimon Glass  *
52e192b24SSimon Glass  * SPDX-License-Identifier:	GPL-2.0+
62e192b24SSimon Glass  */
72e192b24SSimon Glass 
82e192b24SSimon Glass /*
92e192b24SSimon Glass  * Boot support
102e192b24SSimon Glass  */
112e192b24SSimon Glass #include <common.h>
122e192b24SSimon Glass #include <command.h>
132e192b24SSimon Glass #include <linux/compiler.h>
142e192b24SSimon Glass 
152e192b24SSimon Glass DECLARE_GLOBAL_DATA_PTR;
162e192b24SSimon Glass 
172e192b24SSimon Glass __maybe_unused
182e192b24SSimon Glass static void print_num(const char *name, ulong value)
192e192b24SSimon Glass {
202e192b24SSimon Glass 	printf("%-12s= 0x%08lX\n", name, value);
212e192b24SSimon Glass }
222e192b24SSimon Glass 
232e192b24SSimon Glass __maybe_unused
242e192b24SSimon Glass static void print_eth(int idx)
252e192b24SSimon Glass {
262e192b24SSimon Glass 	char name[10], *val;
272e192b24SSimon Glass 	if (idx)
282e192b24SSimon Glass 		sprintf(name, "eth%iaddr", idx);
292e192b24SSimon Glass 	else
302e192b24SSimon Glass 		strcpy(name, "ethaddr");
312e192b24SSimon Glass 	val = getenv(name);
322e192b24SSimon Glass 	if (!val)
332e192b24SSimon Glass 		val = "(not set)";
342e192b24SSimon Glass 	printf("%-12s= %s\n", name, val);
352e192b24SSimon Glass }
362e192b24SSimon Glass 
372e192b24SSimon Glass #ifndef CONFIG_DM_ETH
382e192b24SSimon Glass __maybe_unused
392e192b24SSimon Glass static void print_eths(void)
402e192b24SSimon Glass {
412e192b24SSimon Glass 	struct eth_device *dev;
422e192b24SSimon Glass 	int i = 0;
432e192b24SSimon Glass 
442e192b24SSimon Glass 	do {
452e192b24SSimon Glass 		dev = eth_get_dev_by_index(i);
462e192b24SSimon Glass 		if (dev) {
472e192b24SSimon Glass 			printf("eth%dname    = %s\n", i, dev->name);
482e192b24SSimon Glass 			print_eth(i);
492e192b24SSimon Glass 			i++;
502e192b24SSimon Glass 		}
512e192b24SSimon Glass 	} while (dev);
522e192b24SSimon Glass 
532e192b24SSimon Glass 	printf("current eth = %s\n", eth_get_name());
542e192b24SSimon Glass 	printf("ip_addr     = %s\n", getenv("ipaddr"));
552e192b24SSimon Glass }
562e192b24SSimon Glass #endif
572e192b24SSimon Glass 
582e192b24SSimon Glass __maybe_unused
592e192b24SSimon Glass static void print_lnum(const char *name, unsigned long long value)
602e192b24SSimon Glass {
612e192b24SSimon Glass 	printf("%-12s= 0x%.8llX\n", name, value);
622e192b24SSimon Glass }
632e192b24SSimon Glass 
642e192b24SSimon Glass __maybe_unused
652e192b24SSimon Glass static void print_mhz(const char *name, unsigned long hz)
662e192b24SSimon Glass {
672e192b24SSimon Glass 	char buf[32];
682e192b24SSimon Glass 
692e192b24SSimon Glass 	printf("%-12s= %6s MHz\n", name, strmhz(buf, hz));
702e192b24SSimon Glass }
712e192b24SSimon Glass 
72171e5396SMax Filippov 
73171e5396SMax Filippov static inline void print_bi_boot_params(const bd_t *bd)
74171e5396SMax Filippov {
75171e5396SMax Filippov 	print_num("boot_params",	(ulong)bd->bi_boot_params);
76171e5396SMax Filippov }
77171e5396SMax Filippov 
7812feb364SMax Filippov static inline void print_bi_mem(const bd_t *bd)
7912feb364SMax Filippov {
8012feb364SMax Filippov #if defined(CONFIG_SH)
8112feb364SMax Filippov 	print_num("mem start      ",	(ulong)bd->bi_memstart);
8212feb364SMax Filippov 	print_lnum("mem size       ",	(u64)bd->bi_memsize);
8312feb364SMax Filippov #elif defined(CONFIG_ARC)
8412feb364SMax Filippov 	print_num("mem start",		(ulong)bd->bi_memstart);
8512feb364SMax Filippov 	print_lnum("mem size",		(u64)bd->bi_memsize);
8612feb364SMax Filippov #elif defined(CONFIG_AVR32)
8712feb364SMax Filippov 	print_num("memstart",		(ulong)bd->bi_dram[0].start);
8812feb364SMax Filippov 	print_lnum("memsize",		(u64)bd->bi_dram[0].size);
8912feb364SMax Filippov #else
9012feb364SMax Filippov 	print_num("memstart",		(ulong)bd->bi_memstart);
9112feb364SMax Filippov 	print_lnum("memsize",		(u64)bd->bi_memsize);
9212feb364SMax Filippov #endif
9312feb364SMax Filippov }
9412feb364SMax Filippov 
95fd60e99fSMax Filippov static inline void print_bi_dram(const bd_t *bd)
96fd60e99fSMax Filippov {
97fd60e99fSMax Filippov #ifdef CONFIG_NR_DRAM_BANKS
98fd60e99fSMax Filippov 	int i;
99fd60e99fSMax Filippov 
100fd60e99fSMax Filippov 	for (i = 0; i < CONFIG_NR_DRAM_BANKS; ++i) {
101ddd917b8SSimon Glass 		if (bd->bi_dram[i].size) {
102fd60e99fSMax Filippov 			print_num("DRAM bank",	i);
103fd60e99fSMax Filippov 			print_num("-> start",	bd->bi_dram[i].start);
104fd60e99fSMax Filippov 			print_num("-> size",	bd->bi_dram[i].size);
105fd60e99fSMax Filippov 		}
106ddd917b8SSimon Glass 	}
107fd60e99fSMax Filippov #endif
108fd60e99fSMax Filippov }
109fd60e99fSMax Filippov 
110f80e5359SMax Filippov static inline void print_bi_flash(const bd_t *bd)
111f80e5359SMax Filippov {
112f80e5359SMax Filippov #if defined(CONFIG_MICROBLAZE) || defined(CONFIG_SH)
113f80e5359SMax Filippov 	print_num("flash start    ",	(ulong)bd->bi_flashstart);
114f80e5359SMax Filippov 	print_num("flash size     ",	(ulong)bd->bi_flashsize);
115f80e5359SMax Filippov 	print_num("flash offset   ",	(ulong)bd->bi_flashoffset);
116f80e5359SMax Filippov 
11770cc0c34STom Rini #elif defined(CONFIG_NIOS2)
118f80e5359SMax Filippov 	print_num("flash start",	(ulong)bd->bi_flashstart);
119f80e5359SMax Filippov 	print_num("flash size",		(ulong)bd->bi_flashsize);
120f80e5359SMax Filippov 	print_num("flash offset",	(ulong)bd->bi_flashoffset);
121f80e5359SMax Filippov #else
122f80e5359SMax Filippov 	print_num("flashstart",		(ulong)bd->bi_flashstart);
123f80e5359SMax Filippov 	print_num("flashsize",		(ulong)bd->bi_flashsize);
124f80e5359SMax Filippov 	print_num("flashoffset",	(ulong)bd->bi_flashoffset);
125f80e5359SMax Filippov #endif
126f80e5359SMax Filippov }
127f80e5359SMax Filippov 
1288752e260SMax Filippov static inline void print_eth_ip_addr(void)
1298752e260SMax Filippov {
1308752e260SMax Filippov #if defined(CONFIG_CMD_NET)
1318752e260SMax Filippov 	print_eth(0);
1328752e260SMax Filippov #if defined(CONFIG_HAS_ETH1)
1338752e260SMax Filippov 	print_eth(1);
1348752e260SMax Filippov #endif
1358752e260SMax Filippov #if defined(CONFIG_HAS_ETH2)
1368752e260SMax Filippov 	print_eth(2);
1378752e260SMax Filippov #endif
1388752e260SMax Filippov #if defined(CONFIG_HAS_ETH3)
1398752e260SMax Filippov 	print_eth(3);
1408752e260SMax Filippov #endif
1418752e260SMax Filippov #if defined(CONFIG_HAS_ETH4)
1428752e260SMax Filippov 	print_eth(4);
1438752e260SMax Filippov #endif
1448752e260SMax Filippov #if defined(CONFIG_HAS_ETH5)
1458752e260SMax Filippov 	print_eth(5);
1468752e260SMax Filippov #endif
1478752e260SMax Filippov 	printf("IP addr     = %s\n", getenv("ipaddr"));
1488752e260SMax Filippov #endif
1498752e260SMax Filippov }
1508752e260SMax Filippov 
1514e3fa7d8SMax Filippov static inline void print_baudrate(void)
1524e3fa7d8SMax Filippov {
1534e3fa7d8SMax Filippov #if defined(CONFIG_PPC)
1544e3fa7d8SMax Filippov 	printf("baudrate    = %6u bps\n", gd->baudrate);
1554e3fa7d8SMax Filippov #else
1564e3fa7d8SMax Filippov 	printf("baudrate    = %u bps\n", gd->baudrate);
1574e3fa7d8SMax Filippov #endif
1584e3fa7d8SMax Filippov }
1594e3fa7d8SMax Filippov 
160*b37483c4STom Rini static inline void __maybe_unused print_std_bdinfo(const bd_t *bd)
161e3795084SMax Filippov {
162e3795084SMax Filippov 	print_bi_boot_params(bd);
163e3795084SMax Filippov 	print_bi_mem(bd);
164e3795084SMax Filippov 	print_bi_flash(bd);
165e3795084SMax Filippov 	print_eth_ip_addr();
166e3795084SMax Filippov 	print_baudrate();
167e3795084SMax Filippov }
168e3795084SMax Filippov 
1692e192b24SSimon Glass #if defined(CONFIG_PPC)
1702e192b24SSimon Glass void __weak board_detail(void)
1712e192b24SSimon Glass {
1722e192b24SSimon Glass 	/* Please define boot_detail() for your platform */
1732e192b24SSimon Glass }
1742e192b24SSimon Glass 
1752e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
1762e192b24SSimon Glass {
1772e192b24SSimon Glass 	bd_t *bd = gd->bd;
1782e192b24SSimon Glass 
1792e192b24SSimon Glass #ifdef DEBUG
1802e192b24SSimon Glass 	print_num("bd address",		(ulong)bd);
1812e192b24SSimon Glass #endif
18212feb364SMax Filippov 	print_bi_mem(bd);
183f80e5359SMax Filippov 	print_bi_flash(bd);
1842e192b24SSimon Glass 	print_num("sramstart",		bd->bi_sramstart);
1852e192b24SSimon Glass 	print_num("sramsize",		bd->bi_sramsize);
1862e192b24SSimon Glass #if	defined(CONFIG_5xx)  || defined(CONFIG_8xx) || \
1872e192b24SSimon Glass 	defined(CONFIG_MPC8260) || defined(CONFIG_E500)
1882e192b24SSimon Glass 	print_num("immr_base",		bd->bi_immr_base);
1892e192b24SSimon Glass #endif
1902e192b24SSimon Glass 	print_num("bootflags",		bd->bi_bootflags);
1912e192b24SSimon Glass #if	defined(CONFIG_405EP) || \
1922e192b24SSimon Glass 	defined(CONFIG_405GP) || \
1932e192b24SSimon Glass 	defined(CONFIG_440EP) || defined(CONFIG_440EPX) || \
1942e192b24SSimon Glass 	defined(CONFIG_440GR) || defined(CONFIG_440GRX) || \
1952e192b24SSimon Glass 	defined(CONFIG_440SP) || defined(CONFIG_440SPE) || \
1962e192b24SSimon Glass 	defined(CONFIG_XILINX_405)
1972e192b24SSimon Glass 	print_mhz("procfreq",		bd->bi_procfreq);
1982e192b24SSimon Glass 	print_mhz("plb_busfreq",	bd->bi_plb_busfreq);
1992e192b24SSimon Glass #if	defined(CONFIG_405EP) || defined(CONFIG_405GP) || \
2002e192b24SSimon Glass 	defined(CONFIG_440EP) || defined(CONFIG_440EPX) || \
2012e192b24SSimon Glass 	defined(CONFIG_440GR) || defined(CONFIG_440GRX) || \
2022e192b24SSimon Glass 	defined(CONFIG_440SPE) || defined(CONFIG_XILINX_405)
2032e192b24SSimon Glass 	print_mhz("pci_busfreq",	bd->bi_pci_busfreq);
2042e192b24SSimon Glass #endif
2052e192b24SSimon Glass #else	/* ! CONFIG_405GP, CONFIG_405EP, CONFIG_XILINX_405, CONFIG_440EP CONFIG_440GR */
2062e192b24SSimon Glass #if defined(CONFIG_CPM2)
2072e192b24SSimon Glass 	print_mhz("vco",		bd->bi_vco);
2082e192b24SSimon Glass 	print_mhz("sccfreq",		bd->bi_sccfreq);
2092e192b24SSimon Glass 	print_mhz("brgfreq",		bd->bi_brgfreq);
2102e192b24SSimon Glass #endif
2112e192b24SSimon Glass 	print_mhz("intfreq",		bd->bi_intfreq);
2122e192b24SSimon Glass #if defined(CONFIG_CPM2)
2132e192b24SSimon Glass 	print_mhz("cpmfreq",		bd->bi_cpmfreq);
2142e192b24SSimon Glass #endif
2152e192b24SSimon Glass 	print_mhz("busfreq",		bd->bi_busfreq);
2162e192b24SSimon Glass #endif /* CONFIG_405GP, CONFIG_405EP, CONFIG_XILINX_405, CONFIG_440EP CONFIG_440GR */
2172e192b24SSimon Glass 
2182e192b24SSimon Glass #ifdef CONFIG_ENABLE_36BIT_PHYS
2192e192b24SSimon Glass #ifdef CONFIG_PHYS_64BIT
2202e192b24SSimon Glass 	puts("addressing  = 36-bit\n");
2212e192b24SSimon Glass #else
2222e192b24SSimon Glass 	puts("addressing  = 32-bit\n");
2232e192b24SSimon Glass #endif
2242e192b24SSimon Glass #endif
2252e192b24SSimon Glass 
2268752e260SMax Filippov 	print_eth_ip_addr();
2274e3fa7d8SMax Filippov 	print_baudrate();
2282e192b24SSimon Glass 	print_num("relocaddr", gd->relocaddr);
2292e192b24SSimon Glass 	board_detail();
2302e192b24SSimon Glass 	return 0;
2312e192b24SSimon Glass }
2322e192b24SSimon Glass 
2332e192b24SSimon Glass #elif defined(CONFIG_NIOS2)
2342e192b24SSimon Glass 
2352e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
2362e192b24SSimon Glass {
2372e192b24SSimon Glass 	bd_t *bd = gd->bd;
2382e192b24SSimon Glass 
239fd60e99fSMax Filippov 	print_bi_dram(bd);
240f80e5359SMax Filippov 	print_bi_flash(bd);
2412e192b24SSimon Glass 
2422e192b24SSimon Glass #if defined(CONFIG_SYS_SRAM_BASE)
2432e192b24SSimon Glass 	print_num ("sram start",	(ulong)bd->bi_sramstart);
2442e192b24SSimon Glass 	print_num ("sram size",		(ulong)bd->bi_sramsize);
2452e192b24SSimon Glass #endif
2462e192b24SSimon Glass 
2478752e260SMax Filippov 	print_eth_ip_addr();
2484e3fa7d8SMax Filippov 	print_baudrate();
2492e192b24SSimon Glass 
2502e192b24SSimon Glass 	return 0;
2512e192b24SSimon Glass }
2522e192b24SSimon Glass 
2532e192b24SSimon Glass #elif defined(CONFIG_MICROBLAZE)
2542e192b24SSimon Glass 
2552e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
2562e192b24SSimon Glass {
2572e192b24SSimon Glass 	bd_t *bd = gd->bd;
2582e192b24SSimon Glass 
259fd60e99fSMax Filippov 	print_bi_dram(bd);
260f80e5359SMax Filippov 	print_bi_flash(bd);
2612e192b24SSimon Glass #if defined(CONFIG_SYS_SRAM_BASE)
2622e192b24SSimon Glass 	print_num("sram start     ",	(ulong)bd->bi_sramstart);
2632e192b24SSimon Glass 	print_num("sram size      ",	(ulong)bd->bi_sramsize);
2642e192b24SSimon Glass #endif
265062f078cSMichal Simek #if defined(CONFIG_CMD_NET) && !defined(CONFIG_DM_ETH)
2662e192b24SSimon Glass 	print_eths();
2672e192b24SSimon Glass #endif
2684e3fa7d8SMax Filippov 	print_baudrate();
2692e192b24SSimon Glass 	print_num("relocaddr", gd->relocaddr);
2702e192b24SSimon Glass 	print_num("reloc off", gd->reloc_off);
2712e192b24SSimon Glass 	print_num("fdt_blob", (ulong)gd->fdt_blob);
2722e192b24SSimon Glass 	print_num("new_fdt", (ulong)gd->new_fdt);
2732e192b24SSimon Glass 	print_num("fdt_size", (ulong)gd->fdt_size);
2742e192b24SSimon Glass 
2752e192b24SSimon Glass 	return 0;
2762e192b24SSimon Glass }
2772e192b24SSimon Glass 
2782e192b24SSimon Glass #elif defined(CONFIG_M68K)
2792e192b24SSimon Glass 
2802e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
2812e192b24SSimon Glass {
2822e192b24SSimon Glass 	bd_t *bd = gd->bd;
2832e192b24SSimon Glass 
28412feb364SMax Filippov 	print_bi_mem(bd);
285f80e5359SMax Filippov 	print_bi_flash(bd);
2862e192b24SSimon Glass #if defined(CONFIG_SYS_INIT_RAM_ADDR)
2872e192b24SSimon Glass 	print_num("sramstart",		(ulong)bd->bi_sramstart);
2882e192b24SSimon Glass 	print_num("sramsize",		(ulong)bd->bi_sramsize);
2892e192b24SSimon Glass #endif
2902e192b24SSimon Glass #if defined(CONFIG_SYS_MBAR)
2912e192b24SSimon Glass 	print_num("mbar",		bd->bi_mbar_base);
2922e192b24SSimon Glass #endif
2932e192b24SSimon Glass 	print_mhz("cpufreq",		bd->bi_intfreq);
2942e192b24SSimon Glass 	print_mhz("busfreq",		bd->bi_busfreq);
2952e192b24SSimon Glass #ifdef CONFIG_PCI
2962e192b24SSimon Glass 	print_mhz("pcifreq",		bd->bi_pcifreq);
2972e192b24SSimon Glass #endif
2982e192b24SSimon Glass #ifdef CONFIG_EXTRA_CLOCK
2992e192b24SSimon Glass 	print_mhz("flbfreq",		bd->bi_flbfreq);
3002e192b24SSimon Glass 	print_mhz("inpfreq",		bd->bi_inpfreq);
3012e192b24SSimon Glass 	print_mhz("vcofreq",		bd->bi_vcofreq);
3022e192b24SSimon Glass #endif
3038752e260SMax Filippov 	print_eth_ip_addr();
3044e3fa7d8SMax Filippov 	print_baudrate();
3052e192b24SSimon Glass 
3062e192b24SSimon Glass 	return 0;
3072e192b24SSimon Glass }
3082e192b24SSimon Glass 
3092e192b24SSimon Glass #elif defined(CONFIG_MIPS)
3102e192b24SSimon Glass 
3112e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
3122e192b24SSimon Glass {
313e3795084SMax Filippov 	print_std_bdinfo(gd->bd);
3148cf7a418STim Chick 	print_num("relocaddr", gd->relocaddr);
3158cf7a418STim Chick 	print_num("reloc off", gd->reloc_off);
3162e192b24SSimon Glass 
3172e192b24SSimon Glass 	return 0;
3182e192b24SSimon Glass }
3192e192b24SSimon Glass 
3202e192b24SSimon Glass #elif defined(CONFIG_AVR32)
3212e192b24SSimon Glass 
3222e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
3232e192b24SSimon Glass {
324e3795084SMax Filippov 	print_std_bdinfo(gd->bd);
3252e192b24SSimon Glass 	return 0;
3262e192b24SSimon Glass }
3272e192b24SSimon Glass 
3282e192b24SSimon Glass #elif defined(CONFIG_ARM)
3292e192b24SSimon Glass 
3302e192b24SSimon Glass static int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc,
3312e192b24SSimon Glass 			char * const argv[])
3322e192b24SSimon Glass {
3332e192b24SSimon Glass 	bd_t *bd = gd->bd;
3342e192b24SSimon Glass 
3352e192b24SSimon Glass 	print_num("arch_number",	bd->bi_arch_number);
336171e5396SMax Filippov 	print_bi_boot_params(bd);
337fd60e99fSMax Filippov 	print_bi_dram(bd);
3382e192b24SSimon Glass 
3392e192b24SSimon Glass #ifdef CONFIG_SYS_MEM_RESERVE_SECURE
340e61a7534SYork Sun 	if (gd->arch.secure_ram & MEM_RESERVE_SECURE_SECURED) {
3412e192b24SSimon Glass 		print_num("Secure ram",
342e61a7534SYork Sun 			  gd->arch.secure_ram & MEM_RESERVE_SECURE_ADDR_MASK);
3432e192b24SSimon Glass 	}
3442e192b24SSimon Glass #endif
345f2ccf7f7SYork Sun #ifdef CONFIG_RESV_RAM
346f2ccf7f7SYork Sun 	if (gd->arch.resv_ram)
347f2ccf7f7SYork Sun 		print_num("Reserved ram", gd->arch.resv_ram);
348f2ccf7f7SYork Sun #endif
3492e192b24SSimon Glass #if defined(CONFIG_CMD_NET) && !defined(CONFIG_DM_ETH)
3502e192b24SSimon Glass 	print_eths();
3512e192b24SSimon Glass #endif
3524e3fa7d8SMax Filippov 	print_baudrate();
3532e192b24SSimon Glass #if !(defined(CONFIG_SYS_ICACHE_OFF) && defined(CONFIG_SYS_DCACHE_OFF))
3542e192b24SSimon Glass 	print_num("TLB addr", gd->arch.tlb_addr);
3552e192b24SSimon Glass #endif
3562e192b24SSimon Glass 	print_num("relocaddr", gd->relocaddr);
3572e192b24SSimon Glass 	print_num("reloc off", gd->reloc_off);
3582e192b24SSimon Glass 	print_num("irq_sp", gd->irq_sp);	/* irq stack pointer */
3592e192b24SSimon Glass 	print_num("sp start ", gd->start_addr_sp);
3602e192b24SSimon Glass #if defined(CONFIG_LCD) || defined(CONFIG_VIDEO)
3612e192b24SSimon Glass 	print_num("FB base  ", gd->fb_base);
3622e192b24SSimon Glass #endif
3632e192b24SSimon Glass 	/*
3642e192b24SSimon Glass 	 * TODO: Currently only support for davinci SOC's is added.
3652e192b24SSimon Glass 	 * Remove this check once all the board implement this.
3662e192b24SSimon Glass 	 */
3672e192b24SSimon Glass #ifdef CONFIG_CLOCKS
3682e192b24SSimon Glass 	printf("ARM frequency = %ld MHz\n", gd->bd->bi_arm_freq);
3692e192b24SSimon Glass 	printf("DSP frequency = %ld MHz\n", gd->bd->bi_dsp_freq);
3702e192b24SSimon Glass 	printf("DDR frequency = %ld MHz\n", gd->bd->bi_ddr_freq);
3712e192b24SSimon Glass #endif
3722e192b24SSimon Glass #ifdef CONFIG_BOARD_TYPES
3732e192b24SSimon Glass 	printf("Board Type  = %ld\n", gd->board_type);
3742e192b24SSimon Glass #endif
3757f7ddf2aSSimon Glass #ifdef CONFIG_SYS_MALLOC_F
3767f7ddf2aSSimon Glass 	printf("Early malloc usage: %lx / %x\n", gd->malloc_ptr,
3777f7ddf2aSSimon Glass 	       CONFIG_SYS_MALLOC_F_LEN);
3787f7ddf2aSSimon Glass #endif
3797f7ddf2aSSimon Glass 
3802e192b24SSimon Glass 	return 0;
3812e192b24SSimon Glass }
3822e192b24SSimon Glass 
3832e192b24SSimon Glass #elif defined(CONFIG_SH)
3842e192b24SSimon Glass 
3852e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
3862e192b24SSimon Glass {
3872e192b24SSimon Glass 	bd_t *bd = gd->bd;
38812feb364SMax Filippov 
38912feb364SMax Filippov 	print_bi_mem(bd);
390f80e5359SMax Filippov 	print_bi_flash(bd);
3918752e260SMax Filippov 	print_eth_ip_addr();
3924e3fa7d8SMax Filippov 	print_baudrate();
3932e192b24SSimon Glass 	return 0;
3942e192b24SSimon Glass }
3952e192b24SSimon Glass 
3962e192b24SSimon Glass #elif defined(CONFIG_X86)
3972e192b24SSimon Glass 
3982e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
3992e192b24SSimon Glass {
4002e192b24SSimon Glass 	bd_t *bd = gd->bd;
4012e192b24SSimon Glass 
402171e5396SMax Filippov 	print_bi_boot_params(bd);
4032e192b24SSimon Glass 
404fd60e99fSMax Filippov 	print_bi_dram(bd);
4052e192b24SSimon Glass 
4062e192b24SSimon Glass #if defined(CONFIG_CMD_NET)
4078752e260SMax Filippov 	print_eth_ip_addr();
4082e192b24SSimon Glass 	print_mhz("ethspeed",	    bd->bi_ethspeed);
4092e192b24SSimon Glass #endif
4104e3fa7d8SMax Filippov 	print_baudrate();
4112e192b24SSimon Glass 
4122e192b24SSimon Glass 	return 0;
4132e192b24SSimon Glass }
4142e192b24SSimon Glass 
4152e192b24SSimon Glass #elif defined(CONFIG_SANDBOX)
4162e192b24SSimon Glass 
4172e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
4182e192b24SSimon Glass {
4192e192b24SSimon Glass 	bd_t *bd = gd->bd;
4202e192b24SSimon Glass 
421171e5396SMax Filippov 	print_bi_boot_params(bd);
422fd60e99fSMax Filippov 	print_bi_dram(bd);
4238752e260SMax Filippov 	print_eth_ip_addr();
4242e192b24SSimon Glass 
4252e192b24SSimon Glass #if defined(CONFIG_LCD) || defined(CONFIG_VIDEO)
4262e192b24SSimon Glass 	print_num("FB base  ", gd->fb_base);
4272e192b24SSimon Glass #endif
4282e192b24SSimon Glass 	return 0;
4292e192b24SSimon Glass }
4302e192b24SSimon Glass 
4312e192b24SSimon Glass #elif defined(CONFIG_NDS32)
4322e192b24SSimon Glass 
4332e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
4342e192b24SSimon Glass {
4352e192b24SSimon Glass 	bd_t *bd = gd->bd;
4362e192b24SSimon Glass 
4372e192b24SSimon Glass 	print_num("arch_number",	bd->bi_arch_number);
438171e5396SMax Filippov 	print_bi_boot_params(bd);
439fd60e99fSMax Filippov 	print_bi_dram(bd);
4408752e260SMax Filippov 	print_eth_ip_addr();
4414e3fa7d8SMax Filippov 	print_baudrate();
4422e192b24SSimon Glass 
4432e192b24SSimon Glass 	return 0;
4442e192b24SSimon Glass }
4452e192b24SSimon Glass 
4462e192b24SSimon Glass #elif defined(CONFIG_ARC)
4472e192b24SSimon Glass 
4482e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
4492e192b24SSimon Glass {
4502e192b24SSimon Glass 	bd_t *bd = gd->bd;
4512e192b24SSimon Glass 
45212feb364SMax Filippov 	print_bi_mem(bd);
4538752e260SMax Filippov 	print_eth_ip_addr();
4544e3fa7d8SMax Filippov 	print_baudrate();
4552e192b24SSimon Glass 
4562e192b24SSimon Glass 	return 0;
4572e192b24SSimon Glass }
4582e192b24SSimon Glass 
459de5e5ceaSChris Zankel #elif defined(CONFIG_XTENSA)
460de5e5ceaSChris Zankel 
461de5e5ceaSChris Zankel int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
462de5e5ceaSChris Zankel {
463de5e5ceaSChris Zankel 	print_std_bdinfo(gd->bd);
464de5e5ceaSChris Zankel 	return 0;
465de5e5ceaSChris Zankel }
466de5e5ceaSChris Zankel 
4672e192b24SSimon Glass #else
4682e192b24SSimon Glass  #error "a case for this architecture does not exist!"
4692e192b24SSimon Glass #endif
4702e192b24SSimon Glass 
4712e192b24SSimon Glass /* -------------------------------------------------------------------- */
4722e192b24SSimon Glass 
4732e192b24SSimon Glass U_BOOT_CMD(
4742e192b24SSimon Glass 	bdinfo,	1,	1,	do_bdinfo,
4752e192b24SSimon Glass 	"print Board Info structure",
4762e192b24SSimon Glass 	""
4772e192b24SSimon Glass );
478