|
|
b28c64 |
From 1882bb1a0967e7d513b0d5bd060fa214bc44efcb Mon Sep 17 00:00:00 2001
|
|
|
b28c64 |
From: Fam Zheng <famz@redhat.com>
|
|
|
b28c64 |
Date: Fri, 19 May 2017 00:35:15 +0200
|
|
|
b28c64 |
Subject: [PATCH 10/18] serial: check if backed by a physical serial port at
|
|
|
b28c64 |
realize time
|
|
|
b28c64 |
|
|
|
b28c64 |
RH-Author: Fam Zheng <famz@redhat.com>
|
|
|
b28c64 |
Message-id: <20170519003523.21163-11-famz@redhat.com>
|
|
|
b28c64 |
Patchwork-id: 75366
|
|
|
b28c64 |
O-Subject: [RHEL-7.3.z qemu-kvm PATCH 10/18] serial: check if backed by a physical serial port at realize time
|
|
|
b28c64 |
Bugzilla: 1452332
|
|
|
b28c64 |
RH-Acked-by: Paolo Bonzini <pbonzini@redhat.com>
|
|
|
b28c64 |
RH-Acked-by: Laurent Vivier <lvivier@redhat.com>
|
|
|
b28c64 |
RH-Acked-by: Eduardo Habkost <ehabkost@redhat.com>
|
|
|
b28c64 |
|
|
|
b28c64 |
From: Paolo Bonzini <pbonzini@redhat.com>
|
|
|
b28c64 |
|
|
|
b28c64 |
Right now, s->poll_msl may linger at "0" value for an arbitrarily long
|
|
|
b28c64 |
time, until serial_update_msl is called for the first time. This is
|
|
|
b28c64 |
unnecessary, and will lead to the s->poll_msl field being unnecessarily
|
|
|
b28c64 |
migrated.
|
|
|
b28c64 |
|
|
|
b28c64 |
We can call serial_update_msl immediately at realize time (via
|
|
|
b28c64 |
serial_reset) and be done with it. The memory-mapped UART was already
|
|
|
b28c64 |
doing that, but not the ISA and PCI variants.
|
|
|
b28c64 |
|
|
|
b28c64 |
Regarding the delta bits, be consistent with what serial_reset does when
|
|
|
b28c64 |
the serial port is not backed by a physical serial port, and always clear
|
|
|
b28c64 |
them at reset time.
|
|
|
b28c64 |
|
|
|
b28c64 |
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
|
|
|
b28c64 |
(cherry picked from commit a30cf8760f4a59797fc060c3c5a13b7749551d0c)
|
|
|
b28c64 |
Signed-off-by: Fam Zheng <famz@redhat.com>
|
|
|
b28c64 |
Signed-off-by: Miroslav Rezanina <mrezanin@redhat.com>
|
|
|
b28c64 |
---
|
|
|
b28c64 |
hw/char/serial.c | 5 +++--
|
|
|
b28c64 |
1 file changed, 3 insertions(+), 2 deletions(-)
|
|
|
b28c64 |
|
|
|
b28c64 |
diff --git a/hw/char/serial.c b/hw/char/serial.c
|
|
|
b28c64 |
index 33e06fb..5ef9b95 100644
|
|
|
b28c64 |
--- a/hw/char/serial.c
|
|
|
b28c64 |
+++ b/hw/char/serial.c
|
|
|
b28c64 |
@@ -650,6 +650,9 @@ static void serial_reset(void *opaque)
|
|
|
b28c64 |
s->thr_ipending = 0;
|
|
|
b28c64 |
s->last_break_enable = 0;
|
|
|
b28c64 |
qemu_irq_lower(s->irq);
|
|
|
b28c64 |
+
|
|
|
b28c64 |
+ serial_update_msl(s);
|
|
|
b28c64 |
+ s->msr &= ~UART_MSR_ANY_DELTA;
|
|
|
b28c64 |
}
|
|
|
b28c64 |
|
|
|
b28c64 |
void serial_init_core(SerialState *s)
|
|
|
b28c64 |
@@ -768,7 +771,5 @@ SerialState *serial_mm_init(MemoryRegion *address_space,
|
|
|
b28c64 |
memory_region_init_io(&s->io, &serial_mm_ops[end], s,
|
|
|
b28c64 |
"serial", 8 << it_shift);
|
|
|
b28c64 |
memory_region_add_subregion(address_space, base, &s->io);
|
|
|
b28c64 |
-
|
|
|
b28c64 |
- serial_update_msl(s);
|
|
|
b28c64 |
return s;
|
|
|
b28c64 |
}
|
|
|
b28c64 |
--
|
|
|
b28c64 |
1.8.3.1
|
|
|
b28c64 |
|