aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Transforms/Utils/Local.cpp
diff options
context:
space:
mode:
authorNikita Popov <npopov@redhat.com>2025-07-22 09:44:03 +0200
committerGitHub <noreply@github.com>2025-07-22 09:44:03 +0200
commit307256ecbd858bc2df5fa9342c67a8205691ade9 (patch)
tree36345870f2bbc008803befffabf22536a7728ea1 /llvm/lib/Transforms/Utils/Local.cpp
parent314ce691df0d699234c871a1772470b5e4aed892 (diff)
downloadllvm-307256ecbd858bc2df5fa9342c67a8205691ade9.zip
llvm-307256ecbd858bc2df5fa9342c67a8205691ade9.tar.gz
llvm-307256ecbd858bc2df5fa9342c67a8205691ade9.tar.bz2
[GVNSink] Do not sink lifetimes of different allocas (#149818)
This was always undesirable, and after #149310 it is illegal and will result in a verifier error. Fix this by moving SimplifyCFG's check for this into canReplaceOperandWithVariable(), so it's shared with GVNSink.
Diffstat (limited to 'llvm/lib/Transforms/Utils/Local.cpp')
-rw-r--r--llvm/lib/Transforms/Utils/Local.cpp4
1 files changed, 4 insertions, 0 deletions
diff --git a/llvm/lib/Transforms/Utils/Local.cpp b/llvm/lib/Transforms/Utils/Local.cpp
index 1e3ef68..f89d36f 100644
--- a/llvm/lib/Transforms/Utils/Local.cpp
+++ b/llvm/lib/Transforms/Utils/Local.cpp
@@ -3857,6 +3857,10 @@ bool llvm::canReplaceOperandWithVariable(const Instruction *I, unsigned OpIdx) {
if (Op->isSwiftError())
return false;
+ // Cannot replace alloca argument with phi/select.
+ if (I->isLifetimeStartOrEnd())
+ return false;
+
// Early exit.
if (!isa<Constant, InlineAsm>(Op))
return true;