Qemu vs. Qemu+USB Tablet vs. VMPlayer using PCMark05

Qemu vs. Qemu+USB Tablet vs. VMPlayer using PCMark05

Background
I have been running a WinXP 32-bit guest on a Debian x86 host computer for some time. I began by using Qemu+KQEMU in -kernel-kqemu mode. I switched to the free vmplayer because I noticed that it was faster than Qemu. When running Qemu, my host processor seemed to spend a majority of its time in kernel mode. This was as reported by top, which apprently is quite unreliable, but was a hint at a problem with my configuration. Apparently, using the very convenient usb tablet emulation wastes a lot of CPU cycles. So I determined to see how much of a difference there was between Qemu+KQEMU and Qemu+KQEMU with usb tablet emulation. While I was at this, I figured I would run a benchmark on the vmplayer.

Host System

CPU Pentium 4 2.66GHz
RAM 1.5GB

Qemu+KQEMU without USB Tablet Emulation CVS 20061216
qemu -hda windowsxp.qcow -m 512 -kernel-kqemu -net nic -net tap,ifname=tap3

Qemu+KQEMU with USB Tablet Emulation CVS 20061216
qemu -hda windowsxp.qcow -m 512 -kernel-kqemu -net nic -net tap,ifname=tap3 -usbdevice tablet

Qemu+KQEMU with USB Tablet Emulation Patch CVS 20061219
qemu -hda windowsxp.qcow -m 512 -kernel-kqemu -net nic -net tap,ifname=tap3 -usbdevice tablet

VMPlayer 1.0.2 build-29634
#!/usr/bin/vmware
config.version = "8"
virtualHW.version = "3"
ide0:0.present = "TRUE"
ide0:0.filename = "winxp2.vmdk"
memsize = "512"
MemAllowAutoScaleDown = "FALSE"
ide1:0.present = "TRUE"
ide1:0.fileName = "auto detect"
ide1:0.deviceType = "cdrom-raw"
ide1:0.autodetect = "TRUE"
floppy0.present = "FALSE"
ethernet0.present = "TRUE"
usb.present = "FALSE"
sound.present = "FALSE"
sound.virtualDev = "es1371"
displayName = "Windows XP Pro"
guestOS = "winxppro"
nvram = "winxp2.nvram"
MemTrimRate = "-1"
ide0:0.redo = ""
ethernet0.addressType = "generated"
uuid.location = "56 4d 88 59 b6 23 e5 8c-3d 31 6d 36 ad 34 c7 99"
uuid.bios = "56 4d 88 59 b6 23 e5 8c-3d 31 6d 36 ad 34 c7 99"
ethernet0.generatedAddress = "00:0c:29:34:c7:99"
ethernet0.generatedAddressOffset = "0"
tools.syncTime = "TRUE"
ide1:0.startConnected = "TRUE"
uuid.action = "create"
checkpoint.vmState = ""
tools.remindInstall = "TRUE"

Benchmarking
I used Futuremark’s PCMark05 for no particular reason, and it was particularly cranky with my display adapters and drivers. I have no expertise or experience benchmarking anything and I do not lay claim to be a benchmarking expert. I performed these tests to determine if there was a *noticeable* difference in two particular areas. HDD I/O and memory access speeds. I am assuming that since Qemu+KQEMU and VMPlayer are both virtualization products they should perform similarly well with CPU-intensive tasks. I am not interested in finding small performance differences, I’m looking for something significant.

Results
The percentages below are relative to the Qemu+KQEMU without USB tablet emulation. You can see that with the USB tablet emulation, Qemu is slowed to almost half the speed it would be without USB tablet emulation.

Qemu Qemu USB Tablet Qemu USB Tablet Patch VMPlayer
HDD – XP Startup 5.78 MB/s 4.94 MB/s 5.78 MB/s 9.25 MB/s
Web Page Rendering 0.58 Pages/s 0.26 MB/s 0.48 Pages/s 1.37 Pages/s
File Decryption 41.8 MB/s 24.44 MB/s 40.23 MB/s 47.91 MB/s
HDD – General Usage 8.02 MB/s 5.08 MB/s 7.17 MB/s 7.39 MB/s
MT / Audio Compression 726.63 KB/s 375.43 KB/s 690.24 KB/s 1247.69 KB/s
MT / Video Encoding 90.98 KB/s 47.01 KB/s 86.63 KB/s 115.04 KB/s
MT / Text Edit 15.1 Pages/s 7.51 Pages/s 14.77 Pages/s 45.92 Pages/s
MT / Image Decompression 7.3 MPixels/s 4.86 MPixels/s 7.53 MPixels/s 5.49 MPixels/s
MT / File Compression 1.65 MB/s 0.94 MB/s 1.64 MB/s 1.93 MB/s
MT / File Encryption 11.18 MB/s 7.01 MB/s 9.89 MB/s 13.42 MB/s
MT / HDD – Virus Scan 17.14 MB/s 9.53 MB/s 17.61 MB/s 21.4 MB/s
MT / Memory Latency – Random 16MB 1.03 MAccesses/s 0.31 MAccesses/s 1.07 MAccesses/s 4.31 MAccesses/s
Qemu USB Tablet % VMPlayer %
HDD – XP Startup 85.47% 160.03%
Web Page Rendering 44.83% 236.21%
File Decryption 58.47% 114.62%
HDD – General Usage 63.34% 92.14%
MT / Audio Compression 51.67% 171.71%
MT / Video Encoding 51.67% 126.45%
MT / Text Edit 49.74% 304.11%
MT / Image Decompression 66.58% 75.21%
MT / File Compression 56.97% 116.97%
MT / File Encryption 62.70% 120.04%
MT / HDD – Virus Scan 55.60% 124.85%
MT / Memory Latency – Random 16MB 30.10% 418.45%
Average (Completely Meaningless) 56.43% 171.73%

What Does It Mean?
Well, Qemu’s USB tablet emulation sucks, unless of course you really need it, then it’s great 😉 It is very interesting that the CPU speed results of Qemu vs. VMPlayer are similar and that the disk I/O speeds are also similar. Why is that interesting? Because the memory access of VMPlayer is about 4 times faster than Qemu. Almost all of the differences in performance between Qemu and VMPlayer in these results could be attributed to the memory performance differences. I consider this good news because disk I/O seems slightly faster in Qemu than VMPlayer. Once the memory access speed issue is worked out in Qemu, Qemu is likely to be faster than VMPlayer. I’m assuming that this is an issue for KQEMU or Qvm86 and that the Qemu developers can do little about it. Fabrice, what can be the culprit?


Posted

in

by