@@ -11,24 +11,23 @@ define <8 x float> @powi_v8f32(<8 x float> %va, i32 %b) nounwind {
11
11
; CHECK-NEXT: st.d $fp, $sp, 80 # 8-byte Folded Spill
12
12
; CHECK-NEXT: xvst $xr0, $sp, 16 # 32-byte Folded Spill
13
13
; CHECK-NEXT: addi.w $fp, $a0, 0
14
- ; CHECK-NEXT: xvpickve2gr.w $a0, $xr0, 0
14
+ ; CHECK-NEXT: xvpickve2gr.w $a0, $xr0, 1
15
15
; CHECK-NEXT: movgr2fr.w $fa0, $a0
16
16
; CHECK-NEXT: move $a0, $fp
17
17
; CHECK-NEXT: pcaddu18i $ra, %call36(__powisf2)
18
18
; CHECK-NEXT: jirl $ra, $ra, 0
19
19
; CHECK-NEXT: # kill: def $f0 killed $f0 def $xr0
20
- ; CHECK-NEXT: xvinsve0.w $xr0, $xr0, 0
21
20
; CHECK-NEXT: xvst $xr0, $sp, 48 # 32-byte Folded Spill
22
21
; CHECK-NEXT: xvld $xr0, $sp, 16 # 32-byte Folded Reload
23
- ; CHECK-NEXT: xvpickve2gr.w $a0, $xr0, 1
22
+ ; CHECK-NEXT: xvpickve2gr.w $a0, $xr0, 0
24
23
; CHECK-NEXT: movgr2fr.w $fa0, $a0
25
24
; CHECK-NEXT: move $a0, $fp
26
25
; CHECK-NEXT: pcaddu18i $ra, %call36(__powisf2)
27
26
; CHECK-NEXT: jirl $ra, $ra, 0
28
27
; CHECK-NEXT: # kill: def $f0 killed $f0 def $xr0
29
28
; CHECK-NEXT: xvld $xr1, $sp, 48 # 32-byte Folded Reload
30
- ; CHECK-NEXT: xvinsve0.w $xr1 , $xr0 , 1
31
- ; CHECK-NEXT: xvst $xr1 , $sp, 48 # 32-byte Folded Spill
29
+ ; CHECK-NEXT: xvinsve0.w $xr0 , $xr1 , 1
30
+ ; CHECK-NEXT: xvst $xr0 , $sp, 48 # 32-byte Folded Spill
32
31
; CHECK-NEXT: xvld $xr0, $sp, 16 # 32-byte Folded Reload
33
32
; CHECK-NEXT: xvpickve2gr.w $a0, $xr0, 2
34
33
; CHECK-NEXT: movgr2fr.w $fa0, $a0
@@ -106,44 +105,43 @@ define <4 x double> @powi_v4f64(<4 x double> %va, i32 %b) nounwind {
106
105
; CHECK-NEXT: addi.d $sp, $sp, -96
107
106
; CHECK-NEXT: st.d $ra, $sp, 88 # 8-byte Folded Spill
108
107
; CHECK-NEXT: st.d $fp, $sp, 80 # 8-byte Folded Spill
109
- ; CHECK-NEXT: xvst $xr0, $sp, 16 # 32-byte Folded Spill
108
+ ; CHECK-NEXT: xvst $xr0, $sp, 48 # 32-byte Folded Spill
110
109
; CHECK-NEXT: addi.w $fp, $a0, 0
111
- ; CHECK-NEXT: xvpickve2gr.d $a0, $xr0, 0
110
+ ; CHECK-NEXT: xvpickve2gr.d $a0, $xr0, 1
112
111
; CHECK-NEXT: movgr2fr.d $fa0, $a0
113
112
; CHECK-NEXT: move $a0, $fp
114
113
; CHECK-NEXT: pcaddu18i $ra, %call36(__powidf2)
115
114
; CHECK-NEXT: jirl $ra, $ra, 0
116
115
; CHECK-NEXT: # kill: def $f0_64 killed $f0_64 def $xr0
117
- ; CHECK-NEXT: xvinsve0.d $xr0, $xr0, 0
118
- ; CHECK-NEXT: xvst $xr0, $sp, 48 # 32-byte Folded Spill
119
- ; CHECK-NEXT: xvld $xr0, $sp, 16 # 32-byte Folded Reload
120
- ; CHECK-NEXT: xvpickve2gr.d $a0, $xr0, 1
116
+ ; CHECK-NEXT: xvst $xr0, $sp, 16 # 32-byte Folded Spill
117
+ ; CHECK-NEXT: xvld $xr0, $sp, 48 # 32-byte Folded Reload
118
+ ; CHECK-NEXT: xvpickve2gr.d $a0, $xr0, 0
121
119
; CHECK-NEXT: movgr2fr.d $fa0, $a0
122
120
; CHECK-NEXT: move $a0, $fp
123
121
; CHECK-NEXT: pcaddu18i $ra, %call36(__powidf2)
124
122
; CHECK-NEXT: jirl $ra, $ra, 0
125
123
; CHECK-NEXT: # kill: def $f0_64 killed $f0_64 def $xr0
126
- ; CHECK-NEXT: xvld $xr1, $sp, 48 # 32-byte Folded Reload
127
- ; CHECK-NEXT: xvinsve0.d $xr1 , $xr0 , 1
128
- ; CHECK-NEXT: xvst $xr1 , $sp, 48 # 32-byte Folded Spill
129
- ; CHECK-NEXT: xvld $xr0, $sp, 16 # 32-byte Folded Reload
124
+ ; CHECK-NEXT: xvld $xr1, $sp, 16 # 32-byte Folded Reload
125
+ ; CHECK-NEXT: xvinsve0.d $xr0 , $xr1 , 1
126
+ ; CHECK-NEXT: xvst $xr0 , $sp, 16 # 32-byte Folded Spill
127
+ ; CHECK-NEXT: xvld $xr0, $sp, 48 # 32-byte Folded Reload
130
128
; CHECK-NEXT: xvpickve2gr.d $a0, $xr0, 2
131
129
; CHECK-NEXT: movgr2fr.d $fa0, $a0
132
130
; CHECK-NEXT: move $a0, $fp
133
131
; CHECK-NEXT: pcaddu18i $ra, %call36(__powidf2)
134
132
; CHECK-NEXT: jirl $ra, $ra, 0
135
133
; CHECK-NEXT: # kill: def $f0_64 killed $f0_64 def $xr0
136
- ; CHECK-NEXT: xvld $xr1, $sp, 48 # 32-byte Folded Reload
134
+ ; CHECK-NEXT: xvld $xr1, $sp, 16 # 32-byte Folded Reload
137
135
; CHECK-NEXT: xvinsve0.d $xr1, $xr0, 2
138
- ; CHECK-NEXT: xvst $xr1, $sp, 48 # 32-byte Folded Spill
139
- ; CHECK-NEXT: xvld $xr0, $sp, 16 # 32-byte Folded Reload
136
+ ; CHECK-NEXT: xvst $xr1, $sp, 16 # 32-byte Folded Spill
137
+ ; CHECK-NEXT: xvld $xr0, $sp, 48 # 32-byte Folded Reload
140
138
; CHECK-NEXT: xvpickve2gr.d $a0, $xr0, 3
141
139
; CHECK-NEXT: movgr2fr.d $fa0, $a0
142
140
; CHECK-NEXT: move $a0, $fp
143
141
; CHECK-NEXT: pcaddu18i $ra, %call36(__powidf2)
144
142
; CHECK-NEXT: jirl $ra, $ra, 0
145
143
; CHECK-NEXT: # kill: def $f0_64 killed $f0_64 def $xr0
146
- ; CHECK-NEXT: xvld $xr1, $sp, 48 # 32-byte Folded Reload
144
+ ; CHECK-NEXT: xvld $xr1, $sp, 16 # 32-byte Folded Reload
147
145
; CHECK-NEXT: xvinsve0.d $xr1, $xr0, 3
148
146
; CHECK-NEXT: xvori.b $xr0, $xr1, 0
149
147
; CHECK-NEXT: ld.d $fp, $sp, 80 # 8-byte Folded Reload
0 commit comments