From a54b6a61433600fe80d215dc8f8489fab44d0bfd Mon Sep 17 00:00:00 2001 From: Gabe Black Date: Sat, 29 Sep 2012 00:21:27 -0700 Subject: libpayload: Add support for the CBMEM in memory console. Change-Id: I1489b5306ef1ca078686fed4dba2d242f70ad941 Signed-off-by: Gabe Black Reviewed-on: http://review.coreboot.org/1727 Tested-by: build bot (Jenkins) Reviewed-by: Ronald G. Minnich --- 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(+) create mode 100644 payloads/libpayload/drivers/cbmem_console.c (limited to 'payloads') diff --git a/payloads/libpayload/Config.in b/payloads/libpayload/Config.in index 8b54f8f4f6..90a22ff523 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 8d50f56208..d5876fca37 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 80c9a5b075..e3bb995324 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 0000000000..d4f01bf25a --- /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 +#include + +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 b47d79f7fc..3a91cbc959 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 5368dd698b..fce6de4fa0 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) -- cgit v1.2.3