Experimental Code Published For Virtual CRTCs

Posted by Michael Larabel on November 03, 2011

If you're interested in multi-GPU rendering, capabilities for DisplayLink-like devices, or NVIDIA Optimus / MUX-less hybrid graphics switching, here's some news worth reading about virtual CRTCs.

Annoucned today to DRI and fbdev developers is a patch-set that a few unknown developers have been working on for several months. This code allows DRM GPU drivers to have an arbitrary number of CRTCs, including virtual CRTCs, rather than being limited by the number of physical CRTCs on the graphics hardware.

A CRTC (Cathode Ray Tube Controller) deals with video timings and reads the frame-buffer from video RAM so that it can be outputted. This code allows virtual CRTCs to be created in the kernel drivers so that they can be used for a variety of tasks. A virtual CRTC with this code is treated just like a real hardware CRTC. This experimental code allows these virtual CRTCs to be attached to "CTD devices" (Compression Transmission and Display). Then finishing off the equation is a new kernel module, the VCRTCM (Virtual CRTC Manager), that bridges the traffic between GPUs and CTDs.

With being able to basically stream rendered data from one GPU/display to another, there's interesting possible use-cases. Here's a description from the announcement, "In one example, we use AMD/ATI Radeon GPU to do 3D rendering (accelerated, of course) and we use our code to add additional monitor heads using DisplayLink devices. In other words, we achieve accelerated 3D rendering on a DisplayLink monitor. In another example we funnel rendered pixels to userland by emulating a Video-for-Linux
device (and then userland can do whatever it wants with it). While doing all this, GPU has no idea that we are doing this, the entire DRI "thinks" that it is just dealing with a GPU that has a few "extra" connectors and CRTCs. So everything ports without the need to modify anything in the userland."

As was confirmed by the developer announcing this work, this could help in the NVIDIA Optimus / MUX-less hybrid graphics situations. The discrete GPU can be used for rendering the data and then passing the contents to the integrated graphics processor.

These developers have also written a fake driver to represent a V4L2 device as a CTD device. Drivers wishing to take advantage of virtual CRTCs require slight modifications. The developers also seem to have some other interesting plans for this work too, assuming the upstream DRM developers welcome the contributions.

Find more information in the mailing list announcement for Virtual CRTCs.

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. Intel Haswell HD Graphics 4600 vs. AMD Radeon Graphics On Linux
  2. Intel Haswell HD Graphics 4600 Performance On Ubuntu Linux
  3. Intel Core i7 4770K "Haswell" Benchmarks On Ubuntu Linux
  4. The First Experience Of Intel Haswell On Linux
Latest Software Articles
  1. Optimized Binaries Provide Great Benefits For Intel Haswell
  2. 11-Way Linux, BSD Platform Comparison
  3. SNA Acceleration Works Great For Intel Core i7 Haswell
  4. The Linux Evolution For Intel Haswell's Performance
Latest Linux News
  1. KDE's KWin Made Lots Of Progress In 4.11
  2. Ubuntu Announces Carrier Advisory Group
  3. Qt 5.1 Release Candidate 1 Has Arrived
  4. In-Fighting Continues Over Mir On Non-Unity Ubuntu
  5. Subversion 1.8 Presents New Features
  6. LLVM 3.3 Officially Released
  7. LLVM/Clang Now Uses Loop Vectorizer At New Levels
  8. Intel GPU Driver Tries To Rip Out FBDEV Support
  9. Coreboot Doing AMD USB 3.0, Q35 QEMU Emulation
  10. VP9 Codec Now Enabled By Default In Chrome
  11. openSUSE 13.1 M2 Plays On PulseAudio 4.0
Latest Forum Talk
  1. In-Fighting Continues Over Mir On Non-Unity Ubuntu
  2. Commodity Tips
  3. I got robbed at gunpoint today....
  4. Ubuntu Announces Carrier Advisory Group
  5. KDE's KWin Made Lots Of Progress In 4.11
  6. Planetary Annihilation Plans To Come To Linux
  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