<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
</head>
<body text="#000000" bgcolor="#FFFFFF">
<p><br>
</p>
<pre class="moz-signature" cols="72">-------------
Best regards,
Alexey Bataev</pre>
<div class="moz-cite-prefix">26.06.2019 11:09, Doerfert, Johannes
via llvm-dev пишет:<br>
</div>
<blockquote type="cite"
cite="mid:%3C20190626150953.GC1378@arch-linux-jd%3E">
<div class="moz-text-plain" wrap="true" graphical-quote="true"
style="font-family: -moz-fixed; font-size: 14px;"
lang="x-unicode">
<pre class="moz-quote-pre" wrap="">Hi Rajasekhar,
thanks for reporting this.
On 06/26, Raja Sekhar Bhetala via llvm-dev wrote:
</pre>
<blockquote type="cite" style="color: #000000;">
<pre class="moz-quote-pre" wrap="">The specification on this loop is incorrect as the parallel_accesses
metadata indicate that there is no loop carried memory dependence, which is
not true in this case.
</pre>
</blockquote>
<pre class="moz-quote-pre" wrap="">First, I think the lowering is actually broken if a simdlen is given.
Since we use parallel_accesses metadata it indicates the loop is free of
dependences but #pragma simd simdlen(4) means we are allowed to assume
there are no loop carried dependences of length smaller than 4.
</pre>
<blockquote type="cite" style="color: #000000;">
<pre class="moz-quote-pre" wrap="">Shouldn't the compiler not Vectorize if it can prove that there is a loop
carried dependence and the Vectorizer will generate an incorrect code ?
Or Should it blindly follow the user directive (without a warning) ?
</pre>
</blockquote>
<pre class="moz-quote-pre" wrap="">I'm always on the fence when it comes to these questions. I think we
should blindly follow the directives but offer a flag that globally
turns on warning for such odd situations.</pre>
</div>
</blockquote>
<p>Currently, there could be some problems. Vectorizer has only 3
modes: no vectorization, analysis+vectorization and unconditional
vectorization, as I understand. If we want to add the mode where
we could emit at least warnings for possible incorrect
vectorization, we need a new mode: analysis+unconditional
vectorization.</p>
<p>As an alternative, we can add an option (disabled by default,
because the behavior does not meet the standard) to emit the
OpenMP simd loops in analysis+vectorization (hint) mode.<br>
</p>
<blockquote type="cite"
cite="mid:%3C20190626150953.GC1378@arch-linux-jd%3E">
<div class="moz-text-plain" wrap="true" graphical-quote="true"
style="font-family: -moz-fixed; font-size: 14px;"
lang="x-unicode">
<pre class="moz-quote-pre" wrap="">
</pre>
<blockquote type="cite" style="color: #000000;">
<pre class="moz-quote-pre" wrap="">It is very difficult for the user to identify the real source of the
problem if the compiler vectorizes the loop silently. I agree its hard to
detect incorrect specifications. But for cases, where it is easy to detect
we should atleast dump a warning.
</pre>
</blockquote>
<pre class="moz-quote-pre" wrap="">No default warning, that will clutter the output. On second though,
maybe if the we determine the given information is plain wrong.
Cheers,
Johannes
<div class="moz-txt-sig">--
Johannes Doerfert
Researcher
Argonne National Laboratory
Lemont, IL 60439, USA
<a class="moz-txt-link-abbreviated" href="mailto:jdoerfert@anl.gov" moz-do-not-send="true">jdoerfert@anl.gov</a>
</div></pre>
</div>
</blockquote>
</body>
</html>