| /* | 
|  * (C) Copyright 2011-2012 Pali Rohár <pali.rohar@gmail.com> | 
|  * | 
|  * SPDX-License-Identifier:    GPL-2.0+ | 
|  */ | 
|   | 
| ANSI terminal bootmenu command | 
|   | 
| The "bootmenu" command uses U-Boot menu interfaces and provides | 
| a simple mechanism for creating menus with different boot items. | 
| The cursor keys "Up" and "Down" are used for navigation through | 
| the items. Current active menu item is highlighted and can be | 
| selected using the "Enter" key. The selection of the highlighted | 
| menu entry invokes an U-Boot command (or a list of commands) | 
| associated with this menu entry. | 
|   | 
| The "bootmenu" command interprets ANSI escape sequencies, so | 
| an ANSI terminal is required for proper menu rendering and item | 
| selection. | 
|   | 
| The assembling of the menu is done via a set of environment variables | 
| "bootmenu_<num>" and "bootmenu_delay", i.e.: | 
|   | 
|   bootmenu_delay=<delay> | 
|   bootmenu_<num>="<title>=<commands>" | 
|   | 
|   <delay> is the autoboot delay in seconds, after which the first | 
|   menu entry will be selected automatically | 
|   | 
|   <num> is the boot menu entry number, starting from zero | 
|   | 
|   <title> is the text of the menu entry shown on the console | 
|   or on the boot screen | 
|   | 
|   <commands> are commands which will be executed when a menu | 
|   entry is selected | 
|   | 
|   (title and commands are separated by first appearance of '=' | 
|    character in the environment variable) | 
|   | 
| First (optional) argument of the "bootmenu" command is a delay specifier | 
| and it overrides the delay value defined by "bootmenu_delay" environment | 
| variable. If the environment variable "bootmenu_delay" is not set or if | 
| the argument of the "bootmenu" command is not specified, the default delay | 
| will be CONFIG_BOOTDELAY. If delay is 0, no menu entries will be shown on | 
| the console (or on the screen) and the command of the first menu entry will | 
| be called immediately. If delay is less then 0, bootmenu will be shown and | 
| autoboot will be disabled. | 
|   | 
| Bootmenu always adds menu entry "U-Boot console" at the end of all menu | 
| entries specified by environment variables. When selecting this entry | 
| the bootmenu terminates and the usual U-Boot command prompt is presented | 
| to the user. | 
|   | 
| Example environment: | 
|   | 
|   setenv bootmenu_0 Boot 1. kernel=bootm 0x82000000  # Set first menu entry | 
|   setenv bootmenu_1 Boot 2. kernel=bootm 0x83000000  # Set second menu entry | 
|   setenv bootmenu_2 Reset board=reset                # Set third menu entry | 
|   setenv bootmenu_3 U-Boot boot order=boot           # Set fourth menu entry | 
|   bootmenu 20        # Run bootmenu with autoboot delay 20s | 
|   | 
|   | 
| The above example will be rendered as below | 
| (without decorating rectangle): | 
|   | 
| ┌──────────────────────────────────────────┐ | 
| │                                          │ | 
| │  *** U-Boot Boot Menu ***                │ | 
| │                                          │ | 
| │     Boot 1. kernel                       │ | 
| │     Boot 2. kernel                       │ | 
| │     Reset board                          │ | 
| │     U-Boot boot order                    │ | 
| │     U-Boot console                       │ | 
| │                                          │ | 
| │  Hit any key to stop autoboot: 20        │ | 
| │  Press UP/DOWN to move, ENTER to select  │ | 
| │                                          │ | 
| └──────────────────────────────────────────┘ | 
|   | 
| Selected menu entry will be highlighted - it will have inverted | 
| background and text colors. | 
|   | 
| To enable the "bootmenu" command add following definitions to the | 
| board config file: | 
|   | 
|   #define CONFIG_CMD_BOOTMENU | 
|   #define CONFIG_MENU | 
|   | 
| To run the bootmenu at startup add these additional definitions: | 
|   | 
|   #define CONFIG_AUTOBOOT_KEYED | 
|   #define CONFIG_BOOTDELAY 30 | 
|   #define CONFIG_MENU_SHOW | 
|   | 
| When you intend to use the bootmenu on color frame buffer console, | 
| make sure to additionally define CONFIG_CFB_CONSOLE_ANSI in the | 
| board config file. |