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 <[EMAIL PROTECTED]>

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
[email protected]
http://www.coreboot.org/mailman/listinfo/coreboot

Reply via email to