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 #else 8712feb364SMax Filippov print_num("memstart", (ulong)bd->bi_memstart); 8812feb364SMax Filippov print_lnum("memsize", (u64)bd->bi_memsize); 8912feb364SMax Filippov #endif 9012feb364SMax Filippov } 9112feb364SMax Filippov 92fd60e99fSMax Filippov static inline void print_bi_dram(const bd_t *bd) 93fd60e99fSMax Filippov { 94fd60e99fSMax Filippov #ifdef CONFIG_NR_DRAM_BANKS 95fd60e99fSMax Filippov int i; 96fd60e99fSMax Filippov 97fd60e99fSMax Filippov for (i = 0; i < CONFIG_NR_DRAM_BANKS; ++i) { 98ddd917b8SSimon Glass if (bd->bi_dram[i].size) { 99fd60e99fSMax Filippov print_num("DRAM bank", i); 100fd60e99fSMax Filippov print_num("-> start", bd->bi_dram[i].start); 101fd60e99fSMax Filippov print_num("-> size", bd->bi_dram[i].size); 102fd60e99fSMax Filippov } 103ddd917b8SSimon Glass } 104fd60e99fSMax Filippov #endif 105fd60e99fSMax Filippov } 106fd60e99fSMax Filippov 107f80e5359SMax Filippov static inline void print_bi_flash(const bd_t *bd) 108f80e5359SMax Filippov { 109f80e5359SMax Filippov #if defined(CONFIG_MICROBLAZE) || defined(CONFIG_SH) 110f80e5359SMax Filippov print_num("flash start ", (ulong)bd->bi_flashstart); 111f80e5359SMax Filippov print_num("flash size ", (ulong)bd->bi_flashsize); 112f80e5359SMax Filippov print_num("flash offset ", (ulong)bd->bi_flashoffset); 113f80e5359SMax Filippov 11470cc0c34STom Rini #elif defined(CONFIG_NIOS2) 115f80e5359SMax Filippov print_num("flash start", (ulong)bd->bi_flashstart); 116f80e5359SMax Filippov print_num("flash size", (ulong)bd->bi_flashsize); 117f80e5359SMax Filippov print_num("flash offset", (ulong)bd->bi_flashoffset); 118f80e5359SMax Filippov #else 119f80e5359SMax Filippov print_num("flashstart", (ulong)bd->bi_flashstart); 120f80e5359SMax Filippov print_num("flashsize", (ulong)bd->bi_flashsize); 121f80e5359SMax Filippov print_num("flashoffset", (ulong)bd->bi_flashoffset); 122f80e5359SMax Filippov #endif 123f80e5359SMax Filippov } 124f80e5359SMax Filippov 1258752e260SMax Filippov static inline void print_eth_ip_addr(void) 1268752e260SMax Filippov { 1278752e260SMax Filippov #if defined(CONFIG_CMD_NET) 1288752e260SMax Filippov print_eth(0); 1298752e260SMax Filippov #if defined(CONFIG_HAS_ETH1) 1308752e260SMax Filippov print_eth(1); 1318752e260SMax Filippov #endif 1328752e260SMax Filippov #if defined(CONFIG_HAS_ETH2) 1338752e260SMax Filippov print_eth(2); 1348752e260SMax Filippov #endif 1358752e260SMax Filippov #if defined(CONFIG_HAS_ETH3) 1368752e260SMax Filippov print_eth(3); 1378752e260SMax Filippov #endif 1388752e260SMax Filippov #if defined(CONFIG_HAS_ETH4) 1398752e260SMax Filippov print_eth(4); 1408752e260SMax Filippov #endif 1418752e260SMax Filippov #if defined(CONFIG_HAS_ETH5) 1428752e260SMax Filippov print_eth(5); 1438752e260SMax Filippov #endif 1448752e260SMax Filippov printf("IP addr = %s\n", getenv("ipaddr")); 1458752e260SMax Filippov #endif 1468752e260SMax Filippov } 1478752e260SMax Filippov 1484e3fa7d8SMax Filippov static inline void print_baudrate(void) 1494e3fa7d8SMax Filippov { 1504e3fa7d8SMax Filippov #if defined(CONFIG_PPC) 1514e3fa7d8SMax Filippov printf("baudrate = %6u bps\n", gd->baudrate); 1524e3fa7d8SMax Filippov #else 1534e3fa7d8SMax Filippov printf("baudrate = %u bps\n", gd->baudrate); 1544e3fa7d8SMax Filippov #endif 1554e3fa7d8SMax Filippov } 1564e3fa7d8SMax Filippov 157b37483c4STom Rini static inline void __maybe_unused print_std_bdinfo(const bd_t *bd) 158e3795084SMax Filippov { 159e3795084SMax Filippov print_bi_boot_params(bd); 160e3795084SMax Filippov print_bi_mem(bd); 161e3795084SMax Filippov print_bi_flash(bd); 162e3795084SMax Filippov print_eth_ip_addr(); 163e3795084SMax Filippov print_baudrate(); 164e3795084SMax Filippov } 165e3795084SMax Filippov 1662e192b24SSimon Glass #if defined(CONFIG_PPC) 1672e192b24SSimon Glass void __weak board_detail(void) 1682e192b24SSimon Glass { 1692e192b24SSimon Glass /* Please define boot_detail() for your platform */ 1702e192b24SSimon Glass } 1712e192b24SSimon Glass 1722e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) 1732e192b24SSimon Glass { 1742e192b24SSimon Glass bd_t *bd = gd->bd; 1752e192b24SSimon Glass 1762e192b24SSimon Glass #ifdef DEBUG 1772e192b24SSimon Glass print_num("bd address", (ulong)bd); 1782e192b24SSimon Glass #endif 17912feb364SMax Filippov print_bi_mem(bd); 180f80e5359SMax Filippov print_bi_flash(bd); 1812e192b24SSimon Glass print_num("sramstart", bd->bi_sramstart); 1822e192b24SSimon Glass print_num("sramsize", bd->bi_sramsize); 183907208c4SChristophe Leroy #if defined(CONFIG_8xx) || defined(CONFIG_E500) 1842e192b24SSimon Glass print_num("immr_base", bd->bi_immr_base); 1852e192b24SSimon Glass #endif 1862e192b24SSimon Glass print_num("bootflags", bd->bi_bootflags); 1872e192b24SSimon Glass #if defined(CONFIG_CPM2) 1882e192b24SSimon Glass print_mhz("vco", bd->bi_vco); 1892e192b24SSimon Glass print_mhz("sccfreq", bd->bi_sccfreq); 1902e192b24SSimon Glass print_mhz("brgfreq", bd->bi_brgfreq); 1912e192b24SSimon Glass #endif 1922e192b24SSimon Glass print_mhz("intfreq", bd->bi_intfreq); 1932e192b24SSimon Glass #if defined(CONFIG_CPM2) 1942e192b24SSimon Glass print_mhz("cpmfreq", bd->bi_cpmfreq); 1952e192b24SSimon Glass #endif 1962e192b24SSimon Glass print_mhz("busfreq", bd->bi_busfreq); 1972e192b24SSimon Glass 1982e192b24SSimon Glass #ifdef CONFIG_ENABLE_36BIT_PHYS 1992e192b24SSimon Glass #ifdef CONFIG_PHYS_64BIT 2002e192b24SSimon Glass puts("addressing = 36-bit\n"); 2012e192b24SSimon Glass #else 2022e192b24SSimon Glass puts("addressing = 32-bit\n"); 2032e192b24SSimon Glass #endif 2042e192b24SSimon Glass #endif 2052e192b24SSimon Glass 2068752e260SMax Filippov print_eth_ip_addr(); 2074e3fa7d8SMax Filippov print_baudrate(); 2082e192b24SSimon Glass print_num("relocaddr", gd->relocaddr); 2092e192b24SSimon Glass board_detail(); 2102e192b24SSimon Glass return 0; 2112e192b24SSimon Glass } 2122e192b24SSimon Glass 2132e192b24SSimon Glass #elif defined(CONFIG_NIOS2) 2142e192b24SSimon Glass 2152e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) 2162e192b24SSimon Glass { 2172e192b24SSimon Glass bd_t *bd = gd->bd; 2182e192b24SSimon Glass 219fd60e99fSMax Filippov print_bi_dram(bd); 220f80e5359SMax Filippov print_bi_flash(bd); 2212e192b24SSimon Glass 2222e192b24SSimon Glass #if defined(CONFIG_SYS_SRAM_BASE) 2232e192b24SSimon Glass print_num ("sram start", (ulong)bd->bi_sramstart); 2242e192b24SSimon Glass print_num ("sram size", (ulong)bd->bi_sramsize); 2252e192b24SSimon Glass #endif 2262e192b24SSimon Glass 2278752e260SMax Filippov print_eth_ip_addr(); 2284e3fa7d8SMax Filippov print_baudrate(); 2292e192b24SSimon Glass 2302e192b24SSimon Glass return 0; 2312e192b24SSimon Glass } 2322e192b24SSimon Glass 2332e192b24SSimon Glass #elif defined(CONFIG_MICROBLAZE) 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 #if defined(CONFIG_SYS_SRAM_BASE) 2422e192b24SSimon Glass print_num("sram start ", (ulong)bd->bi_sramstart); 2432e192b24SSimon Glass print_num("sram size ", (ulong)bd->bi_sramsize); 2442e192b24SSimon Glass #endif 245062f078cSMichal Simek #if defined(CONFIG_CMD_NET) && !defined(CONFIG_DM_ETH) 2462e192b24SSimon Glass print_eths(); 2472e192b24SSimon Glass #endif 2484e3fa7d8SMax Filippov print_baudrate(); 2492e192b24SSimon Glass print_num("relocaddr", gd->relocaddr); 2502e192b24SSimon Glass print_num("reloc off", gd->reloc_off); 2512e192b24SSimon Glass print_num("fdt_blob", (ulong)gd->fdt_blob); 2522e192b24SSimon Glass print_num("new_fdt", (ulong)gd->new_fdt); 2532e192b24SSimon Glass print_num("fdt_size", (ulong)gd->fdt_size); 2542e192b24SSimon Glass 2552e192b24SSimon Glass return 0; 2562e192b24SSimon Glass } 2572e192b24SSimon Glass 2582e192b24SSimon Glass #elif defined(CONFIG_M68K) 2592e192b24SSimon Glass 2602e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) 2612e192b24SSimon Glass { 2622e192b24SSimon Glass bd_t *bd = gd->bd; 2632e192b24SSimon Glass 26412feb364SMax Filippov print_bi_mem(bd); 265f80e5359SMax Filippov print_bi_flash(bd); 2662e192b24SSimon Glass #if defined(CONFIG_SYS_INIT_RAM_ADDR) 2672e192b24SSimon Glass print_num("sramstart", (ulong)bd->bi_sramstart); 2682e192b24SSimon Glass print_num("sramsize", (ulong)bd->bi_sramsize); 2692e192b24SSimon Glass #endif 2702e192b24SSimon Glass #if defined(CONFIG_SYS_MBAR) 2712e192b24SSimon Glass print_num("mbar", bd->bi_mbar_base); 2722e192b24SSimon Glass #endif 2732e192b24SSimon Glass print_mhz("cpufreq", bd->bi_intfreq); 2742e192b24SSimon Glass print_mhz("busfreq", bd->bi_busfreq); 2752e192b24SSimon Glass #ifdef CONFIG_PCI 2762e192b24SSimon Glass print_mhz("pcifreq", bd->bi_pcifreq); 2772e192b24SSimon Glass #endif 2782e192b24SSimon Glass #ifdef CONFIG_EXTRA_CLOCK 2792e192b24SSimon Glass print_mhz("flbfreq", bd->bi_flbfreq); 2802e192b24SSimon Glass print_mhz("inpfreq", bd->bi_inpfreq); 2812e192b24SSimon Glass print_mhz("vcofreq", bd->bi_vcofreq); 2822e192b24SSimon Glass #endif 2838752e260SMax Filippov print_eth_ip_addr(); 2844e3fa7d8SMax Filippov print_baudrate(); 2852e192b24SSimon Glass 2862e192b24SSimon Glass return 0; 2872e192b24SSimon Glass } 2882e192b24SSimon Glass 2892e192b24SSimon Glass #elif defined(CONFIG_MIPS) 2902e192b24SSimon Glass 2912e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) 2922e192b24SSimon Glass { 293e3795084SMax Filippov print_std_bdinfo(gd->bd); 2948cf7a418STim Chick print_num("relocaddr", gd->relocaddr); 2958cf7a418STim Chick print_num("reloc off", gd->reloc_off); 2962e192b24SSimon Glass 2972e192b24SSimon Glass return 0; 2982e192b24SSimon Glass } 2992e192b24SSimon Glass 3002e192b24SSimon Glass #elif defined(CONFIG_ARM) 3012e192b24SSimon Glass 3022e192b24SSimon Glass static int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, 3032e192b24SSimon Glass char * const argv[]) 3042e192b24SSimon Glass { 3052e192b24SSimon Glass bd_t *bd = gd->bd; 3062e192b24SSimon Glass 3072e192b24SSimon Glass print_num("arch_number", bd->bi_arch_number); 308171e5396SMax Filippov print_bi_boot_params(bd); 309fd60e99fSMax Filippov print_bi_dram(bd); 3102e192b24SSimon Glass 3112e192b24SSimon Glass #ifdef CONFIG_SYS_MEM_RESERVE_SECURE 312e61a7534SYork Sun if (gd->arch.secure_ram & MEM_RESERVE_SECURE_SECURED) { 3132e192b24SSimon Glass print_num("Secure ram", 314e61a7534SYork Sun gd->arch.secure_ram & MEM_RESERVE_SECURE_ADDR_MASK); 3152e192b24SSimon Glass } 3162e192b24SSimon Glass #endif 317f2ccf7f7SYork Sun #ifdef CONFIG_RESV_RAM 318f2ccf7f7SYork Sun if (gd->arch.resv_ram) 319f2ccf7f7SYork Sun print_num("Reserved ram", gd->arch.resv_ram); 320f2ccf7f7SYork Sun #endif 3212e192b24SSimon Glass #if defined(CONFIG_CMD_NET) && !defined(CONFIG_DM_ETH) 3222e192b24SSimon Glass print_eths(); 3232e192b24SSimon Glass #endif 3244e3fa7d8SMax Filippov print_baudrate(); 3252e192b24SSimon Glass #if !(defined(CONFIG_SYS_ICACHE_OFF) && defined(CONFIG_SYS_DCACHE_OFF)) 3262e192b24SSimon Glass print_num("TLB addr", gd->arch.tlb_addr); 3272e192b24SSimon Glass #endif 3282e192b24SSimon Glass print_num("relocaddr", gd->relocaddr); 3292e192b24SSimon Glass print_num("reloc off", gd->reloc_off); 3302e192b24SSimon Glass print_num("irq_sp", gd->irq_sp); /* irq stack pointer */ 3312e192b24SSimon Glass print_num("sp start ", gd->start_addr_sp); 3322e192b24SSimon Glass #if defined(CONFIG_LCD) || defined(CONFIG_VIDEO) 3332e192b24SSimon Glass print_num("FB base ", gd->fb_base); 3342e192b24SSimon Glass #endif 3352e192b24SSimon Glass /* 3362e192b24SSimon Glass * TODO: Currently only support for davinci SOC's is added. 3372e192b24SSimon Glass * Remove this check once all the board implement this. 3382e192b24SSimon Glass */ 3392e192b24SSimon Glass #ifdef CONFIG_CLOCKS 3402e192b24SSimon Glass printf("ARM frequency = %ld MHz\n", gd->bd->bi_arm_freq); 3412e192b24SSimon Glass printf("DSP frequency = %ld MHz\n", gd->bd->bi_dsp_freq); 3422e192b24SSimon Glass printf("DDR frequency = %ld MHz\n", gd->bd->bi_ddr_freq); 3432e192b24SSimon Glass #endif 3442e192b24SSimon Glass #ifdef CONFIG_BOARD_TYPES 3452e192b24SSimon Glass printf("Board Type = %ld\n", gd->board_type); 3462e192b24SSimon Glass #endif 347*f1896c45SAndy Yan #if CONFIG_VAL(SYS_MALLOC_F_LEN) 3487f7ddf2aSSimon Glass printf("Early malloc usage: %lx / %x\n", gd->malloc_ptr, 349*f1896c45SAndy Yan CONFIG_VAL(SYS_MALLOC_F_LEN)); 3507f7ddf2aSSimon Glass #endif 35153539533SHeiko Schocher if (gd->fdt_blob) 35253539533SHeiko Schocher printf("fdt_blob = %p\n", gd->fdt_blob); 3537f7ddf2aSSimon Glass 3542e192b24SSimon Glass return 0; 3552e192b24SSimon Glass } 3562e192b24SSimon Glass 3572e192b24SSimon Glass #elif defined(CONFIG_SH) 3582e192b24SSimon Glass 3592e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) 3602e192b24SSimon Glass { 3612e192b24SSimon Glass bd_t *bd = gd->bd; 36212feb364SMax Filippov 36312feb364SMax Filippov print_bi_mem(bd); 364f80e5359SMax Filippov print_bi_flash(bd); 3658752e260SMax Filippov print_eth_ip_addr(); 3664e3fa7d8SMax Filippov print_baudrate(); 3672e192b24SSimon Glass return 0; 3682e192b24SSimon Glass } 3692e192b24SSimon Glass 3702e192b24SSimon Glass #elif defined(CONFIG_X86) 3712e192b24SSimon Glass 3722e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) 3732e192b24SSimon Glass { 3742e192b24SSimon Glass bd_t *bd = gd->bd; 3752e192b24SSimon Glass 376171e5396SMax Filippov print_bi_boot_params(bd); 3772e192b24SSimon Glass 378fd60e99fSMax Filippov print_bi_dram(bd); 3792e192b24SSimon Glass 3802e192b24SSimon Glass #if defined(CONFIG_CMD_NET) 3818752e260SMax Filippov print_eth_ip_addr(); 3822e192b24SSimon Glass print_mhz("ethspeed", bd->bi_ethspeed); 3832e192b24SSimon Glass #endif 3844e3fa7d8SMax Filippov print_baudrate(); 3852e192b24SSimon Glass 3862e192b24SSimon Glass return 0; 3872e192b24SSimon Glass } 3882e192b24SSimon Glass 3892e192b24SSimon Glass #elif defined(CONFIG_SANDBOX) 3902e192b24SSimon Glass 3912e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) 3922e192b24SSimon Glass { 3932e192b24SSimon Glass bd_t *bd = gd->bd; 3942e192b24SSimon Glass 395171e5396SMax Filippov print_bi_boot_params(bd); 396fd60e99fSMax Filippov print_bi_dram(bd); 3978752e260SMax Filippov print_eth_ip_addr(); 3982e192b24SSimon Glass 3992e192b24SSimon Glass #if defined(CONFIG_LCD) || defined(CONFIG_VIDEO) 4002e192b24SSimon Glass print_num("FB base ", gd->fb_base); 4012e192b24SSimon Glass #endif 4022e192b24SSimon Glass return 0; 4032e192b24SSimon Glass } 4042e192b24SSimon Glass 4052e192b24SSimon Glass #elif defined(CONFIG_NDS32) 4062e192b24SSimon Glass 4072e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) 4082e192b24SSimon Glass { 4092e192b24SSimon Glass bd_t *bd = gd->bd; 4102e192b24SSimon Glass 4112e192b24SSimon Glass print_num("arch_number", bd->bi_arch_number); 412171e5396SMax Filippov print_bi_boot_params(bd); 413fd60e99fSMax Filippov print_bi_dram(bd); 4148752e260SMax Filippov print_eth_ip_addr(); 4154e3fa7d8SMax Filippov print_baudrate(); 4162e192b24SSimon Glass 4172e192b24SSimon Glass return 0; 4182e192b24SSimon Glass } 4192e192b24SSimon Glass 4202e192b24SSimon Glass #elif defined(CONFIG_ARC) 4212e192b24SSimon Glass 4222e192b24SSimon Glass int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) 4232e192b24SSimon Glass { 4242e192b24SSimon Glass bd_t *bd = gd->bd; 4252e192b24SSimon Glass 42612feb364SMax Filippov print_bi_mem(bd); 4278752e260SMax Filippov print_eth_ip_addr(); 4284e3fa7d8SMax Filippov print_baudrate(); 4292e192b24SSimon Glass 4302e192b24SSimon Glass return 0; 4312e192b24SSimon Glass } 4322e192b24SSimon Glass 433de5e5ceaSChris Zankel #elif defined(CONFIG_XTENSA) 434de5e5ceaSChris Zankel 435de5e5ceaSChris Zankel int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) 436de5e5ceaSChris Zankel { 437de5e5ceaSChris Zankel print_std_bdinfo(gd->bd); 438de5e5ceaSChris Zankel return 0; 439de5e5ceaSChris Zankel } 440de5e5ceaSChris Zankel 4412e192b24SSimon Glass #else 4422e192b24SSimon Glass #error "a case for this architecture does not exist!" 4432e192b24SSimon Glass #endif 4442e192b24SSimon Glass 4452e192b24SSimon Glass /* -------------------------------------------------------------------- */ 4462e192b24SSimon Glass 4472e192b24SSimon Glass U_BOOT_CMD( 4482e192b24SSimon Glass bdinfo, 1, 1, do_bdinfo, 4492e192b24SSimon Glass "print Board Info structure", 4502e192b24SSimon Glass "" 4512e192b24SSimon Glass ); 452