Finding Bottlenecks In Your Linux Game, Application

Posted by Michael Larabel on July 21, 2012

If you are curious how Valve and Intel improved the OpenGL performance of their Mesa driver and also at the same time finding areas for performance optimizations within the Source Engine, here's some of the tools used.

The tools that seem to be predominantly used, based upon what Intel's Ian Romanick wrote in a blog comment and from what I've learned in email communications and while at Valve, are Sysprof and APITrace.

Sysprof isn't limited to just games or OpenGL workloads but is a system-wide performance profiler for Linux. Sysprof traces user-space and kernel-space calls, doesn't require the rebuilding of any software, supports saving/loading profiles, provides a straightforward user-interface, and does have command-line options. Intel and Valve developers used Sysprof to determine where the most amount of time within the system was being consumed and from there it's much easier to analyze the chunks of code keeping your prrogram the most easy.

Sysprof itself isn't a new tool and has been around for some years. Back in 2010 I wrote about the Karsk module for the Phoronix Test Suite that pairs automated benchmarking with Sysprof to automatically analyze different configurations, although the PTS Karsk module isn't publicly available at the moment.

When it comes to analyzing OpenGL usage and the different GL calls a program makes, the excellent utility for that is the open-source APITrace. APITrace is largely developed by the Intel Mesa developers as well as VMware (former Tungsten Graphics developers) and others. APITrace makes it easy to trace all of the calls made by a user-space program not only for OpenGL but also OpenGL ES, Direct3D, and DirectDraw. After a trace has been stored, re-traces can happen, OpenGL states can be inspected at anytime, traces can be visualized, and there's a handy Qt-based GUI as well. APITrace allows for trimming traces to only preserve the specific set of calls that illustrates a regression or other issues, compressing traces, and many other useful features.

Aside from supporting multiple 3D/drawing APIs, APITrace works not only under Linux but also Windows, Mac OS X, and Android. APITrace is very useful open-source tool and I'm a big fan of it as well.

In addition to APITrace, for OpenGL debugging there is GLIntercept, OpenGL's BuGLe, Tracy, and the closed-source AMD gDEBugger.

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. Intel Linux OpenGL Driver Leading Over Apple OS X
  2. The Cost Of Ubuntu Disk Encryption
  3. Btrfs vs. EXT4 vs. XFS vs. F2FS On Linux 3.10
  4. AMD Radeon R600 GPU LLVM 3.3 Back-End Testing
Latest Linux News
  1. Linux Desktop Security Could Be A Whole Lot Better
  2. KDE 4.11 Will Be The Last Major KDE4 Workspaces Feature Release
  3. New NVIDIA Linux Driver Supports The GeForce GTX 780
  4. Chrome 28 To Offer More Speed Improvements
  5. Digia Announces "Boot To Qt" Project
  6. X.Org Libraries Hit By Round Of Security Issues
  7. Wayland's Weston Gets Output Scaling Support
  8. Raspberry Pi Gets New Wayland Weston Renderer
  9. Debian GNU/Hurd 2013 Release Brings New Packages
  10. Intel Ultrabook Performance Is Faster With Mesa 9.2
  11. Hot Relocation HDD To SSD Support For Btrfs
Latest Forum Talk
  1. Linux Desktop Security Could Be A Whole Lot Better
  2. Steam: No used games...
  3. Xserver 1.14 support will arrive with Catalyst...
  4. New NVIDIA Linux Driver Supports The GeForce GTX...
  5. KDE 4.11 Will Be The Last Major KDE4 Workspaces...
  6. Openbenchmarking.org main page is damaged
  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