<div dir="ltr">Hi David,<div><br></div><div>Sure I agree in part but "very misleading" is a strong statement and I think we might want to see a different perspective. People present this mental model in conferences [1]</div><div>"If you want to optimize, you use opt, which takes LLVM IR and generates LLVM IR". We could say that this is misleading too, as it seems that opt does the optimization, but is it really?</div><div>This an "Introduction to LLVM", going into specifics at this point would probably confuse people a lot more than it would help them.</div><div><br></div><div>Same here [2]. Chandler was using clang -O2, then he used opt -O2 mentioning it as the "default" pipeline. Wow, that should be super misleading, but again is it really? Would it help</div><div>if Chandler stopped and said "Oh by the way... Let me digress here and explain a thing about libraries and opt etc."</div><div><br></div><div>With the same logic, when I said "target-independent" optimizations, that was misleading too.</div><div><br></div><div>But my message was like, 1 page long already and I think spending another 1 page (or more) to explain such things would not help. And I think this is similar for people in conferences and llvm posts.</div><div><br></div><div>Anyway, it's obvious that your message came with good intentions and I appreciate that. But I think it should be mentioned that for any beginner trying to understand the beast called LLVM,</div><div>it's not super important to know it now, at least IMHO. But it's good to be mentioned that it's not the grand truth so that they come back to it when they're more comfortable with the "approximation".</div><div><br></div><div>Best,</div><div>Stefanos</div><div><br></div><div>[1] <a href="https://youtu.be/J5xExRGaIIY?t=429">https://youtu.be/J5xExRGaIIY?t=429</a></div><div>[2] <a href="https://youtu.be/s4wnuiCwTGU?t=433">https://youtu.be/s4wnuiCwTGU?t=433</a></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">Στις Τρί, 26 Ιαν 2021 στις 11:47 π.μ., ο/η David Chisnall via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a>> έγραψε:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">On 26/01/2021 02:53, Stefanos Baziotis via llvm-dev wrote:<br>
> Alright, now to use that: This is _not_ an option of Clang (or the Clang <br>
> driver; i.e., the command: clang test.c -print-after-all won't work), <br>
> but an option of opt. opt, in case you're not familiar with it, is <br>
> basically the middle-end optimizer of LLVM<br>
<br>
I think this is sufficiently close to being true that it ends up being <br>
very misleading.  I've seen a lot of posts on the mailing lists from <br>
people who have a mental model of LLVM like this.<br>
<br>
The opt tool is a thin wrapper around the LLVM pass pipeline <br>
infrastructure.  Most of the command-line flags for opt are not specific <br>
to opt, they are exposed by LLVM libraries.  Opt passes all of its <br>
arguments to LLVM, clang passes only the ones prefixed with -mllvm, but <br>
they are both handled by the same logic.<br>
<br>
Opt has some default pipelines with names such as -O1 and -O3 but these <br>
are *not* the same as the pipelines of the same names in clang (or other <br>
compilers that use LLVM).  This is a common source of confusion from <br>
people wondering why clang and opt give different output at -O2 (for <br>
example).<br>
<br>
The opt tool is primarily intended for unit testing.  It is a convenient <br>
way of running a single pass or sequence of passes (which is also useful <br>
for producing reduced test cases when a long pass pipeline generates a <br>
miscompile).  Almost none of the logic, including most of the <br>
command-line handling, is actually present in opt.<br>
<br>
David<br>
<br>
_______________________________________________<br>
LLVM Developers mailing list<br>
<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a><br>
<a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br>
</blockquote></div>