[LLVMbugs] [Bug 20188] New: [AArch64] Address Type Promotion - Assertion `use_empty() && "Uses remain when a value is destroyed!"' failed.

bugzilla-daemon at llvm.org bugzilla-daemon at llvm.org
Tue Jul 1 19:55:45 PDT 2014


http://llvm.org/bugs/show_bug.cgi?id=20188

            Bug ID: 20188
           Summary: [AArch64] Address Type Promotion - Assertion
                    `use_empty() && "Uses remain when a value is
                    destroyed!"' failed.
           Product: libraries
           Version: trunk
          Hardware: PC
                OS: All
            Status: ASSIGNED
          Severity: normal
          Priority: P
         Component: Backend: AArch64
          Assignee: dexonsmith at apple.com
          Reporter: mcrosier at codeaurora.org
                CC: apazos at codeaurora.org, llvmbugs at cs.uiuc.edu,
                    t.p.northover at gmail.com, zhaoshiz at codeaurora.org
    Classification: Unclassified

I believe this was introduced in one of these two commits:
http://llvm.org/viewvc/llvm-project?view=revision&revision=212073
http://llvm.org/viewvc/llvm-project?view=revision&revision=212075

Reproduce with:
llc -O3 -mcpu=cortex-a53 -mtriple=aarch64--linux-gnu
bugpoint-reduced-simplified.ll

Testcase:

define void @foo() unnamed_addr align 2 {
entry:
  br label %invoke.cont145

invoke.cont145:
  %or.cond = and i1 undef, false
  br i1 %or.cond, label %if.then274, label %invoke.cont145

if.then274:
  %0 = load i32* null, align 4
  br i1 undef, label %invoke.cont291, label %if.else313

invoke.cont291:
  %idxprom.i.i.i605 = sext i32 %0 to i64
  %arrayidx.i.i.i607 = getelementptr inbounds double* undef, i64
%idxprom.i.i.i605
  %idxprom.i.i.i596 = sext i32 %0 to i64
  %arrayidx.i.i.i598 = getelementptr inbounds double* undef, i64
%idxprom.i.i.i596
  br label %if.end356

if.else313:
  %cmp314 = fcmp olt double undef, 0.000000e+00
  br i1 %cmp314, label %invoke.cont317, label %invoke.cont353

invoke.cont317:
  br i1 undef, label %invoke.cont326, label %invoke.cont334

invoke.cont326:
  %idxprom.i.i.i587 = sext i32 %0 to i64
  %arrayidx.i.i.i589 = getelementptr inbounds double* undef, i64
%idxprom.i.i.i587
  %sub329 = fsub fast double undef, undef
  br label %invoke.cont334

invoke.cont334:
  %lo.1 = phi double [ %sub329, %invoke.cont326 ], [ undef, %invoke.cont317 ]
  br i1 undef, label %invoke.cont342, label %if.end356

invoke.cont342:
  %idxprom.i.i.i578 = sext i32 %0 to i64
  %arrayidx.i.i.i580 = getelementptr inbounds double* undef, i64
%idxprom.i.i.i578
  br label %if.end356

invoke.cont353:
  %idxprom.i.i.i572 = sext i32 %0 to i64
  %arrayidx.i.i.i574 = getelementptr inbounds double* undef, i64
%idxprom.i.i.i572
  br label %if.end356

if.end356:
  %lo.2 = phi double [ 0.000000e+00, %invoke.cont291 ], [ %lo.1,
%invoke.cont342 ], [ undef, %invoke.cont353 ], [ %lo.1, %invoke.cont334 ]
  call void null(i32 %0, double %lo.2)
  unreachable
}

-- 
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/20140702/07e340b0/attachment.html>


More information about the llvm-bugs mailing list