mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-06 13:05:20 +00:00
qemuDomainChrInsertPreAlloced: Fix adding implicit console
When hotpluging a <serial/> device, we might need to add a
<console/> device with it (because of some crazy backcompat).
Now, hotplugging is done in several phases. In one of them,
qemuDomainChrPreInsert() allocates space for both devices, and
then qemuDomainChrInsertPreAlloced() actually inserts the device
into domain definition and sets up the <console/> device with it.
Except, the condition that checks whether to create the aliased
<console/> is wrong as it compares nconsoles against 0.
Surprisingly, qemuDomainChrInsertPreAllocCleanup() doesn't suffer
from the same error.
Fixes: daf51be5f1
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
This commit is contained in:
parent
985f78e804
commit
9129643d26
@ -1875,9 +1875,8 @@ qemuDomainChrInsertPreAlloced(virDomainDef *vmdef,
|
|||||||
virDomainChrDef *chr)
|
virDomainChrDef *chr)
|
||||||
{
|
{
|
||||||
virDomainChrInsertPreAlloced(vmdef, chr);
|
virDomainChrInsertPreAlloced(vmdef, chr);
|
||||||
if (vmdef->nserials == 1 && vmdef->nconsoles == 0 &&
|
if (vmdef->nserials == 1 && vmdef->nconsoles == 1 &&
|
||||||
chr->deviceType == VIR_DOMAIN_CHR_DEVICE_TYPE_SERIAL) {
|
chr->deviceType == VIR_DOMAIN_CHR_DEVICE_TYPE_SERIAL) {
|
||||||
vmdef->nconsoles = 1;
|
|
||||||
|
|
||||||
/* Create an console alias for the serial port */
|
/* Create an console alias for the serial port */
|
||||||
vmdef->consoles[0]->deviceType = VIR_DOMAIN_CHR_DEVICE_TYPE_CONSOLE;
|
vmdef->consoles[0]->deviceType = VIR_DOMAIN_CHR_DEVICE_TYPE_CONSOLE;
|
||||||
|
Loading…
Reference in New Issue
Block a user