blob: 8c846c84c804a7e9e561bee292ab745580858847 [file] [log] [blame]
wdenkc6097192002-11-03 00:24:07 +00001/*
2 * (C) Copyright 2000
3 * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4 *
Wolfgang Denk1a459662013-07-08 09:37:19 +02005 * SPDX-License-Identifier: GPL-2.0+
wdenkc6097192002-11-03 00:24:07 +00006 */
7
wdenka6c7ad22002-12-03 21:28:10 +00008/* #define DEBUG */
9
wdenkc6097192002-11-03 00:24:07 +000010#include <common.h>
Simon Glass66ded172014-04-10 20:01:28 -060011#include <autoboot.h>
Simon Glass18d66532014-04-10 20:01:25 -060012#include <cli.h>
Simon Glassfbcdf322013-05-15 06:23:59 +000013#include <malloc.h>
Simon Glassfbcdf322013-05-15 06:23:59 +000014#include <version.h>
wdenkbdccc4f2003-08-05 17:43:17 +000015
Simon Glass9272a9b2014-04-10 20:01:32 -060016DECLARE_GLOBAL_DATA_PTR;
17
Heiko Schocherfad63402007-07-13 09:54:17 +020018/*
19 * Board-specific Platform code can reimplement show_boot_progress () if needed
20 */
21void inline __show_boot_progress (int val) {}
Emil Medve5e2c08c2009-05-12 13:48:32 -050022void show_boot_progress (int val) __attribute__((weak, alias("__show_boot_progress")));
Heiko Schocherfad63402007-07-13 09:54:17 +020023
Simon Glass1364a0e2014-04-10 20:01:33 -060024static void modem_init(void)
Simon Glassbc2b4c22013-05-15 06:23:56 +000025{
Simon Glassbc2b4c22013-05-15 06:23:56 +000026#ifdef CONFIG_MODEM_SUPPORT
Simon Glass9272a9b2014-04-10 20:01:32 -060027 debug("DEBUG: main_loop: gd->do_mdm_init=%lu\n", gd->do_mdm_init);
28 if (gd->do_mdm_init) {
Simon Glassbc2b4c22013-05-15 06:23:56 +000029 char *str = strdup(getenv("mdm_cmd"));
30 setenv("preboot", str); /* set or delete definition */
31 if (str != NULL)
32 free(str);
33 mdm_init(); /* wait for modem connection */
34 }
35#endif /* CONFIG_MODEM_SUPPORT */
Simon Glass1364a0e2014-04-10 20:01:33 -060036}
Simon Glassbc2b4c22013-05-15 06:23:56 +000037
Simon Glass1364a0e2014-04-10 20:01:33 -060038static void run_preboot_environment_command(void)
39{
Simon Glassbc2b4c22013-05-15 06:23:56 +000040#ifdef CONFIG_PREBOOT
Simon Glass1364a0e2014-04-10 20:01:33 -060041 char *p;
42
Simon Glassbc2b4c22013-05-15 06:23:56 +000043 p = getenv("preboot");
44 if (p != NULL) {
45# ifdef CONFIG_AUTOBOOT_KEYED
46 int prev = disable_ctrlc(1); /* disable Control C checking */
47# endif
48
49 run_command_list(p, -1, 0);
50
51# ifdef CONFIG_AUTOBOOT_KEYED
52 disable_ctrlc(prev); /* restore Control C checking */
53# endif
54 }
55#endif /* CONFIG_PREBOOT */
Simon Glass1364a0e2014-04-10 20:01:33 -060056}
57
58void main_loop(void)
59{
60 bootstage_mark_name(BOOTSTAGE_ID_MAIN_LOOP, "main_loop");
61
62#ifndef CONFIG_SYS_GENERIC_BOARD
63 puts("Warning: Your board does not use generic board. Please read\n");
64 puts("doc/README.generic-board and take action. Boards not\n");
65 puts("upgraded by the late 2014 may break or be removed.\n");
66#endif
67
68 modem_init();
69#ifdef CONFIG_VERSION_VARIABLE
70 setenv("ver", version_string); /* set version variable */
71#endif /* CONFIG_VERSION_VARIABLE */
72
Simon Glassc1bb2cd2014-04-10 20:01:34 -060073 cli_init();
Simon Glass1364a0e2014-04-10 20:01:33 -060074
75 run_preboot_environment_command();
Simon Glassbc2b4c22013-05-15 06:23:56 +000076
77#if defined(CONFIG_UPDATE_TFTP)
78 update_tftp(0UL);
79#endif /* CONFIG_UPDATE_TFTP */
80
Simon Glass66ded172014-04-10 20:01:28 -060081 bootdelay_process();
wdenkc6097192002-11-03 00:24:07 +000082 /*
83 * Main Loop for Monitor Command Processing
84 */
Simon Glassc1bb2cd2014-04-10 20:01:34 -060085
Simon Glass6493ccc2014-04-10 20:01:26 -060086 cli_loop();
wdenkc6097192002-11-03 00:24:07 +000087}