NVIDIA Publishes Open-Source 2D Driver Code

Posted by Michael Larabel on November 26, 2012

NVIDIA has published initial patches for providing open-source 2D hardware acceleration support on their NVIDIA Tegra 2 and Tegra 3 SoCs. This work is based upon the experimental open-source Direct Rendering Manager driver to be merged into the Linux 3.8 kernel.

Times are great with NVIDIA dabbling with more open-source code and Imagination looking at some level of open-source PowerVR support. This weekend I wrote about NVIDIA working on open-source support for their Tegra graphics while this morning new open-source patches arrived from the NVIDIA Finland office.

In that article this past weekend I mentioned that besides it being known for months that NVIDIA has been working on 2D GPU documentation covering Tegra, the NVIDIA Linux mobile engineers have also helped advance the Tegra DRM driver in supporting HDMI output and other functionality.

The NVIDIA Tegra DRM driver was started by Thierry Reding as an independent project but is now being improved by NVIDIA and others. This driver is set to be merged into the kernel's staging area with Linux 3.8. This open-source driver has been in development since this past April for supporting the Tegra 2 SoC.

NVIDIA's patches published today by Terje Bergstrom provide host1x and 2D on Tegra 2 and Tegra 3 SoCs. There's still some unresolved issues so the patches haven't been merged yet, but hopefully we might see them just in time for Linux 3.8. There's still about one week left until the Linux 3.7 kernel final release and the 3.8 merge window then opens.

In terms of host1x/nvhost, Terje writes, "nvhost is the driver that controls host1x hardware. It supports host1x command channels, synchronization, run-time power management and memory management. It is sectioned into logical driver under drivers/video/tegra/host and physical driver under drivers/video/tegra/host/host1x. The physical driver is compiled with the hardware headers of the particular host1x version."

The NVIDIA Tegra DRM driver uses nvhost for communicating with host1x to access sync points and channels. The same code will be used as well for future NVIDIA host1x clients, thereby keeping nvhost and the "tegradrm" driver separate.

These new patches to expose a user-space API for Tegra DRM to access host1d and 2D while NVIDIA is still working on some to-be-published patches against the libdrm user-space library for using this API. Other items still being worked on is IOMMU support, better PRIME support, host1x documentation, user-space 2D code, and re-basing the code upon linux-next.

The GPL patches provided by NVIDIA today for this 2D Tegra support amount to just over 8,000 lines of code. The set of eight patches can be examined on the dri-devel list.

The NVIDIA Tegra 2 packs an ultra-low-power (ULP) GeForce GPU with just four pixel shaders and four vertex shaders while the core operates between 300 and 400MHz. The NVIDIA Tegra 3 has eight pixel shaders and clock frequencies for its GeForce core between 416MHz and 520MHz.

It's interesting to see NVIDIA work on this open-source graphics acceleration support, but too bad right now it's limited to just Tegra/mobile coverage and no change of course on the desktop side. On the desktop side they used to maintain the UMS-only xf86-video-nv DDX driver that did have 2D acceleration support, but that driver was eventually canned when Nouveau began to grow in popularity. We also haven't yet seen any open-source 3D support for Tegra, but back in September heard there might be some open-source 3D 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. 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. Linux's "Ondemand" Governor Is No...
  2. A New X.Org-Free Wayland LiveCD Released
  3. Jolla Announces Their First Phone
  4. Steam: No used games...
  5. AMD RadeonSI Gallium3D Begins Simple CL Demos
  6. KDE 4.11 Will Be The Last Major KDE4 Workspaces...
  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