<div dir="ltr">BTW<div><br></div><div>This (or <a href="http://llvm.org/viewvc/llvm-project?revision=289413&view=revision" class="cremed">http://llvm.org/viewvc/llvm-project?revision=289413&view=revision</a> - can't tell for sure don't have windows) has also broken sanitizer-windows bot:</div><div><br></div><div><a href="http://lab.llvm.org:8011/builders/sanitizer-windows/builds/2786">http://lab.llvm.org:8011/builders/sanitizer-windows/builds/2786</a><br></div><div><br></div><div><div>FAILED: projects/compiler-rt/lib/sanitizer_common/tests/sanitizer_stacktrace_test.cc.i386.o </div><div>cmd.exe /C "cd /D C:\b\slave\sanitizer-windows\build\projects\compiler-rt\lib\sanitizer_common\tests && C:\b\slave\sanitizer-windows\build\.\bin\clang.exe -DWIN32 -D_WINDOWS -Wno-unknown-warning-option -fms-compatibility-version=19.00.24215.1 -D_HAS_EXCEPTIONS=0 -Wno-undefined-inline -DGTEST_NO_LLVM_RAW_OSTREAM=1 -DGTEST_HAS_RTTI=0 -IC:/b/slave/sanitizer-windows/llvm/utils/unittest/googletest/include -IC:/b/slave/sanitizer-windows/llvm/utils/unittest/googletest -DGTEST_HAS_SEH=0 -Wno-deprecated-declarations -IC:/b/slave/sanitizer-windows/llvm/projects/compiler-rt/include -IC:/b/slave/sanitizer-windows/llvm/projects/compiler-rt/lib -IC:/b/slave/sanitizer-windows/llvm/projects/compiler-rt/lib/sanitizer_common -fno-rtti -O2 -Werror=sign-compare -Wno-non-virtual-dtor -fno-exceptions -DGTEST_HAS_SEH=0 -gline-tables-only -gcodeview -c -o sanitizer_stacktrace_test.cc.i386.o C:/b/slave/sanitizer-windows/llvm/projects/compiler-rt/lib/sanitizer_common/tests/sanitizer_stacktrace_test.cc"</div><div>Assertion failed: (PtrWord & ~PointerBitMask) == 0 && "Pointer is not sufficiently aligned", file C:\b\slave\sanitizer-windows\llvm\include\llvm/ADT/PointerIntPair.h, line 160</div><div><br></div><div>Wrote crash dump file "C:\Users\buildbot\AppData\Local\Temp\clang.exe-692761.dmp"</div><div><br></div><div>#0 0x01f8dd87 (C:\b\slave\sanitizer-windows\build\bin\clang.exe+0xd4dd87)</div><div><br></div><div>#1 0x70a64672 (C:\windows\SYSTEM32\ucrtbase.DLL+0x84672)</div><div><br></div><div>#2 0x70a65cab (C:\windows\SYSTEM32\ucrtbase.DLL+0x85cab)</div><div><br></div><div>#3 0x70a650e8 (C:\windows\SYSTEM32\ucrtbase.DLL+0x850e8)</div><div><br></div><div>#4 0x70a65da6 (C:\windows\SYSTEM32\ucrtbase.DLL+0x85da6)</div><div><br></div><div>#5 0x02ff860d (C:\b\slave\sanitizer-windows\build\bin\clang.exe+0x1db860d)</div><div><br></div><div>clang.exe: error: clang frontend command failed due to signal (use -v to see invocation)</div><div><br></div><div>clang version 4.0.0 (trunk 289413)</div><div><br></div><div>Target: i686-pc-windows-msvc</div><div><br></div><div>Thread model: posix</div><div><br></div><div>InstalledDir: C:\b\slave\sanitizer-windows\build\bin</div><div><br></div><div>clang.exe: note: diagnostic msg: PLEASE submit a bug report to <a href="http://llvm.org/bugs/">http://llvm.org/bugs/</a> and include the crash backtrace, preprocessed source, and associated run script.</div><div><br></div><div>clang.exe: note: diagnostic msg: </div><div><br></div><div>********************</div><div><br></div></div></div><br><div class="gmail_quote"><div dir="ltr">On Mon, Dec 12, 2016 at 3:34 PM Reid Kleckner via llvm-commits <<a href="mailto:llvm-commits@lists.llvm.org">llvm-commits@lists.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr" class="gmail_msg">Reverted in r<span style="color:rgb(0,0,0)" class="gmail_msg">289453. This is still reducing, but here's a link to the partially reduced source if you want to take a look at it:</span><div class="gmail_msg"><font color="#000000" class="gmail_msg"><a href="https://drive.google.com/open?id=0B5-KodWdXF4YbHQ5RlJiaEQ2REE" class="gmail_msg" target="_blank">https://drive.google.com/open?id=0B5-KodWdXF4YbHQ5RlJiaEQ2REE</a></font><br class="gmail_msg"></div><div class="gmail_msg"><font color="#000000" class="gmail_msg"><br class="gmail_msg"></font></div><div class="gmail_msg"><font color="#000000" class="gmail_msg">Compile with 'clang -c -fsanitize=address -O2 -std=c++11 -fno-exceptions test.cpp'</font></div></div><div class="gmail_extra gmail_msg"><br class="gmail_msg"><div class="gmail_quote gmail_msg">On Mon, Dec 12, 2016 at 10:53 AM, Sanjoy Das <span dir="ltr" class="gmail_msg"><<a href="mailto:sanjoy@playingwithpointers.com" class="gmail_msg" target="_blank">sanjoy@playingwithpointers.com</a>></span> wrote:<br class="gmail_msg"><blockquote class="gmail_quote gmail_msg" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">You may also need to revert rL289435 to avoid merge conflicts.<br class="gmail_msg">
<br class="gmail_msg">
Sent from a mobile device, please excuse typos.<br class="gmail_msg">
<br class="gmail_msg">
On Dec 12, 2016 10:34, "Reid Kleckner via llvm-commits"<br class="gmail_msg">
<div class="m_-5508012771008760051HOEnZb gmail_msg"><div class="m_-5508012771008760051h5 gmail_msg"><<a href="mailto:llvm-commits@lists.llvm.org" class="gmail_msg" target="_blank">llvm-commits@lists.llvm.org</a>> wrote:<br class="gmail_msg">
<br class="gmail_msg">
Heads up, this caused a crash in instcombine during an ASan self-host<br class="gmail_msg">
in X86ISelLowering.cpp. I should be able to get a reduction soon, but<br class="gmail_msg">
I'll probably end up reverting this soon.<br class="gmail_msg">
<br class="gmail_msg">
On Sun, Dec 11, 2016 at 6:52 PM, Sebastian Pop via llvm-commits<br class="gmail_msg">
<<a href="mailto:llvm-commits@lists.llvm.org" class="gmail_msg" target="_blank">llvm-commits@lists.llvm.org</a>> wrote:<br class="gmail_msg">
><br class="gmail_msg">
> Author: spop<br class="gmail_msg">
> Date: Sun Dec 11 20:52:51 2016<br class="gmail_msg">
> New Revision: 289412<br class="gmail_msg">
><br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project?rev=289412&view=rev" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project?rev=289412&view=rev</a><br class="gmail_msg">
> Log:<br class="gmail_msg">
> [SCEVExpand] do not hoist divisions by zero (PR30935)<br class="gmail_msg">
><br class="gmail_msg">
> SCEVExpand computes the insertion point for the components of a SCEV to be code<br class="gmail_msg">
> generated. When it comes to generating code for a division, SCEVexpand would<br class="gmail_msg">
> not be able to check (at compilation time) all the conditions necessary to avoid<br class="gmail_msg">
> a division by zero. The patch disables hoisting of expressions containing<br class="gmail_msg">
> divisions by anything other than non-zero constants in order to avoid hoisting<br class="gmail_msg">
> these expressions past conditions that should hold before doing the division.<br class="gmail_msg">
><br class="gmail_msg">
> The patch passes check-all on x86_64-linux.<br class="gmail_msg">
><br class="gmail_msg">
> Differential Revision: <a href="https://reviews.llvm.org/D27216" rel="noreferrer" class="gmail_msg" target="_blank">https://reviews.llvm.org/D27216</a><br class="gmail_msg">
><br class="gmail_msg">
> Added:<br class="gmail_msg">
> llvm/trunk/test/Transforms/LoopIdiom/pr30935.ll<br class="gmail_msg">
> Modified:<br class="gmail_msg">
> llvm/trunk/lib/Analysis/ScalarEvolution.cpp<br class="gmail_msg">
> llvm/trunk/lib/Analysis/ScalarEvolutionExpander.cpp<br class="gmail_msg">
> llvm/trunk/unittests/Analysis/ScalarEvolutionTest.cpp<br class="gmail_msg">
><br class="gmail_msg">
> Modified: llvm/trunk/lib/Analysis/ScalarEvolution.cpp<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Analysis/ScalarEvolution.cpp?rev=289412&r1=289411&r2=289412&view=diff" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Analysis/ScalarEvolution.cpp?rev=289412&r1=289411&r2=289412&view=diff</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- llvm/trunk/lib/Analysis/ScalarEvolution.cpp (original)<br class="gmail_msg">
> +++ llvm/trunk/lib/Analysis/ScalarEvolution.cpp Sun Dec 11 20:52:51 2016<br class="gmail_msg">
> @@ -2130,7 +2130,7 @@ const SCEV *ScalarEvolution::getAddExpr(<br class="gmail_msg">
> }<br class="gmail_msg">
><br class="gmail_msg">
> // Okay, check to see if the same value occurs in the operand list more than<br class="gmail_msg">
> - // once. If so, merge them together into an multiply expression. Since we<br class="gmail_msg">
> + // once. If so, merge them together into a multiply expression. Since we<br class="gmail_msg">
> // sorted the list, these values are required to be adjacent.<br class="gmail_msg">
> Type *Ty = Ops[0]->getType();<br class="gmail_msg">
> bool FoundMatch = false;<br class="gmail_msg">
><br class="gmail_msg">
> Modified: llvm/trunk/lib/Analysis/ScalarEvolutionExpander.cpp<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Analysis/ScalarEvolutionExpander.cpp?rev=289412&r1=289411&r2=289412&view=diff" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Analysis/ScalarEvolutionExpander.cpp?rev=289412&r1=289411&r2=289412&view=diff</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- llvm/trunk/lib/Analysis/ScalarEvolutionExpander.cpp (original)<br class="gmail_msg">
> +++ llvm/trunk/lib/Analysis/ScalarEvolutionExpander.cpp Sun Dec 11 20:52:51 2016<br class="gmail_msg">
> @@ -166,6 +166,16 @@ Value *SCEVExpander::InsertNoopCastOfTo(<br class="gmail_msg">
> return ReuseOrCreateCast(I, Ty, Op, IP);<br class="gmail_msg">
> }<br class="gmail_msg">
><br class="gmail_msg">
> +// Return true when S may contain the value zero.<br class="gmail_msg">
> +static bool mayBeValueZero(Value *V) {<br class="gmail_msg">
> + if (ConstantInt *C = dyn_cast<ConstantInt>(V))<br class="gmail_msg">
> + if (!C->isZero())<br class="gmail_msg">
> + return false;<br class="gmail_msg">
> +<br class="gmail_msg">
> + // All other expressions may have a zero value.<br class="gmail_msg">
> + return true;<br class="gmail_msg">
> +}<br class="gmail_msg">
> +<br class="gmail_msg">
> /// InsertBinop - Insert the specified binary operator, doing a small amount<br class="gmail_msg">
> /// of work to avoid inserting an obviously redundant operation.<br class="gmail_msg">
> Value *SCEVExpander::InsertBinop(Instruction::BinaryOps Opcode,<br class="gmail_msg">
> @@ -198,14 +208,17 @@ Value *SCEVExpander::InsertBinop(Instruc<br class="gmail_msg">
> DebugLoc Loc = Builder.GetInsertPoint()->getDebugLoc();<br class="gmail_msg">
> SCEVInsertPointGuard Guard(Builder, this);<br class="gmail_msg">
><br class="gmail_msg">
> - // Move the insertion point out of as many loops as we can.<br class="gmail_msg">
> - while (const Loop *L = SE.LI.getLoopFor(Builder.GetInsertBlock())) {<br class="gmail_msg">
> - if (!L->isLoopInvariant(LHS) || !L->isLoopInvariant(RHS)) break;<br class="gmail_msg">
> - BasicBlock *Preheader = L->getLoopPreheader();<br class="gmail_msg">
> - if (!Preheader) break;<br class="gmail_msg">
> + // Only move the insertion point up when it is not a division by zero.<br class="gmail_msg">
> + if (Opcode != Instruction::UDiv || !mayBeValueZero(RHS)) {<br class="gmail_msg">
> + // Move the insertion point out of as many loops as we can.<br class="gmail_msg">
> + while (const Loop *L = SE.LI.getLoopFor(Builder.GetInsertBlock())) {<br class="gmail_msg">
> + if (!L->isLoopInvariant(LHS) || !L->isLoopInvariant(RHS)) break;<br class="gmail_msg">
> + BasicBlock *Preheader = L->getLoopPreheader();<br class="gmail_msg">
> + if (!Preheader) break;<br class="gmail_msg">
><br class="gmail_msg">
> - // Ok, move up a level.<br class="gmail_msg">
> - Builder.SetInsertPoint(Preheader->getTerminator());<br class="gmail_msg">
> + // Ok, move up a level.<br class="gmail_msg">
> + Builder.SetInsertPoint(Preheader->getTerminator());<br class="gmail_msg">
> + }<br class="gmail_msg">
> }<br class="gmail_msg">
><br class="gmail_msg">
> // If we haven't found this binop, insert it.<br class="gmail_msg">
> @@ -1666,31 +1679,46 @@ Value *SCEVExpander::expand(const SCEV *<br class="gmail_msg">
> // Compute an insertion point for this SCEV object. Hoist the instructions<br class="gmail_msg">
> // as far out in the loop nest as possible.<br class="gmail_msg">
> Instruction *InsertPt = &*Builder.GetInsertPoint();<br class="gmail_msg">
> - for (Loop *L = SE.LI.getLoopFor(Builder.GetInsertBlock());;<br class="gmail_msg">
> - L = L->getParentLoop())<br class="gmail_msg">
> - if (SE.isLoopInvariant(S, L)) {<br class="gmail_msg">
> - if (!L) break;<br class="gmail_msg">
> - if (BasicBlock *Preheader = L->getLoopPreheader())<br class="gmail_msg">
> - InsertPt = Preheader->getTerminator();<br class="gmail_msg">
> - else {<br class="gmail_msg">
> - // LSR sets the insertion point for AddRec start/step values to the<br class="gmail_msg">
> - // block start to simplify value reuse, even though it's an invalid<br class="gmail_msg">
> - // position. SCEVExpander must correct for this in all cases.<br class="gmail_msg">
> - InsertPt = &*L->getHeader()->getFirstInsertionPt();<br class="gmail_msg">
> + bool SafeToHoist = !SCEVExprContains(S, [](const SCEV *S) {<br class="gmail_msg">
> + if (const auto *D = dyn_cast<SCEVUDivExpr>(S)) {<br class="gmail_msg">
> + if (const auto *SC = dyn_cast<SCEVConstant>(D->getRHS()))<br class="gmail_msg">
> + // Division by non-zero constants can be hoisted.<br class="gmail_msg">
> + return SC->getValue()->isZero();<br class="gmail_msg">
> +<br class="gmail_msg">
> + // All other divisions should not be moved as they may be divisions by<br class="gmail_msg">
> + // zero and should be kept within the conditions of the surrounding<br class="gmail_msg">
> + // loops that guard their execution (see PR30935.)<br class="gmail_msg">
> + return true;<br class="gmail_msg">
> }<br class="gmail_msg">
> - } else {<br class="gmail_msg">
> - // If the SCEV is computable at this level, insert it into the header<br class="gmail_msg">
> - // after the PHIs (and after any other instructions that we've inserted<br class="gmail_msg">
> - // there) so that it is guaranteed to dominate any user inside the loop.<br class="gmail_msg">
> - if (L && SE.hasComputableLoopEvolution(S, L) && !PostIncLoops.count(L))<br class="gmail_msg">
> - InsertPt = &*L->getHeader()->getFirstInsertionPt();<br class="gmail_msg">
> - while (InsertPt->getIterator() != Builder.GetInsertPoint() &&<br class="gmail_msg">
> - (isInsertedInstruction(InsertPt) ||<br class="gmail_msg">
> - isa<DbgInfoIntrinsic>(InsertPt))) {<br class="gmail_msg">
> - InsertPt = &*std::next(InsertPt->getIterator());<br class="gmail_msg">
> + return false;<br class="gmail_msg">
> + });<br class="gmail_msg">
> + if (SafeToHoist) {<br class="gmail_msg">
> + for (Loop *L = SE.LI.getLoopFor(Builder.GetInsertBlock());;<br class="gmail_msg">
> + L = L->getParentLoop())<br class="gmail_msg">
> + if (SE.isLoopInvariant(S, L)) {<br class="gmail_msg">
> + if (!L) break;<br class="gmail_msg">
> + if (BasicBlock *Preheader = L->getLoopPreheader())<br class="gmail_msg">
> + InsertPt = Preheader->getTerminator();<br class="gmail_msg">
> + else {<br class="gmail_msg">
> + // LSR sets the insertion point for AddRec start/step values to the<br class="gmail_msg">
> + // block start to simplify value reuse, even though it's an invalid<br class="gmail_msg">
> + // position. SCEVExpander must correct for this in all cases.<br class="gmail_msg">
> + InsertPt = &*L->getHeader()->getFirstInsertionPt();<br class="gmail_msg">
> + }<br class="gmail_msg">
> + } else {<br class="gmail_msg">
> + // If the SCEV is computable at this level, insert it into the header<br class="gmail_msg">
> + // after the PHIs (and after any other instructions that we've inserted<br class="gmail_msg">
> + // there) so that it is guaranteed to dominate any user inside the loop.<br class="gmail_msg">
> + if (L && SE.hasComputableLoopEvolution(S, L) && !PostIncLoops.count(L))<br class="gmail_msg">
> + InsertPt = &*L->getHeader()->getFirstInsertionPt();<br class="gmail_msg">
> + while (InsertPt->getIterator() != Builder.GetInsertPoint() &&<br class="gmail_msg">
> + (isInsertedInstruction(InsertPt) ||<br class="gmail_msg">
> + isa<DbgInfoIntrinsic>(InsertPt))) {<br class="gmail_msg">
> + InsertPt = &*std::next(InsertPt->getIterator());<br class="gmail_msg">
> + }<br class="gmail_msg">
> + break;<br class="gmail_msg">
> }<br class="gmail_msg">
> - break;<br class="gmail_msg">
> - }<br class="gmail_msg">
> + }<br class="gmail_msg">
><br class="gmail_msg">
> // Check to see if we already expanded this here.<br class="gmail_msg">
> auto I = InsertedExpressions.find(std::make_pair(S, InsertPt));<br class="gmail_msg">
><br class="gmail_msg">
> Added: llvm/trunk/test/Transforms/LoopIdiom/pr30935.ll<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/LoopIdiom/pr30935.ll?rev=289412&view=auto" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/LoopIdiom/pr30935.ll?rev=289412&view=auto</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- llvm/trunk/test/Transforms/LoopIdiom/pr30935.ll (added)<br class="gmail_msg">
> +++ llvm/trunk/test/Transforms/LoopIdiom/pr30935.ll Sun Dec 11 20:52:51 2016<br class="gmail_msg">
> @@ -0,0 +1,94 @@<br class="gmail_msg">
> +; RUN: opt -loop-idiom -S < %s | FileCheck %s<br class="gmail_msg">
> +<br class="gmail_msg">
> +; CHECK-LABEL: define i32 @main(<br class="gmail_msg">
> +; CHECK: udiv<br class="gmail_msg">
> +; CHECK-NOT: udiv<br class="gmail_msg">
> +; CHECK: call void @llvm.memset.p0i8.i64<br class="gmail_msg">
> +<br class="gmail_msg">
> +@a = common local_unnamed_addr global [4 x i8] zeroinitializer, align 1<br class="gmail_msg">
> +@b = common local_unnamed_addr global i32 0, align 4<br class="gmail_msg">
> +@c = common local_unnamed_addr global i32 0, align 4<br class="gmail_msg">
> +@d = common local_unnamed_addr global i32 0, align 4<br class="gmail_msg">
> +@e = common local_unnamed_addr global i32 0, align 4<br class="gmail_msg">
> +@f = common local_unnamed_addr global i32 0, align 4<br class="gmail_msg">
> +@g = common local_unnamed_addr global i32 0, align 4<br class="gmail_msg">
> +@h = common local_unnamed_addr global i64 0, align 8<br class="gmail_msg">
> +<br class="gmail_msg">
> +<br class="gmail_msg">
> +define i32 @main() local_unnamed_addr #0 {<br class="gmail_msg">
> +entry:<br class="gmail_msg">
> + %0 = load i32, i32* @e, align 4<br class="gmail_msg">
> + %tobool19 = icmp eq i32 %0, 0<br class="gmail_msg">
> + %1 = load i32, i32* @c, align 4<br class="gmail_msg">
> + %cmp10 = icmp eq i32 %1, 0<br class="gmail_msg">
> + %2 = load i32, i32* @g, align 4<br class="gmail_msg">
> + %3 = load i32, i32* @b, align 4<br class="gmail_msg">
> + %tobool = icmp eq i32 %0, 0<br class="gmail_msg">
> + br label %for.cond<br class="gmail_msg">
> +<br class="gmail_msg">
> +for.cond.loopexit: ; preds = %for.inc14<br class="gmail_msg">
> + br label %for.cond.backedge<br class="gmail_msg">
> +<br class="gmail_msg">
> +for.cond: ; preds = %for.cond.backedge, %entry<br class="gmail_msg">
> + %.pr = load i32, i32* @f, align 4<br class="gmail_msg">
> + %cmp20 = icmp eq i32 %.pr, 0<br class="gmail_msg">
> + br i1 %cmp20, label %for.cond2.preheader.preheader, label %for.cond.backedge<br class="gmail_msg">
> +<br class="gmail_msg">
> +for.cond.backedge: ; preds = %for.cond, %for.cond.loopexit<br class="gmail_msg">
> + br label %for.cond<br class="gmail_msg">
> +<br class="gmail_msg">
> +for.cond2.preheader.preheader: ; preds = %for.cond<br class="gmail_msg">
> + br label %for.cond2.preheader<br class="gmail_msg">
> +<br class="gmail_msg">
> +for.cond2.preheader: ; preds = %for.cond2.preheader.preheader, %for.inc14<br class="gmail_msg">
> + br i1 %tobool19, label %for.cond9, label %<a href="http://for.body3.lr.ph" rel="noreferrer" class="gmail_msg" target="_blank">for.body3.lr.ph</a><br class="gmail_msg">
> +<br class="gmail_msg">
> +<a href="http://for.body3.lr.ph" rel="noreferrer" class="gmail_msg" target="_blank">for.body3.lr.ph</a>: ; preds = %for.cond2.preheader<br class="gmail_msg">
> + %div = udiv i32 %2, %3<br class="gmail_msg">
> + %conv = zext i32 %div to i64<br class="gmail_msg">
> + br label %for.body3<br class="gmail_msg">
> +<br class="gmail_msg">
> +for.cond4.for.cond2.loopexit_crit_edge: ; preds = %for.body6<br class="gmail_msg">
> + store i32 0, i32* @d, align 4<br class="gmail_msg">
> + br label %for.cond2.loopexit<br class="gmail_msg">
> +<br class="gmail_msg">
> +for.cond2.loopexit: ; preds = %for.cond4.for.cond2.loopexit_crit_edge, %for.body3<br class="gmail_msg">
> + br i1 %tobool, label %for.cond2.for.cond9_crit_edge, label %for.body3<br class="gmail_msg">
> +<br class="gmail_msg">
> +for.body3: ; preds = %<a href="http://for.body3.lr.ph" rel="noreferrer" class="gmail_msg" target="_blank">for.body3.lr.ph</a>, %for.cond2.loopexit<br class="gmail_msg">
> + %.pr17 = load i32, i32* @d, align 4<br class="gmail_msg">
> + %tobool518 = icmp eq i32 %.pr17, 0<br class="gmail_msg">
> + br i1 %tobool518, label %for.cond2.loopexit, label %for.body6.preheader<br class="gmail_msg">
> +<br class="gmail_msg">
> +for.body6.preheader: ; preds = %for.body3<br class="gmail_msg">
> + %4 = zext i32 %.pr17 to i64<br class="gmail_msg">
> + br label %for.body6<br class="gmail_msg">
> +<br class="gmail_msg">
> +for.body6: ; preds = %for.body6.preheader, %for.body6<br class="gmail_msg">
> + %indvars.iv = phi i64 [ %4, %for.body6.preheader ], [ %indvars.iv.next, %for.body6 ]<br class="gmail_msg">
> + %add = add nuw nsw i64 %conv, %indvars.iv<br class="gmail_msg">
> + %arrayidx = getelementptr inbounds [4 x i8], [4 x i8]* @a, i64 0, i64 %add<br class="gmail_msg">
> + store i8 1, i8* %arrayidx, align 1<br class="gmail_msg">
> + %5 = trunc i64 %indvars.iv to i32<br class="gmail_msg">
> + %inc = add i32 %5, 1<br class="gmail_msg">
> + %tobool5 = icmp eq i32 %inc, 0<br class="gmail_msg">
> + %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1<br class="gmail_msg">
> + br i1 %tobool5, label %for.cond4.for.cond2.loopexit_crit_edge, label %for.body6<br class="gmail_msg">
> +<br class="gmail_msg">
> +for.cond2.for.cond9_crit_edge: ; preds = %for.cond2.loopexit<br class="gmail_msg">
> + store i64 %conv, i64* @h, align 8<br class="gmail_msg">
> + br label %for.cond9<br class="gmail_msg">
> +<br class="gmail_msg">
> +for.cond9: ; preds = %for.cond2.for.cond9_crit_edge, %for.cond2.preheader<br class="gmail_msg">
> + br i1 %cmp10, label %for.body12, label %for.inc14<br class="gmail_msg">
> +<br class="gmail_msg">
> +for.body12: ; preds = %for.cond9<br class="gmail_msg">
> + ret i32 0<br class="gmail_msg">
> +<br class="gmail_msg">
> +for.inc14: ; preds = %for.cond9<br class="gmail_msg">
> + %6 = load i32, i32* @f, align 4<br class="gmail_msg">
> + %inc15 = add i32 %6, 1<br class="gmail_msg">
> + store i32 %inc15, i32* @f, align 4<br class="gmail_msg">
> + %cmp = icmp eq i32 %inc15, 0<br class="gmail_msg">
> + br i1 %cmp, label %for.cond2.preheader, label %for.cond.loopexit<br class="gmail_msg">
> +}<br class="gmail_msg">
><br class="gmail_msg">
> Modified: llvm/trunk/unittests/Analysis/ScalarEvolutionTest.cpp<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/unittests/Analysis/ScalarEvolutionTest.cpp?rev=289412&r1=289411&r2=289412&view=diff" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/unittests/Analysis/ScalarEvolutionTest.cpp?rev=289412&r1=289411&r2=289412&view=diff</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- llvm/trunk/unittests/Analysis/ScalarEvolutionTest.cpp (original)<br class="gmail_msg">
> +++ llvm/trunk/unittests/Analysis/ScalarEvolutionTest.cpp Sun Dec 11 20:52:51 2016<br class="gmail_msg">
> @@ -349,6 +349,13 @@ static Instruction *getInstructionByName<br class="gmail_msg">
> llvm_unreachable("Expected to find instruction!");<br class="gmail_msg">
> }<br class="gmail_msg">
><br class="gmail_msg">
> +static Argument *getArgByName(Function &F, StringRef Name) {<br class="gmail_msg">
> + for (auto &A : F.args())<br class="gmail_msg">
> + if (A.getName() == Name)<br class="gmail_msg">
> + return &A;<br class="gmail_msg">
> + llvm_unreachable("Expected to find argument!");<br class="gmail_msg">
> +}<br class="gmail_msg">
> +<br class="gmail_msg">
> TEST_F(ScalarEvolutionsTest, CommutativeExprOperandOrder) {<br class="gmail_msg">
> LLVMContext C;<br class="gmail_msg">
> SMDiagnostic Err;<br class="gmail_msg">
> @@ -532,5 +539,74 @@ TEST_F(ScalarEvolutionsTest, SCEVCompare<br class="gmail_msg">
> EXPECT_NE(nullptr, SE.getSCEV(Acc[0]));<br class="gmail_msg">
> }<br class="gmail_msg">
><br class="gmail_msg">
> +TEST_F(ScalarEvolutionsTest, BadHoistingSCEVExpander_PR30942) {<br class="gmail_msg">
> + LLVMContext C;<br class="gmail_msg">
> + SMDiagnostic Err;<br class="gmail_msg">
> + std::unique_ptr<Module> M = parseAssemblyString(<br class="gmail_msg">
> + "target datalayout = \"e-m:e-p:32:32-f64:32:64-f80:32-n8:16:32-S128\" "<br class="gmail_msg">
> + " "<br class="gmail_msg">
> + "define void @f_1(i32 %x, i32 %y, i32 %n, i1* %cond_buf) "<br class="gmail_msg">
> + " local_unnamed_addr { "<br class="gmail_msg">
> + "entry: "<br class="gmail_msg">
> + " %entrycond = icmp sgt i32 %n, 0 "<br class="gmail_msg">
> + " br i1 %entrycond, label %<a href="http://loop.ph" rel="noreferrer" class="gmail_msg" target="_blank">loop.ph</a>, label %for.end "<br class="gmail_msg">
> + " "<br class="gmail_msg">
> + "<a href="http://loop.ph" rel="noreferrer" class="gmail_msg" target="_blank">loop.ph</a>: "<br class="gmail_msg">
> + " br label %loop "<br class="gmail_msg">
> + " "<br class="gmail_msg">
> + "loop: "<br class="gmail_msg">
> + " %iv1 = phi i32 [ %iv1.inc, %right ], [ 0, %<a href="http://loop.ph" rel="noreferrer" class="gmail_msg" target="_blank">loop.ph</a> ] "<br class="gmail_msg">
> + " %iv1.inc = add nuw nsw i32 %iv1, 1 "<br class="gmail_msg">
> + " %cond = load volatile i1, i1* %cond_buf "<br class="gmail_msg">
> + " br i1 %cond, label %left, label %right "<br class="gmail_msg">
> + " "<br class="gmail_msg">
> + "left: "<br class="gmail_msg">
> + " %div = udiv i32 %x, %y "<br class="gmail_msg">
> + " br label %right "<br class="gmail_msg">
> + " "<br class="gmail_msg">
> + "right: "<br class="gmail_msg">
> + " %exitcond = icmp eq i32 %iv1.inc, %n "<br class="gmail_msg">
> + " br i1 %exitcond, label %for.end.loopexit, label %loop "<br class="gmail_msg">
> + " "<br class="gmail_msg">
> + "for.end.loopexit: "<br class="gmail_msg">
> + " br label %for.end "<br class="gmail_msg">
> + " "<br class="gmail_msg">
> + "for.end: "<br class="gmail_msg">
> + " ret void "<br class="gmail_msg">
> + "} ",<br class="gmail_msg">
> + Err, C);<br class="gmail_msg">
> +<br class="gmail_msg">
> + assert(M && "Could not parse module?");<br class="gmail_msg">
> + assert(!verifyModule(*M) && "Must have been well formed!");<br class="gmail_msg">
> +<br class="gmail_msg">
> + runWithFunctionAndSE(*M, "f_1", [&](Function &F, ScalarEvolution &SE) {<br class="gmail_msg">
> + SCEVExpander Expander(SE, M->getDataLayout(), "unittests");<br class="gmail_msg">
> + auto *DivInst = getInstructionByName(F, "div");<br class="gmail_msg">
> +<br class="gmail_msg">
> + {<br class="gmail_msg">
> + auto *DivSCEV = SE.getSCEV(DivInst);<br class="gmail_msg">
> + auto *DivExpansion = Expander.expandCodeFor(<br class="gmail_msg">
> + DivSCEV, DivSCEV->getType(), DivInst->getParent()->getTerminator());<br class="gmail_msg">
> + auto *DivExpansionInst = dyn_cast<Instruction>(DivExpansion);<br class="gmail_msg">
> + ASSERT_NE(DivExpansionInst, nullptr);<br class="gmail_msg">
> + EXPECT_EQ(DivInst->getParent(), DivExpansionInst->getParent());<br class="gmail_msg">
> + }<br class="gmail_msg">
> +<br class="gmail_msg">
> + {<br class="gmail_msg">
> + auto *ArgY = getArgByName(F, "y");<br class="gmail_msg">
> + auto *DivFromScratchSCEV =<br class="gmail_msg">
> + SE.getUDivExpr(SE.getOne(ArgY->getType()), SE.getSCEV(ArgY));<br class="gmail_msg">
> +<br class="gmail_msg">
> + auto *DivFromScratchExpansion = Expander.expandCodeFor(<br class="gmail_msg">
> + DivFromScratchSCEV, DivFromScratchSCEV->getType(),<br class="gmail_msg">
> + DivInst->getParent()->getTerminator());<br class="gmail_msg">
> + auto *DivFromScratchExpansionInst =<br class="gmail_msg">
> + dyn_cast<Instruction>(DivFromScratchExpansion);<br class="gmail_msg">
> + ASSERT_NE(DivFromScratchExpansionInst, nullptr);<br class="gmail_msg">
> + EXPECT_EQ(DivInst->getParent(), DivFromScratchExpansionInst->getParent());<br class="gmail_msg">
> + }<br class="gmail_msg">
> + });<br class="gmail_msg">
> +}<br class="gmail_msg">
> +<br class="gmail_msg">
> } // end anonymous namespace<br class="gmail_msg">
> } // end namespace llvm<br class="gmail_msg">
><br class="gmail_msg">
><br class="gmail_msg">
> _______________________________________________<br class="gmail_msg">
> llvm-commits mailing list<br class="gmail_msg">
> <a href="mailto:llvm-commits@lists.llvm.org" class="gmail_msg" target="_blank">llvm-commits@lists.llvm.org</a><br class="gmail_msg">
> <a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits" rel="noreferrer" class="gmail_msg" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits</a><br class="gmail_msg">
<br class="gmail_msg">
<br class="gmail_msg">
<br class="gmail_msg">
_______________________________________________<br class="gmail_msg">
llvm-commits mailing list<br class="gmail_msg">
<a href="mailto:llvm-commits@lists.llvm.org" class="gmail_msg" target="_blank">llvm-commits@lists.llvm.org</a><br class="gmail_msg">
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits" rel="noreferrer" class="gmail_msg" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits</a><br class="gmail_msg">
</div></div></blockquote></div><br class="gmail_msg"></div>
_______________________________________________<br class="gmail_msg">
llvm-commits mailing list<br class="gmail_msg">
<a href="mailto:llvm-commits@lists.llvm.org" class="gmail_msg" target="_blank">llvm-commits@lists.llvm.org</a><br class="gmail_msg">
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits" rel="noreferrer" class="gmail_msg" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits</a><br class="gmail_msg">
</blockquote></div><div dir="ltr">-- <br></div><div data-smartmail="gmail_signature"><div dir="ltr">Mike<br>Sent from phone</div></div>