<div dir="ltr">Hi Sudakshina,<div><br></div><div>> the loop to be optimized has to be enclosed between #pragma scop and #pragma endoscop</div><div><br></div><div>No it doesn't :) So, ok. There is a way to do loop optimizations, called polyhedral optimization and is based on a mathematical framework.</div><div>Why do I mention this ? Because in polyhedral optimization there is the term SCOP, which is basically parts of the code where polyhedral optimization shines.</div><div>The fact that you mentioned this pragma implies that you're probably trying to do polyhedral optimization. <br></div><div><br></div><div>Now, LLVM has Polly, an infrastructure based on polyhedral optimization. Unfortunately, I'm not familiar with Polly, so if you really want to use it,</div><div>I could CC people who are more familiar with it.</div><div><br></div><div>_However_, you don't _have_ to use Polly to do loop optimizations. In fact, Polly is not enabled by default in LLVM (i.e., when you do -O3, Polly doesn't run)</div><div>Classic loop optimizations implemented in LLVM, like loop-unrolling, loop-invariant code motion and all that are not based on polyhedral optimization.</div><div><br></div><div>So, it depends on what you're trying to do. And what log file are you using... A couple of ways to obtain logs were mentioned, it would</div><div>be good to mention what you're using.</div><div><br></div><div>Best,</div><div>Stefanos</div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">Στις Παρ, 29 Ιαν 2021 στις 2:18 μ.μ., ο/η Sudakshina Dutta <<a href="mailto:sudakshina@iitgoa.ac.in">sudakshina@iitgoa.ac.in</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"><div dir="ltr"><div>Dear Stefanos,</div><div><br></div><div>Thanks for all your reply. I have one simple question to ask. I am new to llvm. I know that the loop to be optimized has to be enclosed between #pragma scop and #pragma endoscop. I have seen the llvm log. It says about the attempted optimizations. My question is does the log specify the loop which is optimized ? More precisely, if there are multiple loops, does the log specify which loop has been optimized ? I request you to kindly answer the above question or give me pointers to the answers.</div><div><br></div><div>Thanks.</div><div>Sudakshina<br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Tue, Jan 26, 2021 at 8:10 PM Stefanos Baziotis via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><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" target="_blank">https://youtu.be/J5xExRGaIIY?t=429</a></div><div>[2] <a href="https://youtu.be/s4wnuiCwTGU?t=433" target="_blank">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" target="_blank">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>
_______________________________________________<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>
</blockquote></div>