]>
Commit | Line | Data |
---|---|---|
a7812ae4 | 1 | #include "def-helper.h" |
f10dc08e | 2 | |
e5f17ac6 BS |
3 | DEF_HELPER_3(raise_exception_err, void, env, i32, i32) |
4 | DEF_HELPER_2(raise_exception, void, env, i32) | |
5 | DEF_HELPER_4(tw, void, env, tl, tl, i32) | |
cab3bee2 | 6 | #if defined(TARGET_PPC64) |
e5f17ac6 | 7 | DEF_HELPER_4(td, void, env, tl, tl, i32) |
cab3bee2 | 8 | #endif |
d72a19f7 | 9 | #if !defined(CONFIG_USER_ONLY) |
e5f17ac6 BS |
10 | DEF_HELPER_2(store_msr, void, env, tl) |
11 | DEF_HELPER_1(rfi, void, env) | |
12 | DEF_HELPER_1(rfsvc, void, env) | |
13 | DEF_HELPER_1(40x_rfci, void, env) | |
14 | DEF_HELPER_1(rfci, void, env) | |
15 | DEF_HELPER_1(rfdi, void, env) | |
16 | DEF_HELPER_1(rfmci, void, env) | |
d72a19f7 | 17 | #if defined(TARGET_PPC64) |
e5f17ac6 BS |
18 | DEF_HELPER_1(rfid, void, env) |
19 | DEF_HELPER_1(hrfid, void, env) | |
d72a19f7 AJ |
20 | #endif |
21 | #endif | |
64adab3f | 22 | |
ff4a62cd AJ |
23 | DEF_HELPER_2(lmw, void, tl, i32) |
24 | DEF_HELPER_2(stmw, void, tl, i32) | |
dfbc799d AJ |
25 | DEF_HELPER_3(lsw, void, tl, i32, i32) |
26 | DEF_HELPER_4(lswx, void, tl, i32, i32, i32) | |
27 | DEF_HELPER_3(stsw, void, tl, i32, i32) | |
799a8c8d AJ |
28 | DEF_HELPER_1(dcbz, void, tl) |
29 | DEF_HELPER_1(dcbz_970, void, tl) | |
37d269df | 30 | DEF_HELPER_1(icbi, void, tl) |
bdb4b689 AJ |
31 | DEF_HELPER_4(lscbx, tl, tl, i32, i32, i32) |
32 | ||
74637406 | 33 | #if defined(TARGET_PPC64) |
69a218fc AJ |
34 | DEF_HELPER_FLAGS_2(mulhd, TCG_CALL_CONST | TCG_CALL_PURE, i64, i64, i64) |
35 | DEF_HELPER_FLAGS_2(mulhdu, TCG_CALL_CONST | TCG_CALL_PURE, i64, i64, i64) | |
a7812ae4 | 36 | DEF_HELPER_2(mulldo, i64, i64, i64) |
74637406 AJ |
37 | #endif |
38 | ||
69a218fc AJ |
39 | DEF_HELPER_FLAGS_1(cntlzw, TCG_CALL_CONST | TCG_CALL_PURE, tl, tl) |
40 | DEF_HELPER_FLAGS_1(popcntb, TCG_CALL_CONST | TCG_CALL_PURE, tl, tl) | |
eaabeef2 | 41 | DEF_HELPER_FLAGS_1(popcntw, TCG_CALL_CONST | TCG_CALL_PURE, tl, tl) |
a7812ae4 | 42 | DEF_HELPER_2(sraw, tl, tl, tl) |
26d67362 | 43 | #if defined(TARGET_PPC64) |
69a218fc | 44 | DEF_HELPER_FLAGS_1(cntlzd, TCG_CALL_CONST | TCG_CALL_PURE, tl, tl) |
eaabeef2 | 45 | DEF_HELPER_FLAGS_1(popcntd, TCG_CALL_CONST | TCG_CALL_PURE, tl, tl) |
a7812ae4 | 46 | DEF_HELPER_2(srad, tl, tl, tl) |
26d67362 AJ |
47 | #endif |
48 | ||
69a218fc AJ |
49 | DEF_HELPER_FLAGS_1(cntlsw32, TCG_CALL_CONST | TCG_CALL_PURE, i32, i32) |
50 | DEF_HELPER_FLAGS_1(cntlzw32, TCG_CALL_CONST | TCG_CALL_PURE, i32, i32) | |
51 | DEF_HELPER_FLAGS_2(brinc, TCG_CALL_CONST | TCG_CALL_PURE, tl, tl, tl) | |
a7812ae4 | 52 | |
8e703949 BS |
53 | DEF_HELPER_1(float_check_status, void, env) |
54 | DEF_HELPER_1(reset_fpstatus, void, env) | |
55 | DEF_HELPER_3(compute_fprf, i32, env, i64, i32) | |
56 | DEF_HELPER_3(store_fpscr, void, env, i64, i32) | |
57 | DEF_HELPER_2(fpscr_clrbit, void, env, i32) | |
58 | DEF_HELPER_2(fpscr_setbit, void, env, i32) | |
59 | DEF_HELPER_2(float64_to_float32, i32, env, i64) | |
60 | DEF_HELPER_2(float32_to_float64, i64, env, i32) | |
af12906f | 61 | |
8e703949 BS |
62 | DEF_HELPER_4(fcmpo, void, env, i64, i64, i32) |
63 | DEF_HELPER_4(fcmpu, void, env, i64, i64, i32) | |
d72a19f7 | 64 | |
8e703949 BS |
65 | DEF_HELPER_2(fctiw, i64, env, i64) |
66 | DEF_HELPER_2(fctiwz, i64, env, i64) | |
af12906f | 67 | #if defined(TARGET_PPC64) |
8e703949 BS |
68 | DEF_HELPER_2(fcfid, i64, env, i64) |
69 | DEF_HELPER_2(fctid, i64, env, i64) | |
70 | DEF_HELPER_2(fctidz, i64, env, i64) | |
af12906f | 71 | #endif |
8e703949 BS |
72 | DEF_HELPER_2(frsp, i64, env, i64) |
73 | DEF_HELPER_2(frin, i64, env, i64) | |
74 | DEF_HELPER_2(friz, i64, env, i64) | |
75 | DEF_HELPER_2(frip, i64, env, i64) | |
76 | DEF_HELPER_2(frim, i64, env, i64) | |
af12906f | 77 | |
8e703949 BS |
78 | DEF_HELPER_3(fadd, i64, env, i64, i64) |
79 | DEF_HELPER_3(fsub, i64, env, i64, i64) | |
80 | DEF_HELPER_3(fmul, i64, env, i64, i64) | |
81 | DEF_HELPER_3(fdiv, i64, env, i64, i64) | |
82 | DEF_HELPER_4(fmadd, i64, env, i64, i64, i64) | |
83 | DEF_HELPER_4(fmsub, i64, env, i64, i64, i64) | |
84 | DEF_HELPER_4(fnmadd, i64, env, i64, i64, i64) | |
85 | DEF_HELPER_4(fnmsub, i64, env, i64, i64, i64) | |
86 | DEF_HELPER_2(fabs, i64, env, i64) | |
87 | DEF_HELPER_2(fnabs, i64, env, i64) | |
88 | DEF_HELPER_2(fneg, i64, env, i64) | |
89 | DEF_HELPER_2(fsqrt, i64, env, i64) | |
90 | DEF_HELPER_2(fre, i64, env, i64) | |
91 | DEF_HELPER_2(fres, i64, env, i64) | |
92 | DEF_HELPER_2(frsqrte, i64, env, i64) | |
93 | DEF_HELPER_4(fsel, i64, env, i64, i64, i64) | |
af12906f | 94 | |
7872c51c | 95 | #define dh_alias_avr ptr |
c227f099 | 96 | #define dh_ctype_avr ppc_avr_t * |
2bece2c8 | 97 | #define dh_is_signed_avr dh_is_signed_ptr |
7872c51c AJ |
98 | |
99 | DEF_HELPER_3(vaddubm, void, avr, avr, avr) | |
100 | DEF_HELPER_3(vadduhm, void, avr, avr, avr) | |
101 | DEF_HELPER_3(vadduwm, void, avr, avr, avr) | |
102 | DEF_HELPER_3(vsububm, void, avr, avr, avr) | |
103 | DEF_HELPER_3(vsubuhm, void, avr, avr, avr) | |
104 | DEF_HELPER_3(vsubuwm, void, avr, avr, avr) | |
fab3cbe9 AJ |
105 | DEF_HELPER_3(vavgub, void, avr, avr, avr) |
106 | DEF_HELPER_3(vavguh, void, avr, avr, avr) | |
107 | DEF_HELPER_3(vavguw, void, avr, avr, avr) | |
108 | DEF_HELPER_3(vavgsb, void, avr, avr, avr) | |
109 | DEF_HELPER_3(vavgsh, void, avr, avr, avr) | |
110 | DEF_HELPER_3(vavgsw, void, avr, avr, avr) | |
e4039339 AJ |
111 | DEF_HELPER_3(vminsb, void, avr, avr, avr) |
112 | DEF_HELPER_3(vminsh, void, avr, avr, avr) | |
113 | DEF_HELPER_3(vminsw, void, avr, avr, avr) | |
114 | DEF_HELPER_3(vmaxsb, void, avr, avr, avr) | |
115 | DEF_HELPER_3(vmaxsh, void, avr, avr, avr) | |
116 | DEF_HELPER_3(vmaxsw, void, avr, avr, avr) | |
117 | DEF_HELPER_3(vminub, void, avr, avr, avr) | |
118 | DEF_HELPER_3(vminuh, void, avr, avr, avr) | |
119 | DEF_HELPER_3(vminuw, void, avr, avr, avr) | |
120 | DEF_HELPER_3(vmaxub, void, avr, avr, avr) | |
121 | DEF_HELPER_3(vmaxuh, void, avr, avr, avr) | |
122 | DEF_HELPER_3(vmaxuw, void, avr, avr, avr) | |
1add6e23 AJ |
123 | DEF_HELPER_3(vcmpequb, void, avr, avr, avr) |
124 | DEF_HELPER_3(vcmpequh, void, avr, avr, avr) | |
125 | DEF_HELPER_3(vcmpequw, void, avr, avr, avr) | |
126 | DEF_HELPER_3(vcmpgtub, void, avr, avr, avr) | |
127 | DEF_HELPER_3(vcmpgtuh, void, avr, avr, avr) | |
128 | DEF_HELPER_3(vcmpgtuw, void, avr, avr, avr) | |
129 | DEF_HELPER_3(vcmpgtsb, void, avr, avr, avr) | |
130 | DEF_HELPER_3(vcmpgtsh, void, avr, avr, avr) | |
131 | DEF_HELPER_3(vcmpgtsw, void, avr, avr, avr) | |
819ca121 AJ |
132 | DEF_HELPER_3(vcmpeqfp, void, avr, avr, avr) |
133 | DEF_HELPER_3(vcmpgefp, void, avr, avr, avr) | |
134 | DEF_HELPER_3(vcmpgtfp, void, avr, avr, avr) | |
135 | DEF_HELPER_3(vcmpbfp, void, avr, avr, avr) | |
1add6e23 AJ |
136 | DEF_HELPER_3(vcmpequb_dot, void, avr, avr, avr) |
137 | DEF_HELPER_3(vcmpequh_dot, void, avr, avr, avr) | |
138 | DEF_HELPER_3(vcmpequw_dot, void, avr, avr, avr) | |
139 | DEF_HELPER_3(vcmpgtub_dot, void, avr, avr, avr) | |
140 | DEF_HELPER_3(vcmpgtuh_dot, void, avr, avr, avr) | |
141 | DEF_HELPER_3(vcmpgtuw_dot, void, avr, avr, avr) | |
142 | DEF_HELPER_3(vcmpgtsb_dot, void, avr, avr, avr) | |
143 | DEF_HELPER_3(vcmpgtsh_dot, void, avr, avr, avr) | |
144 | DEF_HELPER_3(vcmpgtsw_dot, void, avr, avr, avr) | |
819ca121 AJ |
145 | DEF_HELPER_3(vcmpeqfp_dot, void, avr, avr, avr) |
146 | DEF_HELPER_3(vcmpgefp_dot, void, avr, avr, avr) | |
147 | DEF_HELPER_3(vcmpgtfp_dot, void, avr, avr, avr) | |
148 | DEF_HELPER_3(vcmpbfp_dot, void, avr, avr, avr) | |
3b430048 AJ |
149 | DEF_HELPER_3(vmrglb, void, avr, avr, avr) |
150 | DEF_HELPER_3(vmrglh, void, avr, avr, avr) | |
151 | DEF_HELPER_3(vmrglw, void, avr, avr, avr) | |
152 | DEF_HELPER_3(vmrghb, void, avr, avr, avr) | |
153 | DEF_HELPER_3(vmrghh, void, avr, avr, avr) | |
154 | DEF_HELPER_3(vmrghw, void, avr, avr, avr) | |
2c277908 AJ |
155 | DEF_HELPER_3(vmulesb, void, avr, avr, avr) |
156 | DEF_HELPER_3(vmulesh, void, avr, avr, avr) | |
157 | DEF_HELPER_3(vmuleub, void, avr, avr, avr) | |
158 | DEF_HELPER_3(vmuleuh, void, avr, avr, avr) | |
159 | DEF_HELPER_3(vmulosb, void, avr, avr, avr) | |
160 | DEF_HELPER_3(vmulosh, void, avr, avr, avr) | |
161 | DEF_HELPER_3(vmuloub, void, avr, avr, avr) | |
162 | DEF_HELPER_3(vmulouh, void, avr, avr, avr) | |
07ef34c3 AJ |
163 | DEF_HELPER_3(vsrab, void, avr, avr, avr) |
164 | DEF_HELPER_3(vsrah, void, avr, avr, avr) | |
165 | DEF_HELPER_3(vsraw, void, avr, avr, avr) | |
166 | DEF_HELPER_3(vsrb, void, avr, avr, avr) | |
167 | DEF_HELPER_3(vsrh, void, avr, avr, avr) | |
168 | DEF_HELPER_3(vsrw, void, avr, avr, avr) | |
d79f0809 AJ |
169 | DEF_HELPER_3(vslb, void, avr, avr, avr) |
170 | DEF_HELPER_3(vslh, void, avr, avr, avr) | |
171 | DEF_HELPER_3(vslw, void, avr, avr, avr) | |
7b239bec AJ |
172 | DEF_HELPER_3(vslo, void, avr, avr, avr) |
173 | DEF_HELPER_3(vsro, void, avr, avr, avr) | |
e343da72 AJ |
174 | DEF_HELPER_3(vaddcuw, void, avr, avr, avr) |
175 | DEF_HELPER_3(vsubcuw, void, avr, avr, avr) | |
bf8d8ded AJ |
176 | DEF_HELPER_2(lvsl, void, avr, tl); |
177 | DEF_HELPER_2(lvsr, void, avr, tl); | |
5ab09f33 AJ |
178 | DEF_HELPER_3(vaddsbs, void, avr, avr, avr) |
179 | DEF_HELPER_3(vaddshs, void, avr, avr, avr) | |
180 | DEF_HELPER_3(vaddsws, void, avr, avr, avr) | |
181 | DEF_HELPER_3(vsubsbs, void, avr, avr, avr) | |
182 | DEF_HELPER_3(vsubshs, void, avr, avr, avr) | |
183 | DEF_HELPER_3(vsubsws, void, avr, avr, avr) | |
184 | DEF_HELPER_3(vaddubs, void, avr, avr, avr) | |
185 | DEF_HELPER_3(vadduhs, void, avr, avr, avr) | |
186 | DEF_HELPER_3(vadduws, void, avr, avr, avr) | |
187 | DEF_HELPER_3(vsububs, void, avr, avr, avr) | |
188 | DEF_HELPER_3(vsubuhs, void, avr, avr, avr) | |
189 | DEF_HELPER_3(vsubuws, void, avr, avr, avr) | |
5e1d0985 AJ |
190 | DEF_HELPER_3(vrlb, void, avr, avr, avr) |
191 | DEF_HELPER_3(vrlh, void, avr, avr, avr) | |
192 | DEF_HELPER_3(vrlw, void, avr, avr, avr) | |
d9430add AJ |
193 | DEF_HELPER_3(vsl, void, avr, avr, avr) |
194 | DEF_HELPER_3(vsr, void, avr, avr, avr) | |
cd633b10 | 195 | DEF_HELPER_4(vsldoi, void, avr, avr, avr, i32) |
c026766b AJ |
196 | DEF_HELPER_2(vspltisb, void, avr, i32) |
197 | DEF_HELPER_2(vspltish, void, avr, i32) | |
198 | DEF_HELPER_2(vspltisw, void, avr, i32) | |
e4e6bee7 AJ |
199 | DEF_HELPER_3(vspltb, void, avr, avr, i32) |
200 | DEF_HELPER_3(vsplth, void, avr, avr, i32) | |
201 | DEF_HELPER_3(vspltw, void, avr, avr, i32) | |
79f85c3a AJ |
202 | DEF_HELPER_2(vupkhpx, void, avr, avr) |
203 | DEF_HELPER_2(vupklpx, void, avr, avr) | |
6cf1c6e5 AJ |
204 | DEF_HELPER_2(vupkhsb, void, avr, avr) |
205 | DEF_HELPER_2(vupkhsh, void, avr, avr) | |
206 | DEF_HELPER_2(vupklsb, void, avr, avr) | |
207 | DEF_HELPER_2(vupklsh, void, avr, avr) | |
b04ae981 AJ |
208 | DEF_HELPER_4(vmsumubm, void, avr, avr, avr, avr) |
209 | DEF_HELPER_4(vmsummbm, void, avr, avr, avr, avr) | |
d1258698 AJ |
210 | DEF_HELPER_4(vsel, void, avr, avr, avr, avr) |
211 | DEF_HELPER_4(vperm, void, avr, avr, avr, avr) | |
5335a145 AJ |
212 | DEF_HELPER_3(vpkshss, void, avr, avr, avr) |
213 | DEF_HELPER_3(vpkshus, void, avr, avr, avr) | |
214 | DEF_HELPER_3(vpkswss, void, avr, avr, avr) | |
215 | DEF_HELPER_3(vpkswus, void, avr, avr, avr) | |
216 | DEF_HELPER_3(vpkuhus, void, avr, avr, avr) | |
217 | DEF_HELPER_3(vpkuwus, void, avr, avr, avr) | |
218 | DEF_HELPER_3(vpkuhum, void, avr, avr, avr) | |
219 | DEF_HELPER_3(vpkuwum, void, avr, avr, avr) | |
1dd9ffb9 | 220 | DEF_HELPER_3(vpkpx, void, avr, avr, avr) |
b161ae27 AJ |
221 | DEF_HELPER_4(vmhaddshs, void, avr, avr, avr, avr) |
222 | DEF_HELPER_4(vmhraddshs, void, avr, avr, avr, avr) | |
4d9903b6 AJ |
223 | DEF_HELPER_4(vmsumuhm, void, avr, avr, avr, avr) |
224 | DEF_HELPER_4(vmsumuhs, void, avr, avr, avr, avr) | |
eae07261 AJ |
225 | DEF_HELPER_4(vmsumshm, void, avr, avr, avr, avr) |
226 | DEF_HELPER_4(vmsumshs, void, avr, avr, avr, avr) | |
bcd2ee23 | 227 | DEF_HELPER_4(vmladduhm, void, avr, avr, avr, avr) |
6e87b7c7 | 228 | DEF_HELPER_1(mtvscr, void, avr); |
cbfb6ae9 AJ |
229 | DEF_HELPER_2(lvebx, void, avr, tl) |
230 | DEF_HELPER_2(lvehx, void, avr, tl) | |
231 | DEF_HELPER_2(lvewx, void, avr, tl) | |
232 | DEF_HELPER_2(stvebx, void, avr, tl) | |
233 | DEF_HELPER_2(stvehx, void, avr, tl) | |
234 | DEF_HELPER_2(stvewx, void, avr, tl) | |
8142cddd AJ |
235 | DEF_HELPER_3(vsumsws, void, avr, avr, avr) |
236 | DEF_HELPER_3(vsum2sws, void, avr, avr, avr) | |
237 | DEF_HELPER_3(vsum4sbs, void, avr, avr, avr) | |
238 | DEF_HELPER_3(vsum4shs, void, avr, avr, avr) | |
239 | DEF_HELPER_3(vsum4ubs, void, avr, avr, avr) | |
56fdd213 AJ |
240 | DEF_HELPER_3(vaddfp, void, avr, avr, avr) |
241 | DEF_HELPER_3(vsubfp, void, avr, avr, avr) | |
1536ff64 AJ |
242 | DEF_HELPER_3(vmaxfp, void, avr, avr, avr) |
243 | DEF_HELPER_3(vminfp, void, avr, avr, avr) | |
bdfbac35 | 244 | DEF_HELPER_2(vrefp, void, avr, avr) |
071fc3b1 | 245 | DEF_HELPER_2(vrsqrtefp, void, avr, avr) |
35cf7c7e AJ |
246 | DEF_HELPER_4(vmaddfp, void, avr, avr, avr, avr) |
247 | DEF_HELPER_4(vnmsubfp, void, avr, avr, avr, avr) | |
0bffbc6c | 248 | DEF_HELPER_2(vexptefp, void, avr, avr) |
b580763f | 249 | DEF_HELPER_2(vlogefp, void, avr, avr) |
f6b19645 AJ |
250 | DEF_HELPER_2(vrfim, void, avr, avr) |
251 | DEF_HELPER_2(vrfin, void, avr, avr) | |
252 | DEF_HELPER_2(vrfip, void, avr, avr) | |
253 | DEF_HELPER_2(vrfiz, void, avr, avr) | |
e140632e AJ |
254 | DEF_HELPER_3(vcfux, void, avr, avr, i32) |
255 | DEF_HELPER_3(vcfsx, void, avr, avr, i32) | |
875b31db AJ |
256 | DEF_HELPER_3(vctuxs, void, avr, avr, i32) |
257 | DEF_HELPER_3(vctsxs, void, avr, avr, i32) | |
fab3cbe9 | 258 | |
8e703949 BS |
259 | DEF_HELPER_2(efscfsi, i32, env, i32) |
260 | DEF_HELPER_2(efscfui, i32, env, i32) | |
261 | DEF_HELPER_2(efscfuf, i32, env, i32) | |
262 | DEF_HELPER_2(efscfsf, i32, env, i32) | |
263 | DEF_HELPER_2(efsctsi, i32, env, i32) | |
264 | DEF_HELPER_2(efsctui, i32, env, i32) | |
265 | DEF_HELPER_2(efsctsiz, i32, env, i32) | |
266 | DEF_HELPER_2(efsctuiz, i32, env, i32) | |
267 | DEF_HELPER_2(efsctsf, i32, env, i32) | |
268 | DEF_HELPER_2(efsctuf, i32, env, i32) | |
269 | DEF_HELPER_2(evfscfsi, i64, env, i64) | |
270 | DEF_HELPER_2(evfscfui, i64, env, i64) | |
271 | DEF_HELPER_2(evfscfuf, i64, env, i64) | |
272 | DEF_HELPER_2(evfscfsf, i64, env, i64) | |
273 | DEF_HELPER_2(evfsctsi, i64, env, i64) | |
274 | DEF_HELPER_2(evfsctui, i64, env, i64) | |
275 | DEF_HELPER_2(evfsctsiz, i64, env, i64) | |
276 | DEF_HELPER_2(evfsctuiz, i64, env, i64) | |
277 | DEF_HELPER_2(evfsctsf, i64, env, i64) | |
278 | DEF_HELPER_2(evfsctuf, i64, env, i64) | |
279 | DEF_HELPER_3(efsadd, i32, env, i32, i32) | |
280 | DEF_HELPER_3(efssub, i32, env, i32, i32) | |
281 | DEF_HELPER_3(efsmul, i32, env, i32, i32) | |
282 | DEF_HELPER_3(efsdiv, i32, env, i32, i32) | |
283 | DEF_HELPER_3(evfsadd, i64, env, i64, i64) | |
284 | DEF_HELPER_3(evfssub, i64, env, i64, i64) | |
285 | DEF_HELPER_3(evfsmul, i64, env, i64, i64) | |
286 | DEF_HELPER_3(evfsdiv, i64, env, i64, i64) | |
287 | DEF_HELPER_3(efststlt, i32, env, i32, i32) | |
288 | DEF_HELPER_3(efststgt, i32, env, i32, i32) | |
289 | DEF_HELPER_3(efststeq, i32, env, i32, i32) | |
290 | DEF_HELPER_3(efscmplt, i32, env, i32, i32) | |
291 | DEF_HELPER_3(efscmpgt, i32, env, i32, i32) | |
292 | DEF_HELPER_3(efscmpeq, i32, env, i32, i32) | |
293 | DEF_HELPER_3(evfststlt, i32, env, i64, i64) | |
294 | DEF_HELPER_3(evfststgt, i32, env, i64, i64) | |
295 | DEF_HELPER_3(evfststeq, i32, env, i64, i64) | |
296 | DEF_HELPER_3(evfscmplt, i32, env, i64, i64) | |
297 | DEF_HELPER_3(evfscmpgt, i32, env, i64, i64) | |
298 | DEF_HELPER_3(evfscmpeq, i32, env, i64, i64) | |
299 | DEF_HELPER_2(efdcfsi, i64, env, i32) | |
300 | DEF_HELPER_2(efdcfsid, i64, env, i64) | |
301 | DEF_HELPER_2(efdcfui, i64, env, i32) | |
302 | DEF_HELPER_2(efdcfuid, i64, env, i64) | |
303 | DEF_HELPER_2(efdctsi, i32, env, i64) | |
304 | DEF_HELPER_2(efdctui, i32, env, i64) | |
305 | DEF_HELPER_2(efdctsiz, i32, env, i64) | |
306 | DEF_HELPER_2(efdctsidz, i64, env, i64) | |
307 | DEF_HELPER_2(efdctuiz, i32, env, i64) | |
308 | DEF_HELPER_2(efdctuidz, i64, env, i64) | |
309 | DEF_HELPER_2(efdcfsf, i64, env, i32) | |
310 | DEF_HELPER_2(efdcfuf, i64, env, i32) | |
311 | DEF_HELPER_2(efdctsf, i32, env, i64) | |
312 | DEF_HELPER_2(efdctuf, i32, env, i64) | |
313 | DEF_HELPER_2(efscfd, i32, env, i64) | |
314 | DEF_HELPER_2(efdcfs, i64, env, i32) | |
315 | DEF_HELPER_3(efdadd, i64, env, i64, i64) | |
316 | DEF_HELPER_3(efdsub, i64, env, i64, i64) | |
317 | DEF_HELPER_3(efdmul, i64, env, i64, i64) | |
318 | DEF_HELPER_3(efddiv, i64, env, i64, i64) | |
319 | DEF_HELPER_3(efdtstlt, i32, env, i64, i64) | |
320 | DEF_HELPER_3(efdtstgt, i32, env, i64, i64) | |
321 | DEF_HELPER_3(efdtsteq, i32, env, i64, i64) | |
322 | DEF_HELPER_3(efdcmplt, i32, env, i64, i64) | |
323 | DEF_HELPER_3(efdcmpgt, i32, env, i64, i64) | |
324 | DEF_HELPER_3(efdcmpeq, i32, env, i64, i64) | |
1c97856d | 325 | |
0f3955e2 | 326 | #if !defined(CONFIG_USER_ONLY) |
74d37793 AJ |
327 | DEF_HELPER_1(4xx_tlbre_hi, tl, tl) |
328 | DEF_HELPER_1(4xx_tlbre_lo, tl, tl) | |
329 | DEF_HELPER_2(4xx_tlbwe_hi, void, tl, tl) | |
330 | DEF_HELPER_2(4xx_tlbwe_lo, void, tl, tl) | |
331 | DEF_HELPER_1(4xx_tlbsx, tl, tl) | |
332 | DEF_HELPER_2(440_tlbre, tl, i32, tl) | |
333 | DEF_HELPER_3(440_tlbwe, void, i32, tl, tl) | |
334 | DEF_HELPER_1(440_tlbsx, tl, tl) | |
01662f3e AG |
335 | DEF_HELPER_0(booke206_tlbre, void) |
336 | DEF_HELPER_0(booke206_tlbwe, void) | |
337 | DEF_HELPER_1(booke206_tlbsx, void, tl) | |
338 | DEF_HELPER_1(booke206_tlbivax, void, tl) | |
6d3db821 AG |
339 | DEF_HELPER_1(booke206_tlbilx0, void, tl) |
340 | DEF_HELPER_1(booke206_tlbilx1, void, tl) | |
341 | DEF_HELPER_1(booke206_tlbilx3, void, tl) | |
01662f3e AG |
342 | DEF_HELPER_1(booke206_tlbflush, void, i32) |
343 | DEF_HELPER_2(booke_setpid, void, i32, tl) | |
74d37793 AJ |
344 | DEF_HELPER_1(6xx_tlbd, void, tl) |
345 | DEF_HELPER_1(6xx_tlbi, void, tl) | |
346 | DEF_HELPER_1(74xx_tlbd, void, tl) | |
347 | DEF_HELPER_1(74xx_tlbi, void, tl) | |
69a218fc AJ |
348 | DEF_HELPER_FLAGS_0(tlbia, TCG_CALL_CONST, void) |
349 | DEF_HELPER_FLAGS_1(tlbie, TCG_CALL_CONST, void, tl) | |
74d37793 | 350 | #if defined(TARGET_PPC64) |
69a218fc | 351 | DEF_HELPER_FLAGS_2(store_slb, TCG_CALL_CONST, void, tl, tl) |
efdef95f DG |
352 | DEF_HELPER_1(load_slb_esid, tl, tl) |
353 | DEF_HELPER_1(load_slb_vsid, tl, tl) | |
69a218fc AJ |
354 | DEF_HELPER_FLAGS_0(slbia, TCG_CALL_CONST, void) |
355 | DEF_HELPER_FLAGS_1(slbie, TCG_CALL_CONST, void, tl) | |
74d37793 | 356 | #endif |
69a218fc AJ |
357 | DEF_HELPER_FLAGS_1(load_sr, TCG_CALL_CONST, tl, tl); |
358 | DEF_HELPER_FLAGS_2(store_sr, TCG_CALL_CONST, void, tl, tl) | |
cf02a65c | 359 | |
69a218fc | 360 | DEF_HELPER_FLAGS_1(602_mfrom, TCG_CALL_CONST | TCG_CALL_PURE, tl, tl) |
d5d11a39 | 361 | DEF_HELPER_1(msgsnd, void, tl) |
e5f17ac6 | 362 | DEF_HELPER_2(msgclr, void, env, tl) |
0f3955e2 AJ |
363 | #endif |
364 | ||
ef0d51af | 365 | DEF_HELPER_3(dlmzb, tl, tl, tl, i32) |
69a218fc | 366 | DEF_HELPER_FLAGS_1(clcs, TCG_CALL_CONST | TCG_CALL_PURE, tl, i32) |
22e0e173 AJ |
367 | #if !defined(CONFIG_USER_ONLY) |
368 | DEF_HELPER_1(rac, tl, tl) | |
369 | #endif | |
370 | DEF_HELPER_2(div, tl, tl, tl) | |
371 | DEF_HELPER_2(divo, tl, tl, tl) | |
372 | DEF_HELPER_2(divs, tl, tl, tl) | |
373 | DEF_HELPER_2(divso, tl, tl, tl) | |
ef0d51af | 374 | |
95ff895f AJ |
375 | DEF_HELPER_1(load_dcr, tl, tl); |
376 | DEF_HELPER_2(store_dcr, void, tl, tl) | |
45d827d2 AJ |
377 | |
378 | DEF_HELPER_1(load_dump_spr, void, i32) | |
379 | DEF_HELPER_1(store_dump_spr, void, i32) | |
380 | DEF_HELPER_0(load_tbl, tl) | |
381 | DEF_HELPER_0(load_tbu, tl) | |
382 | DEF_HELPER_0(load_atbl, tl) | |
383 | DEF_HELPER_0(load_atbu, tl) | |
384 | DEF_HELPER_0(load_601_rtcl, tl) | |
385 | DEF_HELPER_0(load_601_rtcu, tl) | |
386 | #if !defined(CONFIG_USER_ONLY) | |
387 | #if defined(TARGET_PPC64) | |
388 | DEF_HELPER_1(store_asr, void, tl) | |
3a7f009a | 389 | DEF_HELPER_0(load_purr, tl) |
45d827d2 AJ |
390 | #endif |
391 | DEF_HELPER_1(store_sdr1, void, tl) | |
392 | DEF_HELPER_1(store_tbl, void, tl) | |
393 | DEF_HELPER_1(store_tbu, void, tl) | |
394 | DEF_HELPER_1(store_atbl, void, tl) | |
395 | DEF_HELPER_1(store_atbu, void, tl) | |
396 | DEF_HELPER_1(store_601_rtcl, void, tl) | |
397 | DEF_HELPER_1(store_601_rtcu, void, tl) | |
398 | DEF_HELPER_0(load_decr, tl) | |
399 | DEF_HELPER_1(store_decr, void, tl) | |
400 | DEF_HELPER_1(store_hid0_601, void, tl) | |
401 | DEF_HELPER_2(store_403_pbr, void, i32, tl) | |
402 | DEF_HELPER_0(load_40x_pit, tl) | |
403 | DEF_HELPER_1(store_40x_pit, void, tl) | |
404 | DEF_HELPER_1(store_40x_dbcr0, void, tl) | |
405 | DEF_HELPER_1(store_40x_sler, void, tl) | |
406 | DEF_HELPER_1(store_booke_tcr, void, tl) | |
407 | DEF_HELPER_1(store_booke_tsr, void, tl) | |
408 | DEF_HELPER_2(store_ibatl, void, i32, tl) | |
409 | DEF_HELPER_2(store_ibatu, void, i32, tl) | |
410 | DEF_HELPER_2(store_dbatl, void, i32, tl) | |
411 | DEF_HELPER_2(store_dbatu, void, i32, tl) | |
412 | DEF_HELPER_2(store_601_batl, void, i32, tl) | |
413 | DEF_HELPER_2(store_601_batu, void, i32, tl) | |
414 | #endif | |
06dca6a7 | 415 | |
a7812ae4 | 416 | #include "def-helper.h" |