[InstCombine] Signed saturation tests. NFC
[llvm-complete.git] / test / Transforms / Inline / PowerPC / ext.ll
blobf7a409467b2c0a7d3652320c03cf21f555792d88
1 ; REQUIRES: asserts
2 ; RUN: opt -inline -S -debug-only=inline-cost < %s 2>&1 | FileCheck %s
4 target datalayout = "E-m:e-i64:64-n32:64"
5 target triple = "powerpc64le-ibm-linux-gnu"
7 define i16 @outer1(i8* %ptr) {
8   %C = call i16 @inner1(i8* %ptr)
9   ret i16 %C
12 ; It is an ExtLoad.
13 ; CHECK: Analyzing call of inner1
14 ; CHECK: NumInstructionsSimplified: 2
15 ; CHECK: NumInstructions: 3
16 define i16 @inner1(i8* %ptr) {
17   %L = load i8, i8* %ptr
18   %E = zext i8 %L to i16
19   ret i16 %E
22 define i32 @outer2(i8* %ptr) {
23   %C = call i32 @inner2(i8* %ptr)
24   ret i32 %C
27 ; It is an ExtLoad.
28 ; CHECK: Analyzing call of inner2
29 ; CHECK: NumInstructionsSimplified: 2
30 ; CHECK: NumInstructions: 3
31 define i32 @inner2(i8* %ptr) {
32   %L = load i8, i8* %ptr
33   %E = zext i8 %L to i32
34   ret i32 %E
37 define i32 @outer3(i16* %ptr) {
38   %C = call i32 @inner3(i16* %ptr)
39   ret i32 %C
42 ; It is an ExtLoad.
43 ; CHECK: Analyzing call of inner3
44 ; CHECK: NumInstructionsSimplified: 2
45 ; CHECK: NumInstructions: 3
46 define i32 @inner3(i16* %ptr) {
47   %L = load i16, i16* %ptr
48   %E = zext i16 %L to i32
49   ret i32 %E
52 define i32 @outer4(i16* %ptr) {
53   %C = call i32 @inner4(i16* %ptr)
54   ret i32 %C
57 ; It is an ExtLoad.
58 ; CHECK: Analyzing call of inner4
59 ; CHECK: NumInstructionsSimplified: 2
60 ; CHECK: NumInstructions: 3
61 define i32 @inner4(i16* %ptr) {
62   %L = load i16, i16* %ptr
63   %E = sext i16 %L to i32
64   ret i32 %E
67 define i64 @outer5(i8* %ptr) {
68   %C = call i64 @inner5(i8* %ptr)
69   ret i64 %C
72 ; It is an ExtLoad.
73 ; CHECK: Analyzing call of inner5
74 ; CHECK: NumInstructionsSimplified: 2
75 ; CHECK: NumInstructions: 3
76 define i64 @inner5(i8* %ptr) {
77   %L = load i8, i8* %ptr
78   %E = zext i8 %L to i64
79   ret i64 %E
82 define i64 @outer6(i16* %ptr) {
83   %C = call i64 @inner6(i16* %ptr)
84   ret i64 %C
87 ; It is an ExtLoad.
88 ; CHECK: Analyzing call of inner6
89 ; CHECK: NumInstructionsSimplified: 2
90 ; CHECK: NumInstructions: 3
91 define i64 @inner6(i16* %ptr) {
92   %L = load i16, i16* %ptr
93   %E = zext i16 %L to i64
94   ret i64 %E
97 define i64 @outer7(i16* %ptr) {
98   %C = call i64 @inner7(i16* %ptr)
99   ret i64 %C
102 ; It is an ExtLoad.
103 ; CHECK: Analyzing call of inner7
104 ; CHECK: NumInstructionsSimplified: 2
105 ; CHECK: NumInstructions: 3
106 define i64 @inner7(i16* %ptr) {
107   %L = load i16, i16* %ptr
108   %E = sext i16 %L to i64
109   ret i64 %E
112 define i64 @outer8(i32* %ptr) {
113   %C = call i64 @inner8(i32* %ptr)
114   ret i64 %C
117 ; It is an ExtLoad.
118 ; CHECK: Analyzing call of inner8
119 ; CHECK: NumInstructionsSimplified: 2
120 ; CHECK: NumInstructions: 3
121 define i64 @inner8(i32* %ptr) {
122   %L = load i32, i32* %ptr
123   %E = zext i32 %L to i64
124   ret i64 %E
127 define i64 @outer9(i32* %ptr) {
128   %C = call i64 @inner9(i32* %ptr)
129   ret i64 %C
132 ; It is an ExtLoad.
133 ; CHECK: Analyzing call of inner9
134 ; CHECK: NumInstructionsSimplified: 2
135 ; CHECK: NumInstructions: 3
136 define i64 @inner9(i32* %ptr) {
137   %L = load i32, i32* %ptr
138   %E = sext i32 %L to i64
139   ret i64 %E