diff --git a/llvm/test/Transforms/ADCE/willreturn.ll b/llvm/test/Transforms/ADCE/willreturn.ll new file mode 100644 index 00000000000000..c3482a417cb05e --- /dev/null +++ b/llvm/test/Transforms/ADCE/willreturn.ll @@ -0,0 +1,17 @@ +; NOTE: Assertions have been autogenerated by utils/update_test_checks.py +; RUN: opt -adce -S < %s | FileCheck %s + +declare void @may_not_return(i32) nounwind readnone +declare void @will_return(i32) nounwind readnone willreturn + +; FIXME: This is a miscompile. +define void @test(i32 %a) { +; CHECK-LABEL: @test( +; CHECK-NEXT: ret void +; + %b = add i32 %a, 1 + call void @may_not_return(i32 %b) + %c = add i32 %b, 1 + call void @will_return(i32 %c) + ret void +} diff --git a/llvm/test/Transforms/BDCE/willreturn.ll b/llvm/test/Transforms/BDCE/willreturn.ll new file mode 100644 index 00000000000000..b87ab0050e7ae4 --- /dev/null +++ b/llvm/test/Transforms/BDCE/willreturn.ll @@ -0,0 +1,17 @@ +; NOTE: Assertions have been autogenerated by utils/update_test_checks.py +; RUN: opt -bdce -S < %s | FileCheck %s + +declare void @may_not_return(i32) nounwind readnone +declare void @will_return(i32) nounwind readnone willreturn + +; FIXME: This is a miscompile. +define void @test(i32 %a) { +; CHECK-LABEL: @test( +; CHECK-NEXT: ret void +; + %b = add i32 %a, 1 + call void @may_not_return(i32 %b) + %c = add i32 %b, 1 + call void @will_return(i32 %c) + ret void +}