[coreboot] libpayload: support color over serial
Jordan Crouse
jordan.crouse at amd.com
Wed Sep 3 22:05:17 CEST 2008
On 03/09/08 21:24 +0200, Ulf Jordan wrote:
> Here is an updated version of the serial color patch.
>
> Compared to the previous patch:
>
> * serial_set_color takes explicit foreground and background color numbers.
>
> * The need to output color escape sequences is determined from the
> color pair number, not the color content of a given pair. This eliminates
> the possibbility of obtaining incorrect colors after \e[m (e.g. bold to
> non-bold transition) on terminals where the default color is not white on
> black.
>
> * doxygen comment added to serial_set_color
>
> * Foreground and background colors of a color pair are extracted with
> pair_content(), instead of relying on explicit bitmasking and shifting.
> Improves readability and removes some code duplication.
>
> Build and runtime tested with coreinfo+libpayload+coreboot-v3 under QEMU.
>
>
> /ulf
> Add support for curses color output over serial.
>
> Note that the sequence \e[m for turning off bold resets all attributes,
> including color.
>
> Signed-off-by: Ulf Jordan <jordan at chalmers.se>
Acked-by: Jordan Crouse <jordan.crouse at amd.com>
r3561. And thanks for documenting the function.
Jordan
> Index: libpayload/curses/tinycurses.c
> ===================================================================
> --- libpayload/curses/tinycurses.c.orig 2008-08-19 20:04:18.000000000 +0200
> +++ libpayload/curses/tinycurses.c 2008-09-02 22:12:14.000000000 +0200
> @@ -669,10 +669,12 @@
> // FIXME.
> int serial_is_bold = 0;
> int serial_is_altcharset = 0;
> + int serial_cur_pair = 0;
>
> int x, y;
> chtype ch;
> int need_altcharset;
> + short fg, bg;
>
> serial_end_bold();
> serial_end_altcharset();
> @@ -703,6 +705,7 @@
> if (serial_is_bold) {
> serial_end_bold();
> serial_is_bold = 0;
> + serial_cur_pair = 0;
> }
> }
>
> @@ -723,6 +726,13 @@
> serial_is_altcharset = 0;
> }
>
> + if (serial_cur_pair != PAIR_NUMBER(attr)) {
> + pair_content(PAIR_NUMBER(attr),
> + &fg, &bg);
> + serial_set_color(fg, bg);
> + serial_cur_pair = PAIR_NUMBER(attr);
> + }
> +
> serial_putchar(ch);
> }
>
> Index: libpayload/drivers/serial.c
> ===================================================================
> --- libpayload/drivers/serial.c.orig 2008-08-19 20:04:18.000000000 +0200
> +++ libpayload/drivers/serial.c 2008-09-02 22:38:19.000000000 +0200
> @@ -110,6 +110,8 @@
> enacs=\E(B\E)0, smacs=^N, rmacs=^O. */
> #define VT100_SMACS "\e(0"
> #define VT100_RMACS "\e(B"
> +/* A vt100 doesn't do color, setaf/setab below are from xterm-color. */
> +#define VT100_SET_COLOR "\e[3%d;4%dm"
>
> static void serial_putcmd(char *str)
> {
> @@ -142,6 +144,19 @@
> serial_putcmd(VT100_RMACS);
> }
>
> +/**
> + * Set the foreground and background colors on the serial console.
> + *
> + * @param fg Foreground color number.
> + * @param bg Background color number.
> + */
> +void serial_set_color(short fg, short bg)
> +{
> + char buffer[32];
> + snprintf(buffer, sizeof(buffer), VT100_SET_COLOR, fg, bg);
> + serial_putcmd(buffer);
> +}
> +
> void serial_set_cursor(int y, int x)
> {
> char buffer[32];
> Index: libpayload/include/libpayload.h
> ===================================================================
> --- libpayload/include/libpayload.h.orig 2008-09-02 21:25:39.000000000 +0200
> +++ libpayload/include/libpayload.h 2008-09-02 22:07:45.000000000 +0200
> @@ -139,6 +139,7 @@
> void serial_end_bold(void);
> void serial_start_altcharset(void);
> void serial_end_altcharset(void);
> +void serial_set_color(short fg, short bg);
> void serial_set_cursor(int y, int x);
> /** @} */
>
> --
> coreboot mailing list
> coreboot at coreboot.org
> http://www.coreboot.org/mailman/listinfo/coreboot
--
Jordan Crouse
Systems Software Development Engineer
Advanced Micro Devices, Inc.
More information about the coreboot
mailing list