mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-09 22:45:21 +00:00
qemu: cleanup error checking on agent replies
On all the places where qemuAgentComand() was called, we did a check
for errors in the reply. Unfortunately, some of the places called
qemuAgentCheckError() without checking for non-null reply which might
have resulted in a crash.
So this patch makes the error-checking part of qemuAgentCommand()
itself, which:
a) makes it look better,
b) makes the check mandatory and, most importantly,
c) checks for the errors if and only if it is appropriate.
This actually fixes a potential crashers when qemuAgentComand()
returned 0, but reply was NULL. Having said that, it *should* fix the
following bug:
https://bugzilla.redhat.com/show_bug.cgi?id=1058149
Signed-off-by: Martin Kletzander <mkletzan@redhat.com>
(cherry picked from commit 5b3492fadb
)
This commit is contained in:
parent
595ada1973
commit
d39dd6e414
@ -115,6 +115,8 @@ struct _qemuAgent {
|
|||||||
qemuAgentEvent await_event;
|
qemuAgentEvent await_event;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static int qemuAgentCheckError(virJSONValuePtr cmd, virJSONValuePtr reply);
|
||||||
|
|
||||||
static virClassPtr qemuAgentClass;
|
static virClassPtr qemuAgentClass;
|
||||||
static void qemuAgentDispose(void *obj);
|
static void qemuAgentDispose(void *obj);
|
||||||
|
|
||||||
@ -1005,6 +1007,7 @@ qemuAgentCommand(qemuAgentPtr mon,
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
*reply = msg.rxObject;
|
*reply = msg.rxObject;
|
||||||
|
ret = qemuAgentCheckError(cmd, *reply);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1273,9 +1276,6 @@ int qemuAgentShutdown(qemuAgentPtr mon,
|
|||||||
ret = qemuAgentCommand(mon, cmd, &reply,
|
ret = qemuAgentCommand(mon, cmd, &reply,
|
||||||
VIR_DOMAIN_QEMU_AGENT_COMMAND_BLOCK);
|
VIR_DOMAIN_QEMU_AGENT_COMMAND_BLOCK);
|
||||||
|
|
||||||
if (reply && ret == 0)
|
|
||||||
ret = qemuAgentCheckError(cmd, reply);
|
|
||||||
|
|
||||||
virJSONValueFree(cmd);
|
virJSONValueFree(cmd);
|
||||||
virJSONValueFree(reply);
|
virJSONValueFree(reply);
|
||||||
return ret;
|
return ret;
|
||||||
@ -1304,8 +1304,7 @@ int qemuAgentFSFreeze(qemuAgentPtr mon)
|
|||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (qemuAgentCommand(mon, cmd, &reply,
|
if (qemuAgentCommand(mon, cmd, &reply,
|
||||||
VIR_DOMAIN_QEMU_AGENT_COMMAND_BLOCK) < 0 ||
|
VIR_DOMAIN_QEMU_AGENT_COMMAND_BLOCK) < 0)
|
||||||
qemuAgentCheckError(cmd, reply) < 0)
|
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (virJSONValueObjectGetNumberInt(reply, "return", &ret) < 0) {
|
if (virJSONValueObjectGetNumberInt(reply, "return", &ret) < 0) {
|
||||||
@ -1342,8 +1341,7 @@ int qemuAgentFSThaw(qemuAgentPtr mon)
|
|||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (qemuAgentCommand(mon, cmd, &reply,
|
if (qemuAgentCommand(mon, cmd, &reply,
|
||||||
VIR_DOMAIN_QEMU_AGENT_COMMAND_BLOCK) < 0 ||
|
VIR_DOMAIN_QEMU_AGENT_COMMAND_BLOCK) < 0)
|
||||||
qemuAgentCheckError(cmd, reply) < 0)
|
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (virJSONValueObjectGetNumberInt(reply, "return", &ret) < 0) {
|
if (virJSONValueObjectGetNumberInt(reply, "return", &ret) < 0) {
|
||||||
@ -1382,9 +1380,6 @@ qemuAgentSuspend(qemuAgentPtr mon,
|
|||||||
ret = qemuAgentCommand(mon, cmd, &reply,
|
ret = qemuAgentCommand(mon, cmd, &reply,
|
||||||
VIR_DOMAIN_QEMU_AGENT_COMMAND_BLOCK);
|
VIR_DOMAIN_QEMU_AGENT_COMMAND_BLOCK);
|
||||||
|
|
||||||
if (reply && ret == 0)
|
|
||||||
ret = qemuAgentCheckError(cmd, reply);
|
|
||||||
|
|
||||||
virJSONValueFree(cmd);
|
virJSONValueFree(cmd);
|
||||||
virJSONValueFree(reply);
|
virJSONValueFree(reply);
|
||||||
return ret;
|
return ret;
|
||||||
@ -1415,9 +1410,6 @@ qemuAgentArbitraryCommand(qemuAgentPtr mon,
|
|||||||
if ((ret = qemuAgentCommand(mon, cmd, &reply, timeout)) < 0)
|
if ((ret = qemuAgentCommand(mon, cmd, &reply, timeout)) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if ((ret = qemuAgentCheckError(cmd, reply)) < 0)
|
|
||||||
goto cleanup;
|
|
||||||
|
|
||||||
if (!(*result = virJSONValueToString(reply, false)))
|
if (!(*result = virJSONValueToString(reply, false)))
|
||||||
ret = -1;
|
ret = -1;
|
||||||
|
|
||||||
@ -1445,9 +1437,6 @@ qemuAgentFSTrim(qemuAgentPtr mon,
|
|||||||
ret = qemuAgentCommand(mon, cmd, &reply,
|
ret = qemuAgentCommand(mon, cmd, &reply,
|
||||||
VIR_DOMAIN_QEMU_AGENT_COMMAND_BLOCK);
|
VIR_DOMAIN_QEMU_AGENT_COMMAND_BLOCK);
|
||||||
|
|
||||||
if (reply && ret == 0)
|
|
||||||
ret = qemuAgentCheckError(cmd, reply);
|
|
||||||
|
|
||||||
virJSONValueFree(cmd);
|
virJSONValueFree(cmd);
|
||||||
virJSONValueFree(reply);
|
virJSONValueFree(reply);
|
||||||
return ret;
|
return ret;
|
||||||
@ -1468,8 +1457,7 @@ qemuAgentGetVCPUs(qemuAgentPtr mon,
|
|||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (qemuAgentCommand(mon, cmd, &reply,
|
if (qemuAgentCommand(mon, cmd, &reply,
|
||||||
VIR_DOMAIN_QEMU_AGENT_COMMAND_BLOCK) < 0 ||
|
VIR_DOMAIN_QEMU_AGENT_COMMAND_BLOCK) < 0)
|
||||||
qemuAgentCheckError(cmd, reply) < 0)
|
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (!(data = virJSONValueObjectGet(reply, "return"))) {
|
if (!(data = virJSONValueObjectGet(reply, "return"))) {
|
||||||
@ -1577,8 +1565,7 @@ qemuAgentSetVCPUs(qemuAgentPtr mon,
|
|||||||
cpus = NULL;
|
cpus = NULL;
|
||||||
|
|
||||||
if (qemuAgentCommand(mon, cmd, &reply,
|
if (qemuAgentCommand(mon, cmd, &reply,
|
||||||
VIR_DOMAIN_QEMU_AGENT_COMMAND_BLOCK) < 0 ||
|
VIR_DOMAIN_QEMU_AGENT_COMMAND_BLOCK) < 0)
|
||||||
qemuAgentCheckError(cmd, reply) < 0)
|
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (virJSONValueObjectGetNumberInt(reply, "return", &ret) < 0) {
|
if (virJSONValueObjectGetNumberInt(reply, "return", &ret) < 0) {
|
||||||
|
Loading…
Reference in New Issue
Block a user