diff options
Diffstat (limited to 'llvm/test/Transforms/Util')
| -rw-r--r-- | llvm/test/Transforms/Util/PredicateInfo/testandor.ll | 27 | ||||
| -rw-r--r-- | llvm/test/Transforms/Util/dbg-user-of-aext.ll | 7 | ||||
| -rw-r--r-- | llvm/test/Transforms/Util/libcalls-fast-math-inf-loop.ll | 14 | 
3 files changed, 34 insertions, 14 deletions
| diff --git a/llvm/test/Transforms/Util/PredicateInfo/testandor.ll b/llvm/test/Transforms/Util/PredicateInfo/testandor.ll index 2e96a92..cc1dc4e 100644 --- a/llvm/test/Transforms/Util/PredicateInfo/testandor.ll +++ b/llvm/test/Transforms/Util/PredicateInfo/testandor.ll @@ -994,3 +994,30 @@ define void @test_assume_deep_and_tree(i1 %a1) {    call void @foo(i1 %a15)    ret void  } + +define i32 @test_and_with_phinode(i32 %x) { +; CHECK-LABEL: @test_and_with_phinode( +; CHECK-NEXT:  entry: +; CHECK-NEXT:    [[XGE1:%.*]] = icmp uge i32 [[X:%.*]], 1 +; CHECK-NEXT:    [[XLT2:%.*]] = icmp ult i32 [[X]], 2 +; CHECK-NEXT:    [[AND:%.*]] = and i1 [[XGE1]], [[XLT2]] +; CHECK:         [[X_0_1:%.*]] = bitcast i32 [[X]] to i32 +; CHECK:         [[X_0_2:%.*]] = bitcast i32 [[X_0_1]] to i32 +; CHECK-NEXT:    br i1 [[AND]], label [[PHI:%.*]], label [[NOPE:%.*]] +; CHECK:       nope: +; CHECK-NEXT:    br label [[PHI]] +; CHECK:       phi: +; CHECK-NEXT:    [[RES:%.*]] = phi i32 [ [[X_0_2]], [[ENTRY:%.*]] ], [ 1, [[NOPE]] ] +; CHECK-NEXT:    ret i32 [[RES]] +; +entry: +  %xge1 = icmp uge i32 %x, 1 +  %xlt2 = icmp ult i32 %x, 2 +  %and = and i1 %xge1, %xlt2 +  br i1 %and, label %phi, label %nope +nope: +  br label %phi +phi: +  %res = phi i32 [ %x, %entry ], [ 1, %nope ] +  ret i32 %res +} diff --git a/llvm/test/Transforms/Util/dbg-user-of-aext.ll b/llvm/test/Transforms/Util/dbg-user-of-aext.ll index 9e7935e..b3d1b90 100644 --- a/llvm/test/Transforms/Util/dbg-user-of-aext.ll +++ b/llvm/test/Transforms/Util/dbg-user-of-aext.ll @@ -27,7 +27,7 @@  %struct.foo = type { i8, i64 }  ; Function Attrs: noinline nounwind uwtable -define void @_Z1fbb3foo(i1 zeroext %b, i1 zeroext %frag, i8 %g.coerce0, i64 %g.coerce1) #0 !dbg !6 { +define void @_Z1fbb3foo(i1 zeroext %b, i1 zeroext %frag, i8 %g.coerce0, i64 %g.coerce1) !dbg !6 {  entry:    %g = alloca %struct.foo, align 8    %b.addr = alloca i8, align 1 @@ -51,10 +51,7 @@ entry:  ; CHECK: ![[VAR_FRAG]] = !DILocalVariable(name: "frag"  ; Function Attrs: nounwind readnone speculatable -declare void @llvm.dbg.declare(metadata, metadata, metadata) #1 - -attributes #0 = { noinline nounwind uwtable "correctly-rounded-divide-sqrt-fp-math"="false" "disable-tail-calls"="false" "less-precise-fpmad"="false" "frame-pointer"="all" "no-infs-fp-math"="false" "no-jump-tables"="false" "no-nans-fp-math"="false" "no-signed-zeros-fp-math"="false" "no-trapping-math"="false" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+fxsr,+mmx,+sse,+sse2,+x87" "unsafe-fp-math"="false" "use-soft-float"="false" } -attributes #1 = { nounwind readnone speculatable } +declare void @llvm.dbg.declare(metadata, metadata, metadata)  !llvm.dbg.cu = !{!0}  !llvm.module.flags = !{!3, !4} diff --git a/llvm/test/Transforms/Util/libcalls-fast-math-inf-loop.ll b/llvm/test/Transforms/Util/libcalls-fast-math-inf-loop.ll index ad23bf7..e9f0c8c 100644 --- a/llvm/test/Transforms/Util/libcalls-fast-math-inf-loop.ll +++ b/llvm/test/Transforms/Util/libcalls-fast-math-inf-loop.ll @@ -19,18 +19,18 @@ target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"  target triple = "x86_64-unknown-unknown"  ; Function Attrs: nounwind -define float @fn(float %f) #0 { +define float @fn(float %f) {  ; CHECK: define float @fn(  ; CHECK: call fast float @expf(    %f.addr = alloca float, align 4    store float %f, ptr %f.addr, align 4, !tbaa !1    %1 = load float, ptr %f.addr, align 4, !tbaa !1 -  %call = call fast float @expf(float %1) #3 +  %call = call fast float @expf(float %1)    ret float %call  }  ; Function Attrs: inlinehint nounwind readnone -define available_externally float @expf(float %x) #1 { +define available_externally float @expf(float %x) {  ; CHECK: define available_externally float @expf(  ; CHECK: fpext float  ; CHECK: call fast double @exp( @@ -39,17 +39,13 @@ define available_externally float @expf(float %x) #1 {    store float %x, ptr %x.addr, align 4, !tbaa !1    %1 = load float, ptr %x.addr, align 4, !tbaa !1    %conv = fpext float %1 to double -  %call = call fast double @exp(double %conv) #3 +  %call = call fast double @exp(double %conv)    %conv1 = fptrunc double %call to float    ret float %conv1  }  ; Function Attrs: nounwind readnone -declare double @exp(double) #2 - -attributes #0 = { nounwind "correctly-rounded-divide-sqrt-fp-math"="false" "disable-tail-calls"="false" "less-precise-fpmad"="false" "frame-pointer"="none" "no-infs-fp-math"="false" "no-jump-tables"="false" "no-nans-fp-math"="false" "no-signed-zeros-fp-math"="false" "no-trapping-math"="false" "stack-protector-buffer-size"="8" "target-features"="+mmx,+sse,+sse2,+x87" "unsafe-fp-math"="false" "use-soft-float"="false" } -attributes #1 = { inlinehint nounwind readnone "correctly-rounded-divide-sqrt-fp-math"="false" "disable-tail-calls"="false" "less-precise-fpmad"="false" "frame-pointer"="none" "no-infs-fp-math"="false" "no-jump-tables"="false" "no-nans-fp-math"="false" "no-signed-zeros-fp-math"="false" "no-trapping-math"="false" "stack-protector-buffer-size"="8" "target-features"="+mmx,+sse,+sse2,+x87" "unsafe-fp-math"="false" "use-soft-float"="false" } -attributes #2 = { nounwind readnone } +declare double @exp(double)  !llvm.ident = !{!0} | 
