<html>
<head>
<base href="https://bugs.llvm.org/">
</head>
<body><table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Bug ID</th>
<td><a class="bz_bug_link
bz_status_NEW "
title="NEW - [LV] Miscompile caused due to incorrect index for extracting vector result"
href="https://bugs.llvm.org/show_bug.cgi?id=32396">32396</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>[LV] Miscompile caused due to incorrect index for extracting vector result
</td>
</tr>
<tr>
<th>Product</th>
<td>new-bugs
</td>
</tr>
<tr>
<th>Version</th>
<td>trunk
</td>
</tr>
<tr>
<th>Hardware</th>
<td>PC
</td>
</tr>
<tr>
<th>OS</th>
<td>All
</td>
</tr>
<tr>
<th>Status</th>
<td>NEW
</td>
</tr>
<tr>
<th>Severity</th>
<td>enhancement
</td>
</tr>
<tr>
<th>Priority</th>
<td>P
</td>
</tr>
<tr>
<th>Component</th>
<td>new bugs
</td>
</tr>
<tr>
<th>Assignee</th>
<td>unassignedbugs@nondot.org
</td>
</tr>
<tr>
<th>Reporter</th>
<td>anna@azul.com
</td>
</tr>
<tr>
<th>CC</th>
<td>llvm-bugs@lists.llvm.org
</td>
</tr></table>
<p>
<div>
<pre>Loop vectorizer extracts incorrect result from the vector.
Source code snippet:
int byres = 52, i=1;
for (i1 = 141; i1 < 170; i1++) {
i2 = 193;
while (--i2 > 0) {
byRes = (((i) * i));
i = i1 + i2;
}
}
printf("%d", byRes);
Here byRes should be (169 + 2) ^ 2, i.e. i2 = 2 and i1 = 169
After vectorization of inner loop, byRes becomes (169 + 1) ^ 2, i.e. i2 = 1.
In the vectorized code, I've verified that the incorrect result comes about by
extracting from the incorrect index.
vector.ph: ; preds = %min.iters.checked
%broadcast.splatinsert = insertelement <16 x i32> undef, i32 %local_4_, i32 0
%broadcast.splat = shufflevector <16 x i32> %broadcast.splatinsert, <16 x
i32> undef, <16 x i32> zeroinitializer
...
br label %vector.body
vector.body:
%vec.ind = phi <16 x i32> [ <i32 192, i32 191, i32 190, i32 189, i32 188, i32
187, i32 186, i32 185, i32 184, i32 183, i32 182, i32 181, i32 180, i32 179,
i32 178, i32 177>, %vector.ph ], [ %vec.ind.next, %vector.body ]
....
%16 = add nuw nsw <16 x i32> %vec.ind, %broadcast.splat
%vec.ind.next = add <16 x i32> %vec.ind, <i32 -16, i32 -16, i32 -16, i32 -16,
i32 -16, i32 -16, i32 -16, i32 -16, i32 -16, i32 -16, i32 -16, i32 -16, i32
-16, i32 -16, i32 -16, i32 -16>
%18 = icmp eq i32 %index.next, 192
br i1 %18, label %middle.block, label %vector.body, !llvm.loop !0
middle.block: ; preds = %vector.body
%cmp.n = icmp eq i32 192, 192
%vector.recur.extract = extractelement <16 x i32> %16, i32 15
At index 15 from vector extract, we have i2 + i1 = 170, which is the incorrect
result to extract. The correct result is at index 14 (i2 + i1 = 171).
I'll attach the IR before vectorization and after vectorization.
Reproduce problem:
lli test.ll
29241
opt -loop-vectorize test.ll -S > test_after_vectorize.ll 2>&1
lli test_after_vectorize.ll
28900</pre>
</div>
</p>
<hr>
<span>You are receiving this mail because:</span>
<ul>
<li>You are on the CC list for the bug.</li>
</ul>
</body>
</html>