Why Clang

Michel Talon talon at lpthe.jussieu.fr
Tue Jun 19 14:44:16 UTC 2012


David Brodbeck said:
> Another way of looking at it is after 25 years of optimization GCC is
> unable to beat a new compiler that's had almost none...
Unfortunately this affirmation is blatantly false, recent gcc produce code
much faster than clang. I give here an example which i like, a monte carlo computation for a spin lattice.
Everything runs on my macbook.

lilas% clang -v
Apple clang version 2.1 (tags/Apple/clang-163.7.1) (based on LLVM 3.0svn)
Target: x86_64-apple-darwin11.4.0
lilas% clang -O4 test.c -lf2c
lilas% time ./a.out
...

real	0m2.359s
user	0m2.341s
sys	0m0.003s

lilas% /usr/local/bin/gcc -v
…
gcc version 4.6.1 (GCC)

lilas% /usr/local/bin/gcc -O3 test.c -lf2c
lilas% time ./a.out
…

real	0m1.241s
user	0m1.234s
sys	0m0.003s

So gcc gives an executable running twice faster than clang, basically, when both compilers
are run at maximal optimization. To show the effectiveness of the optimizer, here is the running
time without any optimization:

lilas% /usr/local/bin/gcc  test.c -lf2c
lilas% time ./a.out
…

real	0m6.895s
user	0m6.889s
sys	0m0.005s

What this demonstrates is that for programs which do real computations, optimization is
*very* important, and gcc is now very good (i have not shown the numbers but they match the Intel compiler)
while clang is at the level gcc was ten years ago. So i fully agree with Wojciech Puchar, the move to clang
is only driven by anti GPL propaganda which is frankly completely stupid, since in any events, gcc
does not contaminate the binaries it produces (except when using contaminated accompanying libraries
e.g. for C++). Of course, when compiling FreeBSD kernel or similar programs which do little computation
there is no harm using clang. I suspect that the price is higher for programs like mencoder which require
the highest efficiency.

I will not comment on the better error messages coming from clang, this could be a more serious argument.

--

Michel Talon
talon at lpthe.jussieu.fr







More information about the freebsd-questions mailing list