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

GNOME Shell Now Works With Software Rendering!

Fedora

Published on 03 November 2011 09:26 PM EDT
Written by Michael Larabel in Fedora
18 Comments

There's some great news today: it's now possible to run the GNOME Shell with Mutter but not having to rely upon any GPU hardware driver! Software rendering is now working with GNOME Shell rather than any fall-back thanks to improvements with Gallium3D's LLVMpipe.

Adam Jackson of Red Hat has announced to the world that it's now possible for everyone to use GNOME Shell, regardless of whether you have a proper 3D hardware driver loaded. Adam says that as of tomorrow, LLVMpipe will no longer be treated as an unsupported driver for Fedora's Rawhide, which is what will eventually be Fedora 17.

While most have open or closed-source 3D drivers available for their GPU, this will be of use to those with QEMU guests where hardware acceleration is lacking, those using Intel Poulsbo on open-source, etc. GNOME Shell now works in software rendering with LLVMpipe and the performance is reported to be decent, but performance optimizations are surely to come as new paths are stressed. In particular, enhancements should land within the Linux kernel and Mesa.

LLVMpipe is a software-based Gallium3D driver that leverages LLVM to provide decent OpenGL acceleration on the CPU for modern CPUs. In particular, LLVMpipe tends to do the best in 64-bit mode and with the latest SSE instruction sets. LLVMpipe still isn't fast enough for many OpenGL games, but for simple window effects that should be a different story with more lax hardware requirements.

While Red Hat can be thanked for much of the improvements to Mesa/Gallium3D, GNOME, and other key components, Red Hat isn't the only one to thank for this new support. Google and others have been working on GLX_EXT_texture_from_pixmap for LLVMpipe and various support improvements.

Details on the GNOME Shell over LLVMpipe accomplishment in Fedora Rawhide can be found on Adam Willianson's blog while more details are available from Adam Jackson himself on the Fedora development list. Adam additionally wrote in an email to me, "[Adam Jackson] says performance is tolerable on cirrus/VNC and 'notably snappier' on qxl/SPICE."

With LLVMpipe now working on GNOME Shell / Mutter, it is likely possible now to use this CPU-based driver for Unity / Compiz (or with not much more work ahead).

This isn't the end of Red Hat's work on GNOME Shell software rendering. In time for Fedora 17 are also other improvements, per this feature specification. Among the items talked about are turning down the Mutter effects automatically when a software-based driver is detected, creating a fake GEM allocator in the Linux kernel DRM that is backed by system memory (would result in a big performance win), and adding more support and optimizations to Mesa. Jackson has already identified some extensions worth adding and other performance optimizations to make to LLVMpipe. With the mock-GEM DRM approach in the kernel, display drivers not using the kernel DRM by default (e.g. xf86-video-vesa, xf86-video-cirrus, etc) would need to be slightly modified to take advantage of the fake DRM.

While Red Hat will be releasing Fedora 16 next week Tuesday (thanks Red Hat, will be a great birthday present!), this GNOME Shell support in software will not land until Fedora 17. The Fedora 17 release will be a beefy miracle and released in the first half of 2012. For those wishing to play with the GNOME Shell software acceleration right now can tap the Fedora Rawhide packages.

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. Preview: AMD's FX-9590 Eight-Core At Up To 5.0GHz On Linux
  2. Intel Launches The Core i7 5960X, Mighty Powerful Haswell-E CPUs
  3. AMD Radeon R9 290: Gallium3D vs. Catalyst Drivers
  4. AMD Radeon R9 290 Open-Source Driver Works, But Has A Ways To Go
Latest Linux Articles
  1. How Intel Graphics On Linux Compare To Open-Source AMD/NVIDIA Drivers
  2. The Fastest NVIDIA GPUs For Open-Source Nouveau With Steam Linux Gaming
  3. Testing For The Latest Linux Kernel Power Regression
  4. The Most Energy Efficient Radeon GPU For AMD Linux Gaming
Latest Linux News
  1. Nouveau X.Org Driver Released With DRI3+Present, Maxwell, GLAMOR
  2. Microsoft & AMD Release C++ AMP Compiler With Linux Support
  3. AMD, Wine & Valve Dominated August For Linux Users
  4. Linux 3.17-rc3 Kernel Released Back On Schedule
  5. Lennart Poettering Talks Up His New Linux Vision That Involves Btrfs
  6. Mesa 10.3 RC2 Arrives Via Its New Release Manager
  7. Ubuntu 14.10's Lack Of X.Org Server 1.16 Gets Blamed On AMD
  8. MSI Motherboard BIOS Updating Remains A Pain For Linux Users
  9. See How Your Linux System Performs Against The Latest Intel/AMD CPUs
  10. AMD Steppe Eagle Flys To Coreboot
Latest Forum Discussions
  1. Lennart Poettering Talks Up His New Linux Vision That Involves Btrfs
  2. The dangers of Linux kernel development
  3. Updated and Optimized Ubuntu Free Graphics Drivers
  4. AMD Releases UVD Video Decode Support For R600 GPUs
  5. SSD seems slow
  6. Is laptop with Intel CPU and AMD dGPU worth buying considering especially AMD Enduro?
  7. Radeon HD5670 and Ubuntu 14.04
  8. Btrfs Gets Talked Up, Googler Encourages You To Try Btrfs