blob: a1b1cebc3e2f59443050ecc37e9493ffaba34006 [file] [log] [blame]
; RUN: llc -march=hexagon < %s | FileCheck %s
; CHECK: dfcmp
@g0 = internal constant [12 x i8] c"a < b = %d\0A\00"
@g1 = internal constant [13 x i8] c"a <= b = %d\0A\00"
@g2 = internal constant [12 x i8] c"a > b = %d\0A\00"
@g3 = internal constant [13 x i8] c"a >= b = %d\0A\00"
@g4 = internal constant [13 x i8] c"a == b = %d\0A\00"
@g5 = internal constant [13 x i8] c"a != b = %d\0A\00"
@g6 = global double 2.000000e+00
@g7 = global double 5.000000e+00
declare i32 @f0(ptr, ...) #0
define i32 @f1() #0 {
b0:
%v0 = load double, ptr @g6
%v1 = load double, ptr @g7
%v2 = fcmp olt double %v0, %v1
%v3 = fcmp ole double %v0, %v1
%v4 = fcmp ogt double %v0, %v1
%v5 = fcmp oge double %v0, %v1
%v6 = fcmp oeq double %v0, %v1
%v7 = fcmp une double %v0, %v1
%v14 = call i32 (ptr, ...) @f0(ptr @g0, i1 %v2)
%v15 = call i32 (ptr, ...) @f0(ptr @g1, i1 %v3)
%v16 = call i32 (ptr, ...) @f0(ptr @g2, i1 %v4)
%v17 = call i32 (ptr, ...) @f0(ptr @g3, i1 %v5)
%v18 = call i32 (ptr, ...) @f0(ptr @g4, i1 %v6)
%v19 = call i32 (ptr, ...) @f0(ptr @g5, i1 %v7)
ret i32 0
}
attributes #0 = { nounwind "target-cpu"="hexagonv5" }