Haicheng Wu 8c939cb97f [TTI] Refine the cost of EXT in getUserCost()
Now, getUserCost() only checks the src and dst types of EXT to decide it is free
or not. This change first checks the types, then calls isExtFreeImpl(), and
check if EXT can form ExtLoad at last. Currently, only AArch64 has customized
implementation of isExtFreeImpl() to check if EXT can be folded into its use.

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

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@308076 91177308-0d34-0410-b5e6-96231b3b80d8
2017-07-15 02:12:16 +00:00

141 lines
2.8 KiB
LLVM

; REQUIRES: asserts
; RUN: opt -inline -S -debug-only=inline-cost < %s 2>&1 | FileCheck %s
target datalayout = "E-m:e-i64:64-n32:64"
target triple = "powerpc64le-ibm-linux-gnu"
define i16 @outer1(i8* %ptr) {
%C = call i16 @inner1(i8* %ptr)
ret i16 %C
}
; It is an ExtLoad.
; CHECK: Analyzing call of inner1
; CHECK: NumInstructionsSimplified: 2
; CHECK: NumInstructions: 3
define i16 @inner1(i8* %ptr) {
%L = load i8, i8* %ptr
%E = zext i8 %L to i16
ret i16 %E
}
define i32 @outer2(i8* %ptr) {
%C = call i32 @inner2(i8* %ptr)
ret i32 %C
}
; It is an ExtLoad.
; CHECK: Analyzing call of inner2
; CHECK: NumInstructionsSimplified: 2
; CHECK: NumInstructions: 3
define i32 @inner2(i8* %ptr) {
%L = load i8, i8* %ptr
%E = zext i8 %L to i32
ret i32 %E
}
define i32 @outer3(i16* %ptr) {
%C = call i32 @inner3(i16* %ptr)
ret i32 %C
}
; It is an ExtLoad.
; CHECK: Analyzing call of inner3
; CHECK: NumInstructionsSimplified: 2
; CHECK: NumInstructions: 3
define i32 @inner3(i16* %ptr) {
%L = load i16, i16* %ptr
%E = zext i16 %L to i32
ret i32 %E
}
define i32 @outer4(i16* %ptr) {
%C = call i32 @inner4(i16* %ptr)
ret i32 %C
}
; It is an ExtLoad.
; CHECK: Analyzing call of inner4
; CHECK: NumInstructionsSimplified: 2
; CHECK: NumInstructions: 3
define i32 @inner4(i16* %ptr) {
%L = load i16, i16* %ptr
%E = sext i16 %L to i32
ret i32 %E
}
define i64 @outer5(i8* %ptr) {
%C = call i64 @inner5(i8* %ptr)
ret i64 %C
}
; It is an ExtLoad.
; CHECK: Analyzing call of inner5
; CHECK: NumInstructionsSimplified: 2
; CHECK: NumInstructions: 3
define i64 @inner5(i8* %ptr) {
%L = load i8, i8* %ptr
%E = zext i8 %L to i64
ret i64 %E
}
define i64 @outer6(i16* %ptr) {
%C = call i64 @inner6(i16* %ptr)
ret i64 %C
}
; It is an ExtLoad.
; CHECK: Analyzing call of inner6
; CHECK: NumInstructionsSimplified: 2
; CHECK: NumInstructions: 3
define i64 @inner6(i16* %ptr) {
%L = load i16, i16* %ptr
%E = zext i16 %L to i64
ret i64 %E
}
define i64 @outer7(i16* %ptr) {
%C = call i64 @inner7(i16* %ptr)
ret i64 %C
}
; It is an ExtLoad.
; CHECK: Analyzing call of inner7
; CHECK: NumInstructionsSimplified: 2
; CHECK: NumInstructions: 3
define i64 @inner7(i16* %ptr) {
%L = load i16, i16* %ptr
%E = sext i16 %L to i64
ret i64 %E
}
define i64 @outer8(i32* %ptr) {
%C = call i64 @inner8(i32* %ptr)
ret i64 %C
}
; It is an ExtLoad.
; CHECK: Analyzing call of inner8
; CHECK: NumInstructionsSimplified: 2
; CHECK: NumInstructions: 3
define i64 @inner8(i32* %ptr) {
%L = load i32, i32* %ptr
%E = zext i32 %L to i64
ret i64 %E
}
define i64 @outer9(i32* %ptr) {
%C = call i64 @inner9(i32* %ptr)
ret i64 %C
}
; It is an ExtLoad.
; CHECK: Analyzing call of inner9
; CHECK: NumInstructionsSimplified: 2
; CHECK: NumInstructions: 3
define i64 @inner9(i32* %ptr) {
%L = load i32, i32* %ptr
%E = sext i32 %L to i64
ret i64 %E
}