In a C++ template library (a matrix library with expression templates)
upgrading from g++-4.2 to g++-4.3 results in 3x slower programs.

Compiler versions:
g++-4.2 (GCC) 4.2.1 (Debian 4.2.1-5)
g++-4.3 (Debian 4.3-20070902-1) 4.3.0 20070902 (experimental) [trunk revision
128028]

$ g++-4.2 -O3 -DNDEBUG benchmark.cpp -o benchmark && time ./benchmark
1.0001 0 0
0 1.0001 0
0 0 1.0001

real    0m4.495s
user    0m4.416s
sys     0m0.003s

$ g++-4.3 -O3 -DNDEBUG benchmark.cpp -o benchmark && time ./benchmark
1.0001 0 0
0 1.0001 0
0 0 1.0001

real    0m15.891s
user    0m15.595s
sys     0m0.018s

I looked at the assembler code but I didn't see anything obvious (I don't
know much about assembler so I may have missed something.
I did notice that adding -fforce-addr changes the result for 4.3 but not
for 4.2.

$ g++-4.3 -O3 -DNDEBUG benchmark.cpp -fforce-addr -o benchmark && time
./benchmark
1.0001 0 0
0 1.0001 0
0 0 1.0001

real    0m8.779s
user    0m8.662s
sys     0m0.007s


-- 
           Summary: significantly slower results with 4.3 compared to 4.2
           Product: gcc
           Version: 4.3.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: c++
        AssignedTo: unassigned at gcc dot gnu dot org
        ReportedBy: michael dot olbrich at gmx dot net
 GCC build triplet: i486-linux-gnu
  GCC host triplet: i486-linux-gnu
GCC target triplet: i486-linux-gnu


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=33604

Reply via email to