[llvm-bugs] [Bug 27858] New: mldst-motion miscompile with call to exit()
via llvm-bugs
llvm-bugs at lists.llvm.org
Tue May 24 12:07:37 PDT 2016
https://llvm.org/bugs/show_bug.cgi?id=27858
Bug ID: 27858
Summary: mldst-motion miscompile with call to exit()
Product: libraries
Version: trunk
Hardware: PC
OS: Windows NT
Status: NEW
Severity: normal
Priority: P
Component: Scalar Optimizations
Assignee: unassignedbugs at nondot.org
Reporter: eli.friedman at gmail.com
CC: llvm-bugs at lists.llvm.org
Classification: Unclassified
Testcase:
#include <stdlib.h>
void f() { exit(1); }
void (*ff)() = f;
int r, s;
void g(int a, int*restrict p) {
if (a) {ff(); r = p[1]; }
else { s = p[1]; }
}
void (*gg)(int, int*restrict) = g;
int main() {
gg(1, 0);
}
Works with gcc or clang -O0, crashes with clang -O2.
Testcase:
#include <stdlib.h>
#include <stdio.h>
void f() { throw 1; }
void (*ff)() = f;
void f2() {}
void (*ff2)() = f2;
int r, s;
void g(int a, int*__restrict p) {
if (a) { ff2(); p[1] = 2; ff(); }
else { p[1] = 2; }
}
void (*gg)(int, int*restrict) = g;
int main() {
int a[2] = {0};
try {
gg(1, a);
} catch (...) {}
if (a[1] != 2) abort();
}
Works with gcc or clang -O0, aborts with clang -O2.
I think the problem is
MergedLoadStoreMotion::isLoadHoistBarrierInRange/isStoreSinkBarrierInRange; you
can't use alias analysis to prove that a pointer is valid.
(Artificial testcases.)
--
You are receiving this mail because:
You are on the CC list for the bug.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-bugs/attachments/20160524/e50b79e7/attachment.html>
More information about the llvm-bugs
mailing list