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