llvm-for-llvmta/test/CodeGen/Hexagon/block-ranges-nodef.ll

56 lines
1.7 KiB
LLVM
Raw Permalink Normal View History

2022-04-25 10:02:23 +02:00
; RUN: llc -march=hexagon < %s
; REQUIRES: asserts
target triple = "hexagon"
declare void @foo() #0
define hidden fastcc void @fred(i32 %a, i64 %b, i64 %c) unnamed_addr #1 {
entry:
%cmp17 = icmp ne i64 %c, 0
%conv19 = zext i1 %cmp17 to i64
%or = or i64 %conv19, %b
store i64 %or, i64* undef, align 8
br i1 undef, label %if.then44, label %if.end96
if.then44: ; preds = %entry
br i1 undef, label %overflow, label %lor.lhs.false
lor.lhs.false: ; preds = %if.then44
br i1 undef, label %overflow, label %if.end52
if.end52: ; preds = %lor.lhs.false
br i1 undef, label %if.then55, label %if.end96
if.then55: ; preds = %if.end52
%cmp60 = icmp slt i32 %a, 0
%or.cond = or i1 %cmp60, false
%cmp63 = icmp ule i64 %or, undef
%.cmp63 = or i1 %cmp63, %or.cond
call void @foo()
%or.cond299 = and i1 %.cmp63, undef
br i1 %or.cond299, label %if.then72, label %if.end73
if.then72: ; preds = %if.then55
unreachable
if.end73: ; preds = %if.then55
unreachable
if.end96: ; preds = %if.end52, %entry
br i1 undef, label %if.end102, label %if.then98
if.then98: ; preds = %if.end96
br label %if.end102
if.end102: ; preds = %if.then98, %if.end96
unreachable
overflow: ; preds = %lor.lhs.false, %if.then44
ret void
}
attributes #0 = { noinline norecurse nounwind }
attributes #1 = { noinline nounwind }