mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-07 12:30:44 +00:00
d57e2db4cf
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@267174 91177308-0d34-0410-b5e6-96231b3b80d8
56 lines
1.7 KiB
LLVM
56 lines
1.7 KiB
LLVM
; 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 }
|
|
|