Nouveau GeForce 600 "Kepler" Support Gets FUC'ed

Posted by Michael Larabel on September 10, 2012

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.

Discuss this article in our forums, IRC channel, or email the author. You can also follow our content via RSS and on social networks like Facebook, Identi.ca, and Twitter (@Phoronix and @MichaelLarabel). Subscribe to Phoronix Premium to view our content without advertisements, view entire articles on a single page, and experience other benefits.
Latest Hardware Reviews
  1. Sumo Lounge Emperor
  2. Gallium3D Continues Improving OpenGL For Older Radeon GPUs
  3. 15-Way Open vs. Closed Source NVIDIA/AMD Linux GPU Comparison
  4. Nouveau vs. NVIDIA Linux Comparison Shows Shortcomings
Latest Software Articles
  1. Intel Linux OpenGL Driver Leading Over Apple OS X
  2. The Cost Of Ubuntu Disk Encryption
  3. Btrfs vs. EXT4 vs. XFS vs. F2FS On Linux 3.10
  4. AMD Radeon R600 GPU LLVM 3.3 Back-End Testing
Latest Linux News
  1. Wayland's Weston Gets Output Scaling Support
  2. Raspberry Pi Gets New Wayland Weston Renderer
  3. Debian GNU/Hurd 2013 Release Brings New Packages
  4. Intel Ultrabook Performance Is Faster With Mesa 9.2
  5. Hot Relocation HDD To SSD Support For Btrfs
  6. Phoronix Test Suite 4.6.0 "Utsira" Released
  7. New Intel X.Org Driver Supports All Of Haswell
  8. SQLite Now Faster With Memory Mapped I/O
  9. Microsoft Releases Skype For Linux 4.2, Has Bug-Fixes
  10. Qt For Tizen Launches, Based On Qt 5.1
  11. KTAP Released For Linux Kernel Dynamic Tracing
Latest Forum Talk
  1. Handbrake 0.9.9 Supports OpenCL Offloading
  2. Humble Indie Bundle Finally Sells Out
  3. Debian GNU/Hurd 2013 Release Brings New Packages
  4. Wayland's Weston Gets Output Scaling Support
  5. Richard Stallman is right yet, again.
  6. Raspberry Pi Gets New Wayland Weston Renderer
  1. Computers
  2. Display Drivers
  3. Graphics Cards
  4. Motherboards
  5. Peripherals
  6. Processors
  7. Software
  8. Operating Systems
  9. All Articles
  1. Linux Benchmarking
  2. OpenBenchmarking.org
  3. Phoronix Test Suite