[libvirt] [PATCH] qemu: Return meaningful error when qemu dies early

Jiri Denemark jdenemar at redhat.com
Mon Mar 17 12:24:25 UTC 2014


On Mon, Mar 17, 2014 at 13:21:56 +0100, Jiri Denemark wrote:
> https://bugzilla.redhat.com/show_bug.cgi?id=844378
> 
> When qemu dies early after connecting to its monitor but before we
> actually try to read something from the monitor, we would just fail
> domain start with useless message:
> 
>     "An error occurred, but the cause is unknown"
> 
> This is because the real error gets reported in a monitor EOF handler
> executing within libvirt's event loop.
> 
> The fix is to take any error set in qemuMonitor structure and propagate
> it into the thread-local error when qemuMonitorClose is called and no
> thread-local error is set.
> 
> Signed-off-by: Jiri Denemark <jdenemar at redhat.com>
> ---

Oops, I forgot to send notes:

To reproduce the issue, just apply the following patch and kill
qemu process while libvirtd is sleeping:

diff --git i/src/qemu/qemu_process.c w/src/qemu/qemu_process.c
index 400625a..3b77ecc 100644
--- i/src/qemu/qemu_process.c
+++ w/src/qemu/qemu_process.c
@@ -1415,6 +1415,9 @@ qemuConnectMonitor(virQEMUDriverPtr driver, virDomainObjPtr vm, int logfd)
     if (mon)
         ignore_value(qemuMonitorSetDomainLog(mon, logfd));

+    VIR_DEBUG("Sleeping");
+    sleep(5);
+
     virObjectLock(vm);
     virObjectUnref(vm);
     priv->monStart = 0;




More information about the libvir-list mailing list