1. Computers
  2. Display Drivers
  3. Graphics Cards
  4. Memory
  5. Motherboards
  6. Processors
  7. Software
  8. Storage
  9. Operating Systems


Facebook RSS Twitter Twitter Google Plus


Phoronix Test Suite

OpenBenchmarking.org

SPICE On KVM/QEMU Works Towards Gallium3D

Red Hat

Published on 09 February 2012 08:29 AM EST
Written by Michael Larabel in Red Hat
3 Comments

Red Hat's SPICE project that's used in KVM/QEMU virtualization environments is working towards better graphics support, which also includes work on a DRM driver and Gallium3D component for offering 3D acceleration support within guest virtual machines.

Alon Levy of Red Hat presented at FOSDEM last weekend about "Xspice: Integrating spice-server into Xorg", during which he talked a lot about their graphics driver plans. Right now QEMU/KVM really doesn't have any guest 3D support in the manner that VirtualBox or VMware graphics exposes OpenGL/DirectX support to guest systems and in turn passes the graphics calls onto the host system so it can be executed on bare metal.

Right now with QEMU/KVM you just go without acceleration or are left banging LLVMpipe on the CPU. Fortunately, the SPICE project is coming up with a spicy solution for better graphics. (For those not familiar with SPICE, see spice-space.org.)

VirtualBox has its own graphics driver stack while VMware implements a virtual Gallium3D driver with kernel DRM and it fits nicely into the common Linux stack. (There's actually an article going up tomorrow on Phoronix that's looking at the "vmwgfx" performance.) The approach that the SPICE developers are looking at is very similar to VMware's approach of complying with the existing Linux infrastructure.

Right now what SPICE users have in terms of driver support for their virtual GPU is the xf86-video-qxl DDX, which can work without any kernel DRM. However, the Red Hat developers have been working on a DRM driver as well as UXA acceleration support as was recently talked about on Phoronix.

Alon Levy mentions that this currently out-of-tree SPICE QXL DRM kernel driver is working right now for the frame-buffer and on the X.Org side with xf86-video-modesetting (the generic KMS X.Org driver). The xf86-video-qxl driver is still being re-written to handle support for the DRM/KMS driver while maintaining compatibility with the existing mode-setting paths. The QXL graphics ioctls for the kernel are still a work in progress.

For offering 3D support over SPICE to both Linux and Windows guests is a planned (but yet-to-be-written) Gallium3D driver. With also supporting Microsoft Windows, the Direct3D state tracker was mentioned for possible use during this presentation. The SPICE 3D plans date back to last year after they first had a "false start" when trying to use Xen's Gallium3D driver (vGallium) in their environment. Going with the Xen Gallium3D driver, which is not living in Mesa's code-base and is no longer actively maintained, the Red Hat developers deemed it a dead-end.

Aside from 3D, other missing general features at the moment for this virtualization path is multiple monitor support, sound/USB/smart-card support still being a work in progress, and namely support for handling an existing X.Org server like x11vnc, which would be dependent upon GPU hot-plug support working for X.

As far as when the new DRM and/or Gallium3D driver will be ready for SPICE users, that is really an open question at this point. Alon Levy isn't sure and it's just a few virtualization developers working on it with what appears to be little to no collaboration from the X.Org/graphics developers at Red Hat with the actual graphics driver experience.

In ending, here's a look at the planned graphics architecture:

SPICE On KVM/QEMU Works Towards Gallium3D


About The Author
Michael Larabel is the principal author of Phoronix.com and founded the web-site in 2004 with a focus on enriching the Linux hardware experience and being the largest web-site devoted to Linux hardware reviews, particularly for products relevant to Linux gamers and enthusiasts but also commonly reviewing servers/workstations and embedded Linux devices. Michael has written more than 10,000 articles covering the state of Linux hardware support, Linux performance, graphics hardware drivers, and other topics. Michael is also the lead developer of the Phoronix Test Suite, Phoromatic, and OpenBenchmarking.org automated testing software. He can be followed via and or contacted via .
Latest Linux Hardware Reviews
  1. ASRock X99 Extreme3 Is An Affordable Choice For Linux Users
  2. A Walkthrough Of The New 32 System Open-Source Linux Benchmarking Test Farm
  3. Habey MITX-6771: Mini-ITX Board With Quad-Core J1900 Bay Trail
  4. OCZ Vector 150 SSD On Linux
Latest Linux Articles
  1. 17-Way Linux Graphics Card Comparison With Civilization Beyond Earth
  2. AMD Kaveri: Open-Source Radeon Gallium3D vs. Catalyst 14.12 Omega Driver
  3. 12-Way AMD Catalyst 14.12 vs. NVIDIA 346 Series Linux GPU Comparison
  4. AMD Catalyst 14.12 Omega Driver Brings Mixed Results For Linux Users
Latest Linux News
  1. Orange Pi Is The Latest Raspberry Pi Inspired ARM Board
  2. An Open-Source Hardware Ambient Light Sensor Is Brought Up
  3. Heterogeneous Memory Management Is Coming Along For The Linux Kernel
  4. NTP Is The Latest Project Struck By Security Issues
  5. LDC 0.15.1 Released For A D Compiler In LLVM
  6. Fedora Doesn't Yet Enable F2FS File-System Support
  7. XZ 5.2 Adds New Multi-Threaded Options
  8. Intel 2.99.917 X.Org Driver Released, 3.0 Release Finally Near
  9. Server-Side XCB Is Being Discussed For The X.Org Server
  10. Adreno A4xx Rendering With Freedreno Takes Shape
Latest Forum Discussions
  1. Need some hand holding with upgrading xserver
  2. Maker3D - create your 3D RPG
  3. FPS capped on Linux (AMD fglrx drivers)
  4. Looking for an nVidia GPU, but not sure how well they are supported.
  5. Speeding up systemd networking service
  6. Major Performance Breakthrough Discovered For Intel's Mesa Driver
  7. Are there an app using HSA ?
  8. The New SuperTuxKart Looks Better, But Can Cause GPU/Driver Problems