summaryrefslogtreecommitdiff
path: root/src/pc80
diff options
context:
space:
mode:
authorYinghai Lu <yinghai.lu@amd.com>2007-02-28 11:17:02 +0000
committerStefan Reinauer <stepan@openbios.org>2007-02-28 11:17:02 +0000
commitd57241fab5d4b941f72811a9ce9edafca3993ba1 (patch)
treedae6993cc29b010896d5b733133058a673fd3a4b /src/pc80
parent3f5411cfca8e1b4552e13a3a286358e917bb5382 (diff)
downloadcoreboot-d57241fab5d4b941f72811a9ce9edafca3993ba1.tar.xz
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 <yinghai.lu@amd.com> Signed-off-by: Uwe Hermann <uwe@hermann-uwe.de> Acked-by: Stefan Reinauer <stepan@coresystems.de> git-svn-id: svn://svn.coreboot.org/coreboot/trunk@2563 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
Diffstat (limited to 'src/pc80')
-rw-r--r--src/pc80/usbdebug_direct_serial.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/src/pc80/usbdebug_direct_serial.c b/src/pc80/usbdebug_direct_serial.c
new file mode 100644
index 0000000000..e795349a22
--- /dev/null
+++ b/src/pc80/usbdebug_direct_serial.c
@@ -0,0 +1,25 @@
+#include <part/fallback_boot.h>
+#include "../lib/usbdebug_direct.c"
+static void early_usbdebug_direct_init(void)
+{
+ struct ehci_debug_info *dbg_info =
+ (struct ehci_debug_info *)(DCACHE_RAM_BASE + DCACHE_RAM_SIZE - sizeof (struct ehci_debug_info));
+
+ usbdebug_direct_init(EHCI_BAR, EHCI_DEBUG_OFFSET, dbg_info);
+}
+void usbdebug_direct_tx_byte(unsigned char data)
+{
+ struct ehci_debug_info *dbg_info;
+ dbg_info = (struct ehci_debug_info *)(DCACHE_RAM_BASE + DCACHE_RAM_SIZE - sizeof (struct ehci_debug_info)); // in Cache
+ if (dbg_info->ehci_debug) {
+ dbgp_bulk_write_x(dbg_info, &data, 1);
+ }
+}
+void usbdebug_direct_ram_tx_byte(unsigned char data)
+{
+ struct ehci_debug_info *dbg_info;
+ dbg_info = (struct ehci_debug_info *)((CONFIG_LB_MEM_TOPK<<10) - sizeof (struct ehci_debug_info)); //in RAM
+ if (dbg_info->ehci_debug) {
+ dbgp_bulk_write_x(dbg_info, &data, 1);
+ }
+}