1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-23 19:23:23 +01:00
llvm-mirror/test/Reduce/remove-instructions.ll
David Blaikie d5d1d93e4d llvm-reduce: Add pass to reduce instructions
Patch by Diego Treviño!

Differential Revision: https://reviews.llvm.org/D66263

llvm-svn: 372282
2019-09-19 00:59:27 +00:00

24 lines
824 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
; CHECK-COUNT-5: %interesting
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
; CHECK-NOT: ret
ret i32 0
}