From: Ian Jackson Date: Tue, 10 Mar 2009 18:15:30 +0000 (+0000) Subject: serial: open a null device if the CharDriverState argument is null X-Git-Url: http://xenbits.xensource.com/gitweb?a=commitdiff_plain;h=9bdc5f8350aa1a93d49fffe984fd9ebc6e1116b0;p=xenclient%2Fioemu.git serial: open a null device if the CharDriverState argument is null Signed-off-by: Aurelien Jarno git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@6366 c046a42c-6fe2-441c-8c8c-71466251a162 As adapted by Stefano to qemu-xen-unstable in his posting: [PATCH 11 of 13] serial: open a null device if the CharDriverState argument is null Signed-off-by: Stefano Stabellini --- diff --git a/hw/serial.c b/hw/serial.c index d14973ad..80fd3645 100644 --- a/hw/serial.c +++ b/hw/serial.c @@ -712,7 +712,7 @@ static void serial_init_core(SerialState *s, qemu_irq irq, int baudbase, { s->irq = irq; s->baudbase = baudbase; - s->chr = chr; + s->chr = chr ?: qemu_chr_open("null", "null", NULL); s->modem_status_poll = qemu_new_timer(vm_clock, (QEMUTimerCB *) serial_update_msl, s); @@ -722,6 +722,8 @@ static void serial_init_core(SerialState *s, qemu_irq irq, int baudbase, qemu_register_reset(serial_reset, s); serial_reset(s); + qemu_chr_add_handlers(s->chr, serial_can_receive1, serial_receive1, + serial_event, s); } /* If fd is zero, it means that the serial device uses the console */ @@ -740,8 +742,6 @@ SerialState *serial_init(int base, qemu_irq irq, int baudbase, register_ioport_write(base, 8, 1, serial_ioport_write, s); register_ioport_read(base, 8, 1, serial_ioport_read, s); - qemu_chr_add_handlers(chr, serial_can_receive1, serial_receive1, - serial_event, s); return s; } @@ -839,8 +839,6 @@ SerialState *serial_mm_init (target_phys_addr_t base, int it_shift, serial_mm_write, s); cpu_register_physical_memory(base, 8 << it_shift, s_io_memory); } - qemu_chr_add_handlers(chr, serial_can_receive1, serial_receive1, - serial_event, s); serial_update_msl(s); return s; }