mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 11:13:28 +01:00
27f75460b8
Removing terminators will result in invalid IR, making further reductions pointless. I do not think there is any valid use case where we actually want to create invalid IR as part of a reduction. Reviewed By: lebedev.ri Differential Revision: https://reviews.llvm.org/D86210
27 lines
868 B
LLVM
27 lines
868 B
LLVM
; Test that llvm-reduce can remove uninteresting instructions.
|
|
;
|
|
; RUN: llvm-reduce --test %python --test-arg %p/Inputs/remove-instructions.py %s -o %t
|
|
; RUN: cat %t | FileCheck -implicit-check-not=uninteresting %s
|
|
; REQUIRES: plugins
|
|
|
|
; We're testing all direct uses of %interesting are conserved. The terminator
|
|
; (ret) must also be preserved.
|
|
|
|
; CHECK-COUNT-5: %interesting
|
|
; CHECK: ret
|
|
|
|
define i32 @main() #0 {
|
|
entry:
|
|
%uninteresting1 = alloca i32, align 4
|
|
%interesting = alloca i32, align 4
|
|
%uninteresting2 = alloca i32, align 4
|
|
store i32 0, i32* %uninteresting1, align 4
|
|
store i32 0, i32* %interesting, align 4
|
|
%0 = load i32, i32* %interesting, align 4
|
|
%uninteresting3 = add nsw i32 %0, 1
|
|
store i32 %uninteresting3, i32* %interesting, align 4
|
|
%1 = load i32, i32* %interesting, align 4
|
|
store i32 %1, i32* %uninteresting2, align 4
|
|
ret i32 0
|
|
}
|