SeaBIOS outputs debugging messages to special debug port ("0x0402"). This patch unconditionally hooks the PIO port to LKVM so that when user specifies a SeaBIOS image, you'll see this for "vm run": [penberg@tux kvm]$ ./vm run --bios /usr/share/seabios/bios.bin # lkvm run -k ../../arch/x86/boot/bzImage -m 448 -c 4 --name guest-25983 Start bios (version 0.6.0) Unable to unlock ram - bridge not found Ram Size=0x00100000 (0x0000000000000000 high) <hangs here> Once we have SeaBIOS fully operational, we probably should hide the feature under "--debug-seabios" command line option. Cc: Yang Bai <hamo.by@xxxxxxxxx> Cc: Matt Evans <matt@xxxxxxxxxx> Cc: Ron Minnich <rminnich@xxxxxxxxx> Cc: Anthony Liguori <aliguori@xxxxxxxxxx> Cc: John Floren <john@xxxxxxxxxxx> Cc: Sasha Levin <levinsasha928@xxxxxxxxx> Cc: Cyrill Gorcunov <gorcunov@xxxxxxxxxx> Cc: Asias He <asias.hejun@xxxxxxxxx> Cc: Ingo Molnar <mingo@xxxxxxx> Signed-off-by: Pekka Enberg <penberg@xxxxxxxxxx> --- tools/kvm/x86/ioport.c | 18 ++++++++++++++++++ 1 files changed, 18 insertions(+), 0 deletions(-) diff --git a/tools/kvm/x86/ioport.c b/tools/kvm/x86/ioport.c index 8a91bf2..86302e6 100644 --- a/tools/kvm/x86/ioport.c +++ b/tools/kvm/x86/ioport.c @@ -1,6 +1,7 @@ #include "kvm/ioport.h" #include <stdlib.h> +#include <stdio.h> static bool debug_io_out(struct ioport *ioport, struct kvm *kvm, u16 port, void *data, int size) { @@ -11,6 +12,21 @@ static struct ioport_operations debug_ops = { .io_out = debug_io_out, }; +static bool seabios_debug_io_out(struct ioport *ioport, struct kvm *kvm, u16 port, void *data, int size) +{ + char ch; + + ch = ioport__read8(data); + + putchar(ch); + + return true; +} + +static struct ioport_operations seabios_debug_ops = { + .io_out = seabios_debug_io_out, +}; + static bool dummy_io_in(struct ioport *ioport, struct kvm *kvm, u16 port, void *data, int size) { return true; @@ -56,4 +72,6 @@ void ioport__setup_arch(void) /* PORT 03D4-03D5 - COLOR VIDEO - CRT CONTROL REGISTERS */ ioport__register(0x03D4, &dummy_read_write_ioport_ops, 1, NULL); ioport__register(0x03D5, &dummy_write_only_ioport_ops, 1, NULL); + + ioport__register(0x402, &seabios_debug_ops, 1, NULL); } -- 1.7.6.5 -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html