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

Nouveau GeForce 600 "Kepler" Support Gets FUC'ed

Nouveau

Published on 10 September 2012 05:22 PM EDT
Written by Michael Larabel in Nouveau
1 Comment

The reverse-engineered open-source Nouveau driver has received its own FUC microcode implementation that frees it from having to use the binary microcode produced by the proprietary NVIDIA Linux graphics driver for the GeForce 600 "Kepler" graphics processors, but there's still problems ahead in supporting this latest-generation hardware.

Committed to the Nouveau DRM driver development repository last week was an initial FUC implementation for "NVE0", a.k.a. Kepler GPUs. The FUC implementation, which is based upon the Fermi FUC code, amounts to just over 3,000 lines of code. The commit description read:
drm/nve0/gr: initial fuc implementation, based on fermi's code
Currently identical except the available chipset register lists. This will *not* currently work and is disabled by default because of this. May get merged again later, remains to be seen what further changes will be required.
But then following this initial commit was another related to the NVE0 FUC. This follow-up commit avoided bashing 0x404160 by changing around about 300 lines of code. As a result of this commit, the FUC loads on Kepler and for NVE4 hardware can at least provide acceleration support for a frame-buffer console, X.Org, glxgears, and OpenArena.

One commit later, the Nouveau Kepler-based Fermi FUC was enabled by default. However, even after this commit the hardware-accelerated GeForce 600 series support is still disabled by default due to outstanding bugs.

The FUC (Flexible micro-controller it's been called, among other terms) microcode is needed for modern hardware in order for accelerated support on modern NVIDIA GPUs. Like for Kepler, it initially took several months for Fermi FUC microcode to be developed so that first the NVIDIA driver didn't need to be loaded followed by running MMIOtrace in order to extract your own microcode for initializing the hardware when running the Nouveau driver.

When the NVIDIA GeForce 600 graphics cards were launched back in March there was the big surprise of same-day Nouveau support as the community developers somehow got early access to a few GeForce GTX 680 graphics cards. However, the needing of this FUC microcode has limited the open-source Nouveau support so far of this new hardware. There were also some early Kepler bugs. The Nouveau Kepler support works with OpenGL acceleration works but is quite slow at the moment due to the lack of proper graphics core / memory re-clocking, which is also defeating the use of the open-source driver on the latest NVIDIA GPUs.

This continued Nouveau work by Red Hat's Ben Skeggs is terrific and hopefully by the time the Linux 3.7 kernel merge window opens they will be able to have Kepler acceleration support by default. Unfortunately by the time this supported kernel ends up in most non-rolling-release distributions, Kepler will have been around one year old.... At least Nouveau has already begun work on unreleased GK110 "Kepler 2" support.

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 Articles & Reviews
  1. OS X 10.10 vs. Ubuntu 15.04 vs. Fedora 21 Tests: Linux Sweeps The Board
  2. The New Place Where Linux Code Is Constantly Being Benchmarked
  3. 18-GPU NVIDIA/AMD Linux Comparison Of BioShock: Infinite
  4. Phoronix Test Suite 5.6 Adds New Phoromatic Enterprise Benchmarking Features
  5. OpenGL Threaded Optimizations Responsible For NVIDIA's Faster Performance?
  6. Big Graphics Card Comparison Of Metro Redux Games On Linux
Latest Linux News
  1. Git 2.4.0-rc0 Does A Ton Of Polishing
  2. The Most Common, Annoying Issue When Benchmarking Ubuntu On Many Systems
  3. Mesa Is At Nearly 1,500 Commits This Year
  4. Gestures & Other GTK3 Features For LibreOffice
  5. It's Now Easier To Try PHP 7 On Fedora & RHEL
  6. BQ Is Cleaning Up Their Aquaris E4.5 Ubuntu Kernel
  7. Allwinner Continues Jerking Around The Open-Source Community
  8. NVIDIA Linux 349.12 Beta Has Improved G-SYNC & VDPAU Features
  9. Canonical Just Made It Even Easier To Benchmark Ubuntu Linux In The Cloud
  10. NVIDIA GeForce GTX TITAN X Linux Testing Time
Most Viewed News This Week
  1. Introducing The Library Operating System For Linux
  2. AMD Is Hiring Two More Open-Source Linux GPU Driver Developers
  3. New SecureBoot Concerns Arise With Windows 10
  4. Allwinner Caught Obfuscating Their Improperly Licensed Code
  5. Latest OpenSSL Vulnerabilities Revealed; LibreSSL In Better Shape
  6. GNU Nano 2.4.0 Brings Complete Undo System, Linter Support & More
  7. GNOME Shell & Mutter 3.16.0 Released
  8. Systemd Change Allows For Stateless Systems With Tmpfs
%%CLICK_URL_UNESC%%