Stefan Reinauer (stefan.reinauer@coreboot.org) just uploaded a new patch set to gerrit, which you can find at http://review.coreboot.org/1727
-gerrit
commit f05e5c90f6d763a83c6002a34ee96973a53f3db7 Author: Gabe Black gabeblack@google.com Date: Sat Sep 29 00:21:27 2012 -0700
libpayload: Add support for the CBMEM in memory console.
Change-Id: I1489b5306ef1ca078686fed4dba2d242f70ad941 Signed-off-by: Gabe Black gabeblack@google.com --- payloads/libpayload/Config.in | 4 +++ payloads/libpayload/configs/defconfig | 1 + payloads/libpayload/drivers/Makefile.inc | 2 ++ payloads/libpayload/drivers/cbmem_console.c | 53 +++++++++++++++++++++++++++++ payloads/libpayload/include/libpayload.h | 9 +++++ payloads/libpayload/libc/console.c | 3 ++ 6 files changed, 72 insertions(+)
diff --git a/payloads/libpayload/Config.in b/payloads/libpayload/Config.in index 8b54f8f..90a22ff 100644 --- a/payloads/libpayload/Config.in +++ b/payloads/libpayload/Config.in @@ -147,6 +147,10 @@ endmenu
menu "Console Options"
+config CBMEM_CONSOLE + bool "Send output to the in memory CBMEM console" + default y + config SERIAL_CONSOLE bool "See output on the serial port console" default y diff --git a/payloads/libpayload/configs/defconfig b/payloads/libpayload/configs/defconfig index 8d50f56..d5876fc 100644 --- a/payloads/libpayload/configs/defconfig +++ b/payloads/libpayload/configs/defconfig @@ -32,6 +32,7 @@ CONFIG_LZMA=y # # Console Options # +CONFIG_CBMEM_CONSOLE=y CONFIG_SERIAL_CONSOLE=y CONFIG_SERIAL_IOBASE=0x3f8 # CONFIG_SERIAL_SET_SPEED is not set diff --git a/payloads/libpayload/drivers/Makefile.inc b/payloads/libpayload/drivers/Makefile.inc index 80c9a5b..e3bb995 100644 --- a/payloads/libpayload/drivers/Makefile.inc +++ b/payloads/libpayload/drivers/Makefile.inc @@ -37,6 +37,8 @@ libc-$(CONFIG_SERIAL_CONSOLE) += serial.c
libc-$(CONFIG_PC_KEYBOARD) += keyboard.c
+libc-$(CONFIG_CBMEM_CONSOLE) += cbmem_console.c + libc-$(CONFIG_NVRAM) += nvram.c libc-$(CONFIG_NVRAM) += options.c
diff --git a/payloads/libpayload/drivers/cbmem_console.c b/payloads/libpayload/drivers/cbmem_console.c new file mode 100644 index 0000000..d4f01bf --- /dev/null +++ b/payloads/libpayload/drivers/cbmem_console.c @@ -0,0 +1,53 @@ +/* + * Copyright (c) 2012 The Chromium OS Authors. + * + * See file CREDITS for list of people who contributed to this + * project. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2 of + * the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but without any warranty; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, + * MA 02111-1307 USA + */ + +#include <libpayload.h> +#include <stdint.h> + +struct cbmem_console { + uint32_t size; + uint32_t cursor; + uint8_t body[0]; +} __attribute__ ((__packed__)); + +static struct cbmem_console *cbmem_console_p; + +static struct console_output_driver cbmem_console_driver = +{ + .putchar = &cbmem_console_putc +}; + +void cbmem_console_init(void) +{ + cbmem_console_p = lib_sysinfo.cbmem_cons; + if (cbmem_console_p) + console_add_output_driver(&cbmem_console_driver); +} + +void cbmem_console_putc(unsigned int data) +{ + // Bail out if the buffer is full. + if (cbmem_console_p->cursor >= cbmem_console_p->size) + return; + + cbmem_console_p->body[cbmem_console_p->cursor++] = data; +} diff --git a/payloads/libpayload/include/libpayload.h b/payloads/libpayload/include/libpayload.h index b47d79f..3a91cbc 100644 --- a/payloads/libpayload/include/libpayload.h +++ b/payloads/libpayload/include/libpayload.h @@ -201,6 +201,15 @@ void video_console_get_cursor(unsigned int *x, unsigned int *y, unsigned int *en void video_console_set_cursor(unsigned int cursorx, unsigned int cursory); /** @} */
+/** + * @defgroup cbmem_console CBMEM memory console. + * @ingroup input + * @{ + */ +void cbmem_console_init(void); +void cbmem_console_putc(unsigned int data); +/** @} */ + /* drivers/option.c */ struct nvram_accessor { u8 (*read)(u8 reg); diff --git a/payloads/libpayload/libc/console.c b/payloads/libpayload/libc/console.c index 5368dd6..fce6de4 100644 --- a/payloads/libpayload/libc/console.c +++ b/payloads/libpayload/libc/console.c @@ -57,6 +57,9 @@ void console_init(void) #ifdef CONFIG_PC_KEYBOARD keyboard_init(); #endif +#ifdef CONFIG_CBMEM_CONSOLE + cbmem_console_init(); +#endif }
static void device_putchar(unsigned char c)