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> 738068820SSimon Glass #include <errno.h> 85c2859cdSSimon Glass #include <os.h> 97dbcb76eSRabin Vincent #include <cli.h> 101f32ae95SSimon Glass #include <malloc.h> 1170db4212SSimon Glass #include <asm/getopt.h> 124d94dfa0SSimon Glass #include <asm/io.h> 1370db4212SSimon Glass #include <asm/sections.h> 146fb62078SSimon Glass #include <asm/state.h> 15bace3d00SSimon Glass 16808434cdSSimon Glass DECLARE_GLOBAL_DATA_PTR; 17808434cdSSimon Glass 1870db4212SSimon Glass int sandbox_early_getopt_check(void) 1970db4212SSimon Glass { 2070db4212SSimon Glass struct sandbox_state *state = state_get_current(); 217b3efc66SSimon Glass struct sandbox_cmdline_option **sb_opt = __u_boot_sandbox_option_start; 2270db4212SSimon Glass size_t num_options = __u_boot_sandbox_option_count(); 2370db4212SSimon Glass size_t i; 2470db4212SSimon Glass int max_arg_len, max_noarg_len; 2570db4212SSimon Glass 2670db4212SSimon Glass /* parse_err will be a string of the faulting option */ 2770db4212SSimon Glass if (!state->parse_err) 2870db4212SSimon Glass return 0; 2970db4212SSimon Glass 3070db4212SSimon Glass if (strcmp(state->parse_err, "help")) { 3170db4212SSimon Glass printf("u-boot: error: failed while parsing option: %s\n" 3270db4212SSimon Glass "\ttry running with --help for more information.\n", 3370db4212SSimon Glass state->parse_err); 3470db4212SSimon Glass os_exit(1); 3570db4212SSimon Glass } 3670db4212SSimon Glass 3770db4212SSimon Glass printf( 3870db4212SSimon Glass "u-boot, a command line test interface to U-Boot\n\n" 3970db4212SSimon Glass "Usage: u-boot [options]\n" 4070db4212SSimon Glass "Options:\n"); 4170db4212SSimon Glass 4270db4212SSimon Glass max_arg_len = 0; 4370db4212SSimon Glass for (i = 0; i < num_options; ++i) 44b4141195SMasahiro Yamada max_arg_len = max((int)strlen(sb_opt[i]->flag), max_arg_len); 4570db4212SSimon Glass max_noarg_len = max_arg_len + 7; 4670db4212SSimon Glass 4770db4212SSimon Glass for (i = 0; i < num_options; ++i) { 487b3efc66SSimon Glass struct sandbox_cmdline_option *opt = sb_opt[i]; 4970db4212SSimon Glass 5070db4212SSimon Glass /* first output the short flag if it has one */ 5170db4212SSimon Glass if (opt->flag_short >= 0x100) 5270db4212SSimon Glass printf(" "); 5370db4212SSimon Glass else 5470db4212SSimon Glass printf(" -%c, ", opt->flag_short); 5570db4212SSimon Glass 5670db4212SSimon Glass /* then the long flag */ 5770db4212SSimon Glass if (opt->has_arg) 5870db4212SSimon Glass printf("--%-*s <arg> ", max_arg_len, opt->flag); 596ebcab8dSSimon Glass else 606ebcab8dSSimon Glass printf("--%-*s", max_noarg_len, opt->flag); 6170db4212SSimon Glass 6270db4212SSimon Glass /* finally the help text */ 6370db4212SSimon Glass printf(" %s\n", opt->help); 6470db4212SSimon Glass } 6570db4212SSimon Glass 6670db4212SSimon Glass os_exit(0); 6770db4212SSimon Glass } 6870db4212SSimon Glass 697b3efc66SSimon Glass static int sandbox_cmdline_cb_help(struct sandbox_state *state, const char *arg) 7070db4212SSimon Glass { 7170db4212SSimon Glass /* just flag to sandbox_early_getopt_check to show usage */ 7270db4212SSimon Glass return 1; 7370db4212SSimon Glass } 747b3efc66SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(help, 'h', 0, "Display help"); 7570db4212SSimon Glass 76ab4e07ebSSimon Glass int sandbox_main_loop_init(void) 77ab4e07ebSSimon Glass { 7870db4212SSimon Glass struct sandbox_state *state = state_get_current(); 7970db4212SSimon Glass 8070db4212SSimon Glass /* Execute command if required */ 81ebaa832eSSjoerd Simons if (state->cmd || state->run_distro_boot) { 82ebaa832eSSjoerd Simons int retval = 0; 8388539e44SJoe Hershberger 847dbcb76eSRabin Vincent cli_init(); 857dbcb76eSRabin Vincent 86*2b6793deSSimon Glass #ifdef CONFIG_CMDLINE 87ebaa832eSSjoerd Simons if (state->cmd) 8888539e44SJoe Hershberger retval = run_command_list(state->cmd, -1, 0); 89ebaa832eSSjoerd Simons 90ebaa832eSSjoerd Simons if (state->run_distro_boot) 91ebaa832eSSjoerd Simons retval = cli_simple_run_command("run distro_bootcmd", 92ebaa832eSSjoerd Simons 0); 93*2b6793deSSimon Glass #endif 94c5a62d4aSSimon Glass if (!state->interactive) 9588539e44SJoe Hershberger os_exit(retval); 9670db4212SSimon Glass } 9770db4212SSimon Glass 98ab4e07ebSSimon Glass return 0; 99ab4e07ebSSimon Glass } 100ab4e07ebSSimon Glass 101ebaa832eSSjoerd Simons static int sandbox_cmdline_cb_boot(struct sandbox_state *state, 102ebaa832eSSjoerd Simons const char *arg) 103ebaa832eSSjoerd Simons { 104ebaa832eSSjoerd Simons state->run_distro_boot = true; 105ebaa832eSSjoerd Simons return 0; 106ebaa832eSSjoerd Simons } 107ebaa832eSSjoerd Simons SANDBOX_CMDLINE_OPT_SHORT(boot, 'b', 0, "Run distro boot commands"); 108ebaa832eSSjoerd Simons 1097b3efc66SSimon Glass static int sandbox_cmdline_cb_command(struct sandbox_state *state, 1107b3efc66SSimon Glass const char *arg) 11170db4212SSimon Glass { 11270db4212SSimon Glass state->cmd = arg; 11370db4212SSimon Glass return 0; 11470db4212SSimon Glass } 1157b3efc66SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(command, 'c', 1, "Execute U-Boot command"); 11670db4212SSimon Glass 1177b3efc66SSimon Glass static int sandbox_cmdline_cb_fdt(struct sandbox_state *state, const char *arg) 118f828bf25SSimon Glass { 119f828bf25SSimon Glass state->fdt_fname = arg; 120f828bf25SSimon Glass return 0; 121f828bf25SSimon Glass } 1227b3efc66SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(fdt, 'd', 1, "Specify U-Boot's control FDT"); 123f828bf25SSimon Glass 1241f32ae95SSimon Glass static int sandbox_cmdline_cb_default_fdt(struct sandbox_state *state, 1251f32ae95SSimon Glass const char *arg) 1261f32ae95SSimon Glass { 1271f32ae95SSimon Glass const char *fmt = "%s.dtb"; 1281f32ae95SSimon Glass char *fname; 1291f32ae95SSimon Glass int len; 1301f32ae95SSimon Glass 1311f32ae95SSimon Glass len = strlen(state->argv[0]) + strlen(fmt) + 1; 1321f32ae95SSimon Glass fname = os_malloc(len); 1331f32ae95SSimon Glass if (!fname) 1341f32ae95SSimon Glass return -ENOMEM; 1351f32ae95SSimon Glass snprintf(fname, len, fmt, state->argv[0]); 1361f32ae95SSimon Glass state->fdt_fname = fname; 1371f32ae95SSimon Glass 1381f32ae95SSimon Glass return 0; 1391f32ae95SSimon Glass } 1401f32ae95SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(default_fdt, 'D', 0, 1411f32ae95SSimon Glass "Use the default u-boot.dtb control FDT in U-Boot directory"); 1421f32ae95SSimon Glass 143c5a62d4aSSimon Glass static int sandbox_cmdline_cb_interactive(struct sandbox_state *state, 144c5a62d4aSSimon Glass const char *arg) 145c5a62d4aSSimon Glass { 146c5a62d4aSSimon Glass state->interactive = true; 147c5a62d4aSSimon Glass return 0; 148c5a62d4aSSimon Glass } 149c5a62d4aSSimon Glass 150c5a62d4aSSimon Glass SANDBOX_CMDLINE_OPT_SHORT(interactive, 'i', 0, "Enter interactive mode"); 151c5a62d4aSSimon Glass 152bda7773fSSimon Glass static int sandbox_cmdline_cb_jump(struct sandbox_state *state, 153bda7773fSSimon Glass const char *arg) 154bda7773fSSimon Glass { 155ab839dc3SSimon Glass /* Remember to delete this U-Boot image later */ 156ab839dc3SSimon Glass state->jumped_fname = arg; 157bda7773fSSimon Glass 158bda7773fSSimon Glass return 0; 159bda7773fSSimon Glass } 160bda7773fSSimon Glass SANDBOX_CMDLINE_OPT_SHORT(jump, 'j', 1, "Jumped from previous U-Boot"); 161bda7773fSSimon Glass 1625c2859cdSSimon Glass static int sandbox_cmdline_cb_memory(struct sandbox_state *state, 1635c2859cdSSimon Glass const char *arg) 1645c2859cdSSimon Glass { 1655c2859cdSSimon Glass int err; 1665c2859cdSSimon Glass 1675c2859cdSSimon Glass /* For now assume we always want to write it */ 1685c2859cdSSimon Glass state->write_ram_buf = true; 1695c2859cdSSimon Glass state->ram_buf_fname = arg; 1705c2859cdSSimon Glass 171f80a8bbeSSimon Glass err = os_read_ram_buf(arg); 172f80a8bbeSSimon Glass if (err) { 1735c2859cdSSimon Glass printf("Failed to read RAM buffer\n"); 1745c2859cdSSimon Glass return err; 1755c2859cdSSimon Glass } 1765c2859cdSSimon Glass 1775c2859cdSSimon Glass return 0; 1785c2859cdSSimon Glass } 1795c2859cdSSimon Glass SANDBOX_CMDLINE_OPT_SHORT(memory, 'm', 1, 1805c2859cdSSimon Glass "Read/write ram_buf memory contents from file"); 1815c2859cdSSimon Glass 182ab839dc3SSimon Glass static int sandbox_cmdline_cb_rm_memory(struct sandbox_state *state, 183ab839dc3SSimon Glass const char *arg) 184ab839dc3SSimon Glass { 185ab839dc3SSimon Glass state->ram_buf_rm = true; 186ab839dc3SSimon Glass 187ab839dc3SSimon Glass return 0; 188ab839dc3SSimon Glass } 189ab839dc3SSimon Glass SANDBOX_CMDLINE_OPT(rm_memory, 0, "Remove memory file after reading"); 190ab839dc3SSimon Glass 1911209e272SSimon Glass static int sandbox_cmdline_cb_state(struct sandbox_state *state, 1921209e272SSimon Glass const char *arg) 1931209e272SSimon Glass { 1941209e272SSimon Glass state->state_fname = arg; 1951209e272SSimon Glass return 0; 1961209e272SSimon Glass } 1971209e272SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(state, 's', 1, "Specify the sandbox state FDT"); 1981209e272SSimon Glass 1991209e272SSimon Glass static int sandbox_cmdline_cb_read(struct sandbox_state *state, 2001209e272SSimon Glass const char *arg) 2011209e272SSimon Glass { 2021209e272SSimon Glass state->read_state = true; 2031209e272SSimon Glass return 0; 2041209e272SSimon Glass } 2051209e272SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(read, 'r', 0, "Read the state FDT on startup"); 2061209e272SSimon Glass 2071209e272SSimon Glass static int sandbox_cmdline_cb_write(struct sandbox_state *state, 2081209e272SSimon Glass const char *arg) 2091209e272SSimon Glass { 2101209e272SSimon Glass state->write_state = true; 2111209e272SSimon Glass return 0; 2121209e272SSimon Glass } 2131209e272SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(write, 'w', 0, "Write state FDT on exit"); 2141209e272SSimon Glass 2151209e272SSimon Glass static int sandbox_cmdline_cb_ignore_missing(struct sandbox_state *state, 2161209e272SSimon Glass const char *arg) 2171209e272SSimon Glass { 2181209e272SSimon Glass state->ignore_missing_state_on_read = true; 2191209e272SSimon Glass return 0; 2201209e272SSimon Glass } 2211209e272SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(ignore_missing, 'n', 0, 2221209e272SSimon Glass "Ignore missing state on read"); 2231209e272SSimon Glass 2247d95f2a3SSimon Glass static int sandbox_cmdline_cb_show_lcd(struct sandbox_state *state, 2257d95f2a3SSimon Glass const char *arg) 2267d95f2a3SSimon Glass { 2277d95f2a3SSimon Glass state->show_lcd = true; 2287d95f2a3SSimon Glass return 0; 2297d95f2a3SSimon Glass } 2307d95f2a3SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(show_lcd, 'l', 0, 2317d95f2a3SSimon Glass "Show the sandbox LCD display"); 2327d95f2a3SSimon Glass 233ffb87905SSimon Glass static const char *term_args[STATE_TERM_COUNT] = { 234ffb87905SSimon Glass "raw-with-sigs", 235ffb87905SSimon Glass "raw", 236ffb87905SSimon Glass "cooked", 237ffb87905SSimon Glass }; 238ffb87905SSimon Glass 239ffb87905SSimon Glass static int sandbox_cmdline_cb_terminal(struct sandbox_state *state, 240ffb87905SSimon Glass const char *arg) 241ffb87905SSimon Glass { 242ffb87905SSimon Glass int i; 243ffb87905SSimon Glass 244ffb87905SSimon Glass for (i = 0; i < STATE_TERM_COUNT; i++) { 245ffb87905SSimon Glass if (!strcmp(arg, term_args[i])) { 246ffb87905SSimon Glass state->term_raw = i; 247ffb87905SSimon Glass return 0; 248ffb87905SSimon Glass } 249ffb87905SSimon Glass } 250ffb87905SSimon Glass 251ffb87905SSimon Glass printf("Unknown terminal setting '%s' (", arg); 252ffb87905SSimon Glass for (i = 0; i < STATE_TERM_COUNT; i++) 253ffb87905SSimon Glass printf("%s%s", i ? ", " : "", term_args[i]); 254ffb87905SSimon Glass puts(")\n"); 255ffb87905SSimon Glass 256ffb87905SSimon Glass return 1; 257ffb87905SSimon Glass } 258ffb87905SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(terminal, 't', 1, 259ffb87905SSimon Glass "Set terminal to raw/cooked mode"); 260ffb87905SSimon Glass 2619ce8b402SSimon Glass static int sandbox_cmdline_cb_verbose(struct sandbox_state *state, 2629ce8b402SSimon Glass const char *arg) 2639ce8b402SSimon Glass { 2649ce8b402SSimon Glass state->show_test_output = true; 2659ce8b402SSimon Glass return 0; 2669ce8b402SSimon Glass } 2679ce8b402SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(verbose, 'v', 0, "Show test output"); 2689ce8b402SSimon Glass 269*2b6793deSSimon Glass int board_run_command(const char *cmdline) 270*2b6793deSSimon Glass { 271*2b6793deSSimon Glass printf("## Commands are disabled. Please enable CONFIG_CMDLINE.\n"); 272*2b6793deSSimon Glass 273*2b6793deSSimon Glass return 1; 274*2b6793deSSimon Glass } 275*2b6793deSSimon Glass 276bace3d00SSimon Glass int main(int argc, char *argv[]) 277bace3d00SSimon Glass { 27870db4212SSimon Glass struct sandbox_state *state; 2794d94dfa0SSimon Glass gd_t data; 2801209e272SSimon Glass int ret; 2816fb62078SSimon Glass 2821209e272SSimon Glass ret = state_init(); 2831209e272SSimon Glass if (ret) 2841209e272SSimon Glass goto err; 2856fb62078SSimon Glass 28670db4212SSimon Glass state = state_get_current(); 28770db4212SSimon Glass if (os_parse_args(state, argc, argv)) 28870db4212SSimon Glass return 1; 28970db4212SSimon Glass 2901209e272SSimon Glass ret = sandbox_read_state(state, state->state_fname); 2911209e272SSimon Glass if (ret) 2921209e272SSimon Glass goto err; 2931209e272SSimon Glass 294ab839dc3SSimon Glass /* Remove old memory file if required */ 295ab839dc3SSimon Glass if (state->ram_buf_rm && state->ram_buf_fname) 296ab839dc3SSimon Glass os_unlink(state->ram_buf_fname); 297ab839dc3SSimon Glass 2984d94dfa0SSimon Glass memset(&data, '\0', sizeof(data)); 2994d94dfa0SSimon Glass gd = &data; 30029afe9e6SSimon Glass #ifdef CONFIG_SYS_MALLOC_F_LEN 30129afe9e6SSimon Glass gd->malloc_base = CONFIG_MALLOC_F_ADDR; 30229afe9e6SSimon Glass #endif 3034d94dfa0SSimon Glass 304808434cdSSimon Glass /* Do pre- and post-relocation init */ 305bace3d00SSimon Glass board_init_f(0); 3068ec21bbeSAllen Martin 307808434cdSSimon Glass board_init_r(gd->new_gd, 0); 308808434cdSSimon Glass 309808434cdSSimon Glass /* NOTREACHED - board_init_r() does not return */ 3108ec21bbeSAllen Martin return 0; 3111209e272SSimon Glass 3121209e272SSimon Glass err: 3131209e272SSimon Glass printf("Error %d\n", ret); 3141209e272SSimon Glass return 1; 315bace3d00SSimon Glass } 316