Nouveau Gets Further Freed From Ctx_Voodoo

Posted by Michael Larabel on February 23, 2010

One of the issues that was widely discussed when Linus Torvalds brought up finally merging the Nouveau DRM into the Linux 2.6.33 kernel was a microcode problem. The past few generations of NVIDIA graphics processors require this specialized microcode/firmware to be loaded in order to provide acceleration of any sort. At first it was it was a mystery what this microcode actually did, but it turns out that it's used for GPU context switching and the like. This wound up being a sticky situation.

The Nouveau DRM was pulled into the Linux 2.6.33 kernel and the microcode of concern ("ctx_voodoo" as it's been called) was left to be loaded externally rather than embedded in the driver itself due to copyright concerns.

Since then, however, the Nouveau development community had created its own NV40 microcode replacement to alleviate the ctx_voodoo usage for the GeForce 6 generation of graphics cards. Emerging now is also a free software alternative to loading the ctx_voodoo microcode for the NV50/NV8x/NV9x/NVAx class hardware. In other words, the newer NVIDIA graphics processors no longer need to deal with this messy firmware.

Unlike the NV40 firmware replacement, this solution for newer NVIDIA GPUs isn't generated firmware being loaded by the driver, but rather the needed microcode is generated in real-time by the driver. With the massive patch (2,000+ lines of code), the Novueau DRM generates its own ctxprogs firmware without any dependence on any potentially copyrighted NVIDIA firmware.

This embedded ctxprogs and ctxvals generator should work for these newer families of NVIDIA GPUs, but it's quite different from NVIDIA's blob, so the developer (Marcin Koƛcielnicki) is looking for many individuals to test out this newest code and look for any regressions. The Nouveau Gallium3D driver also needs to be tested using this ctxprogs/ctxvals generator.

This generator isn't yet merged into the Nouveau DRM, but for now the large patch can be found on this web-page. Hopefully it will be tested and ready for merging into the Linux 2.6.34 kernel next month. The message announcing this NV50/NV8x/NV9x/NVAx ctxprog and ctxvals generator can be found on the Nouveau mailing list.

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. GCC 4.8.0 vs. LLVM Clang 3.3 Compiler Performance
  2. Intel Linux OpenGL Driver Leading Over Apple OS X
  3. The Cost Of Ubuntu Disk Encryption
  4. Btrfs vs. EXT4 vs. XFS vs. F2FS On Linux 3.10
Latest Linux News
  1. A New X.Org-Free Wayland LiveCD Released
  2. Unity 8, Mir Made Progress This Week On Features
  3. LLVM Clang 3.3 RC2 Is Ready For Testing
  4. AMD RadeonSI Gallium3D Begins Simple CL Demos
  5. Intel Shows Off GNOME3-Based Tizen Shell
  6. Linux Desktop Security Could Be A Whole Lot Better
  7. KDE 4.11 Will Be The Last Major KDE4 Workspaces Feature Release
  8. New NVIDIA Linux Driver Supports The GeForce GTX 780
  9. Chrome 28 To Offer More Speed Improvements
  10. Digia Announces "Boot To Qt" Project
  11. X.Org Libraries Hit By Round Of Security Issues
Latest Forum Talk
  1. GCC 4.8.0 vs. LLVM Clang 3.3 Compiler Performance
  2. Linux's "Ondemand" Governor Is No...
  3. A New X.Org-Free Wayland LiveCD Released
  4. Jolla Announces Their First Phone
  5. Steam: No used games...
  6. AMD RadeonSI Gallium3D Begins Simple CL Demos
  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