xref: /rk3399_rockchip-uboot/cmd/bdinfo.c (revision ddd917b8fa32c3ef5e2609282d7e5d8f299f1872)
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) {
101*ddd917b8SSimon 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 		}
106*ddd917b8SSimon 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 
117f80e5359SMax Filippov #elif defined(CONFIG_NIOS2) || defined(CONFIG_OPENRISC)
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 #elif defined(CONFIG_SPARC)
1564e3fa7d8SMax Filippov 	printf("baudrate               = %6u bps\n", gd->baudrate);
1574e3fa7d8SMax Filippov #else
1584e3fa7d8SMax Filippov 	printf("baudrate    = %u bps\n", gd->baudrate);
1594e3fa7d8SMax Filippov #endif
1604e3fa7d8SMax Filippov }
1614e3fa7d8SMax Filippov 
162e3795084SMax Filippov static inline void print_std_bdinfo(const bd_t *bd)
163e3795084SMax Filippov {
164e3795084SMax Filippov 	print_bi_boot_params(bd);
165e3795084SMax Filippov 	print_bi_mem(bd);
166e3795084SMax Filippov 	print_bi_flash(bd);
167e3795084SMax Filippov 	print_eth_ip_addr();
168e3795084SMax Filippov 	print_baudrate();
169e3795084SMax Filippov }
170e3795084SMax Filippov 
1712e192b24SSimon Glass #if defined(CONFIG_PPC)
1722e192b24SSimon Glass void __weak board_detail(void)
1732e192b24SSimon Glass {
1742e192b24SSimon Glass 	/* Please define boot_detail() for your platform */
1752e192b24SSimon Glass }
1762e192b24SSimon Glass 
1772e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
1782e192b24SSimon Glass {
1792e192b24SSimon Glass 	bd_t *bd = gd->bd;
1802e192b24SSimon Glass 
1812e192b24SSimon Glass #ifdef DEBUG
1822e192b24SSimon Glass 	print_num("bd address",		(ulong)bd);
1832e192b24SSimon Glass #endif
18412feb364SMax Filippov 	print_bi_mem(bd);
185f80e5359SMax Filippov 	print_bi_flash(bd);
1862e192b24SSimon Glass 	print_num("sramstart",		bd->bi_sramstart);
1872e192b24SSimon Glass 	print_num("sramsize",		bd->bi_sramsize);
1882e192b24SSimon Glass #if	defined(CONFIG_5xx)  || defined(CONFIG_8xx) || \
1892e192b24SSimon Glass 	defined(CONFIG_MPC8260) || defined(CONFIG_E500)
1902e192b24SSimon Glass 	print_num("immr_base",		bd->bi_immr_base);
1912e192b24SSimon Glass #endif
1922e192b24SSimon Glass 	print_num("bootflags",		bd->bi_bootflags);
1932e192b24SSimon Glass #if	defined(CONFIG_405EP) || \
1942e192b24SSimon Glass 	defined(CONFIG_405GP) || \
1952e192b24SSimon Glass 	defined(CONFIG_440EP) || defined(CONFIG_440EPX) || \
1962e192b24SSimon Glass 	defined(CONFIG_440GR) || defined(CONFIG_440GRX) || \
1972e192b24SSimon Glass 	defined(CONFIG_440SP) || defined(CONFIG_440SPE) || \
1982e192b24SSimon Glass 	defined(CONFIG_XILINX_405)
1992e192b24SSimon Glass 	print_mhz("procfreq",		bd->bi_procfreq);
2002e192b24SSimon Glass 	print_mhz("plb_busfreq",	bd->bi_plb_busfreq);
2012e192b24SSimon Glass #if	defined(CONFIG_405EP) || defined(CONFIG_405GP) || \
2022e192b24SSimon Glass 	defined(CONFIG_440EP) || defined(CONFIG_440EPX) || \
2032e192b24SSimon Glass 	defined(CONFIG_440GR) || defined(CONFIG_440GRX) || \
2042e192b24SSimon Glass 	defined(CONFIG_440SPE) || defined(CONFIG_XILINX_405)
2052e192b24SSimon Glass 	print_mhz("pci_busfreq",	bd->bi_pci_busfreq);
2062e192b24SSimon Glass #endif
2072e192b24SSimon Glass #else	/* ! CONFIG_405GP, CONFIG_405EP, CONFIG_XILINX_405, CONFIG_440EP CONFIG_440GR */
2082e192b24SSimon Glass #if defined(CONFIG_CPM2)
2092e192b24SSimon Glass 	print_mhz("vco",		bd->bi_vco);
2102e192b24SSimon Glass 	print_mhz("sccfreq",		bd->bi_sccfreq);
2112e192b24SSimon Glass 	print_mhz("brgfreq",		bd->bi_brgfreq);
2122e192b24SSimon Glass #endif
2132e192b24SSimon Glass 	print_mhz("intfreq",		bd->bi_intfreq);
2142e192b24SSimon Glass #if defined(CONFIG_CPM2)
2152e192b24SSimon Glass 	print_mhz("cpmfreq",		bd->bi_cpmfreq);
2162e192b24SSimon Glass #endif
2172e192b24SSimon Glass 	print_mhz("busfreq",		bd->bi_busfreq);
2182e192b24SSimon Glass #endif /* CONFIG_405GP, CONFIG_405EP, CONFIG_XILINX_405, CONFIG_440EP CONFIG_440GR */
2192e192b24SSimon Glass 
2202e192b24SSimon Glass #ifdef CONFIG_ENABLE_36BIT_PHYS
2212e192b24SSimon Glass #ifdef CONFIG_PHYS_64BIT
2222e192b24SSimon Glass 	puts("addressing  = 36-bit\n");
2232e192b24SSimon Glass #else
2242e192b24SSimon Glass 	puts("addressing  = 32-bit\n");
2252e192b24SSimon Glass #endif
2262e192b24SSimon Glass #endif
2272e192b24SSimon Glass 
2288752e260SMax Filippov 	print_eth_ip_addr();
2294e3fa7d8SMax Filippov 	print_baudrate();
2302e192b24SSimon Glass 	print_num("relocaddr", gd->relocaddr);
2312e192b24SSimon Glass 	board_detail();
2322e192b24SSimon Glass 	return 0;
2332e192b24SSimon Glass }
2342e192b24SSimon Glass 
2352e192b24SSimon Glass #elif defined(CONFIG_NIOS2)
2362e192b24SSimon Glass 
2372e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
2382e192b24SSimon Glass {
2392e192b24SSimon Glass 	bd_t *bd = gd->bd;
2402e192b24SSimon Glass 
241fd60e99fSMax Filippov 	print_bi_dram(bd);
242f80e5359SMax Filippov 	print_bi_flash(bd);
2432e192b24SSimon Glass 
2442e192b24SSimon Glass #if defined(CONFIG_SYS_SRAM_BASE)
2452e192b24SSimon Glass 	print_num ("sram start",	(ulong)bd->bi_sramstart);
2462e192b24SSimon Glass 	print_num ("sram size",		(ulong)bd->bi_sramsize);
2472e192b24SSimon Glass #endif
2482e192b24SSimon Glass 
2498752e260SMax Filippov 	print_eth_ip_addr();
2504e3fa7d8SMax Filippov 	print_baudrate();
2512e192b24SSimon Glass 
2522e192b24SSimon Glass 	return 0;
2532e192b24SSimon Glass }
2542e192b24SSimon Glass 
2552e192b24SSimon Glass #elif defined(CONFIG_MICROBLAZE)
2562e192b24SSimon Glass 
2572e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
2582e192b24SSimon Glass {
2592e192b24SSimon Glass 	bd_t *bd = gd->bd;
2602e192b24SSimon Glass 
261fd60e99fSMax Filippov 	print_bi_dram(bd);
262f80e5359SMax Filippov 	print_bi_flash(bd);
2632e192b24SSimon Glass #if defined(CONFIG_SYS_SRAM_BASE)
2642e192b24SSimon Glass 	print_num("sram start     ",	(ulong)bd->bi_sramstart);
2652e192b24SSimon Glass 	print_num("sram size      ",	(ulong)bd->bi_sramsize);
2662e192b24SSimon Glass #endif
267062f078cSMichal Simek #if defined(CONFIG_CMD_NET) && !defined(CONFIG_DM_ETH)
2682e192b24SSimon Glass 	print_eths();
2692e192b24SSimon Glass #endif
2704e3fa7d8SMax Filippov 	print_baudrate();
2712e192b24SSimon Glass 	print_num("relocaddr", gd->relocaddr);
2722e192b24SSimon Glass 	print_num("reloc off", gd->reloc_off);
2732e192b24SSimon Glass 	print_num("fdt_blob", (ulong)gd->fdt_blob);
2742e192b24SSimon Glass 	print_num("new_fdt", (ulong)gd->new_fdt);
2752e192b24SSimon Glass 	print_num("fdt_size", (ulong)gd->fdt_size);
2762e192b24SSimon Glass 
2772e192b24SSimon Glass 	return 0;
2782e192b24SSimon Glass }
2792e192b24SSimon Glass 
2802e192b24SSimon Glass #elif defined(CONFIG_SPARC)
2812e192b24SSimon Glass 
2822e192b24SSimon Glass int do_bdinfo(cmd_tbl_t * cmdtp, int flag, int argc, char * const argv[])
2832e192b24SSimon Glass {
2842e192b24SSimon Glass 	bd_t *bd = gd->bd;
2852e192b24SSimon Glass 
2862e192b24SSimon Glass #ifdef DEBUG
2872e192b24SSimon Glass 	print_num("bd address             ", (ulong) bd);
2882e192b24SSimon Glass #endif
2892e192b24SSimon Glass 	print_num("memstart               ", bd->bi_memstart);
2902e192b24SSimon Glass 	print_lnum("memsize                ", bd->bi_memsize);
2912e192b24SSimon Glass 	print_num("flashstart             ", bd->bi_flashstart);
2922e192b24SSimon Glass 	print_num("CONFIG_SYS_MONITOR_BASE       ", CONFIG_SYS_MONITOR_BASE);
2932e192b24SSimon Glass 	print_num("CONFIG_ENV_ADDR           ", CONFIG_ENV_ADDR);
2942e192b24SSimon Glass 	printf("CONFIG_SYS_RELOC_MONITOR_BASE = 0x%x (%d)\n", CONFIG_SYS_RELOC_MONITOR_BASE,
2952e192b24SSimon Glass 	       CONFIG_SYS_MONITOR_LEN);
2962e192b24SSimon Glass 	printf("CONFIG_SYS_MALLOC_BASE        = 0x%x (%d)\n", CONFIG_SYS_MALLOC_BASE,
2972e192b24SSimon Glass 	       CONFIG_SYS_MALLOC_LEN);
2982e192b24SSimon Glass 	printf("CONFIG_SYS_INIT_SP_OFFSET     = 0x%x (%d)\n", CONFIG_SYS_INIT_SP_OFFSET,
2992e192b24SSimon Glass 	       CONFIG_SYS_STACK_SIZE);
3002e192b24SSimon Glass 	printf("CONFIG_SYS_PROM_OFFSET        = 0x%x (%d)\n", CONFIG_SYS_PROM_OFFSET,
3012e192b24SSimon Glass 	       CONFIG_SYS_PROM_SIZE);
3022e192b24SSimon Glass 	printf("CONFIG_SYS_GBL_DATA_OFFSET    = 0x%x (%d)\n", CONFIG_SYS_GBL_DATA_OFFSET,
3032e192b24SSimon Glass 	       GENERATED_GBL_DATA_SIZE);
3042e192b24SSimon Glass 
3058752e260SMax Filippov 	print_eth_ip_addr();
3064e3fa7d8SMax Filippov 	print_baudrate();
3072e192b24SSimon Glass 	return 0;
3082e192b24SSimon Glass }
3092e192b24SSimon Glass 
3102e192b24SSimon Glass #elif defined(CONFIG_M68K)
3112e192b24SSimon Glass 
3122e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
3132e192b24SSimon Glass {
3142e192b24SSimon Glass 	bd_t *bd = gd->bd;
3152e192b24SSimon Glass 
31612feb364SMax Filippov 	print_bi_mem(bd);
317f80e5359SMax Filippov 	print_bi_flash(bd);
3182e192b24SSimon Glass #if defined(CONFIG_SYS_INIT_RAM_ADDR)
3192e192b24SSimon Glass 	print_num("sramstart",		(ulong)bd->bi_sramstart);
3202e192b24SSimon Glass 	print_num("sramsize",		(ulong)bd->bi_sramsize);
3212e192b24SSimon Glass #endif
3222e192b24SSimon Glass #if defined(CONFIG_SYS_MBAR)
3232e192b24SSimon Glass 	print_num("mbar",		bd->bi_mbar_base);
3242e192b24SSimon Glass #endif
3252e192b24SSimon Glass 	print_mhz("cpufreq",		bd->bi_intfreq);
3262e192b24SSimon Glass 	print_mhz("busfreq",		bd->bi_busfreq);
3272e192b24SSimon Glass #ifdef CONFIG_PCI
3282e192b24SSimon Glass 	print_mhz("pcifreq",		bd->bi_pcifreq);
3292e192b24SSimon Glass #endif
3302e192b24SSimon Glass #ifdef CONFIG_EXTRA_CLOCK
3312e192b24SSimon Glass 	print_mhz("flbfreq",		bd->bi_flbfreq);
3322e192b24SSimon Glass 	print_mhz("inpfreq",		bd->bi_inpfreq);
3332e192b24SSimon Glass 	print_mhz("vcofreq",		bd->bi_vcofreq);
3342e192b24SSimon Glass #endif
3358752e260SMax Filippov 	print_eth_ip_addr();
3364e3fa7d8SMax Filippov 	print_baudrate();
3372e192b24SSimon Glass 
3382e192b24SSimon Glass 	return 0;
3392e192b24SSimon Glass }
3402e192b24SSimon Glass 
3412e192b24SSimon Glass #elif defined(CONFIG_BLACKFIN)
3422e192b24SSimon Glass 
3432e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
3442e192b24SSimon Glass {
3452e192b24SSimon Glass 	bd_t *bd = gd->bd;
3462e192b24SSimon Glass 
3472e192b24SSimon Glass 	printf("U-Boot      = %s\n", bd->bi_r_version);
3482e192b24SSimon Glass 	printf("CPU         = %s\n", bd->bi_cpu);
3492e192b24SSimon Glass 	printf("Board       = %s\n", bd->bi_board_name);
3502e192b24SSimon Glass 	print_mhz("VCO",	bd->bi_vco);
3512e192b24SSimon Glass 	print_mhz("CCLK",	bd->bi_cclk);
3522e192b24SSimon Glass 	print_mhz("SCLK",	bd->bi_sclk);
3532e192b24SSimon Glass 
354e3795084SMax Filippov 	print_std_bdinfo(bd);
3552e192b24SSimon Glass 
3562e192b24SSimon Glass 	return 0;
3572e192b24SSimon Glass }
3582e192b24SSimon Glass 
3592e192b24SSimon Glass #elif defined(CONFIG_MIPS)
3602e192b24SSimon Glass 
3612e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
3622e192b24SSimon Glass {
363e3795084SMax Filippov 	print_std_bdinfo(gd->bd);
3648cf7a418STim Chick 	print_num("relocaddr", gd->relocaddr);
3658cf7a418STim Chick 	print_num("reloc off", gd->reloc_off);
3662e192b24SSimon Glass 
3672e192b24SSimon Glass 	return 0;
3682e192b24SSimon Glass }
3692e192b24SSimon Glass 
3702e192b24SSimon Glass #elif defined(CONFIG_AVR32)
3712e192b24SSimon Glass 
3722e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
3732e192b24SSimon Glass {
374e3795084SMax Filippov 	print_std_bdinfo(gd->bd);
3752e192b24SSimon Glass 	return 0;
3762e192b24SSimon Glass }
3772e192b24SSimon Glass 
3782e192b24SSimon Glass #elif defined(CONFIG_ARM)
3792e192b24SSimon Glass 
3802e192b24SSimon Glass static int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc,
3812e192b24SSimon Glass 			char * const argv[])
3822e192b24SSimon Glass {
3832e192b24SSimon Glass 	bd_t *bd = gd->bd;
3842e192b24SSimon Glass 
3852e192b24SSimon Glass 	print_num("arch_number",	bd->bi_arch_number);
386171e5396SMax Filippov 	print_bi_boot_params(bd);
387fd60e99fSMax Filippov 	print_bi_dram(bd);
3882e192b24SSimon Glass 
3892e192b24SSimon Glass #ifdef CONFIG_SYS_MEM_RESERVE_SECURE
390e61a7534SYork Sun 	if (gd->arch.secure_ram & MEM_RESERVE_SECURE_SECURED) {
3912e192b24SSimon Glass 		print_num("Secure ram",
392e61a7534SYork Sun 			  gd->arch.secure_ram & MEM_RESERVE_SECURE_ADDR_MASK);
3932e192b24SSimon Glass 	}
3942e192b24SSimon Glass #endif
3952e192b24SSimon Glass #if defined(CONFIG_CMD_NET) && !defined(CONFIG_DM_ETH)
3962e192b24SSimon Glass 	print_eths();
3972e192b24SSimon Glass #endif
3984e3fa7d8SMax Filippov 	print_baudrate();
3992e192b24SSimon Glass #if !(defined(CONFIG_SYS_ICACHE_OFF) && defined(CONFIG_SYS_DCACHE_OFF))
4002e192b24SSimon Glass 	print_num("TLB addr", gd->arch.tlb_addr);
4012e192b24SSimon Glass #endif
4022e192b24SSimon Glass 	print_num("relocaddr", gd->relocaddr);
4032e192b24SSimon Glass 	print_num("reloc off", gd->reloc_off);
4042e192b24SSimon Glass 	print_num("irq_sp", gd->irq_sp);	/* irq stack pointer */
4052e192b24SSimon Glass 	print_num("sp start ", gd->start_addr_sp);
4062e192b24SSimon Glass #if defined(CONFIG_LCD) || defined(CONFIG_VIDEO)
4072e192b24SSimon Glass 	print_num("FB base  ", gd->fb_base);
4082e192b24SSimon Glass #endif
4092e192b24SSimon Glass 	/*
4102e192b24SSimon Glass 	 * TODO: Currently only support for davinci SOC's is added.
4112e192b24SSimon Glass 	 * Remove this check once all the board implement this.
4122e192b24SSimon Glass 	 */
4132e192b24SSimon Glass #ifdef CONFIG_CLOCKS
4142e192b24SSimon Glass 	printf("ARM frequency = %ld MHz\n", gd->bd->bi_arm_freq);
4152e192b24SSimon Glass 	printf("DSP frequency = %ld MHz\n", gd->bd->bi_dsp_freq);
4162e192b24SSimon Glass 	printf("DDR frequency = %ld MHz\n", gd->bd->bi_ddr_freq);
4172e192b24SSimon Glass #endif
4182e192b24SSimon Glass #ifdef CONFIG_BOARD_TYPES
4192e192b24SSimon Glass 	printf("Board Type  = %ld\n", gd->board_type);
4202e192b24SSimon Glass #endif
4217f7ddf2aSSimon Glass #ifdef CONFIG_SYS_MALLOC_F
4227f7ddf2aSSimon Glass 	printf("Early malloc usage: %lx / %x\n", gd->malloc_ptr,
4237f7ddf2aSSimon Glass 	       CONFIG_SYS_MALLOC_F_LEN);
4247f7ddf2aSSimon Glass #endif
4257f7ddf2aSSimon Glass 
4262e192b24SSimon Glass 	return 0;
4272e192b24SSimon Glass }
4282e192b24SSimon Glass 
4292e192b24SSimon Glass #elif defined(CONFIG_SH)
4302e192b24SSimon Glass 
4312e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
4322e192b24SSimon Glass {
4332e192b24SSimon Glass 	bd_t *bd = gd->bd;
43412feb364SMax Filippov 
43512feb364SMax Filippov 	print_bi_mem(bd);
436f80e5359SMax Filippov 	print_bi_flash(bd);
4378752e260SMax Filippov 	print_eth_ip_addr();
4384e3fa7d8SMax Filippov 	print_baudrate();
4392e192b24SSimon Glass 	return 0;
4402e192b24SSimon Glass }
4412e192b24SSimon Glass 
4422e192b24SSimon Glass #elif defined(CONFIG_X86)
4432e192b24SSimon Glass 
4442e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
4452e192b24SSimon Glass {
4462e192b24SSimon Glass 	bd_t *bd = gd->bd;
4472e192b24SSimon Glass 
448171e5396SMax Filippov 	print_bi_boot_params(bd);
4492e192b24SSimon Glass 	print_num("bi_memstart",	bd->bi_memstart);
4502e192b24SSimon Glass 	print_num("bi_memsize",		bd->bi_memsize);
4512e192b24SSimon Glass 	print_num("bi_flashstart",	bd->bi_flashstart);
4522e192b24SSimon Glass 	print_num("bi_flashsize",	bd->bi_flashsize);
4532e192b24SSimon Glass 	print_num("bi_flashoffset",	bd->bi_flashoffset);
4542e192b24SSimon Glass 	print_num("bi_sramstart",	bd->bi_sramstart);
4552e192b24SSimon Glass 	print_num("bi_sramsize",	bd->bi_sramsize);
4562e192b24SSimon Glass 	print_num("bi_bootflags",	bd->bi_bootflags);
4572e192b24SSimon Glass 	print_mhz("cpufreq",		bd->bi_intfreq);
4582e192b24SSimon Glass 	print_mhz("busfreq",		bd->bi_busfreq);
4592e192b24SSimon Glass 
460fd60e99fSMax Filippov 	print_bi_dram(bd);
4612e192b24SSimon Glass 
4622e192b24SSimon Glass #if defined(CONFIG_CMD_NET)
4638752e260SMax Filippov 	print_eth_ip_addr();
4642e192b24SSimon Glass 	print_mhz("ethspeed",	    bd->bi_ethspeed);
4652e192b24SSimon Glass #endif
4664e3fa7d8SMax Filippov 	print_baudrate();
4672e192b24SSimon Glass 
4682e192b24SSimon Glass 	return 0;
4692e192b24SSimon Glass }
4702e192b24SSimon Glass 
4712e192b24SSimon Glass #elif defined(CONFIG_SANDBOX)
4722e192b24SSimon Glass 
4732e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
4742e192b24SSimon Glass {
4752e192b24SSimon Glass 	bd_t *bd = gd->bd;
4762e192b24SSimon Glass 
477171e5396SMax Filippov 	print_bi_boot_params(bd);
478fd60e99fSMax Filippov 	print_bi_dram(bd);
4798752e260SMax Filippov 	print_eth_ip_addr();
4802e192b24SSimon Glass 
4812e192b24SSimon Glass #if defined(CONFIG_LCD) || defined(CONFIG_VIDEO)
4822e192b24SSimon Glass 	print_num("FB base  ", gd->fb_base);
4832e192b24SSimon Glass #endif
4842e192b24SSimon Glass 	return 0;
4852e192b24SSimon Glass }
4862e192b24SSimon Glass 
4872e192b24SSimon Glass #elif defined(CONFIG_NDS32)
4882e192b24SSimon Glass 
4892e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
4902e192b24SSimon Glass {
4912e192b24SSimon Glass 	bd_t *bd = gd->bd;
4922e192b24SSimon Glass 
4932e192b24SSimon Glass 	print_num("arch_number",	bd->bi_arch_number);
494171e5396SMax Filippov 	print_bi_boot_params(bd);
495fd60e99fSMax Filippov 	print_bi_dram(bd);
4968752e260SMax Filippov 	print_eth_ip_addr();
4974e3fa7d8SMax Filippov 	print_baudrate();
4982e192b24SSimon Glass 
4992e192b24SSimon Glass 	return 0;
5002e192b24SSimon Glass }
5012e192b24SSimon Glass 
5022e192b24SSimon Glass #elif defined(CONFIG_OPENRISC)
5032e192b24SSimon Glass 
5042e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
5052e192b24SSimon Glass {
5062e192b24SSimon Glass 	bd_t *bd = gd->bd;
5072e192b24SSimon Glass 
50812feb364SMax Filippov 	print_bi_mem(bd);
509f80e5359SMax Filippov 	print_bi_flash(bd);
5108752e260SMax Filippov 	print_eth_ip_addr();
5114e3fa7d8SMax Filippov 	print_baudrate();
5122e192b24SSimon Glass 
5132e192b24SSimon Glass 	return 0;
5142e192b24SSimon Glass }
5152e192b24SSimon Glass 
5162e192b24SSimon Glass #elif defined(CONFIG_ARC)
5172e192b24SSimon Glass 
5182e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
5192e192b24SSimon Glass {
5202e192b24SSimon Glass 	bd_t *bd = gd->bd;
5212e192b24SSimon Glass 
52212feb364SMax Filippov 	print_bi_mem(bd);
5238752e260SMax Filippov 	print_eth_ip_addr();
5244e3fa7d8SMax Filippov 	print_baudrate();
5252e192b24SSimon Glass 
5262e192b24SSimon Glass 	return 0;
5272e192b24SSimon Glass }
5282e192b24SSimon Glass 
529de5e5ceaSChris Zankel #elif defined(CONFIG_XTENSA)
530de5e5ceaSChris Zankel 
531de5e5ceaSChris Zankel int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
532de5e5ceaSChris Zankel {
533de5e5ceaSChris Zankel 	print_std_bdinfo(gd->bd);
534de5e5ceaSChris Zankel 	return 0;
535de5e5ceaSChris Zankel }
536de5e5ceaSChris Zankel 
5372e192b24SSimon Glass #else
5382e192b24SSimon Glass  #error "a case for this architecture does not exist!"
5392e192b24SSimon Glass #endif
5402e192b24SSimon Glass 
5412e192b24SSimon Glass /* -------------------------------------------------------------------- */
5422e192b24SSimon Glass 
5432e192b24SSimon Glass U_BOOT_CMD(
5442e192b24SSimon Glass 	bdinfo,	1,	1,	do_bdinfo,
5452e192b24SSimon Glass 	"print Board Info structure",
5462e192b24SSimon Glass 	""
5472e192b24SSimon Glass );
548