<br><br><div class="gmail_quote">On Sat, Oct 30, 2010 at 9:49 AM, Chris Lattner <span dir="ltr"><<a href="mailto:clattner@apple.com">clattner@apple.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
<div style="word-wrap:break-word"><br><div><div class="im"><div>On Oct 29, 2010, at 11:30 PM, Xinliang David Li wrote:</div><br></div><blockquote type="cite"><br><br><div class="gmail_quote"><div class="im">On Fri, Oct 29, 2010 at 11:14 PM, Chris Lattner <span dir="ltr"><<a href="mailto:clattner@apple.com" target="_blank">clattner@apple.com</a>></span> wrote:<br>
</div><div class="im"><blockquote class="gmail_quote" style="margin-top:0px;margin-right:0px;margin-bottom:0px;margin-left:0.8ex;border-left-width:1px;border-left-color:rgb(204, 204, 204);border-left-style:solid;padding-left:1ex">
<div style="word-wrap:break-word"><div><div></div><div>I strongly recommend not using llvmc unless you know exactly what you're doing and what the features and limitations of llvmc are. Please use the clang driver.</div>
</div>
</div></blockquote><div><br></div><div>Is llvmc just a wrapper on top of llvm-gcc and clang? In search of a way to pass down internal llvm options ( I did not know about -m yet), I found that llvmc has -Wo, option (which does not work), that is why I tried it. So many different driver programs makes it little confusing to newbies.</div>
</div></div></blockquote><br></div><div>llvmc is an experimental wrapper, not part of the normal toolchain. I'm not sure why, but it was used by the PIC16 toolchain (when it was in mainline), it allows defining compiler drivers that don't follow the GCC command line syntax.</div>
<div><br></div><div>I completely agree that llvmc is confusing. I would certainly agree with its removal from mainline, but it is actively maintained and presumably there is a reason for that :-)</div><br><div>Lets look at this another way: maybe this is a documentation issue. Did llvmc's existence make you want to use it, or was there some documentation that pushed you in that direction? If it's a doc issue, it is easy to fix.</div>
</div></blockquote><div><br></div><div>Lack of documentation saying llvmc is experimental, it is actually more natural for me to pick llvmc than llvm-gcc or clang as the compiler driver. LLVM is a great brand name, but it seems more a brand name of a new technology, not a product (unlike gcc which is a both a technology and product). llvm-gcc seems a bad name - it is more like gcc-llvm (gcc FE with alternative backend which is llvm backend. Open64 uses gcc FE, but there is no gcc in their product name.). clang is compiler FE, it can be coupled with gcc backend as well, so using 'clang' as the product name does not sound natural. Other questions that may pop up user mind is how is clang and llvm-gcc compare in terms of performance, are they configured with the same set of optimization passes? Without deep investigation, my guess was that 'llvmc' (maybe it should be called lcc, similar to icc, gcc, aCC, occ, etc) is an effort to unify the compiler drivers and saves users some confusion :). </div>
<div><br></div><div>Thanks,</div><div><br></div><div>David</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;"><div style="word-wrap:break-word"><div><br>
</div><div>Thanks!</div><div><br></div><font color="#888888"><div>-Chris</div></font></div></blockquote></div><br>