Mozilla Spots Massive Performance Regression In GCC

Posted by Michael Larabel on June 25, 2010

Mozilla developers on the GCC mailing list have been expressing what they describe as a "massive performance regression" and "what might be the biggest compiler-upgrade-related performance difference we've seen at Mozilla." The Mozilla developers have upgraded from GCC 4.3 to GCC 4.5, which was released in April, and now they are experiencing massive slowdowns.

Taras Glek of Mozilla reports that with this newest release of the GNU Compiler Collection they are experiencing 4-19% slowdowns on average with their automated benchmarks on their 32-bit and 64-bit Linux builds. The only case where there wasn't a slowdown was with the 64-bit SunSpider JavaScript benchmark where it sped up by 8% when being built under GCC 4.5. Some of these Mozilla slowdowns after the GCC upgrade are discussed here and here. The start of the mailing list discussion can be found here.

Because of these performance shortcomings on GCC 4.5, Mozilla is reconsidering their switch to this newest compiler release. At least because Mozilla has an automated benchmarking infrastructure in place, they were able to spot this issue timely themselves rather than waiting for us or others to spot the problem.

Initial thoughts on these major regressions caused by GCC are the Mozilla developers building Firefox with flags for size optimizations rather than speed and possible regressions from code inlining. Mozilla was originally switching to GCC 4.5 due to its newly-introduced plug-in support and the ability to build Firefox with PGO (Profile-Guided Optimizations).

Following the release of GCC 4.5.0 in mid-April we published our own GCC 4.5 benchmarks and GCC vs. Clang/LLVM benchmarks.

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. The Cost Of Ubuntu Disk Encryption
  2. Btrfs vs. EXT4 vs. XFS vs. F2FS On Linux 3.10
  3. AMD Radeon R600 GPU LLVM 3.3 Back-End Testing
  4. F2FS File-System Shows Regressions On Linux 3.10
Latest Linux News
  1. QEMU 1.5 Supports VGA Passthrough, Better USB 3.0
  2. Handbrake 0.9.9 Supports OpenCL Offloading
  3. Freedreno Gallium3D Now Banging The Adreno A3XX
  4. Jolla Announces Their First Phone
  5. Mageia 3 Released, Still Using Legacy GRUB
  6. NetBSD 6.1 Brings In More Features
  7. Using Six Monitors With AMD's Open-Source Linux Driver
  8. Benchmarking The Intel P-State, CPUfreq Changes
  9. FreeBSD Still Working On Next-Gen Package Manager
  10. DNF Still Advancing As Experimental Yum For Fedora
  11. Logitech Begins Supporting Linux Users
Latest Forum Talk
  1. Handbrake 0.9.9 Supports OpenCL Offloading
  2. AMD Radeon R600 GPU LLVM 3.3 Back-End Testing
  3. FreeBSD Still Working On Next-Gen Package Manager
  4. Kubuntu, KDE Has Little Hope For Ubuntu's Mir
  5. Jolla Announces Their First Phone
  6. BHyVe: A New Hypervisor Coming To FreeBSD 10.0
  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