mirror of
https://github.com/Fishwaldo/u-boot.git
synced 2025-06-22 06:32:23 +00:00
sandbox: Allow Ctrl-C to work in sandbox
It is useful for Cltl-C to be handled by U-Boot as it is on other boards. But it is also useful to be able to terminate U-Boot with Ctrl-C. Add an option to enable signals while in raw mode, and make this the default. Add an option to leave the terminal cooked, which is useful for redirecting output. Signed-off-by: Simon Glass <sjg@chromium.org>
This commit is contained in:
parent
20f86a0aea
commit
ffb87905cb
5 changed files with 69 additions and 8 deletions
|
@ -104,21 +104,22 @@ void os_exit(int exit_code)
|
||||||
|
|
||||||
/* Restore tty state when we exit */
|
/* Restore tty state when we exit */
|
||||||
static struct termios orig_term;
|
static struct termios orig_term;
|
||||||
|
static bool term_setup;
|
||||||
|
|
||||||
static void os_fd_restore(void)
|
static void os_fd_restore(void)
|
||||||
{
|
{
|
||||||
tcsetattr(0, TCSANOW, &orig_term);
|
if (term_setup)
|
||||||
|
tcsetattr(0, TCSANOW, &orig_term);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Put tty into raw mode so <tab> and <ctrl+c> work */
|
/* Put tty into raw mode so <tab> and <ctrl+c> work */
|
||||||
void os_tty_raw(int fd)
|
void os_tty_raw(int fd, bool allow_sigs)
|
||||||
{
|
{
|
||||||
static int setup = 0;
|
|
||||||
struct termios term;
|
struct termios term;
|
||||||
|
|
||||||
if (setup)
|
if (term_setup)
|
||||||
return;
|
return;
|
||||||
setup = 1;
|
term_setup = true;
|
||||||
|
|
||||||
/* If not a tty, don't complain */
|
/* If not a tty, don't complain */
|
||||||
if (tcgetattr(fd, &orig_term))
|
if (tcgetattr(fd, &orig_term))
|
||||||
|
@ -128,7 +129,7 @@ void os_tty_raw(int fd)
|
||||||
term.c_iflag = IGNBRK | IGNPAR;
|
term.c_iflag = IGNBRK | IGNPAR;
|
||||||
term.c_oflag = OPOST | ONLCR;
|
term.c_oflag = OPOST | ONLCR;
|
||||||
term.c_cflag = CS8 | CREAD | CLOCAL;
|
term.c_cflag = CS8 | CREAD | CLOCAL;
|
||||||
term.c_lflag = 0;
|
term.c_lflag = allow_sigs ? ISIG : 0;
|
||||||
if (tcsetattr(fd, TCSANOW, &term))
|
if (tcsetattr(fd, TCSANOW, &term))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|
|
@ -184,6 +184,34 @@ static int sandbox_cmdline_cb_show_lcd(struct sandbox_state *state,
|
||||||
SANDBOX_CMDLINE_OPT_SHORT(show_lcd, 'l', 0,
|
SANDBOX_CMDLINE_OPT_SHORT(show_lcd, 'l', 0,
|
||||||
"Show the sandbox LCD display");
|
"Show the sandbox LCD display");
|
||||||
|
|
||||||
|
static const char *term_args[STATE_TERM_COUNT] = {
|
||||||
|
"raw-with-sigs",
|
||||||
|
"raw",
|
||||||
|
"cooked",
|
||||||
|
};
|
||||||
|
|
||||||
|
static int sandbox_cmdline_cb_terminal(struct sandbox_state *state,
|
||||||
|
const char *arg)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < STATE_TERM_COUNT; i++) {
|
||||||
|
if (!strcmp(arg, term_args[i])) {
|
||||||
|
state->term_raw = i;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("Unknown terminal setting '%s' (", arg);
|
||||||
|
for (i = 0; i < STATE_TERM_COUNT; i++)
|
||||||
|
printf("%s%s", i ? ", " : "", term_args[i]);
|
||||||
|
puts(")\n");
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
SANDBOX_CMDLINE_OPT_SHORT(terminal, 't', 1,
|
||||||
|
"Set terminal to raw/cooked mode");
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
struct sandbox_state *state;
|
struct sandbox_state *state;
|
||||||
|
|
|
@ -17,6 +17,29 @@ enum exit_type_id {
|
||||||
STATE_EXIT_POWER_OFF,
|
STATE_EXIT_POWER_OFF,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Selects the behavior of the serial terminal.
|
||||||
|
*
|
||||||
|
* If Ctrl-C is processed by U-Boot, then the only way to quit sandbox is with
|
||||||
|
* the 'reset' command, or equivalent.
|
||||||
|
*
|
||||||
|
* If the terminal is cooked, then Ctrl-C will terminate U-Boot, and the
|
||||||
|
* command line will not be quite such a faithful emulation.
|
||||||
|
*
|
||||||
|
* Options are:
|
||||||
|
*
|
||||||
|
* raw-with-sigs - Raw, but allow signals (Ctrl-C will quit)
|
||||||
|
* raw - Terminal is always raw
|
||||||
|
* cooked - Terminal is always cooked
|
||||||
|
*/
|
||||||
|
enum state_terminal_raw {
|
||||||
|
STATE_TERM_RAW_WITH_SIGS, /* Default */
|
||||||
|
STATE_TERM_RAW,
|
||||||
|
STATE_TERM_COOKED,
|
||||||
|
|
||||||
|
STATE_TERM_COUNT,
|
||||||
|
};
|
||||||
|
|
||||||
struct sandbox_spi_info {
|
struct sandbox_spi_info {
|
||||||
const char *spec;
|
const char *spec;
|
||||||
const struct sandbox_spi_emu_ops *ops;
|
const struct sandbox_spi_emu_ops *ops;
|
||||||
|
@ -42,6 +65,7 @@ struct sandbox_state {
|
||||||
bool write_state; /* Write sandbox state on exit */
|
bool write_state; /* Write sandbox state on exit */
|
||||||
bool ignore_missing_state_on_read; /* No error if state missing */
|
bool ignore_missing_state_on_read; /* No error if state missing */
|
||||||
bool show_lcd; /* Show LCD on start-up */
|
bool show_lcd; /* Show LCD on start-up */
|
||||||
|
enum state_terminal_raw term_raw; /* Terminal raw/cooked */
|
||||||
|
|
||||||
/* Pointer to information for each SPI bus/cs */
|
/* Pointer to information for each SPI bus/cs */
|
||||||
struct sandbox_spi_info spi[CONFIG_SANDBOX_SPI_MAX_BUS]
|
struct sandbox_spi_info spi[CONFIG_SANDBOX_SPI_MAX_BUS]
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
#include <os.h>
|
#include <os.h>
|
||||||
#include <serial.h>
|
#include <serial.h>
|
||||||
#include <linux/compiler.h>
|
#include <linux/compiler.h>
|
||||||
|
#include <asm/state.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
*
|
*
|
||||||
|
@ -31,7 +32,10 @@ static unsigned int serial_buf_read;
|
||||||
|
|
||||||
static int sandbox_serial_init(void)
|
static int sandbox_serial_init(void)
|
||||||
{
|
{
|
||||||
os_tty_raw(0);
|
struct sandbox_state *state = state_get_current();
|
||||||
|
|
||||||
|
if (state->term_raw != STATE_TERM_COOKED)
|
||||||
|
os_tty_raw(0, state->term_raw == STATE_TERM_RAW_WITH_SIGS);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -103,8 +103,12 @@ void os_exit(int exit_code) __attribute__((noreturn));
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Put tty into raw mode to mimic serial console better
|
* Put tty into raw mode to mimic serial console better
|
||||||
|
*
|
||||||
|
* @param fd File descriptor of stdin (normally 0)
|
||||||
|
* @param allow_sigs Allow Ctrl-C, Ctrl-Z to generate signals rather than
|
||||||
|
* be handled by U-Boot
|
||||||
*/
|
*/
|
||||||
void os_tty_raw(int fd);
|
void os_tty_raw(int fd, bool allow_sigs);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Acquires some memory from the underlying os.
|
* Acquires some memory from the underlying os.
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue