1bace3d00SSimon Glass /* 26fb62078SSimon Glass * Copyright (c) 2011-2012 The Chromium OS Authors. 31a459660SWolfgang Denk * SPDX-License-Identifier: GPL-2.0+ 4bace3d00SSimon Glass */ 5bace3d00SSimon Glass 6bace3d00SSimon Glass #include <common.h> 75c2859cdSSimon Glass #include <os.h> 87dbcb76eSRabin Vincent #include <cli.h> 91f32ae95SSimon Glass #include <malloc.h> 1070db4212SSimon Glass #include <asm/getopt.h> 114d94dfa0SSimon Glass #include <asm/io.h> 1270db4212SSimon Glass #include <asm/sections.h> 136fb62078SSimon Glass #include <asm/state.h> 14bace3d00SSimon Glass 15808434cdSSimon Glass DECLARE_GLOBAL_DATA_PTR; 16808434cdSSimon Glass 1770db4212SSimon Glass int sandbox_early_getopt_check(void) 1870db4212SSimon Glass { 1970db4212SSimon Glass struct sandbox_state *state = state_get_current(); 207b3efc66SSimon Glass struct sandbox_cmdline_option **sb_opt = __u_boot_sandbox_option_start; 2170db4212SSimon Glass size_t num_options = __u_boot_sandbox_option_count(); 2270db4212SSimon Glass size_t i; 2370db4212SSimon Glass int max_arg_len, max_noarg_len; 2470db4212SSimon Glass 2570db4212SSimon Glass /* parse_err will be a string of the faulting option */ 2670db4212SSimon Glass if (!state->parse_err) 2770db4212SSimon Glass return 0; 2870db4212SSimon Glass 2970db4212SSimon Glass if (strcmp(state->parse_err, "help")) { 3070db4212SSimon Glass printf("u-boot: error: failed while parsing option: %s\n" 3170db4212SSimon Glass "\ttry running with --help for more information.\n", 3270db4212SSimon Glass state->parse_err); 3370db4212SSimon Glass os_exit(1); 3470db4212SSimon Glass } 3570db4212SSimon Glass 3670db4212SSimon Glass printf( 3770db4212SSimon Glass "u-boot, a command line test interface to U-Boot\n\n" 3870db4212SSimon Glass "Usage: u-boot [options]\n" 3970db4212SSimon Glass "Options:\n"); 4070db4212SSimon Glass 4170db4212SSimon Glass max_arg_len = 0; 4270db4212SSimon Glass for (i = 0; i < num_options; ++i) 43b4141195SMasahiro Yamada max_arg_len = max((int)strlen(sb_opt[i]->flag), max_arg_len); 4470db4212SSimon Glass max_noarg_len = max_arg_len + 7; 4570db4212SSimon Glass 4670db4212SSimon Glass for (i = 0; i < num_options; ++i) { 477b3efc66SSimon Glass struct sandbox_cmdline_option *opt = sb_opt[i]; 4870db4212SSimon Glass 4970db4212SSimon Glass /* first output the short flag if it has one */ 5070db4212SSimon Glass if (opt->flag_short >= 0x100) 5170db4212SSimon Glass printf(" "); 5270db4212SSimon Glass else 5370db4212SSimon Glass printf(" -%c, ", opt->flag_short); 5470db4212SSimon Glass 5570db4212SSimon Glass /* then the long flag */ 5670db4212SSimon Glass if (opt->has_arg) 5770db4212SSimon Glass printf("--%-*s <arg> ", max_arg_len, opt->flag); 586ebcab8dSSimon Glass else 596ebcab8dSSimon Glass printf("--%-*s", max_noarg_len, opt->flag); 6070db4212SSimon Glass 6170db4212SSimon Glass /* finally the help text */ 6270db4212SSimon Glass printf(" %s\n", opt->help); 6370db4212SSimon Glass } 6470db4212SSimon Glass 6570db4212SSimon Glass os_exit(0); 6670db4212SSimon Glass } 6770db4212SSimon Glass 687b3efc66SSimon Glass static int sandbox_cmdline_cb_help(struct sandbox_state *state, const char *arg) 6970db4212SSimon Glass { 7070db4212SSimon Glass /* just flag to sandbox_early_getopt_check to show usage */ 7170db4212SSimon Glass return 1; 7270db4212SSimon Glass } 737b3efc66SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(help, 'h', 0, "Display help"); 7470db4212SSimon Glass 75ab4e07ebSSimon Glass int sandbox_main_loop_init(void) 76ab4e07ebSSimon Glass { 7770db4212SSimon Glass struct sandbox_state *state = state_get_current(); 7870db4212SSimon Glass 7970db4212SSimon Glass /* Execute command if required */ 80*ebaa832eSSjoerd Simons if (state->cmd || state->run_distro_boot) { 81*ebaa832eSSjoerd Simons int retval = 0; 8288539e44SJoe Hershberger 837dbcb76eSRabin Vincent cli_init(); 847dbcb76eSRabin Vincent 85*ebaa832eSSjoerd Simons if (state->cmd) 8688539e44SJoe Hershberger retval = run_command_list(state->cmd, -1, 0); 87*ebaa832eSSjoerd Simons 88*ebaa832eSSjoerd Simons if (state->run_distro_boot) 89*ebaa832eSSjoerd Simons retval = cli_simple_run_command("run distro_bootcmd", 90*ebaa832eSSjoerd Simons 0); 91*ebaa832eSSjoerd Simons 92c5a62d4aSSimon Glass if (!state->interactive) 9388539e44SJoe Hershberger os_exit(retval); 9470db4212SSimon Glass } 9570db4212SSimon Glass 96ab4e07ebSSimon Glass return 0; 97ab4e07ebSSimon Glass } 98ab4e07ebSSimon Glass 99*ebaa832eSSjoerd Simons static int sandbox_cmdline_cb_boot(struct sandbox_state *state, 100*ebaa832eSSjoerd Simons const char *arg) 101*ebaa832eSSjoerd Simons { 102*ebaa832eSSjoerd Simons state->run_distro_boot = true; 103*ebaa832eSSjoerd Simons return 0; 104*ebaa832eSSjoerd Simons } 105*ebaa832eSSjoerd Simons SANDBOX_CMDLINE_OPT_SHORT(boot, 'b', 0, "Run distro boot commands"); 106*ebaa832eSSjoerd Simons 1077b3efc66SSimon Glass static int sandbox_cmdline_cb_command(struct sandbox_state *state, 1087b3efc66SSimon Glass const char *arg) 10970db4212SSimon Glass { 11070db4212SSimon Glass state->cmd = arg; 11170db4212SSimon Glass return 0; 11270db4212SSimon Glass } 1137b3efc66SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(command, 'c', 1, "Execute U-Boot command"); 11470db4212SSimon Glass 1157b3efc66SSimon Glass static int sandbox_cmdline_cb_fdt(struct sandbox_state *state, const char *arg) 116f828bf25SSimon Glass { 117f828bf25SSimon Glass state->fdt_fname = arg; 118f828bf25SSimon Glass return 0; 119f828bf25SSimon Glass } 1207b3efc66SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(fdt, 'd', 1, "Specify U-Boot's control FDT"); 121f828bf25SSimon Glass 1221f32ae95SSimon Glass static int sandbox_cmdline_cb_default_fdt(struct sandbox_state *state, 1231f32ae95SSimon Glass const char *arg) 1241f32ae95SSimon Glass { 1251f32ae95SSimon Glass const char *fmt = "%s.dtb"; 1261f32ae95SSimon Glass char *fname; 1271f32ae95SSimon Glass int len; 1281f32ae95SSimon Glass 1291f32ae95SSimon Glass len = strlen(state->argv[0]) + strlen(fmt) + 1; 1301f32ae95SSimon Glass fname = os_malloc(len); 1311f32ae95SSimon Glass if (!fname) 1321f32ae95SSimon Glass return -ENOMEM; 1331f32ae95SSimon Glass snprintf(fname, len, fmt, state->argv[0]); 1341f32ae95SSimon Glass state->fdt_fname = fname; 1351f32ae95SSimon Glass 1361f32ae95SSimon Glass return 0; 1371f32ae95SSimon Glass } 1381f32ae95SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(default_fdt, 'D', 0, 1391f32ae95SSimon Glass "Use the default u-boot.dtb control FDT in U-Boot directory"); 1401f32ae95SSimon Glass 141c5a62d4aSSimon Glass static int sandbox_cmdline_cb_interactive(struct sandbox_state *state, 142c5a62d4aSSimon Glass const char *arg) 143c5a62d4aSSimon Glass { 144c5a62d4aSSimon Glass state->interactive = true; 145c5a62d4aSSimon Glass return 0; 146c5a62d4aSSimon Glass } 147c5a62d4aSSimon Glass 148c5a62d4aSSimon Glass SANDBOX_CMDLINE_OPT_SHORT(interactive, 'i', 0, "Enter interactive mode"); 149c5a62d4aSSimon Glass 150bda7773fSSimon Glass static int sandbox_cmdline_cb_jump(struct sandbox_state *state, 151bda7773fSSimon Glass const char *arg) 152bda7773fSSimon Glass { 153ab839dc3SSimon Glass /* Remember to delete this U-Boot image later */ 154ab839dc3SSimon Glass state->jumped_fname = arg; 155bda7773fSSimon Glass 156bda7773fSSimon Glass return 0; 157bda7773fSSimon Glass } 158bda7773fSSimon Glass SANDBOX_CMDLINE_OPT_SHORT(jump, 'j', 1, "Jumped from previous U-Boot"); 159bda7773fSSimon Glass 1605c2859cdSSimon Glass static int sandbox_cmdline_cb_memory(struct sandbox_state *state, 1615c2859cdSSimon Glass const char *arg) 1625c2859cdSSimon Glass { 1635c2859cdSSimon Glass int err; 1645c2859cdSSimon Glass 1655c2859cdSSimon Glass /* For now assume we always want to write it */ 1665c2859cdSSimon Glass state->write_ram_buf = true; 1675c2859cdSSimon Glass state->ram_buf_fname = arg; 1685c2859cdSSimon Glass 169f80a8bbeSSimon Glass err = os_read_ram_buf(arg); 170f80a8bbeSSimon Glass if (err) { 1715c2859cdSSimon Glass printf("Failed to read RAM buffer\n"); 1725c2859cdSSimon Glass return err; 1735c2859cdSSimon Glass } 1745c2859cdSSimon Glass 1755c2859cdSSimon Glass return 0; 1765c2859cdSSimon Glass } 1775c2859cdSSimon Glass SANDBOX_CMDLINE_OPT_SHORT(memory, 'm', 1, 1785c2859cdSSimon Glass "Read/write ram_buf memory contents from file"); 1795c2859cdSSimon Glass 180ab839dc3SSimon Glass static int sandbox_cmdline_cb_rm_memory(struct sandbox_state *state, 181ab839dc3SSimon Glass const char *arg) 182ab839dc3SSimon Glass { 183ab839dc3SSimon Glass state->ram_buf_rm = true; 184ab839dc3SSimon Glass 185ab839dc3SSimon Glass return 0; 186ab839dc3SSimon Glass } 187ab839dc3SSimon Glass SANDBOX_CMDLINE_OPT(rm_memory, 0, "Remove memory file after reading"); 188ab839dc3SSimon Glass 1891209e272SSimon Glass static int sandbox_cmdline_cb_state(struct sandbox_state *state, 1901209e272SSimon Glass const char *arg) 1911209e272SSimon Glass { 1921209e272SSimon Glass state->state_fname = arg; 1931209e272SSimon Glass return 0; 1941209e272SSimon Glass } 1951209e272SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(state, 's', 1, "Specify the sandbox state FDT"); 1961209e272SSimon Glass 1971209e272SSimon Glass static int sandbox_cmdline_cb_read(struct sandbox_state *state, 1981209e272SSimon Glass const char *arg) 1991209e272SSimon Glass { 2001209e272SSimon Glass state->read_state = true; 2011209e272SSimon Glass return 0; 2021209e272SSimon Glass } 2031209e272SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(read, 'r', 0, "Read the state FDT on startup"); 2041209e272SSimon Glass 2051209e272SSimon Glass static int sandbox_cmdline_cb_write(struct sandbox_state *state, 2061209e272SSimon Glass const char *arg) 2071209e272SSimon Glass { 2081209e272SSimon Glass state->write_state = true; 2091209e272SSimon Glass return 0; 2101209e272SSimon Glass } 2111209e272SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(write, 'w', 0, "Write state FDT on exit"); 2121209e272SSimon Glass 2131209e272SSimon Glass static int sandbox_cmdline_cb_ignore_missing(struct sandbox_state *state, 2141209e272SSimon Glass const char *arg) 2151209e272SSimon Glass { 2161209e272SSimon Glass state->ignore_missing_state_on_read = true; 2171209e272SSimon Glass return 0; 2181209e272SSimon Glass } 2191209e272SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(ignore_missing, 'n', 0, 2201209e272SSimon Glass "Ignore missing state on read"); 2211209e272SSimon Glass 2227d95f2a3SSimon Glass static int sandbox_cmdline_cb_show_lcd(struct sandbox_state *state, 2237d95f2a3SSimon Glass const char *arg) 2247d95f2a3SSimon Glass { 2257d95f2a3SSimon Glass state->show_lcd = true; 2267d95f2a3SSimon Glass return 0; 2277d95f2a3SSimon Glass } 2287d95f2a3SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(show_lcd, 'l', 0, 2297d95f2a3SSimon Glass "Show the sandbox LCD display"); 2307d95f2a3SSimon Glass 231ffb87905SSimon Glass static const char *term_args[STATE_TERM_COUNT] = { 232ffb87905SSimon Glass "raw-with-sigs", 233ffb87905SSimon Glass "raw", 234ffb87905SSimon Glass "cooked", 235ffb87905SSimon Glass }; 236ffb87905SSimon Glass 237ffb87905SSimon Glass static int sandbox_cmdline_cb_terminal(struct sandbox_state *state, 238ffb87905SSimon Glass const char *arg) 239ffb87905SSimon Glass { 240ffb87905SSimon Glass int i; 241ffb87905SSimon Glass 242ffb87905SSimon Glass for (i = 0; i < STATE_TERM_COUNT; i++) { 243ffb87905SSimon Glass if (!strcmp(arg, term_args[i])) { 244ffb87905SSimon Glass state->term_raw = i; 245ffb87905SSimon Glass return 0; 246ffb87905SSimon Glass } 247ffb87905SSimon Glass } 248ffb87905SSimon Glass 249ffb87905SSimon Glass printf("Unknown terminal setting '%s' (", arg); 250ffb87905SSimon Glass for (i = 0; i < STATE_TERM_COUNT; i++) 251ffb87905SSimon Glass printf("%s%s", i ? ", " : "", term_args[i]); 252ffb87905SSimon Glass puts(")\n"); 253ffb87905SSimon Glass 254ffb87905SSimon Glass return 1; 255ffb87905SSimon Glass } 256ffb87905SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(terminal, 't', 1, 257ffb87905SSimon Glass "Set terminal to raw/cooked mode"); 258ffb87905SSimon Glass 259bace3d00SSimon Glass int main(int argc, char *argv[]) 260bace3d00SSimon Glass { 26170db4212SSimon Glass struct sandbox_state *state; 2624d94dfa0SSimon Glass gd_t data; 2631209e272SSimon Glass int ret; 2646fb62078SSimon Glass 2651209e272SSimon Glass ret = state_init(); 2661209e272SSimon Glass if (ret) 2671209e272SSimon Glass goto err; 2686fb62078SSimon Glass 26970db4212SSimon Glass state = state_get_current(); 27070db4212SSimon Glass if (os_parse_args(state, argc, argv)) 27170db4212SSimon Glass return 1; 27270db4212SSimon Glass 2731209e272SSimon Glass ret = sandbox_read_state(state, state->state_fname); 2741209e272SSimon Glass if (ret) 2751209e272SSimon Glass goto err; 2761209e272SSimon Glass 277ab839dc3SSimon Glass /* Remove old memory file if required */ 278ab839dc3SSimon Glass if (state->ram_buf_rm && state->ram_buf_fname) 279ab839dc3SSimon Glass os_unlink(state->ram_buf_fname); 280ab839dc3SSimon Glass 2814d94dfa0SSimon Glass memset(&data, '\0', sizeof(data)); 2824d94dfa0SSimon Glass gd = &data; 28329afe9e6SSimon Glass #ifdef CONFIG_SYS_MALLOC_F_LEN 28429afe9e6SSimon Glass gd->malloc_base = CONFIG_MALLOC_F_ADDR; 28529afe9e6SSimon Glass #endif 2864d94dfa0SSimon Glass 287808434cdSSimon Glass /* Do pre- and post-relocation init */ 288bace3d00SSimon Glass board_init_f(0); 2898ec21bbeSAllen Martin 290808434cdSSimon Glass board_init_r(gd->new_gd, 0); 291808434cdSSimon Glass 292808434cdSSimon Glass /* NOTREACHED - board_init_r() does not return */ 2938ec21bbeSAllen Martin return 0; 2941209e272SSimon Glass 2951209e272SSimon Glass err: 2961209e272SSimon Glass printf("Error %d\n", ret); 2971209e272SSimon Glass return 1; 298bace3d00SSimon Glass } 299