[llvm] eb6c6e6 - [NFC][InstCombine] Add test showing failure to sink into `resume` block
Roman Lebedev via llvm-commits
llvm-commits at lists.llvm.org
Thu Jan 20 10:42:35 PST 2022
Author: Roman Lebedev
Date: 2022-01-20T21:42:08+03:00
New Revision: eb6c6e60585df1a05c11a7b2625cbecffb88e085
URL: https://github.com/llvm/llvm-project/commit/eb6c6e60585df1a05c11a7b2625cbecffb88e085
DIFF: https://github.com/llvm/llvm-project/commit/eb6c6e60585df1a05c11a7b2625cbecffb88e085.diff
LOG: [NFC][InstCombine] Add test showing failure to sink into `resume` block
Added:
llvm/test/Transforms/InstCombine/sink-into-resume-block.ll
Modified:
Removed:
################################################################################
diff --git a/llvm/test/Transforms/InstCombine/sink-into-resume-block.ll b/llvm/test/Transforms/InstCombine/sink-into-resume-block.ll
new file mode 100644
index 0000000000000..a687977d4b975
--- /dev/null
+++ b/llvm/test/Transforms/InstCombine/sink-into-resume-block.ll
@@ -0,0 +1,63 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
+; RUN: opt -instcombine -S < %s | FileCheck %s
+
+; Check that InstCombine can sink instructions to the landingpad of the invoke.
+
+define void @t0_noop(i32 %arg) personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*) {
+; CHECK-LABEL: @t0_noop(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[C:%.*]] = call i1 @cond()
+; CHECK-NEXT: [[V0:%.*]] = add i32 [[ARG:%.*]], 42
+; CHECK-NEXT: br i1 [[C]], label [[IF_THEN:%.*]], label [[IF_END:%.*]]
+; CHECK: if.then:
+; CHECK-NEXT: invoke void @simple_throw()
+; CHECK-NEXT: to label [[INVOKE_CONT:%.*]] unwind label [[LPAD:%.*]]
+; CHECK: invoke.cont:
+; CHECK-NEXT: unreachable
+; CHECK: lpad:
+; CHECK-NEXT: [[EH:%.*]] = landingpad { i8*, i32 }
+; CHECK-NEXT: cleanup
+; CHECK-NEXT: call void @consume(i32 [[V0]])
+; CHECK-NEXT: call void @destructor()
+; CHECK-NEXT: resume { i8*, i32 } [[EH]]
+; CHECK: if.end:
+; CHECK-NEXT: [[V1:%.*]] = add i32 [[ARG]], 24
+; CHECK-NEXT: call void @consume(i32 [[V1]])
+; CHECK-NEXT: call void @sideeffect()
+; CHECK-NEXT: ret void
+;
+entry:
+ %c = call i1 @cond()
+ %v0 = add i32 %arg, 42
+ %v1 = add i32 %arg, 24
+ br i1 %c, label %if.then, label %if.end
+
+if.then:
+ invoke void @simple_throw() to label %invoke.cont unwind label %lpad
+
+invoke.cont:
+ unreachable
+
+lpad:
+ %eh = landingpad { i8*, i32 } cleanup
+ call void @consume(i32 %v0)
+ call void @destructor()
+ resume { i8*, i32 } %eh
+
+if.end:
+ call void @consume(i32 %v1)
+ call void @sideeffect()
+ ret void
+}
+
+declare i1 @cond()
+
+declare void @sideeffect()
+
+declare void @simple_throw() noreturn
+
+declare void @destructor()
+
+declare void @consume(i32)
+
+declare dso_local i32 @__gxx_personality_v0(...)
More information about the llvm-commits
mailing list