1. Computers
  2. Display Drivers
  3. Graphics Cards
  4. Memory
  5. Motherboards
  6. Processors
  7. Software
  8. Storage
  9. Operating Systems


Facebook RSS Twitter Twitter Google Plus


Phoronix Test Suite

OpenBenchmarking.org

Shader Optimizations Greatly Speed-Up Wayland

Wayland

Published on 23 August 2012 08:56 AM EDT
Written by Michael Larabel in Wayland
2 Comments

Rob Clark, the Texas Instruments developer known for his work on the OMAP DRM driver, DMA-BUF, and hacking a Qualcomm open-source driver in his spare time, has been dabbling with Wayland. Rob's done some optimizations and simplifications to shaders used by Wayland's Weston reference compositor that greatly improve the performance.

With a patch posted under an "RFC" (Request For Comments) flag on the Wayland development list for Weston, he's optimized and simplified some shaders used by the Wayland compositor. When trying to run Wayland on a small SoC GPU like the TI OMAP4 PandaBoard at 1080p, Rob Clark can now obtain 60 FPS while pushing around windows. When pushing YUV buffers for hardware-accelerated decode of 1080p videos he gets 30 FPS. These numbers are compared to below 30 FPS and about 6 FPS, respectively, before writing these optimized shaders. This work should benefit all Weston users, but especially those on mobile/embedded hardware with less-powerful graphics processors.
Re-work how the shaders and emitted vertices work. Rather than always rendering clip-rect sized quads and doing transformation in tex coords (and requiring the corresponding clipping in frag shader), instead emit transformed vertices, clipped wrt. dirty region, and use simpler frag shaders. Also, split the rendering, so blended surfaces with an opaque region have the opaque region drawn with blend disabled. The result is considerably fewer pixels drawn with blend enabled, and much fewer cycles in the frag shader.

This requires having some more complex logic to figure out the vertices of the shape which forms the intersection of the clip rect and the transformed surface. Which has perhaps got a few bugs or missing cases, still (visual glitches in some cases) but at this point more or less is starting to work. I think it is at least far enough along to get some initial review.

The result, on small SoC GPU (omap4/pandaboard) on 1920x1080 display, for simple stuff like moving windows around, I get 60fps (before 30fps or less), and pushing YUV buffers for hw decoded 1080p video goes from ~6fps to 30fps, with no drop in framerate for transformed/rotated video surface.

TODO: compositor-wayland also needs to be updated..
Rob Clark will be speaking next week in San Diego, which will be covered on Phoronix.

About The Author
Michael Larabel is the principal author of Phoronix.com and founded the web-site in 2004 with a focus on enriching the Linux hardware experience and being the largest web-site devoted to Linux hardware reviews, particularly for products relevant to Linux gamers and enthusiasts but also commonly reviewing servers/workstations and embedded Linux devices. Michael has written more than 10,000 articles covering the state of Linux hardware support, Linux performance, graphics hardware drivers, and other topics. Michael is also the lead developer of the Phoronix Test Suite, Phoromatic, and OpenBenchmarking.org automated testing software. He can be followed via and or contacted via .
Latest Linux Hardware Reviews
  1. A Walkthrough Of The New 32 System Open-Source Linux Benchmarking Test Farm
  2. Habey MITX-6771: Mini-ITX Board With Quad-Core J1900 Bay Trail
  3. OCZ Vector 150 SSD On Linux
  4. Noctua i4 CPU Cooler: Great For Cooling High-End LGA-2011v3 CPUs
Latest Linux Articles
  1. 17-Way Linux Graphics Card Comparison With Civilization Beyond Earth
  2. AMD Kaveri: Open-Source Radeon Gallium3D vs. Catalyst 14.12 Omega Driver
  3. 12-Way AMD Catalyst 14.12 vs. NVIDIA 346 Series Linux GPU Comparison
  4. AMD Catalyst 14.12 Omega Driver Brings Mixed Results For Linux Users
Latest Linux News
  1. NTP Is The Latest Project Struck By Security Issues
  2. LDC 0.15.1 Released For A D Compiler In LLVM
  3. Fedora Doesn't Yet Enable F2FS File-System Support
  4. XZ 5.2 Adds New Multi-Threaded Options
  5. Intel 2.99.917 X.Org Driver Released, 3.0 Release Finally Near
  6. Server-Side XCB Is Being Discussed For The X.Org Server
  7. Adreno A4xx Rendering With Freedreno Takes Shape
  8. Linux 3.19-rc1 Kernel Released Ahead Of Schedule
  9. X.Org Server 1.16.3 Released To Fix Security Issues
  10. Linux 3.19 Merge Window Closes Ahead Of Schedule
Latest Forum Discussions
  1. Need some hand holding with upgrading xserver
  2. Maker3D - create your 3D RPG
  3. FPS capped on Linux (AMD fglrx drivers)
  4. Looking for an nVidia GPU, but not sure how well they are supported.
  5. Speeding up systemd networking service
  6. Major Performance Breakthrough Discovered For Intel's Mesa Driver
  7. Are there an app using HSA ?
  8. The New SuperTuxKart Looks Better, But Can Cause GPU/Driver Problems