qemu: Keep QEMU host drive prefix in BlkIoTune

The QEMU -drive id= begins with libvirt's QEMU host drive prefix
("drive-"), which is stripped off in several places two convert between
host ("-drive") and guest ("-device") device names.

In the case of BlkIoTune it is unnecessary to strip the QEMU host drive
prefix because we operate on "info block"/"query-block" output that uses
host drive names.

Stripping the prefix incorrectly caused string comparisons to fail since
we were comparing the guest device name against the host device name.

Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
(cherry picked from commit 04ee70bfda)
This commit is contained in:
Stefan Hajnoczi 2012-11-01 18:20:55 +01:00 committed by Cole Robinson
parent ca1cebdb9e
commit 39a427e8ba
3 changed files with 1 additions and 6 deletions

View File

@ -242,6 +242,7 @@ Patches have also been contributed by:
Eiichi Tsukata <eiichi.tsukata.xh@hitachi.com> Eiichi Tsukata <eiichi.tsukata.xh@hitachi.com>
Wido den Hollander <wido@widodh.nl> Wido den Hollander <wido@widodh.nl>
Gene Czarcinski <gene@czarc.net> Gene Czarcinski <gene@czarc.net>
Stefan Hajnoczi <stefanha@redhat.com>
[....send patches to get your name here....] [....send patches to get your name here....]

View File

@ -3518,9 +3518,6 @@ qemuMonitorJSONBlockIoThrottleInfo(virJSONValuePtr result,
goto cleanup; goto cleanup;
} }
if(STRPREFIX(current_dev, QEMU_DRIVE_HOST_PREFIX))
current_dev += strlen(QEMU_DRIVE_HOST_PREFIX);
if (STREQ(current_dev, device)) if (STREQ(current_dev, device))
continue; continue;

View File

@ -3367,9 +3367,6 @@ qemuMonitorTextParseBlockIoThrottle(const char *result,
p = result; p = result;
while (*p) { while (*p) {
if (STRPREFIX(p, QEMU_DRIVE_HOST_PREFIX))
p += strlen(QEMU_DRIVE_HOST_PREFIX);
if (STREQLEN(p, device, devnamelen) && if (STREQLEN(p, device, devnamelen) &&
p[devnamelen] == ':' && p[devnamelen+1] == ' ') { p[devnamelen] == ':' && p[devnamelen+1] == ' ') {