Files
clang-p2996/llvm/test/Transforms/PhaseOrdering/pr64289-tce.ll
DianQK c3f227ead6 [TailCallElim] Remove the readonly attribute of byval.
When eliminating a tail call, we modify the values of the arguments.
Therefore, if the byval parameter has a readonly attribute, we have to remove it. It is safe because,
from the perspective of a caller, the byval parameter is always treated as "readonly," even if the readonly attribute is removed.

Fixes #64289.

Reviewed By: nikic

Differential Revision: https://reviews.llvm.org/D156793
2023-08-09 07:07:47 +08:00

28 lines
771 B
LLVM

; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt -S -O3 < %s | FileCheck %s
; A miscompilation found on https://github.com/llvm/llvm-project/issues/64289.
; 1. PostOrderFunctionAttrsPass added readonly to the parameter.
; 2. TailCallElimPass modified the parameter but kept readonly.
; 3. LICMPass incorrectly hoisted the load instruction.
define void @pr64289(ptr noalias byval(i64) %x) {
; CHECK-LABEL: @pr64289(
; CHECK-NEXT: start:
; CHECK-NEXT: ret void
;
start:
%new_x = alloca i64, align 8
%x_val = load i64, ptr %x, align 8
%is_zero = icmp eq i64 %x_val, 0
br i1 %is_zero, label %end, label %recurse
recurse:
store i64 0, ptr %new_x, align 8
call void @pr64289(ptr %new_x)
br label %end
end:
ret void
}