<html><head></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; ">Thanks David. Unfortunately many of us cannot use GPL v3 gcc so it's hard for us to investigate this. One question, can you tell if gcc is inlining significantly more than llvm? We have reports that this is one of the issue plaguing eon performance.<div><br></div><div>There are also some relatively well known spec optimizations that we haven't implemented. e.g. <span class="Apple-style-span" style="font-family: monospace; "><a href="http://gcc.gnu.org/wiki/summit2010?action=AttachFile&do=get&target=meissner2.pdf">http://gcc.gnu.org/wiki/summit2010?action=AttachFile&do=get&target=meissner2.pdf</a> Are there more?</span></div><div><div><br></div><div>Evan</div><div><br><div><div>On Nov 13, 2010, at 12:56 PM, Xinliang David Li wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><br><div>Hi, I have looked at the LLVM code generation quality using small test cases and in general it is better than I thought and in some cases better than gcc. However, there are still some gap in SPEC performance. I have not looked at the root cause of those gaps. Anyone who cares about LLVM performance need to take this seriously.</div>
<div><br></div><div>For fair comparison, I used -fno-strict-aliasing in gcc to turn off type based aliasing. I also used -fomit-frame-pointer for clang/llvm because this is not the default.  The base option is -O2.  Measured on 2.4GHz core-2 box.</div>
<div><br></div><div>64bit:</div><div>                                        </div><div><div>                                             llvm                 gcc       gcc vs LLVM</div><div>            164.gzip                1268                1320      4.15%</div>
<div>             175.vpr                1605                1534     -4.42%</div><div>             176.gcc                2203                2315      5.08%</div><div>             181.mcf                1625                1737      6.85%</div>
<div>          186.crafty                2411                2307     -4.30%</div><div>          197.parser                1173                1166     -0.57%</div><div>             252.eon                2245                2464      9.72%</div>
<div>         253.perlbmk                2214                2444     10.37%</div><div>             254.gap                1987                1978     -0.47%</div><div>          255.vortex                2497                2422     -3.00%</div>
<div>           256.bzip2                1585                1740      9.80%</div><div>           300.twolf                2294                2281     -0.58%</div></div><div><br></div><div>As you can see, LLVM beats gcc in vpr, crafty and vortex by about 3%, but falls behind gcc in gzip, gcc, mcf, eon, perfbmk, and bzip2 by a large margin.</div>
<div><br></div><div><br></div><div>32bit:</div><div>                                           llvm                   gcc        gcc vs llvm</div><div><div>            164.gzip                1210                1239      2.44%</div>
<div>             175.vpr                1662                1621     -2.42%</div><div>             181.mcf                2733                3109     13.75%</div><div>          186.crafty                1812                1721     -5.00%</div>
<div>          197.parser                1328                1289     -2.92%</div><div>         253.perlbmk                2086                2580     23.67%</div><div>             254.gap                1968                1912     -2.86%</div>
<div>          255.vortex                1842                1965      6.66%</div><div>           256.bzip2                1440                1553      7.82%</div><div>           300.twolf                2284                2213     -3.08%</div>
</div><div><br></div><div>It beats gcc in vpr, crafty, parser, gap, and twolf by ~3%, but falls behind  gcc in gzip, mcf, perlbmk, vortex, and bzip2. Some of them have very large performance gap.  eon and gcc mis-compile.</div>
<div><br></div><div>Thanks,</div><div><br></div><div>David</div>
_______________________________________________<br>LLVM Developers mailing list<br><a href="mailto:LLVMdev@cs.uiuc.edu">LLVMdev@cs.uiuc.edu</a>         <a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a><br><a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev">http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev</a><br></blockquote></div><br></div></div></body></html>