d6865222c8
Because we had no stack on romcc boards, we had a separate, not as powerful clone of printk: print_*. Back in the day, like more than half a decade ago, we migrated a lot of boards to printk, but we never cleaned up the existing code to be consistent. Instead, we worked around the problem with a very messy console.h (nowadays the mess is hidden in romstage_console.c and early_print.h) This patch cleans up the generic code pieces to use printk() on all non-ROMCC boards. Our two remaining ROMCC boards are fixed up in this commit: bifferos/bifferboard and dmp/vortex86ex. Change-Id: I16676eeabe5c892c8e3c9f3c0cd3bae2e8fd74b6 Signed-off-by: Stefan Reinauer <stefan.reinauer@coreboot.org> Reviewed-on: http://review.coreboot.org/8115 Tested-by: build bot (Jenkins) Reviewed-by: Edward O'Callaghan <eocallaghan@alterapraxis.com> Reviewed-by: Andrew Wu <arw@dmp.com.tw> Reviewed-by: Kyösti Mälkki <kyosti.malkki@gmail.com>
87 lines
2 KiB
C
87 lines
2 KiB
C
/*
|
|
* This file is part of the coreboot project.
|
|
*
|
|
* Copyright (C) 2003 Eric Biederman
|
|
*
|
|
* 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; version 2 of the License.
|
|
*
|
|
* 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., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#include <build.h>
|
|
#include <console/streams.h>
|
|
#include <console/early_print.h>
|
|
#include <console/loglevel.h>
|
|
|
|
/* Include the sources. */
|
|
#if CONFIG_CONSOLE_SERIAL && CONFIG_DRIVERS_UART_8250IO
|
|
#include "drivers/uart/util.c"
|
|
#include "drivers/uart/uart8250io.c"
|
|
#endif
|
|
#if CONFIG_CONSOLE_NE2K
|
|
#include "drivers/net/ne2k.c"
|
|
#endif
|
|
|
|
void console_hw_init(void)
|
|
{
|
|
#if CONFIG_CONSOLE_SERIAL
|
|
uart_init(CONFIG_UART_FOR_CONSOLE);
|
|
#endif
|
|
#if CONFIG_CONSOLE_NE2K
|
|
ne2k_init(CONFIG_CONSOLE_NE2K_IO_PORT);
|
|
#endif
|
|
}
|
|
|
|
void console_tx_byte(unsigned char byte)
|
|
{
|
|
#if CONFIG_CONSOLE_SERIAL
|
|
uart_tx_byte(CONFIG_UART_FOR_CONSOLE, byte);
|
|
#endif
|
|
#if CONFIG_CONSOLE_NE2K
|
|
ne2k_append_data_byte(byte, CONFIG_CONSOLE_NE2K_IO_PORT);
|
|
#endif
|
|
}
|
|
|
|
void console_tx_flush(void)
|
|
{
|
|
#if CONFIG_CONSOLE_SERIAL
|
|
uart_tx_flush(CONFIG_UART_FOR_CONSOLE);
|
|
#endif
|
|
#if CONFIG_CONSOLE_NE2K
|
|
ne2k_transmit(CONFIG_CONSOLE_NE2K_IO_PORT);
|
|
#endif
|
|
}
|
|
|
|
#include <console/early_print.c>
|
|
#include <console/post.c>
|
|
#include <console/die.c>
|
|
|
|
void console_init(void)
|
|
{
|
|
static const char console_test[] =
|
|
"\n\ncoreboot-"
|
|
COREBOOT_VERSION
|
|
COREBOOT_EXTRA_VERSION
|
|
" "
|
|
COREBOOT_BUILD
|
|
" starting...\n";
|
|
|
|
console_hw_init();
|
|
|
|
print_info(console_test);
|
|
}
|
|
|
|
void die(const char *msg)
|
|
{
|
|
print_emerg(msg);
|
|
halt();
|
|
}
|