1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-23 11:13:28 +01:00
llvm-mirror/test/Reduce/remove-instructions.ll
Florian Hahn 27f75460b8 [llvm-reduce] Skip terminators when reducing instructions.
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
2020-08-23 17:20:34 +01:00

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
}