[libvirt] [PATCH] CVE-2014-3633: qemu: blkiotune: Use correct definition when looking up disk
Eric Blake
eblake at redhat.com
Wed Sep 17 16:31:47 UTC 2014
On 09/17/2014 10:25 AM, Peter Krempa wrote:
> Live definition was used to look up the disk index while persistent one
> was indexed leading to a crash in qemuDomainGetBlockIoTune. Use the
> correct def and report a nice error.
>
> Unfortunately it's accessible via read-only connection.
>
Mitigation - a read-only connection can only crash libvirtd in the cases
where the guest is hot-plugging disks without reflecting those changes
to the persistent definition. So avoiding hotplug, or doing hotplug
where persistent is always modified alongside live definition, will
avoid the out-of-bounds access.
> Introduced in: eca96694a7f992be633d48d5ca03cedc9bbc3c9aa (v0.9.8)
> Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1140724
> Reported-by: Luyao Huang <lhuang at redhat.com>
> Signed-off-by: Peter Krempa <pkrempa at redhat.com>
> ---
> src/qemu/qemu_driver.c | 8 ++++++--
> 1 file changed, 6 insertions(+), 2 deletions(-)
ACK. I can write up the libvirt security notice; we'll eventually need
this backported to all the affected maint branches. I'll coordinate the
backport effort with you on IRC.
>
> diff --git a/src/qemu/qemu_driver.c b/src/qemu/qemu_driver.c
> index a5a49ac..209c40e 100644
> --- a/src/qemu/qemu_driver.c
> +++ b/src/qemu/qemu_driver.c
> @@ -16317,9 +16317,13 @@ qemuDomainGetBlockIoTune(virDomainPtr dom,
> }
>
> if (flags & VIR_DOMAIN_AFFECT_CONFIG) {
> - int idx = virDomainDiskIndexByName(vm->def, disk, true);
> - if (idx < 0)
> + int idx = virDomainDiskIndexByName(persistentDef, disk, true);
> + if (idx < 0) {
> + virReportError(VIR_ERR_INVALID_ARG,
> + _("disk '%s' was not found in the domain config"),
> + disk);
> goto endjob;
> + }
> reply = persistentDef->disks[idx]->blkdeviotune;
> }
>
--
Eric Blake eblake redhat com +1-919-301-3266
Libvirt virtualization library http://libvirt.org
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 539 bytes
Desc: OpenPGP digital signature
URL: <http://listman.redhat.com/archives/libvir-list/attachments/20140917/6e97a615/attachment-0001.sig>
More information about the libvir-list
mailing list