<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 - Missed optimization: loop-invariant strlen() not hoisted out of loop"
href="https://bugs.llvm.org/show_bug.cgi?id=36135">36135</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>Missed optimization: loop-invariant strlen() not hoisted out of loop
</td>
</tr>
<tr>
<th>Product</th>
<td>compiler-rt
</td>
</tr>
<tr>
<th>Version</th>
<td>5.0
</td>
</tr>
<tr>
<th>Hardware</th>
<td>PC
</td>
</tr>
<tr>
<th>OS</th>
<td>Linux
</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>compiler-rt
</td>
</tr>
<tr>
<th>Assignee</th>
<td>unassignedbugs@nondot.org
</td>
</tr>
<tr>
<th>Reporter</th>
<td>eyalroz@technion.ac.il
</td>
</tr>
<tr>
<th>CC</th>
<td>llvm-bugs@lists.llvm.org
</td>
</tr></table>
<p>
<div>
<pre>Consider the following code:
#include <string.h>
void bar(char c);
void foo(const char* __restrict__ ss)
{
for (int i = 0; i < strlen(ss); ++i)
{
bar(*ss);
}
}
To my understanding, the fact that ss is __restrict__ed, combined with the fact
that it isn't written through (or that it's a const pointer) should be
sufficient to allow the compiler to assume the memory accessible via ss remains
constant, and thus assume that strlen(ss) will return the same value for all
loop iterations.
But - that's not what happens (with clang 5.0):
.LBB0_2: # =>This Inner Loop Header: Depth=1
mov edi, ebp
call bar(char)
inc rbx
mov rdi, r14
call strlen
cmp rax, rbx
ja .LBB0_2
(obtained with <a href="https://godbolt.org/g/vdGSBe">https://godbolt.org/g/vdGSBe</a> )
Now, I'm no compiler expert, so maybe there are considerations I'm ignoring,
but it seems to me the compiler should be able to hoist the heavier code up
above the loop.
Cf. <a href="https://gcc.gnu.org/bugzilla/show_bug.cgi?id=84083">https://gcc.gnu.org/bugzilla/show_bug.cgi?id=84083</a> and
<a href="https://stackoverflow.com/q/48482003/1593077">https://stackoverflow.com/q/48482003/1593077</a></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>