xref: /llvm-project/llvm/test/CodeGen/PowerPC/pr26356.ll (revision a538b0f023e858d0f71a1295bb9084e851ddd361)
1*a538b0f0SEhsan Amiri; RUN: llc -verify-machineinstrs -O0 -mcpu=pwr7 -mtriple=powerpc64le-unknown-unknown < %s | FileCheck %s
2b6fdce4cSNemanja Ivanovic
3b6fdce4cSNemanja Ivanovicdefine zeroext i32 @f1() {
4b6fdce4cSNemanja Ivanovicentry:
5b6fdce4cSNemanja Ivanovic  ret i32 65535
6b6fdce4cSNemanja Ivanovic}
7b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f1
8b6fdce4cSNemanja Ivanovic; CHECK: lis 3, 0
9b6fdce4cSNemanja Ivanovic; CHECK: ori 3, 3, 65535
10b6fdce4cSNemanja Ivanovic
11b6fdce4cSNemanja Ivanovicdefine zeroext i32 @f2() {
12b6fdce4cSNemanja Ivanovicentry:
13b6fdce4cSNemanja Ivanovic  ret i32 32768
14b6fdce4cSNemanja Ivanovic}
15b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f2
16b6fdce4cSNemanja Ivanovic; CHECK: lis 3, 0
17b6fdce4cSNemanja Ivanovic; CHECK: ori 3, 3, 32768
18b6fdce4cSNemanja Ivanovic
19b6fdce4cSNemanja Ivanovicdefine zeroext i32 @f3() {
20b6fdce4cSNemanja Ivanovicentry:
21b6fdce4cSNemanja Ivanovic  ret i32 32767
22b6fdce4cSNemanja Ivanovic}
23b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f3
24b6fdce4cSNemanja Ivanovic; CHECK: li 3, 32767
25b6fdce4cSNemanja Ivanovic
26b6fdce4cSNemanja Ivanovicdefine zeroext i16 @f4() {
27b6fdce4cSNemanja Ivanovicentry:
28b6fdce4cSNemanja Ivanovic  ret i16 65535
29b6fdce4cSNemanja Ivanovic}
30b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f4
31b6fdce4cSNemanja Ivanovic; CHECK: lis 3, 0
32b6fdce4cSNemanja Ivanovic; CHECK: ori 3, 3, 65535
33b6fdce4cSNemanja Ivanovic
34b6fdce4cSNemanja Ivanovicdefine zeroext i16 @f5() {
35b6fdce4cSNemanja Ivanovicentry:
36b6fdce4cSNemanja Ivanovic  ret i16 32768
37b6fdce4cSNemanja Ivanovic}
38b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f5
39b6fdce4cSNemanja Ivanovic; CHECK: lis 3, 0
40b6fdce4cSNemanja Ivanovic; CHECK: ori 3, 3, 32768
41b6fdce4cSNemanja Ivanovic
42b6fdce4cSNemanja Ivanovicdefine zeroext i16 @f6() {
43b6fdce4cSNemanja Ivanovicentry:
44b6fdce4cSNemanja Ivanovic  ret i16 32767
45b6fdce4cSNemanja Ivanovic}
46b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f6
47b6fdce4cSNemanja Ivanovic; CHECK: li 3, 32767
48b6fdce4cSNemanja Ivanovic
49b6fdce4cSNemanja Ivanovicdefine zeroext i16 @f7() {
50b6fdce4cSNemanja Ivanovicentry:
51b6fdce4cSNemanja Ivanovic  ret i16 -1
52b6fdce4cSNemanja Ivanovic}
53b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f7
54b6fdce4cSNemanja Ivanovic; CHECK: lis 3, 0
55b6fdce4cSNemanja Ivanovic; CHECK: ori 3, 3, 65535
56b6fdce4cSNemanja Ivanovic
57b6fdce4cSNemanja Ivanovicdefine zeroext i16 @f8() {
58b6fdce4cSNemanja Ivanovicentry:
59b6fdce4cSNemanja Ivanovic  ret i16 -32768
60b6fdce4cSNemanja Ivanovic}
61b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f8
62b6fdce4cSNemanja Ivanovic; CHECK: lis 3, 0
63b6fdce4cSNemanja Ivanovic; CHECK: ori 3, 3, 32768
64b6fdce4cSNemanja Ivanovic
65b6fdce4cSNemanja Ivanovicdefine signext i32 @f1s() {
66b6fdce4cSNemanja Ivanovicentry:
67b6fdce4cSNemanja Ivanovic  ret i32 65535
68b6fdce4cSNemanja Ivanovic}
69b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f1s
70b6fdce4cSNemanja Ivanovic; CHECK: lis 3, 0
71b6fdce4cSNemanja Ivanovic; CHECK: ori 3, 3, 65535
72b6fdce4cSNemanja Ivanovic
73b6fdce4cSNemanja Ivanovicdefine signext i32 @f2s() {
74b6fdce4cSNemanja Ivanovicentry:
75b6fdce4cSNemanja Ivanovic  ret i32 32768
76b6fdce4cSNemanja Ivanovic}
77b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f2s
78b6fdce4cSNemanja Ivanovic; CHECK: lis 3, 0
79b6fdce4cSNemanja Ivanovic; CHECK: ori 3, 3, 32768
80b6fdce4cSNemanja Ivanovic
81b6fdce4cSNemanja Ivanovicdefine signext i32 @f3s() {
82b6fdce4cSNemanja Ivanovicentry:
83b6fdce4cSNemanja Ivanovic  ret i32 32767
84b6fdce4cSNemanja Ivanovic}
85b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f3s
86b6fdce4cSNemanja Ivanovic; CHECK: li 3, 32767
87b6fdce4cSNemanja Ivanovic
88b6fdce4cSNemanja Ivanovicdefine signext i16 @f4s() {
89b6fdce4cSNemanja Ivanovicentry:
90b6fdce4cSNemanja Ivanovic  ret i16 32767
91b6fdce4cSNemanja Ivanovic}
92b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f4s
93b6fdce4cSNemanja Ivanovic; CHECK: li 3, 32767
94b6fdce4cSNemanja Ivanovic
95b6fdce4cSNemanja Ivanovicdefine signext i32 @f1sn() {
96b6fdce4cSNemanja Ivanovicentry:
97b6fdce4cSNemanja Ivanovic  ret i32 -65535
98b6fdce4cSNemanja Ivanovic}
99b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f1sn
100b6fdce4cSNemanja Ivanovic; CHECK: lis 3, -1
101b6fdce4cSNemanja Ivanovic; CHECK: ori 3, 3, 1
102b6fdce4cSNemanja Ivanovic
103b6fdce4cSNemanja Ivanovicdefine signext i32 @f2sn() {
104b6fdce4cSNemanja Ivanovicentry:
105b6fdce4cSNemanja Ivanovic  ret i32 -32768
106b6fdce4cSNemanja Ivanovic}
107b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f2sn
108b6fdce4cSNemanja Ivanovic; CHECK: li 3, -32768
109b6fdce4cSNemanja Ivanovic
110b6fdce4cSNemanja Ivanovicdefine signext i32 @f3sn() {
111b6fdce4cSNemanja Ivanovicentry:
112b6fdce4cSNemanja Ivanovic  ret i32 -32767
113b6fdce4cSNemanja Ivanovic}
114b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f3sn
115b6fdce4cSNemanja Ivanovic; CHECK: li 3, -32767
116b6fdce4cSNemanja Ivanovic
117b6fdce4cSNemanja Ivanovicdefine signext i32 @f4sn() {
118b6fdce4cSNemanja Ivanovicentry:
119b6fdce4cSNemanja Ivanovic  ret i32 -65536
120b6fdce4cSNemanja Ivanovic}
121b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f4sn
122b6fdce4cSNemanja Ivanovic; CHECK: lis 3, -1
123b6fdce4cSNemanja Ivanovic
124b6fdce4cSNemanja Ivanovicdefine signext i16 @f5sn() {
125b6fdce4cSNemanja Ivanovicentry:
126b6fdce4cSNemanja Ivanovic  ret i16 -32767
127b6fdce4cSNemanja Ivanovic}
128b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f5sn
129b6fdce4cSNemanja Ivanovic; CHECK: li 3, -32767
130b6fdce4cSNemanja Ivanovic
131b6fdce4cSNemanja Ivanovicdefine signext i16 @f6sn() {
132b6fdce4cSNemanja Ivanovicentry:
133b6fdce4cSNemanja Ivanovic  ret i16 -32768
134b6fdce4cSNemanja Ivanovic}
135b6fdce4cSNemanja Ivanovic; CHECK-LABEL: @f6sn
136b6fdce4cSNemanja Ivanovic; CHECK: li 3, -32768
137