mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-31 20:51:52 +01:00
152dec707a
Summary: When performing constant propagation for call instructions we have historically replaced all uses of the return from a call, but not removed the call itself. This is required for correctness if the calls have side effects, however the compiler should be able to safely remove calls that don't have side effects. This allows the compiler to completely fold away calls to functions that have no side effects if the inputs are constant and the output can be determined at compile time. Reviewers: davide, sanjoy, bruno, dberlin Subscribers: llvm-commits Differential Revision: https://reviews.llvm.org/D38856 llvm-svn: 322125
34 lines
659 B
LLVM
34 lines
659 B
LLVM
; RUN: opt < %s -S -ipsccp | FileCheck %s
|
|
; PR5596
|
|
|
|
; IPSCCP should propagate the 0 argument, eliminate the switch, and propagate
|
|
; the result.
|
|
|
|
; CHECK: define i32 @main() #0 {
|
|
; CHECK-NEXT: entry:
|
|
; CHECK-NOT: call
|
|
; CHECK-NEXT: ret i32 123
|
|
|
|
define i32 @main() noreturn nounwind {
|
|
entry:
|
|
%call2 = tail call i32 @wwrite(i64 0) nounwind
|
|
ret i32 %call2
|
|
}
|
|
|
|
define internal i32 @wwrite(i64 %i) nounwind readnone {
|
|
entry:
|
|
switch i64 %i, label %sw.default [
|
|
i64 3, label %return
|
|
i64 10, label %return
|
|
]
|
|
|
|
sw.default:
|
|
ret i32 123
|
|
|
|
return:
|
|
ret i32 0
|
|
}
|
|
|
|
; CHECK: attributes #0 = { noreturn nounwind }
|
|
; CHECK: attributes #1 = { nounwind readnone }
|