From d57241fab5d4b941f72811a9ce9edafca3993ba1 Mon Sep 17 00:00:00 2001 From: Yinghai Lu Date: Wed, 28 Feb 2007 11:17:02 +0000 Subject: This is (most of) the usb2 debug console code ripped out of Uwe's version of yh_rest_of_patch.patch (13.02.07 - [PATCH] Rest of huge MCP55 patch). I dropped a lot of stuff, like broken indenting, removed copyright messages, and this printk_ram_* stuff (what the heck is this supposed to be) This codebase is really a mess. Further tarball contributions without a _CLEANED UP_ patch will be denied, especially if they are not from an up to date svn tree. Signed-off-by: Yinghai Lu Signed-off-by: Uwe Hermann Acked-by: Stefan Reinauer git-svn-id: svn://svn.coreboot.org/coreboot/trunk@2563 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1 --- src/console/Config.lb | 4 +++ src/console/usbdebug_direct_console.c | 58 +++++++++++++++++++++++++++++++++++ 2 files changed, 62 insertions(+) create mode 100644 src/console/usbdebug_direct_console.c (limited to 'src/console') diff --git a/src/console/Config.lb b/src/console/Config.lb index daba367f94..7a1672e494 100644 --- a/src/console/Config.lb +++ b/src/console/Config.lb @@ -1,4 +1,5 @@ uses CONFIG_CONSOLE_SERIAL8250 +uses CONFIG_USBDEBUG_DIRECT uses CONFIG_CONSOLE_VGA uses CONFIG_CONSOLE_BTEXT uses CONFIG_CONSOLE_LOGBUF @@ -9,6 +10,9 @@ object printk.o if CONFIG_CONSOLE_SERIAL8250 driver uart8250_console.o end +if CONFIG_USBDEBUG_DIRECT + driver usbdebug_direct_console.o +end if CONFIG_CONSOLE_VGA driver vga_console.o end diff --git a/src/console/usbdebug_direct_console.c b/src/console/usbdebug_direct_console.c new file mode 100644 index 0000000000..172d5c8b55 --- /dev/null +++ b/src/console/usbdebug_direct_console.c @@ -0,0 +1,58 @@ +#include +#include +#include + +struct ehci_debug_info dbg_info; + +void set_ehci_base(unsigned ehci_base) +{ + unsigned diff; + if(!dbg_info.ehci_debug) return; + diff = dbg_info.ehci_caps - ehci_base; + dbg_info.ehci_regs -= diff; + dbg_info.ehci_debug -= diff; + dbg_info.ehci_caps = ehci_base; +} +void set_ehci_debug(unsigned ehci_debug) +{ + dbg_info.ehci_debug = ehci_debug; +} + +unsigned get_ehci_debug(void) +{ + return dbg_info.ehci_debug; +} + +static void dbgp_init(void) +{ + struct ehci_debug_info *dbg_infox; + dbg_infox = (struct ehci_debug_info *)((CONFIG_LB_MEM_TOPK<<10) - sizeof (struct ehci_debug_info)); //in RAM + memcpy(&dbg_info, dbg_infox, sizeof(struct ehci_debug_info) ); +} + +static void dbgp_tx_byte(unsigned char data) +{ + if(dbg_info.ehci_debug) + dbgp_bulk_write_x(&dbg_info,&data,1); +} + +static unsigned char dbgp_rx_byte(void) +{ + unsigned char data = 0xff; + if(dbg_info.ehci_debug) + dbgp_bulk_read_x(&dbg_info,&data,1); + return data; +} + +static int dbgp_tst_byte(void) +{ + return dbg_info.ehci_debug; +} + +static struct console_driver usbdebug_direct_console __console = { + .init = dbgp_init, + .tx_byte = dbgp_tx_byte, + .rx_byte = dbgp_rx_byte, + .tst_byte = dbgp_tst_byte, +}; + -- cgit v1.2.3