1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-24 11:42:57 +01:00
llvm-mirror/test/CodeGen/PowerPC/eliminate-compare-of-copy.ll
Nemanja Ivanovic b162e0bc47 [PowerPC] Look through copies for compare elimination
We currently miss the opportunities for optmizing comparisons in the peephole
optimizer if the input is the result of a COPY since we look for record-form
versions of the producing instruction.

This patch simply lets the optimization peek through copies.

Differential revision: https://reviews.llvm.org/D59633

llvm-svn: 362438
2019-06-03 19:09:15 +00:00

30 lines
1000 B
LLVM

; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu \
; RUN: -mcpu=pwr8 -ppc-asm-full-reg-names < %s | FileCheck %s
define dso_local signext i32 @func(i32 zeroext %x, i32 zeroext %y) local_unnamed_addr {
; CHECK-LABEL: func
; CHECK: or. {{r[0-9]+}}, r4, r3
; CHECK-NOT: cmplwi
; CHECK: blr
entry:
%or = or i32 %y, %x
%tobool = icmp eq i32 %or, 0
br i1 %tobool, label %if.else, label %if.then
if.then: ; preds = %entry
%call = tail call signext i32 bitcast (i32 (...)* @f1 to i32 ()*)()
br label %return
if.else: ; preds = %entry
%call1 = tail call signext i32 bitcast (i32 (...)* @f2 to i32 ()*)()
br label %return
return: ; preds = %if.else, %if.then
%retval.0 = phi i32 [ %call, %if.then ], [ %call1, %if.else ]
ret i32 %retval.0
}
declare signext i32 @f1(...) local_unnamed_addr
declare signext i32 @f2(...) local_unnamed_addr