[all-commits] [llvm/llvm-project] 7be55b: [SimplifyCFG] Check if the return instruction caus...
DianQK via All-commits
all-commits at lists.llvm.org
Sat Feb 18 07:33:49 PST 2023
Branch: refs/heads/main
Home: https://github.com/llvm/llvm-project
Commit: 7be55b007698f6b6398cbbea69c327b5a971938a
https://github.com/llvm/llvm-project/commit/7be55b007698f6b6398cbbea69c327b5a971938a
Author: DianQK <dianqk at dianqk.net>
Date: 2023-02-18 (Sat, 18 Feb 2023)
Changed paths:
M llvm/lib/Transforms/Utils/SimplifyCFG.cpp
A llvm/test/Transforms/SimplifyCFG/unreachable-eliminate-on-ret.ll
Log Message:
-----------
[SimplifyCFG] Check if the return instruction causes undefined behavior
This should fix https://github.com/rust-lang/rust/issues/107681.
Return undefined to a noundef return value is undefined.
Example:
```
define noundef i32 @test_ret_noundef(i1 %cond) {
entry:
br i1 %cond, label %bb1, label %bb2
bb1:
br label %bb2
bb2:
%r = phi i32 [ undef, %entry ], [ 1, %bb1 ]
ret i32 %r
}
```
Reviewed By: nikic
Differential Revision: https://reviews.llvm.org/D144319
More information about the All-commits
mailing list