@@ -32,110 +32,103 @@ define { i128, i8 } @muloti_test(i128 %l, i128 %r) unnamed_addr #0 {
32
32
;
33
33
; PPC32-LABEL: muloti_test:
34
34
; PPC32: # %bb.0: # %start
35
- ; PPC32-NEXT: mflr 0
36
- ; PPC32-NEXT: stw 0, 4(1)
37
35
; PPC32-NEXT: stwu 1, -64(1)
38
- ; PPC32-NEXT: stw 24, 32(1) # 4-byte Folded Spill
39
- ; PPC32-NEXT: mfcr 12
40
36
; PPC32-NEXT: stw 26, 40(1) # 4-byte Folded Spill
41
- ; PPC32-NEXT: mr 26, 7
42
- ; PPC32-NEXT: stw 28, 48(1) # 4-byte Folded Spill
43
- ; PPC32-NEXT: mr 28, 4
44
- ; PPC32-NEXT: stw 29, 52(1) # 4-byte Folded Spill
45
- ; PPC32-NEXT: mr 29, 8
46
- ; PPC32-NEXT: mr 24, 3
47
- ; PPC32-NEXT: li 3, 0
48
- ; PPC32-NEXT: li 4, 0
49
- ; PPC32-NEXT: li 7, 0
50
- ; PPC32-NEXT: li 8, 0
37
+ ; PPC32-NEXT: mulhwu. 26, 7, 6
38
+ ; PPC32-NEXT: mcrf 1, 0
39
+ ; PPC32-NEXT: mfcr 12
40
+ ; PPC32-NEXT: cmpwi 7, 5, 0
41
+ ; PPC32-NEXT: cmpwi 2, 7, 0
42
+ ; PPC32-NEXT: stw 22, 24(1) # 4-byte Folded Spill
43
+ ; PPC32-NEXT: mulhwu. 26, 5, 8
44
+ ; PPC32-NEXT: mcrf 5, 0
51
45
; PPC32-NEXT: stw 23, 28(1) # 4-byte Folded Spill
52
- ; PPC32-NEXT: mr 23, 5
46
+ ; PPC32-NEXT: crnor 28, 30, 10
47
+ ; PPC32-NEXT: stw 29, 52(1) # 4-byte Folded Spill
48
+ ; PPC32-NEXT: cmpwi 2, 9, 0
49
+ ; PPC32-NEXT: mulhwu. 26, 3, 10
50
+ ; PPC32-NEXT: mcrf 6, 0
51
+ ; PPC32-NEXT: cmpwi 3, 3, 0
52
+ ; PPC32-NEXT: stw 24, 32(1) # 4-byte Folded Spill
53
+ ; PPC32-NEXT: crnor 29, 10, 14
53
54
; PPC32-NEXT: stw 25, 36(1) # 4-byte Folded Spill
54
- ; PPC32-NEXT: mr 25 , 9
55
+ ; PPC32-NEXT: mulhwu. 26 , 9, 4
55
56
; PPC32-NEXT: stw 27, 44(1) # 4-byte Folded Spill
56
- ; PPC32-NEXT: mr 27, 6
57
+ ; PPC32-NEXT: crorc 28, 28, 6
58
+ ; PPC32-NEXT: stw 28, 48(1) # 4-byte Folded Spill
59
+ ; PPC32-NEXT: crorc 20, 28, 22
57
60
; PPC32-NEXT: stw 30, 56(1) # 4-byte Folded Spill
58
- ; PPC32-NEXT: mr 30, 10
59
- ; PPC32-NEXT: stw 12, 24(1)
60
- ; PPC32-NEXT: bl __multi3
61
- ; PPC32-NEXT: mulhwu. 9, 26, 27
62
- ; PPC32-NEXT: mfcr 9 # cr0
63
- ; PPC32-NEXT: cmpwi 2, 26, 0
64
- ; PPC32-NEXT: stw 9, 20(1)
65
- ; PPC32-NEXT: cmpwi 3, 23, 0
66
- ; PPC32-NEXT: crnor 12, 14, 10
67
- ; PPC32-NEXT: cmpwi 4, 24, 0
68
- ; PPC32-NEXT: mulhwu. 9, 23, 29
69
- ; PPC32-NEXT: mcrf 5, 0
70
- ; PPC32-NEXT: cmpwi 1, 25, 0
71
- ; PPC32-NEXT: crnor 4, 6, 18
72
- ; PPC32-NEXT: mulhwu. 9, 24, 30
73
- ; PPC32-NEXT: mcrf 6, 0
74
- ; PPC32-NEXT: mulhwu. 0, 25, 28
75
- ; PPC32-NEXT: mcrf 7, 0
76
- ; PPC32-NEXT: or. 0, 28, 24
77
- ; PPC32-NEXT: mcrf 2, 0
78
- ; PPC32-NEXT: or. 0, 29, 26
79
- ; PPC32-NEXT: crnor 5, 2, 10
80
- ; PPC32-NEXT: mullw 10, 26, 27
81
- ; PPC32-NEXT: lwz 26, 20(1)
82
- ; PPC32-NEXT: mullw 9, 23, 29
83
- ; PPC32-NEXT: add 9, 10, 9
84
- ; PPC32-NEXT: mtcrf 128, 26 # cr0
85
- ; PPC32-NEXT: crorc 6, 12, 2
86
- ; PPC32-NEXT: crorc 20, 6, 22
87
- ; PPC32-NEXT: mulhwu 7, 29, 27
88
- ; PPC32-NEXT: add 9, 7, 9
89
- ; PPC32-NEXT: cmplw 9, 7
90
- ; PPC32-NEXT: crorc 21, 4, 26
91
- ; PPC32-NEXT: cror 20, 20, 0
92
- ; PPC32-NEXT: crorc 21, 21, 30
93
- ; PPC32-NEXT: mullw 11, 25, 28
94
- ; PPC32-NEXT: mullw 12, 24, 30
95
- ; PPC32-NEXT: add 10, 12, 11
96
- ; PPC32-NEXT: lwz 12, 24(1)
97
- ; PPC32-NEXT: lwz 26, 40(1) # 4-byte Folded Reload
98
- ; PPC32-NEXT: mulhwu 8, 28, 30
99
- ; PPC32-NEXT: add 10, 8, 10
100
- ; PPC32-NEXT: cmplw 10, 8
101
- ; PPC32-NEXT: cror 21, 21, 0
102
- ; PPC32-NEXT: cror 21, 5, 21
61
+ ; PPC32-NEXT: mulhwu 0, 6, 10
62
+ ; PPC32-NEXT: stw 12, 20(1)
63
+ ; PPC32-NEXT: crorc 21, 29, 26
64
+ ; PPC32-NEXT: crorc 21, 21, 2
65
+ ; PPC32-NEXT: li 11, 0
66
+ ; PPC32-NEXT: mullw 26, 5, 10
67
+ ; PPC32-NEXT: addc 0, 26, 0
68
+ ; PPC32-NEXT: mulhwu 29, 5, 10
69
+ ; PPC32-NEXT: addze 29, 29
70
+ ; PPC32-NEXT: mullw 23, 5, 8
71
+ ; PPC32-NEXT: mullw 22, 7, 6
72
+ ; PPC32-NEXT: mulhwu 30, 6, 9
73
+ ; PPC32-NEXT: mulhwu 12, 5, 9
74
+ ; PPC32-NEXT: mulhwu 28, 8, 6
75
+ ; PPC32-NEXT: mullw 25, 6, 9
76
+ ; PPC32-NEXT: mullw 24, 5, 9
77
+ ; PPC32-NEXT: mullw 5, 9, 4
78
+ ; PPC32-NEXT: add 9, 22, 23
79
+ ; PPC32-NEXT: add 9, 28, 9
80
+ ; PPC32-NEXT: cmplw 1, 9, 28
81
+ ; PPC32-NEXT: cror 20, 20, 4
82
+ ; PPC32-NEXT: mullw 23, 3, 10
83
+ ; PPC32-NEXT: add 26, 23, 5
84
+ ; PPC32-NEXT: addc 5, 25, 0
85
+ ; PPC32-NEXT: addze 30, 30
86
+ ; PPC32-NEXT: or. 3, 4, 3
87
+ ; PPC32-NEXT: mulhwu 27, 4, 10
88
+ ; PPC32-NEXT: mcrf 1, 0
89
+ ; PPC32-NEXT: addc 3, 29, 30
90
+ ; PPC32-NEXT: add 26, 27, 26
91
+ ; PPC32-NEXT: cmplw 6, 26, 27
92
+ ; PPC32-NEXT: cror 21, 21, 24
93
+ ; PPC32-NEXT: mullw 0, 4, 10
94
+ ; PPC32-NEXT: or. 4, 8, 7
95
+ ; PPC32-NEXT: addze 4, 11
96
+ ; PPC32-NEXT: addc 7, 24, 3
97
+ ; PPC32-NEXT: crnor 22, 2, 6
98
+ ; PPC32-NEXT: mullw 28, 8, 6
99
+ ; PPC32-NEXT: adde 8, 12, 4
100
+ ; PPC32-NEXT: addc 3, 0, 28
101
+ ; PPC32-NEXT: adde 9, 26, 9
102
+ ; PPC32-NEXT: addc 4, 7, 3
103
+ ; PPC32-NEXT: adde 3, 8, 9
104
+ ; PPC32-NEXT: cror 21, 22, 21
105
+ ; PPC32-NEXT: cmplw 4, 7
106
+ ; PPC32-NEXT: cmplw 1, 3, 8
107
+ ; PPC32-NEXT: lwz 12, 20(1)
103
108
; PPC32-NEXT: cror 20, 21, 20
104
- ; PPC32-NEXT: mullw 0, 29, 27
109
+ ; PPC32-NEXT: crandc 21, 4, 6
110
+ ; PPC32-NEXT: crand 22, 6, 0
111
+ ; PPC32-NEXT: cror 21, 22, 21
112
+ ; PPC32-NEXT: crnor 20, 20, 21
113
+ ; PPC32-NEXT: li 7, 1
114
+ ; PPC32-NEXT: mullw 6, 6, 10
115
+ ; PPC32-NEXT: bc 12, 20, .LBB0_1
116
+ ; PPC32-NEXT: b .LBB0_2
117
+ ; PPC32-NEXT: .LBB0_1: # %start
118
+ ; PPC32-NEXT: li 7, 0
119
+ ; PPC32-NEXT: .LBB0_2: # %start
105
120
; PPC32-NEXT: mtcrf 32, 12 # cr2
106
121
; PPC32-NEXT: mtcrf 16, 12 # cr3
107
- ; PPC32-NEXT: mtcrf 8, 12 # cr4
108
- ; PPC32-NEXT: lwz 29, 52(1) # 4-byte Folded Reload
109
- ; PPC32-NEXT: mullw 7, 28, 30
110
- ; PPC32-NEXT: addc 7, 7, 0
111
- ; PPC32-NEXT: adde 11, 10, 9
112
- ; PPC32-NEXT: addc 9, 4, 7
113
- ; PPC32-NEXT: adde 8, 3, 11
114
- ; PPC32-NEXT: cmplw 6, 9, 4
115
- ; PPC32-NEXT: cmplw 8, 3
116
- ; PPC32-NEXT: crand 22, 2, 24
117
- ; PPC32-NEXT: crandc 23, 0, 2
118
- ; PPC32-NEXT: cror 22, 22, 23
119
- ; PPC32-NEXT: crnor 20, 20, 22
120
- ; PPC32-NEXT: li 3, 1
121
- ; PPC32-NEXT: bc 12, 20, .LBB0_2
122
- ; PPC32-NEXT: # %bb.1: # %start
123
- ; PPC32-NEXT: ori 7, 3, 0
124
- ; PPC32-NEXT: b .LBB0_3
125
- ; PPC32-NEXT: .LBB0_2: # %start
126
- ; PPC32-NEXT: li 7, 0
127
- ; PPC32-NEXT: .LBB0_3: # %start
128
- ; PPC32-NEXT: mr 3, 8
129
- ; PPC32-NEXT: mr 4, 9
130
122
; PPC32-NEXT: lwz 30, 56(1) # 4-byte Folded Reload
123
+ ; PPC32-NEXT: lwz 29, 52(1) # 4-byte Folded Reload
131
124
; PPC32-NEXT: lwz 28, 48(1) # 4-byte Folded Reload
132
125
; PPC32-NEXT: lwz 27, 44(1) # 4-byte Folded Reload
126
+ ; PPC32-NEXT: lwz 26, 40(1) # 4-byte Folded Reload
133
127
; PPC32-NEXT: lwz 25, 36(1) # 4-byte Folded Reload
134
128
; PPC32-NEXT: lwz 24, 32(1) # 4-byte Folded Reload
135
129
; PPC32-NEXT: lwz 23, 28(1) # 4-byte Folded Reload
136
- ; PPC32-NEXT: lwz 0, 68 (1)
130
+ ; PPC32-NEXT: lwz 22, 24 (1) # 4-byte Folded Reload
137
131
; PPC32-NEXT: addi 1, 1, 64
138
- ; PPC32-NEXT: mtlr 0
139
132
; PPC32-NEXT: blr
140
133
start:
141
134
%0 = tail call { i128 , i1 } @llvm.umul.with.overflow.i128 (i128 %l , i128 %r ) #2
0 commit comments