GCC 4.8 vs. LLVM Clang 3.3 SVN Compiler Benchmarking GCC 4.7.2 versus GCC 4.8.0 versus LLVM Clang 3.2 versus LLVM Clang 3.3 SVN compiler benchmarking from an Intel Core i7 990X Gulftown system running Ubuntu 13.04 Linux. Compiler GCC benchmarks for a future article on Phoronix.com.
HTML result view exported from: https://openbenchmarking.org/result/1303255-FO-GCC48LLVM06&grw&rdt .
GCC 4.8 vs. LLVM Clang 3.3 SVN Compiler Benchmarking Processor Motherboard Chipset Memory Disk Graphics Audio Network OS Kernel Desktop Display Server Display Driver OpenGL Compiler File-System Screen Resolution GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 Intel Core i7 990X @ 3.47GHz (12 Cores) MSI X58M (MS-7593) v1.0 Intel 5520/5500/X58 + ICH10R 12288MB 1000GB Western Digital WD1003FBYX-0 NVIDIA GeForce 8400 GS 512MB (500/333MHz) Realtek ALC889 Realtek RTL8111/8168B Ubuntu 13.04 3.8.0-12-generic (x86_64) Unity 6.6.0 X Server 1.13.2 NVIDIA 313.26 3.3.0 NVIDIA 313.26 GCC 4.7 ext4 1920x1080 GCC 4.7.2 Clang 3.3 (SVN 177878) + LLVM 3.3svn Clang 3.2 + LLVM 3.2svn OpenBenchmarking.org Compiler Details - GCC 4.8.0: --build=x86_64-linux-gnu --disable-cloog-version-check --disable-ppl-version-check --disable-werror --enable-checking=release --enable-clocale=gnu --enable-cloog-backend=ppl --enable-gnu-unique-object --enable-languages=c,c++,go,fortran,objc,obj-c++ --enable-libstdcxx-debug --enable-libstdcxx-time=yes --enable-multiarch --enable-nls --enable-objc-gc --enable-plugin --enable-shared --enable-threads=posix --host=x86_64-linux-gnu --target=x86_64-linux-gnu --with-abi=m64 --with-arch-32=i686 --with-cloog --with-multilib-list=m32,m64,mx32 --with-tune=generic -v - GCC 4.7.2: --enable-checking=release --enable-languages=c,c++,fortran --enable-lto - LLVM Clang 3.3 SVN: Optimized build; Built Mar 25 2013 (12:54:43); Default target: x86_64-unknown-linux-gnu; Host CPU: corei7 - LLVM Clang 3.2: Optimized build; Built Mar 25 2013 (15:48:44); Default target: x86_64-unknown-linux-gnu; Host CPU: corei7 Processor Details - Scaling Governor: ondemand OpenCL Details - GCC 4.8.0: GPU Compute Cores: 8 System Details - GCC 4.8.0: GPU Compute Cores: 8.
GCC 4.8 vs. LLVM Clang 3.3 SVN Compiler Benchmarking minion: Graceful minion: Solitaire minion: Quasigroup blake2: Phoronix Test Suite v4.4.1 botan: Tiger botan: KASUMI botan: AES-256 botan: Twofish botan: CAST-256 botan: X9.19-MAC encode-flac: WAV To FLAC encode-mp3: WAV To MP3 mafft: Multiple Sequence Alignment himeno: Poisson Pressure Solver lammps: Rhodopsin Protein n-queens: Elapsed Time build-imagemagick: Time To Compile primesieve: 1e12 Prime Number Generation john-the-ripper: Blowfish john-the-ripper: Traditional DES john-the-ripper: MD5 c-ray: Total Time ffmpeg: H.264 HD To NTSC DV smallpt: Global Illumination Renderer; 100 Samples GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 72.40 103.05 153.93 6.16 376.26 37.91 133.38 172.71 87.37 76.19 6.94 17.00 5.72 1337.12 48.46 29.66 59.67 66.79 7272 12345000 33996 18.83 19.35 32 71.58 107.44 157.81 5.96 360.43 39.35 154.60 175.13 85.71 77.12 6.99 17.23 5.67 1527.02 49.36 28.82 58.05 66.67 23.78 19.06 32 70.29 114.74 159.10 6.85 381.89 65.75 144.74 169.82 109.43 74.87 7.88 16.83 6.13 1499.50 41.36 257.21 24.79 419.76 909 4105667 28585 23.74 19.31 285 71.84 108.48 156.36 6.77 357.40 39.34 154.74 175.13 85.56 76.77 7.98 17.41 6.19 1487.33 49.71 257.21 25.03 66.57 901 4102667 25987 23.78 19.24 31 OpenBenchmarking.org
Minion Benchmark: Graceful OpenBenchmarking.org Seconds, Fewer Is Better Minion 0.15 Benchmark: Graceful GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 16 32 48 64 80 SE +/- 0.38, N = 3 SE +/- 0.37, N = 3 SE +/- 0.35, N = 3 SE +/- 0.08, N = 3 72.40 71.58 70.29 71.84 -lz -lbz2 -lz -lbz2 -lz -lbz2 1. (CXX) g++ options: -O3 -fomit-frame-pointer -rdynamic -lboost_iostreams-mt
Minion Benchmark: Solitaire OpenBenchmarking.org Seconds, Fewer Is Better Minion 0.15 Benchmark: Solitaire GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 30 60 90 120 150 SE +/- 0.82, N = 3 SE +/- 0.76, N = 3 SE +/- 0.68, N = 3 SE +/- 0.76, N = 3 103.05 107.44 114.74 108.48 -lz -lbz2 -lz -lbz2 -lz -lbz2 1. (CXX) g++ options: -O3 -fomit-frame-pointer -rdynamic -lboost_iostreams-mt
Minion Benchmark: Quasigroup OpenBenchmarking.org Seconds, Fewer Is Better Minion 0.15 Benchmark: Quasigroup GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 40 80 120 160 200 SE +/- 0.44, N = 3 SE +/- 0.19, N = 3 SE +/- 0.55, N = 3 SE +/- 0.42, N = 3 153.93 157.81 159.10 156.36 -lz -lbz2 -lz -lbz2 -lz -lbz2 1. (CXX) g++ options: -O3 -fomit-frame-pointer -rdynamic -lboost_iostreams-mt
BLAKE2 Phoronix Test Suite v4.4.1 OpenBenchmarking.org Cycles Per Byte, Fewer Is Better BLAKE2 20121223 Phoronix Test Suite v4.4.1 GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 2 4 6 8 10 SE +/- 0.00, N = 3 SE +/- 0.03, N = 3 SE +/- 0.05, N = 3 SE +/- 0.01, N = 3 6.16 5.96 6.85 6.77 1. (CC) gcc options: -std=gnu99 -O3 -march=native
Botan Test: Tiger OpenBenchmarking.org Mbytes/s, More Is Better Botan 1.10.3 Test: Tiger GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 80 160 240 320 400 376.26 360.43 381.89 357.40 1. (CXX) g++ options: -m64 -ldl -lpthread -lrt
Botan Test: KASUMI OpenBenchmarking.org Mbytes/s, More Is Better Botan 1.10.3 Test: KASUMI GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 15 30 45 60 75 37.91 39.35 65.75 39.34 1. (CXX) g++ options: -m64 -ldl -lpthread -lrt
Botan Test: AES-256 OpenBenchmarking.org Mbytes/s, More Is Better Botan 1.10.3 Test: AES-256 GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 30 60 90 120 150 133.38 154.60 144.74 154.74 1. (CXX) g++ options: -m64 -ldl -lpthread -lrt
Botan Test: Twofish OpenBenchmarking.org Mbytes/s, More Is Better Botan 1.10.3 Test: Twofish GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 40 80 120 160 200 172.71 175.13 169.82 175.13 1. (CXX) g++ options: -m64 -ldl -lpthread -lrt
Botan Test: CAST-256 OpenBenchmarking.org Mbytes/s, More Is Better Botan 1.10.3 Test: CAST-256 GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 20 40 60 80 100 87.37 85.71 109.43 85.56 1. (CXX) g++ options: -m64 -ldl -lpthread -lrt
Botan Test: X9.19-MAC OpenBenchmarking.org Mbytes/s, More Is Better Botan 1.10.3 Test: X9.19-MAC GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 20 40 60 80 100 76.19 77.12 74.87 76.77 1. (CXX) g++ options: -m64 -ldl -lpthread -lrt
FLAC Audio Encoding WAV To FLAC OpenBenchmarking.org Seconds, Fewer Is Better FLAC Audio Encoding 1.2.1 WAV To FLAC GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 2 4 6 8 10 SE +/- 0.01, N = 5 SE +/- 0.01, N = 5 SE +/- 0.01, N = 5 SE +/- 0.02, N = 5 6.94 6.99 7.88 7.98 1. (CXX) g++ options: -O3 -march=native -logg -lm
LAME MP3 Encoding WAV To MP3 OpenBenchmarking.org Seconds, Fewer Is Better LAME MP3 Encoding 3.99.3 WAV To MP3 GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 4 8 12 16 20 SE +/- 0.01, N = 5 SE +/- 0.01, N = 5 SE +/- 0.02, N = 5 SE +/- 0.04, N = 5 17.00 17.23 16.83 17.41
Timed MAFFT Alignment Multiple Sequence Alignment OpenBenchmarking.org Seconds, Fewer Is Better Timed MAFFT Alignment 6.864 Multiple Sequence Alignment GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 2 4 6 8 10 SE +/- 0.10, N = 3 SE +/- 0.09, N = 6 SE +/- 0.13, N = 6 SE +/- 0.06, N = 3 5.72 5.67 6.13 6.19 1. (CC) gcc options: -O3 -lm -lpthread
Himeno Benchmark Poisson Pressure Solver OpenBenchmarking.org MFLOPS, More Is Better Himeno Benchmark 3.0 Poisson Pressure Solver GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 300 600 900 1200 1500 SE +/- 5.16, N = 3 SE +/- 2.54, N = 3 SE +/- 2.56, N = 3 SE +/- 2.43, N = 3 1337.12 1527.02 1499.50 1487.33 1. (CC) gcc options: -O3 -march=native
LAMMPS Molecular Dynamics Simulator Test: Rhodopsin Protein OpenBenchmarking.org Loop Time, Fewer Is Better LAMMPS Molecular Dynamics Simulator 1.0 Test: Rhodopsin Protein GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 11 22 33 44 55 SE +/- 0.14, N = 3 SE +/- 0.18, N = 3 SE +/- 0.09, N = 3 SE +/- 0.07, N = 3 48.46 49.36 41.36 49.71 1. (CXX) g++ options: -lfftw -lmpich
N-Queens Elapsed Time OpenBenchmarking.org Seconds, Fewer Is Better N-Queens 1.0 Elapsed Time GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 60 120 180 240 300 SE +/- 0.13, N = 3 SE +/- 0.02, N = 3 SE +/- 0.05, N = 3 SE +/- 0.04, N = 3 29.66 28.82 257.21 257.21 1. (CC) gcc options: -static -fopenmp -O3 -march=native
Timed ImageMagick Compilation Time To Compile OpenBenchmarking.org Seconds, Fewer Is Better Timed ImageMagick Compilation 6.8.1-10 Time To Compile GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 13 26 39 52 65 SE +/- 0.12, N = 3 SE +/- 0.07, N = 3 SE +/- 0.10, N = 3 SE +/- 0.11, N = 3 59.67 58.05 24.79 25.03
Primesieve 1e12 Prime Number Generation OpenBenchmarking.org Seconds, Fewer Is Better Primesieve 4.2 1e12 Prime Number Generation GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 90 180 270 360 450 SE +/- 0.02, N = 3 SE +/- 0.01, N = 3 SE +/- 0.45, N = 3 SE +/- 0.04, N = 3 66.79 66.67 419.76 66.57 -fopenmp -fopenmp -fopenmp 1. (CXX) g++ options: -O2
John The Ripper Test: Blowfish OpenBenchmarking.org Real C/S, More Is Better John The Ripper 1.7.9-jumbo-7 Test: Blowfish GCC 4.8.0 LLVM Clang 3.3 SVN LLVM Clang 3.2 1600 3200 4800 6400 8000 SE +/- 0.33, N = 3 SE +/- 0.67, N = 3 SE +/- 1.76, N = 3 7272 909 901 1. (CC) gcc options: -lssl -lcrypto -lm -lz -fopenmp -lcrypt -ldl
John The Ripper Test: Traditional DES OpenBenchmarking.org Real C/S, More Is Better John The Ripper 1.7.9-jumbo-7 Test: Traditional DES GCC 4.8.0 LLVM Clang 3.3 SVN LLVM Clang 3.2 3M 6M 9M 12M 15M SE +/- 41000.00, N = 3 SE +/- 6691.62, N = 3 SE +/- 1855.92, N = 3 12345000 4105667 4102667 1. (CC) gcc options: -lssl -lcrypto -lm -lz -fopenmp -lcrypt -ldl
John The Ripper Test: MD5 OpenBenchmarking.org Real C/S, More Is Better John The Ripper 1.7.9-jumbo-7 Test: MD5 GCC 4.8.0 LLVM Clang 3.3 SVN LLVM Clang 3.2 7K 14K 21K 28K 35K SE +/- 31.75, N = 3 SE +/- 75.88, N = 3 SE +/- 52.07, N = 3 33996 28585 25987 1. (CC) gcc options: -lssl -lcrypto -lm -lz -fopenmp -lcrypt -ldl
C-Ray Total Time OpenBenchmarking.org Seconds, Fewer Is Better C-Ray 1.1 Total Time GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 6 12 18 24 30 SE +/- 0.00, N = 3 SE +/- 0.01, N = 3 SE +/- 0.02, N = 3 SE +/- 0.01, N = 3 18.83 23.78 23.74 23.78 1. (CC) gcc options: -lm -lpthread -O3 -march=native
FFmpeg H.264 HD To NTSC DV OpenBenchmarking.org Seconds, Fewer Is Better FFmpeg 1.1 H.264 HD To NTSC DV GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 5 10 15 20 25 SE +/- 0.18, N = 3 SE +/- 0.07, N = 3 SE +/- 0.19, N = 3 SE +/- 0.04, N = 3 19.35 19.06 19.31 19.24 1. (CC) gcc options: -lavdevice -lavfilter -lavformat -lavcodec -lswresample -lswscale -lavutil -ldl -lasound -lSDL -lm -pthread -lbz2
Smallpt Global Illumination Renderer; 100 Samples OpenBenchmarking.org Seconds, Fewer Is Better Smallpt 1.0 Global Illumination Renderer; 100 Samples GCC 4.8.0 GCC 4.7.2 LLVM Clang 3.3 SVN LLVM Clang 3.2 60 120 180 240 300 SE +/- 0.00, N = 3 SE +/- 0.33, N = 3 SE +/- 0.33, N = 3 SE +/- 0.33, N = 3 32 32 285 31 1. (CXX) g++ options: -fopenmp -O3 -march=native
Phoronix Test Suite v10.8.5