xref: /rk3399_rockchip-uboot/arch/sandbox/cpu/start.c (revision 88539e4431cd6a596da316f81b644c4df606dbd9)
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 */
8070db4212SSimon Glass 	if (state->cmd) {
81*88539e44SJoe Hershberger 		int retval;
82*88539e44SJoe Hershberger 
837dbcb76eSRabin Vincent 		cli_init();
847dbcb76eSRabin Vincent 
85*88539e44SJoe Hershberger 		retval = run_command_list(state->cmd, -1, 0);
86c5a62d4aSSimon Glass 		if (!state->interactive)
87*88539e44SJoe Hershberger 			os_exit(retval);
8870db4212SSimon Glass 	}
8970db4212SSimon Glass 
90ab4e07ebSSimon Glass 	return 0;
91ab4e07ebSSimon Glass }
92ab4e07ebSSimon Glass 
937b3efc66SSimon Glass static int sandbox_cmdline_cb_command(struct sandbox_state *state,
947b3efc66SSimon Glass 				      const char *arg)
9570db4212SSimon Glass {
9670db4212SSimon Glass 	state->cmd = arg;
9770db4212SSimon Glass 	return 0;
9870db4212SSimon Glass }
997b3efc66SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(command, 'c', 1, "Execute U-Boot command");
10070db4212SSimon Glass 
1017b3efc66SSimon Glass static int sandbox_cmdline_cb_fdt(struct sandbox_state *state, const char *arg)
102f828bf25SSimon Glass {
103f828bf25SSimon Glass 	state->fdt_fname = arg;
104f828bf25SSimon Glass 	return 0;
105f828bf25SSimon Glass }
1067b3efc66SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(fdt, 'd', 1, "Specify U-Boot's control FDT");
107f828bf25SSimon Glass 
1081f32ae95SSimon Glass static int sandbox_cmdline_cb_default_fdt(struct sandbox_state *state,
1091f32ae95SSimon Glass 					  const char *arg)
1101f32ae95SSimon Glass {
1111f32ae95SSimon Glass 	const char *fmt = "%s.dtb";
1121f32ae95SSimon Glass 	char *fname;
1131f32ae95SSimon Glass 	int len;
1141f32ae95SSimon Glass 
1151f32ae95SSimon Glass 	len = strlen(state->argv[0]) + strlen(fmt) + 1;
1161f32ae95SSimon Glass 	fname = os_malloc(len);
1171f32ae95SSimon Glass 	if (!fname)
1181f32ae95SSimon Glass 		return -ENOMEM;
1191f32ae95SSimon Glass 	snprintf(fname, len, fmt, state->argv[0]);
1201f32ae95SSimon Glass 	state->fdt_fname = fname;
1211f32ae95SSimon Glass 
1221f32ae95SSimon Glass 	return 0;
1231f32ae95SSimon Glass }
1241f32ae95SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(default_fdt, 'D', 0,
1251f32ae95SSimon Glass 		"Use the default u-boot.dtb control FDT in U-Boot directory");
1261f32ae95SSimon Glass 
127c5a62d4aSSimon Glass static int sandbox_cmdline_cb_interactive(struct sandbox_state *state,
128c5a62d4aSSimon Glass 					  const char *arg)
129c5a62d4aSSimon Glass {
130c5a62d4aSSimon Glass 	state->interactive = true;
131c5a62d4aSSimon Glass 	return 0;
132c5a62d4aSSimon Glass }
133c5a62d4aSSimon Glass 
134c5a62d4aSSimon Glass SANDBOX_CMDLINE_OPT_SHORT(interactive, 'i', 0, "Enter interactive mode");
135c5a62d4aSSimon Glass 
136bda7773fSSimon Glass static int sandbox_cmdline_cb_jump(struct sandbox_state *state,
137bda7773fSSimon Glass 				   const char *arg)
138bda7773fSSimon Glass {
139ab839dc3SSimon Glass 	/* Remember to delete this U-Boot image later */
140ab839dc3SSimon Glass 	state->jumped_fname = arg;
141bda7773fSSimon Glass 
142bda7773fSSimon Glass 	return 0;
143bda7773fSSimon Glass }
144bda7773fSSimon Glass SANDBOX_CMDLINE_OPT_SHORT(jump, 'j', 1, "Jumped from previous U-Boot");
145bda7773fSSimon Glass 
1465c2859cdSSimon Glass static int sandbox_cmdline_cb_memory(struct sandbox_state *state,
1475c2859cdSSimon Glass 				     const char *arg)
1485c2859cdSSimon Glass {
1495c2859cdSSimon Glass 	int err;
1505c2859cdSSimon Glass 
1515c2859cdSSimon Glass 	/* For now assume we always want to write it */
1525c2859cdSSimon Glass 	state->write_ram_buf = true;
1535c2859cdSSimon Glass 	state->ram_buf_fname = arg;
1545c2859cdSSimon Glass 
155f80a8bbeSSimon Glass 	err = os_read_ram_buf(arg);
156f80a8bbeSSimon Glass 	if (err) {
1575c2859cdSSimon Glass 		printf("Failed to read RAM buffer\n");
1585c2859cdSSimon Glass 		return err;
1595c2859cdSSimon Glass 	}
1605c2859cdSSimon Glass 
1615c2859cdSSimon Glass 	return 0;
1625c2859cdSSimon Glass }
1635c2859cdSSimon Glass SANDBOX_CMDLINE_OPT_SHORT(memory, 'm', 1,
1645c2859cdSSimon Glass 			  "Read/write ram_buf memory contents from file");
1655c2859cdSSimon Glass 
166ab839dc3SSimon Glass static int sandbox_cmdline_cb_rm_memory(struct sandbox_state *state,
167ab839dc3SSimon Glass 					const char *arg)
168ab839dc3SSimon Glass {
169ab839dc3SSimon Glass 	state->ram_buf_rm = true;
170ab839dc3SSimon Glass 
171ab839dc3SSimon Glass 	return 0;
172ab839dc3SSimon Glass }
173ab839dc3SSimon Glass SANDBOX_CMDLINE_OPT(rm_memory, 0, "Remove memory file after reading");
174ab839dc3SSimon Glass 
1751209e272SSimon Glass static int sandbox_cmdline_cb_state(struct sandbox_state *state,
1761209e272SSimon Glass 				    const char *arg)
1771209e272SSimon Glass {
1781209e272SSimon Glass 	state->state_fname = arg;
1791209e272SSimon Glass 	return 0;
1801209e272SSimon Glass }
1811209e272SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(state, 's', 1, "Specify the sandbox state FDT");
1821209e272SSimon Glass 
1831209e272SSimon Glass static int sandbox_cmdline_cb_read(struct sandbox_state *state,
1841209e272SSimon Glass 				   const char *arg)
1851209e272SSimon Glass {
1861209e272SSimon Glass 	state->read_state = true;
1871209e272SSimon Glass 	return 0;
1881209e272SSimon Glass }
1891209e272SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(read, 'r', 0, "Read the state FDT on startup");
1901209e272SSimon Glass 
1911209e272SSimon Glass static int sandbox_cmdline_cb_write(struct sandbox_state *state,
1921209e272SSimon Glass 				    const char *arg)
1931209e272SSimon Glass {
1941209e272SSimon Glass 	state->write_state = true;
1951209e272SSimon Glass 	return 0;
1961209e272SSimon Glass }
1971209e272SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(write, 'w', 0, "Write state FDT on exit");
1981209e272SSimon Glass 
1991209e272SSimon Glass static int sandbox_cmdline_cb_ignore_missing(struct sandbox_state *state,
2001209e272SSimon Glass 					     const char *arg)
2011209e272SSimon Glass {
2021209e272SSimon Glass 	state->ignore_missing_state_on_read = true;
2031209e272SSimon Glass 	return 0;
2041209e272SSimon Glass }
2051209e272SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(ignore_missing, 'n', 0,
2061209e272SSimon Glass 			  "Ignore missing state on read");
2071209e272SSimon Glass 
2087d95f2a3SSimon Glass static int sandbox_cmdline_cb_show_lcd(struct sandbox_state *state,
2097d95f2a3SSimon Glass 				       const char *arg)
2107d95f2a3SSimon Glass {
2117d95f2a3SSimon Glass 	state->show_lcd = true;
2127d95f2a3SSimon Glass 	return 0;
2137d95f2a3SSimon Glass }
2147d95f2a3SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(show_lcd, 'l', 0,
2157d95f2a3SSimon Glass 			  "Show the sandbox LCD display");
2167d95f2a3SSimon Glass 
217ffb87905SSimon Glass static const char *term_args[STATE_TERM_COUNT] = {
218ffb87905SSimon Glass 	"raw-with-sigs",
219ffb87905SSimon Glass 	"raw",
220ffb87905SSimon Glass 	"cooked",
221ffb87905SSimon Glass };
222ffb87905SSimon Glass 
223ffb87905SSimon Glass static int sandbox_cmdline_cb_terminal(struct sandbox_state *state,
224ffb87905SSimon Glass 				       const char *arg)
225ffb87905SSimon Glass {
226ffb87905SSimon Glass 	int i;
227ffb87905SSimon Glass 
228ffb87905SSimon Glass 	for (i = 0; i < STATE_TERM_COUNT; i++) {
229ffb87905SSimon Glass 		if (!strcmp(arg, term_args[i])) {
230ffb87905SSimon Glass 			state->term_raw = i;
231ffb87905SSimon Glass 			return 0;
232ffb87905SSimon Glass 		}
233ffb87905SSimon Glass 	}
234ffb87905SSimon Glass 
235ffb87905SSimon Glass 	printf("Unknown terminal setting '%s' (", arg);
236ffb87905SSimon Glass 	for (i = 0; i < STATE_TERM_COUNT; i++)
237ffb87905SSimon Glass 		printf("%s%s", i ? ", " : "", term_args[i]);
238ffb87905SSimon Glass 	puts(")\n");
239ffb87905SSimon Glass 
240ffb87905SSimon Glass 	return 1;
241ffb87905SSimon Glass }
242ffb87905SSimon Glass SANDBOX_CMDLINE_OPT_SHORT(terminal, 't', 1,
243ffb87905SSimon Glass 			  "Set terminal to raw/cooked mode");
244ffb87905SSimon Glass 
245bace3d00SSimon Glass int main(int argc, char *argv[])
246bace3d00SSimon Glass {
24770db4212SSimon Glass 	struct sandbox_state *state;
2484d94dfa0SSimon Glass 	gd_t data;
2491209e272SSimon Glass 	int ret;
2506fb62078SSimon Glass 
2511209e272SSimon Glass 	ret = state_init();
2521209e272SSimon Glass 	if (ret)
2531209e272SSimon Glass 		goto err;
2546fb62078SSimon Glass 
25570db4212SSimon Glass 	state = state_get_current();
25670db4212SSimon Glass 	if (os_parse_args(state, argc, argv))
25770db4212SSimon Glass 		return 1;
25870db4212SSimon Glass 
2591209e272SSimon Glass 	ret = sandbox_read_state(state, state->state_fname);
2601209e272SSimon Glass 	if (ret)
2611209e272SSimon Glass 		goto err;
2621209e272SSimon Glass 
263ab839dc3SSimon Glass 	/* Remove old memory file if required */
264ab839dc3SSimon Glass 	if (state->ram_buf_rm && state->ram_buf_fname)
265ab839dc3SSimon Glass 		os_unlink(state->ram_buf_fname);
266ab839dc3SSimon Glass 
2674d94dfa0SSimon Glass 	memset(&data, '\0', sizeof(data));
2684d94dfa0SSimon Glass 	gd = &data;
26929afe9e6SSimon Glass #ifdef CONFIG_SYS_MALLOC_F_LEN
27029afe9e6SSimon Glass 	gd->malloc_base = CONFIG_MALLOC_F_ADDR;
27129afe9e6SSimon Glass #endif
2724d94dfa0SSimon Glass 
273808434cdSSimon Glass 	/* Do pre- and post-relocation init */
274bace3d00SSimon Glass 	board_init_f(0);
2758ec21bbeSAllen Martin 
276808434cdSSimon Glass 	board_init_r(gd->new_gd, 0);
277808434cdSSimon Glass 
278808434cdSSimon Glass 	/* NOTREACHED - board_init_r() does not return */
2798ec21bbeSAllen Martin 	return 0;
2801209e272SSimon Glass 
2811209e272SSimon Glass err:
2821209e272SSimon Glass 	printf("Error %d\n", ret);
2831209e272SSimon Glass 	return 1;
284bace3d00SSimon Glass }
285