[llvm] [FunctionSpecializer] Do not mark function dead if any unexecutable call site exists (PR #154668)
Antonio Frighetto via llvm-commits
llvm-commits at lists.llvm.org
Mon Aug 25 00:48:23 PDT 2025
================
@@ -0,0 +1,41 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5
+; RUN: opt -passes=ipsccp --funcspec-min-function-size=1 -S < %s | FileCheck %s
+
+define i32 @caller() {
+; CHECK-LABEL: define i32 @caller() {
+; CHECK-NEXT: [[ENTRY:.*:]]
+; CHECK-NEXT: [[CALL1:%.*]] = call i32 @callee.specialized.1(i32 1)
+; CHECK-NEXT: [[CALL2:%.*]] = call i32 @callee.specialized.2(i32 0)
+; CHECK-NEXT: [[COND:%.*]] = icmp eq i32 undef, 0
+; CHECK-NEXT: br i1 [[COND]], label %[[COMMON_RET:.*]], label %[[IF_THEN:.*]]
+; CHECK: [[COMMON_RET]]:
+; CHECK-NEXT: ret i32 0
+; CHECK: [[IF_THEN]]:
+; CHECK-NEXT: ret i32 0
+;
+entry:
+ %call1 = call i32 @callee(i32 1)
+ %call2 = call i32 @callee(i32 0)
+ %cond = icmp eq i32 %call2, 0
+ br i1 %cond, label %common.ret, label %if.then
+
+common.ret: ; preds = %entry
+ ret i32 0
+
+if.then: ; preds = %entry
+ %unreachable_call = call i32 @callee(i32 2)
+ ret i32 %unreachable_call
+}
+
+define internal i32 @callee(i32 %ac) {
+entry:
+ br label %ai
+
+ai: ; preds = %ai, %entry
+ %add = or i32 0, 0
+ %cond = icmp eq i32 %ac, 1
+ br i1 %cond, label %aj, label %ai
+
+aj: ; preds = %ai
----------------
antoniofrighetto wrote:
s/aj/ret.bb/ same for ai, ac.
https://github.com/llvm/llvm-project/pull/154668
More information about the llvm-commits
mailing list