1 ; RUN: llc < %s -mtriple=powerpc64-unknown-linux-gnu | FileCheck %s --check-prefixes=PPC64
2 ; RUN: llc < %s -mtriple=powerpc-unknown-linux-gnu | FileCheck %s --check-prefixes=PPC32
4 define { i128, i8 } @muloti_test(i128 %l, i128 %r) unnamed_addr #0 {
6 ; PPC64-LABEL muloti_test:
8 ; PPC64-NEXT: cmpdi 5, 3, 0
9 ; PPC64-NEXT: mulhdu. 9, 3, 6
10 ; PPC64-NEXT: mulld 3, 3, 6
11 ; PPC64-NEXT: mcrf 1, 0
12 ; PPC64-NEXT: add 3, 3, 8
13 ; PPC64-NEXT: cmpdi 5, 0
14 ; PPC64-NEXT: crnor 20, 2, 22
15 ; PPC64-NEXT: cmpldi 3, 0
16 ; PPC64-NEXT: mulhdu 8, 4, 6
17 ; PPC64-NEXT: add 3, 8, 3
18 ; PPC64-NEXT: cmpld 6, 3, 8
19 ; PPC64-NEXT: crandc 21, 24, 2
20 ; PPC64-NEXT: crorc 20, 20, 6
22 ; PPC64-NEXT: mulhdu. 5, 5, 4
23 ; PPC64-NEXT: crorc 20, 20, 2
24 ; PPC64-NEXT: crnor 20, 20, 21
25 ; PPC64-NEXT: mulld 4, 4, 6
26 ; PPC64-NEXT: bc 12, 20, .LBB0_2
29 ; PPC64-NEXT: .LBB0_2:
30 ; PPC64-NEXT: addi 5, 0, 0
33 ; PPC32-LABEL muloti_test:
35 ; PPC32-NEXT: stw 0, 4(1)
36 ; PPC32-NEXT: stwu 1, -80(1)
37 ; PPC32-NEXT: .cfi_def_cfa_offset 80
38 ; PPC32-NEXT: .cfi_offset lr, 4
39 ; PPC32-NEXT: .cfi_offset r20, -48
40 ; PPC32-NEXT: .cfi_offset r21, -44
41 ; PPC32-NEXT: .cfi_offset r22, -40
42 ; PPC32-NEXT: .cfi_offset r23, -36
43 ; PPC32-NEXT: .cfi_offset r24, -32
44 ; PPC32-NEXT: .cfi_offset r25, -28
45 ; PPC32-NEXT: .cfi_offset r26, -24
46 ; PPC32-NEXT: .cfi_offset r27, -20
47 ; PPC32-NEXT: .cfi_offset r28, -16
48 ; PPC32-NEXT: .cfi_offset r29, -12
49 ; PPC32-NEXT: .cfi_offset r30, -8
50 ; PPC32-NEXT: stw 26, 56(1)
51 ; PPC32-NEXT: stw 27, 60(1)
52 ; PPC32-NEXT: stw 29, 68(1)
53 ; PPC32-NEXT: stw 30, 72(1)
55 ; PPC32-NEXT: mr 30, 8
56 ; PPC32-NEXT: mr 29, 7
57 ; PPC32-NEXT: mr 27, 4
58 ; PPC32-NEXT: mr 26, 3
63 ; PPC32-NEXT: stw 20, 32(1)
64 ; PPC32-NEXT: stw 21, 36(1)
65 ; PPC32-NEXT: stw 22, 40(1)
66 ; PPC32-NEXT: stw 23, 44(1)
67 ; PPC32-NEXT: stw 24, 48(1)
68 ; PPC32-NEXT: stw 25, 52(1)
69 ; PPC32-NEXT: stw 28, 64(1)
70 ; PPC32-NEXT: mr 25, 10
71 ; PPC32-NEXT: stw 12, 28(1)
72 ; PPC32-NEXT: mr 28, 9
73 ; PPC32-NEXT: mr 23, 6
74 ; PPC32-NEXT: mr 24, 5
75 ; PPC32-NEXT: bl __multi3@PLT
77 ; PPC32-NEXT: mullw 4, 24, 30
78 ; PPC32-NEXT: mullw 8, 29, 23
79 ; PPC32-NEXT: mullw 10, 28, 27
80 ; PPC32-NEXT: mullw 11, 26, 25
81 ; PPC32-NEXT: mulhwu 9, 30, 23
82 ; PPC32-NEXT: mulhwu 12, 27, 25
83 ; PPC32-NEXT: mullw 0, 30, 23
84 ; PPC32-NEXT: mullw 22, 27, 25
85 ; PPC32-NEXT: add 21, 8, 4
86 ; PPC32-NEXT: add 10, 11, 10
87 ; PPC32-NEXT: addc 4, 22, 0
88 ; PPC32-NEXT: add 11, 9, 21
89 ; PPC32-NEXT: add 0, 12, 10
90 ; PPC32-NEXT: adde 8, 0, 11
91 ; PPC32-NEXT: addc 4, 7, 4
92 ; PPC32-NEXT: adde 8, 3, 8
93 ; PPC32-NEXT: xor 22, 4, 7
94 ; PPC32-NEXT: xor 20, 8, 3
95 ; PPC32-NEXT: or. 22, 22, 20
96 ; PPC32-NEXT: mcrf 1, 0
97 ; PPC32-NEXT: cmpwi 29, 0
98 ; PPC32-NEXT: cmpwi 5, 24, 0
99 ; PPC32-NEXT: cmpwi 6, 26, 0
100 ; PPC32-NEXT: cmpwi 7, 28, 0
101 ; PPC32-NEXT: crnor 8, 22, 2
102 ; PPC32-NEXT: mulhwu. 23, 29, 23
103 ; PPC32-NEXT: crnor 9, 30, 26
104 ; PPC32-NEXT: mcrf 5, 0
105 ; PPC32-NEXT: cmplwi 21, 0
106 ; PPC32-NEXT: cmplw 6, 11, 9
107 ; PPC32-NEXT: cmplwi 7, 10, 0
108 ; PPC32-NEXT: crandc 10, 24, 2
109 ; PPC32-NEXT: cmplw 3, 0, 12
110 ; PPC32-NEXT: mulhwu. 9, 24, 30
111 ; PPC32-NEXT: mcrf 6, 0
112 ; PPC32-NEXT: crandc 11, 12, 30
113 ; PPC32-NEXT: cmplw 4, 7
114 ; PPC32-NEXT: cmplw 7, 8, 3
115 ; PPC32-NEXT: crand 12, 30, 0
116 ; PPC32-NEXT: crandc 13, 28, 30
117 ; PPC32-NEXT: mulhwu. 3, 26, 25
118 ; PPC32-NEXT: mcrf 7, 0
119 ; PPC32-NEXT: cror 0, 12, 13
120 ; PPC32-NEXT: crandc 12, 0, 6
121 ; PPC32-NEXT: crorc 20, 8, 22
122 ; PPC32-NEXT: crorc 20, 20, 26
123 ; PPC32-NEXT: mulhwu. 3, 28, 27
124 ; PPC32-NEXT: mcrf 1, 0
125 ; PPC32-NEXT: crorc 25, 9, 30
126 ; PPC32-NEXT: or. 3, 27, 26
127 ; PPC32-NEXT: cror 24, 20, 10
128 ; PPC32-NEXT: mcrf 5, 0
129 ; PPC32-NEXT: crorc 25, 25, 6
130 ; PPC32-NEXT: or. 3, 30, 29
131 ; PPC32-NEXT: cror 25, 25, 11
132 ; PPC32-NEXT: crnor 20, 2, 22
133 ; PPC32-NEXT: lwz 12, 28(1)
134 ; PPC32-NEXT: cror 20, 20, 25
135 ; PPC32-NEXT: cror 20, 20, 24
136 ; PPC32-NEXT: crnor 20, 20, 12
137 ; PPC32-NEXT: li 3, 1
138 ; PPC32-NEXT: bc 12, 20, .LBB0_2
140 ; PPC32-NEXT: b .LBB0_3
141 ; PPC32-NEXT:.LBB0_2:
142 ; PPC32-NEXT: addi 7, 0, 0
143 ; PPC32-NEXT:.LBB0_3:
144 ; PPC32-NEXT: mr 3, 8
145 ; PPC32-NEXT: mtcrf 32, 12
146 ; PPC32-NEXT: mtcrf 16, 12
147 ; PPC32-NEXT: lwz 30, 72(1)
148 ; PPC32-NEXT: lwz 29, 68(1)
149 ; PPC32-NEXT: lwz 28, 64(1)
150 ; PPC32-NEXT: lwz 27, 60(1)
151 ; PPC32-NEXT: lwz 26, 56(1)
152 ; PPC32-NEXT: lwz 25, 52(1)
153 ; PPC32-NEXT: lwz 24, 48(1)
154 ; PPC32-NEXT: lwz 23, 44(1)
155 ; PPC32-NEXT: lwz 22, 40(1)
156 ; PPC32-NEXT: lwz 21, 36(1)
157 ; PPC32-NEXT: lwz 20, 32(1)
158 ; PPC32-NEXT: lwz 0, 84(1)
159 ; PPC32-NEXT: addi 1, 1, 80
163 %0 = tail call { i128, i1 } @llvm.umul.with.overflow.i128(i128 %l, i128 %r) #2
164 %1 = extractvalue { i128, i1 } %0, 0
165 %2 = extractvalue { i128, i1 } %0, 1
166 %3 = zext i1 %2 to i8
167 %4 = insertvalue { i128, i8 } undef, i128 %1, 0
168 %5 = insertvalue { i128, i8 } %4, i8 %3, 1
172 ; Function Attrs: nounwind readnone speculatable
173 declare { i128, i1 } @llvm.umul.with.overflow.i128(i128, i128) #1
175 attributes #0 = { nounwind readnone uwtable }
176 attributes #1 = { nounwind readnone speculatable }
177 attributes #2 = { nounwind }