NVIDIA Publishes Open-Source 2D Driver Code
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.
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 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.