term: Implement interruptible quiet mode

This commit is contained in:
mintsuki 2021-11-23 11:47:14 +01:00
parent 9aa74ba391
commit 4349918eae
3 changed files with 16 additions and 8 deletions

View File

@ -52,6 +52,7 @@ Some keys take *URIs* as values; these are described in the next section.
*Globally assignable* keys are: *Globally assignable* keys are:
* `TIMEOUT` - Specifies the timeout in seconds before the first *entry* is automatically booted. If set to `no`, disable automatic boot. If set to `0`, boots default entry instantly (see `DEFAULT_ENTRY` key). * `TIMEOUT` - Specifies the timeout in seconds before the first *entry* is automatically booted. If set to `no`, disable automatic boot. If set to `0`, boots default entry instantly (see `DEFAULT_ENTRY` key).
* `QUIET` - If set to `yes`, enable quiet mode, where all screen output except panics and important warnings is suppressed. If `TIMEOUT` is not 0, the `TIMEOUT` still occurs, and pressing any key during the timeout will reveal the menu and disable quiet mode.
* `DEFAULT_ENTRY` - 1-based entry index of the entry which will be automatically selected at startup. If unspecified, it is `1`. * `DEFAULT_ENTRY` - 1-based entry index of the entry which will be automatically selected at startup. If unspecified, it is `1`.
* `GRAPHICS` - If set to `yes`, use a graphical framebuffer for the boot menu, else use text mode. Ignored with Limine UEFI, forced to `yes`. * `GRAPHICS` - If set to `yes`, use a graphical framebuffer for the boot menu, else use text mode. Ignored with Limine UEFI, forced to `yes`.
* `MENU_RESOLUTION` - Specify screen resolution to be used by the Limine menu in the form `<width>x<height>`. This will *only* affect the menu, not any booted OS. If not specified, Limine will pick a resolution automatically. If the resolution is not available, Limine will pick another one automatically. Ignored if `GRAPHICS` is not `yes`. * `MENU_RESOLUTION` - Specify screen resolution to be used by the Limine menu in the form `<width>x<height>`. This will *only* affect the menu, not any booted OS. If not specified, Limine will pick a resolution automatically. If the resolution is not available, Limine will pick another one automatically. Ignored if `GRAPHICS` is not `yes`.
@ -82,7 +83,6 @@ Some keys take *URIs* as values; these are described in the next section.
* `EDITOR_HIGHLIGHTING` - If set to `no`, syntax highlighting in the editor will be disabled. Defaults to `yes`. * `EDITOR_HIGHLIGHTING` - If set to `no`, syntax highlighting in the editor will be disabled. Defaults to `yes`.
* `EDITOR_VALIDATION` - If set to `no`, the editor will not alert you about invalid keys / syntax errors. Defaults to `yes`. * `EDITOR_VALIDATION` - If set to `no`, the editor will not alert you about invalid keys / syntax errors. Defaults to `yes`.
* `VERBOSE` - If set to `yes`, print additional information during boot. Defaults to not verbose. * `VERBOSE` - If set to `yes`, print additional information during boot. Defaults to not verbose.
* `QUIET` - If set to `yes`, enable quiet mode, where all screen output except panics and important warnings is suppressed.
* `RANDOMISE_MEMORY` - If set to `yes`, randomise the contents of RAM at bootup in order to find bugs related to non zeroed memory or for security reasons. This option will slow down boot time significantly. * `RANDOMISE_MEMORY` - If set to `yes`, randomise the contents of RAM at bootup in order to find bugs related to non zeroed memory or for security reasons. This option will slow down boot time significantly.
* `RANDOMIZE_MEMORY` - Alias of `RANDOMISE_MEMORY`. * `RANDOMIZE_MEMORY` - Alias of `RANDOMISE_MEMORY`.

View File

@ -141,10 +141,6 @@ void stage3_common(void) {
char *quiet_str = config_get_value(NULL, 0, "QUIET"); char *quiet_str = config_get_value(NULL, 0, "QUIET");
quiet = quiet_str != NULL && strcmp(quiet_str, "yes") == 0; quiet = quiet_str != NULL && strcmp(quiet_str, "yes") == 0;
#if bios == 1
term_textmode();
#endif
char *verbose_str = config_get_value(NULL, 0, "VERBOSE"); char *verbose_str = config_get_value(NULL, 0, "VERBOSE");
verbose = verbose_str != NULL && strcmp(verbose_str, "yes") == 0; verbose = verbose_str != NULL && strcmp(verbose_str, "yes") == 0;

View File

@ -76,6 +76,7 @@ static size_t get_prev_line(size_t index, const char *buffer) {
static const char *VALID_KEYS[] = { static const char *VALID_KEYS[] = {
"TIMEOUT", "TIMEOUT",
"QUIET",
"DEFAULT_ENTRY", "DEFAULT_ENTRY",
"GRAPHICS", "GRAPHICS",
"MENU_RESOLUTION", "MENU_RESOLUTION",
@ -565,6 +566,8 @@ char *menu(char **cmdline) {
#elif uefi == 1 #elif uefi == 1
char *graphics = "yes"; char *graphics = "yes";
#endif #endif
reterm:
if (graphics != NULL && !strcmp(graphics, "yes")) { if (graphics != NULL && !strcmp(graphics, "yes")) {
size_t req_width = 0, req_height = 0, req_bpp = 0; size_t req_width = 0, req_height = 0, req_bpp = 0;
@ -573,6 +576,10 @@ char *menu(char **cmdline) {
parse_resolution(&req_width, &req_height, &req_bpp, menu_resolution); parse_resolution(&req_width, &req_height, &req_bpp, menu_resolution);
term_vbe(req_width, req_height); term_vbe(req_width, req_height);
} else {
#if bios == 1
term_textmode();
#endif
} }
refresh: refresh:
@ -665,11 +672,16 @@ refresh:
term_double_buffer_flush(); term_double_buffer_flush();
if ((c = pit_sleep_and_quit_on_keypress(1))) { if ((c = pit_sleep_and_quit_on_keypress(1))) {
skip_timeout = true; skip_timeout = true;
if (quiet) {
quiet = false;
goto reterm;
} else {
print("\e[2K"); print("\e[2K");
term_double_buffer_flush(); term_double_buffer_flush();
goto timeout_aborted; goto timeout_aborted;
} }
} }
}
goto autoboot; goto autoboot;
} }