mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-25 05:55:17 +00:00
Fix Xen driver to have sensible error messages
The Xen driver had a number of error reports which passed a constant string without format specifiers and was missing "%s". Furthermore the errors were related to failing system calls, but virReportSystemError was not used. So the only useful piece of info (the errno) was being discarded
This commit is contained in:
parent
fdf588a63d
commit
a8483d425e
2
cfg.mk
2
cfg.mk
@ -540,6 +540,7 @@ msg_gen_function += virReportError
|
|||||||
msg_gen_function += virReportErrorHelper
|
msg_gen_function += virReportErrorHelper
|
||||||
msg_gen_function += virReportSystemError
|
msg_gen_function += virReportSystemError
|
||||||
msg_gen_function += virSecurityReportError
|
msg_gen_function += virSecurityReportError
|
||||||
|
msg_gen_function += virXenError
|
||||||
msg_gen_function += virXenInotifyError
|
msg_gen_function += virXenInotifyError
|
||||||
msg_gen_function += virXenStoreError
|
msg_gen_function += virXenStoreError
|
||||||
msg_gen_function += virXendError
|
msg_gen_function += virXendError
|
||||||
@ -552,7 +553,6 @@ msg_gen_function += xenXMError
|
|||||||
# so that they are translatable.
|
# so that they are translatable.
|
||||||
# msg_gen_function += fprintf
|
# msg_gen_function += fprintf
|
||||||
# msg_gen_function += testError
|
# msg_gen_function += testError
|
||||||
# msg_gen_function += virXenError
|
|
||||||
# msg_gen_function += vshPrint
|
# msg_gen_function += vshPrint
|
||||||
# msg_gen_function += vshError
|
# msg_gen_function += vshError
|
||||||
|
|
||||||
|
@ -526,7 +526,13 @@ static int
|
|||||||
lock_pages(void *addr, size_t len)
|
lock_pages(void *addr, size_t len)
|
||||||
{
|
{
|
||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
return mlock(addr, len);
|
if (mlock(addr, len) < 0) {
|
||||||
|
virReportSystemError(errno,
|
||||||
|
_("Unable to lock %zu bytes of memory"),
|
||||||
|
len);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
#elif defined(__sun)
|
#elif defined(__sun)
|
||||||
return 0;
|
return 0;
|
||||||
#endif
|
#endif
|
||||||
@ -536,7 +542,13 @@ static int
|
|||||||
unlock_pages(void *addr, size_t len)
|
unlock_pages(void *addr, size_t len)
|
||||||
{
|
{
|
||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
return munlock(addr, len);
|
if (munlock(addr, len) < 0) {
|
||||||
|
virReportSystemError(errno,
|
||||||
|
_("Unable to unlock %zu bytes of memory"),
|
||||||
|
len);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
#elif defined(__sun)
|
#elif defined(__sun)
|
||||||
return 0;
|
return 0;
|
||||||
#endif
|
#endif
|
||||||
@ -900,21 +912,18 @@ xenHypervisorDoV0Op(int handle, xen_op_v0 * op)
|
|||||||
hc.op = __HYPERVISOR_dom0_op;
|
hc.op = __HYPERVISOR_dom0_op;
|
||||||
hc.arg[0] = (unsigned long) op;
|
hc.arg[0] = (unsigned long) op;
|
||||||
|
|
||||||
if (lock_pages(op, sizeof(dom0_op_t)) < 0) {
|
if (lock_pages(op, sizeof(dom0_op_t)) < 0)
|
||||||
virXenError(VIR_ERR_XEN_CALL, " locking");
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
|
|
||||||
ret = ioctl(handle, xen_ioctl_hypercall_cmd, (unsigned long) &hc);
|
ret = ioctl(handle, xen_ioctl_hypercall_cmd, (unsigned long) &hc);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
virXenError(VIR_ERR_XEN_CALL, " ioctl %d",
|
virReportSystemError(errno,
|
||||||
|
_("Unable to issue hypervisor ioctl %d"),
|
||||||
xen_ioctl_hypercall_cmd);
|
xen_ioctl_hypercall_cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (unlock_pages(op, sizeof(dom0_op_t)) < 0) {
|
if (unlock_pages(op, sizeof(dom0_op_t)) < 0)
|
||||||
virXenError(VIR_ERR_XEN_CALL, " releasing");
|
|
||||||
ret = -1;
|
ret = -1;
|
||||||
}
|
|
||||||
|
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return -1;
|
return -1;
|
||||||
@ -942,21 +951,18 @@ xenHypervisorDoV1Op(int handle, xen_op_v1* op)
|
|||||||
hc.op = __HYPERVISOR_dom0_op;
|
hc.op = __HYPERVISOR_dom0_op;
|
||||||
hc.arg[0] = (unsigned long) op;
|
hc.arg[0] = (unsigned long) op;
|
||||||
|
|
||||||
if (lock_pages(op, sizeof(dom0_op_t)) < 0) {
|
if (lock_pages(op, sizeof(dom0_op_t)) < 0)
|
||||||
virXenError(VIR_ERR_XEN_CALL, " locking");
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
|
|
||||||
ret = ioctl(handle, xen_ioctl_hypercall_cmd, (unsigned long) &hc);
|
ret = ioctl(handle, xen_ioctl_hypercall_cmd, (unsigned long) &hc);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
virXenError(VIR_ERR_XEN_CALL, " ioctl %d",
|
virReportSystemError(errno,
|
||||||
|
_("Unable to issue hypervisor ioctl %d"),
|
||||||
xen_ioctl_hypercall_cmd);
|
xen_ioctl_hypercall_cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (unlock_pages(op, sizeof(dom0_op_t)) < 0) {
|
if (unlock_pages(op, sizeof(dom0_op_t)) < 0)
|
||||||
virXenError(VIR_ERR_XEN_CALL, " releasing");
|
|
||||||
ret = -1;
|
ret = -1;
|
||||||
}
|
|
||||||
|
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return -1;
|
return -1;
|
||||||
@ -985,21 +991,18 @@ xenHypervisorDoV2Sys(int handle, xen_op_v2_sys* op)
|
|||||||
hc.op = __HYPERVISOR_sysctl;
|
hc.op = __HYPERVISOR_sysctl;
|
||||||
hc.arg[0] = (unsigned long) op;
|
hc.arg[0] = (unsigned long) op;
|
||||||
|
|
||||||
if (lock_pages(op, sizeof(dom0_op_t)) < 0) {
|
if (lock_pages(op, sizeof(dom0_op_t)) < 0)
|
||||||
virXenError(VIR_ERR_XEN_CALL, " locking");
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
|
|
||||||
ret = ioctl(handle, xen_ioctl_hypercall_cmd, (unsigned long) &hc);
|
ret = ioctl(handle, xen_ioctl_hypercall_cmd, (unsigned long) &hc);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
virXenError(VIR_ERR_XEN_CALL, " sys ioctl %d",
|
virReportSystemError(errno,
|
||||||
|
_("Unable to issue hypervisor ioctl %d"),
|
||||||
xen_ioctl_hypercall_cmd);
|
xen_ioctl_hypercall_cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (unlock_pages(op, sizeof(dom0_op_t)) < 0) {
|
if (unlock_pages(op, sizeof(dom0_op_t)) < 0)
|
||||||
virXenError(VIR_ERR_XEN_CALL, " releasing");
|
|
||||||
ret = -1;
|
ret = -1;
|
||||||
}
|
|
||||||
|
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return -1;
|
return -1;
|
||||||
@ -1028,21 +1031,18 @@ xenHypervisorDoV2Dom(int handle, xen_op_v2_dom* op)
|
|||||||
hc.op = __HYPERVISOR_domctl;
|
hc.op = __HYPERVISOR_domctl;
|
||||||
hc.arg[0] = (unsigned long) op;
|
hc.arg[0] = (unsigned long) op;
|
||||||
|
|
||||||
if (lock_pages(op, sizeof(dom0_op_t)) < 0) {
|
if (lock_pages(op, sizeof(dom0_op_t)) < 0)
|
||||||
virXenError(VIR_ERR_XEN_CALL, " locking");
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
|
|
||||||
ret = ioctl(handle, xen_ioctl_hypercall_cmd, (unsigned long) &hc);
|
ret = ioctl(handle, xen_ioctl_hypercall_cmd, (unsigned long) &hc);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
virXenError(VIR_ERR_XEN_CALL, " ioctl %d",
|
virReportSystemError(errno,
|
||||||
|
_("Unable to issue hypervisor ioctl %d"),
|
||||||
xen_ioctl_hypercall_cmd);
|
xen_ioctl_hypercall_cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (unlock_pages(op, sizeof(dom0_op_t)) < 0) {
|
if (unlock_pages(op, sizeof(dom0_op_t)) < 0)
|
||||||
virXenError(VIR_ERR_XEN_CALL, " releasing");
|
|
||||||
ret = -1;
|
ret = -1;
|
||||||
}
|
|
||||||
|
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return -1;
|
return -1;
|
||||||
@ -1068,10 +1068,9 @@ virXen_getdomaininfolist(int handle, int first_domain, int maxids,
|
|||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
if (lock_pages(XEN_GETDOMAININFOLIST_DATA(dominfos),
|
if (lock_pages(XEN_GETDOMAININFOLIST_DATA(dominfos),
|
||||||
XEN_GETDOMAININFO_SIZE * maxids) < 0) {
|
XEN_GETDOMAININFO_SIZE * maxids) < 0)
|
||||||
virXenError(VIR_ERR_XEN_CALL, " locking");
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
if (hv_versions.hypervisor > 1) {
|
if (hv_versions.hypervisor > 1) {
|
||||||
xen_op_v2_sys op;
|
xen_op_v2_sys op;
|
||||||
|
|
||||||
@ -1123,10 +1122,9 @@ virXen_getdomaininfolist(int handle, int first_domain, int maxids,
|
|||||||
ret = op.u.getdomaininfolist.num_domains;
|
ret = op.u.getdomaininfolist.num_domains;
|
||||||
}
|
}
|
||||||
if (unlock_pages(XEN_GETDOMAININFOLIST_DATA(dominfos),
|
if (unlock_pages(XEN_GETDOMAININFOLIST_DATA(dominfos),
|
||||||
XEN_GETDOMAININFO_SIZE * maxids) < 0) {
|
XEN_GETDOMAININFO_SIZE * maxids) < 0)
|
||||||
virXenError(VIR_ERR_XEN_CALL, " release");
|
|
||||||
ret = -1;
|
ret = -1;
|
||||||
}
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1747,10 +1745,9 @@ virXen_setvcpumap(int handle, int id, unsigned int vcpu,
|
|||||||
if (hv_versions.hypervisor > 1) {
|
if (hv_versions.hypervisor > 1) {
|
||||||
xen_op_v2_dom op;
|
xen_op_v2_dom op;
|
||||||
|
|
||||||
if (lock_pages(cpumap, maplen) < 0) {
|
if (lock_pages(cpumap, maplen) < 0)
|
||||||
virXenError(VIR_ERR_XEN_CALL, " locking");
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
memset(&op, 0, sizeof(op));
|
memset(&op, 0, sizeof(op));
|
||||||
op.cmd = XEN_V2_OP_SETVCPUMAP;
|
op.cmd = XEN_V2_OP_SETVCPUMAP;
|
||||||
op.domain = (domid_t) id;
|
op.domain = (domid_t) id;
|
||||||
@ -1782,10 +1779,8 @@ virXen_setvcpumap(int handle, int id, unsigned int vcpu,
|
|||||||
ret = xenHypervisorDoV2Dom(handle, &op);
|
ret = xenHypervisorDoV2Dom(handle, &op);
|
||||||
VIR_FREE(new);
|
VIR_FREE(new);
|
||||||
|
|
||||||
if (unlock_pages(cpumap, maplen) < 0) {
|
if (unlock_pages(cpumap, maplen) < 0)
|
||||||
virXenError(VIR_ERR_XEN_CALL, " release");
|
|
||||||
ret = -1;
|
ret = -1;
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
cpumap_t xen_cpumap; /* limited to 64 CPUs in old hypervisors */
|
cpumap_t xen_cpumap; /* limited to 64 CPUs in old hypervisors */
|
||||||
uint64_t *pm = &xen_cpumap;
|
uint64_t *pm = &xen_cpumap;
|
||||||
@ -1879,10 +1874,9 @@ virXen_getvcpusinfo(int handle, int id, unsigned int vcpu, virVcpuInfoPtr ipt,
|
|||||||
ipt->cpu = op.u.getvcpuinfod5.online ? (int)op.u.getvcpuinfod5.cpu : -1;
|
ipt->cpu = op.u.getvcpuinfod5.online ? (int)op.u.getvcpuinfod5.cpu : -1;
|
||||||
}
|
}
|
||||||
if ((cpumap != NULL) && (maplen > 0)) {
|
if ((cpumap != NULL) && (maplen > 0)) {
|
||||||
if (lock_pages(cpumap, maplen) < 0) {
|
if (lock_pages(cpumap, maplen) < 0)
|
||||||
virXenError(VIR_ERR_XEN_CALL, " locking");
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
memset(cpumap, 0, maplen);
|
memset(cpumap, 0, maplen);
|
||||||
memset(&op, 0, sizeof(op));
|
memset(&op, 0, sizeof(op));
|
||||||
op.cmd = XEN_V2_OP_GETVCPUMAP;
|
op.cmd = XEN_V2_OP_GETVCPUMAP;
|
||||||
@ -1897,11 +1891,9 @@ virXen_getvcpusinfo(int handle, int id, unsigned int vcpu, virVcpuInfoPtr ipt,
|
|||||||
op.u.getvcpumapd5.cpumap.nr_cpus = maplen * 8;
|
op.u.getvcpumapd5.cpumap.nr_cpus = maplen * 8;
|
||||||
}
|
}
|
||||||
ret = xenHypervisorDoV2Dom(handle, &op);
|
ret = xenHypervisorDoV2Dom(handle, &op);
|
||||||
if (unlock_pages(cpumap, maplen) < 0) {
|
if (unlock_pages(cpumap, maplen) < 0)
|
||||||
virXenError(VIR_ERR_XEN_CALL, " release");
|
|
||||||
ret = -1;
|
ret = -1;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
int mapl = maplen;
|
int mapl = maplen;
|
||||||
int cpu;
|
int cpu;
|
||||||
@ -2079,8 +2071,9 @@ xenHypervisorInit(struct xenHypervisorVersions *override_versions)
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
hv_versions.hypervisor = -1;
|
hv_versions.hypervisor = -1;
|
||||||
virXenError(VIR_ERR_XEN_CALL, " ioctl %lu",
|
virReportSystemError(errno,
|
||||||
(unsigned long) IOCTL_PRIVCMD_HYPERCALL);
|
_("Unable to issue hypervisor ioctl %lu"),
|
||||||
|
(unsigned long)IOCTL_PRIVCMD_HYPERCALL);
|
||||||
VIR_FORCE_CLOSE(fd);
|
VIR_FORCE_CLOSE(fd);
|
||||||
in_init = 0;
|
in_init = 0;
|
||||||
return -1;
|
return -1;
|
||||||
@ -2178,14 +2171,15 @@ xenHypervisorInit(struct xenHypervisorVersions *override_versions)
|
|||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* we failed to make the getdomaininfolist hypercall
|
* we failed to make the getdomaininfolist hypercall
|
||||||
*/
|
*/
|
||||||
|
|
||||||
VIR_DEBUG("Failed to find any Xen hypervisor method");
|
|
||||||
hv_versions.hypervisor = -1;
|
hv_versions.hypervisor = -1;
|
||||||
virXenError(VIR_ERR_XEN_CALL, " ioctl %lu",
|
virReportSystemError(errno,
|
||||||
|
_("Unable to issue hypervisor ioctl %lu"),
|
||||||
(unsigned long)IOCTL_PRIVCMD_HYPERCALL);
|
(unsigned long)IOCTL_PRIVCMD_HYPERCALL);
|
||||||
|
VIR_DEBUG("Failed to find any Xen hypervisor method");
|
||||||
VIR_FORCE_CLOSE(fd);
|
VIR_FORCE_CLOSE(fd);
|
||||||
in_init = 0;
|
in_init = 0;
|
||||||
VIR_FREE(ipt);
|
VIR_FREE(ipt);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user