3 // NEC specific instructions
6 // Integer Instructions
7 // --------------------
9 // MulAcc is the Multiply Accumulator.
10 // This register is mapped on the the HI and LO registers.
11 // Upper 32 bits of MulAcc is mapped on to lower 32 bits of HI register.
12 // Lower 32 bits of MulAcc is mapped on to lower 32 bits of LO register.
15 :function:::unsigned64:MulAcc:
17 unsigned64 result = U8_4 (HI, LO);
21 :function:::void:SET_MulAcc:unsigned64 value
23 *AL4_8 (&HI) = VH4_8 (value);
24 *AL4_8 (&LO) = VL4_8 (value);
27 :function:::signed64:SignedMultiply:signed32 l, signed32 r
29 signed64 result = (signed64) l * (signed64) r;
33 :function:::unsigned64:UnsignedMultiply:unsigned32 l, unsigned32 r
35 unsigned64 result = (unsigned64) l * (unsigned64) r;
39 :function:::unsigned64:Low32Bits:unsigned64 value
41 unsigned64 result = (signed64) (signed32) VL4_8 (value);
45 :function:::unsigned64:High32Bits:unsigned64 value
47 unsigned64 result = (signed64) (signed32) VH4_8 (value);
53 // Multiply, Accumulate
54 000000,5.RS,5.RT,00000,00000,101000::::MAC
57 // start-sanitize-vr4320
59 // end-sanitize-vr4320
61 SET_MulAcc (SD_, MulAcc (SD_) + SignedMultiply (SD_, GPR[RS], GPR[RT]));
65 // D-Multiply, Accumulate
66 000000,5.RS,5.RT,00000,00000,101001::::DMAC
69 // start-sanitize-vr4320
71 // end-sanitize-vr4320
73 LO = LO + SignedMultiply (SD_, GPR[RS], GPR[RT]);
77 // start-sanitize-vr4320
78 // Count Leading Zeros
79 000000,5.RS,00000,5.RD,00000,110101::::CLZ
81 // end-sanitize-vr4320
82 // start-sanitize-vr4320
84 // end-sanitize-vr4320
85 // start-sanitize-vr4320
87 unsigned32 t = Low32Bits (SD_, GPR[RS]);
90 while (! (t & ( 1 << 31))
101 // end-sanitize-vr4320
102 // start-sanitize-vr4320
103 // D-Count Leading Zeros
104 000000,5.RS,00000,5.RD,00000,111101::::DCLZ
106 // end-sanitize-vr4320
107 // start-sanitize-vr4320
109 // end-sanitize-vr4320
110 // start-sanitize-vr4320
112 unsigned64 t = GPR[RS];
115 while (! (t & ( (unsigned64)1 << 63))
122 printf("lo %d\n", (int) c);
132 // end-sanitize-vr4320
133 // start-sanitize-vrXXXX
134 // Multiply and Move LO.
135 000000,5.RS,5.RT,5.RD,00100,101000::::MUL
136 "mul r<RD>, r<RS>, r<RT>"
137 // end-sanitize-vrXXXX
138 // start-sanitize-vr4320
140 // end-sanitize-vr4320
141 // start-sanitze-vr5400
143 // end-sanitze-vr5400
144 // start-sanitize-vrXXXX
146 SET_MulAcc (SD_, 0 + SignedMultiply (SD_, GPR[RS], GPR[RT]));
147 GPR[RD] = Low32Bits (SD_, MulAcc (SD_));
151 // end-sanitize-vrXXXX
152 // start-sanitize-vrXXXX
153 // Unsigned Multiply and Move LO.
154 000000,5.RS,5.RT,5.RD,00101,101000::::MULU
155 "mulu r<RD>, r<RS>, r<RT>"
156 // end-sanitize-vrXXXX
157 // start-sanitize-vr4320
159 // end-sanitize-vr4320
160 // start-sanitze-vr5400
162 // end-sanitze-vr5400
163 // start-sanitize-vrXXXX
165 SET_MulAcc (SD_, 0 + UnsignedMultiply (SD_, GPR[RS], GPR[RT]));
166 GPR[RD] = Low32Bits (SD_, MulAcc (SD_));
170 // end-sanitize-vrXXXX
171 // start-sanitize-vrXXXX
172 // Multiply and Move HI.
173 000000,5.RS,5.RT,5.RD,01100,101000::::MULHI
174 "mulhi r<RD>, r<RS>, r<RT>"
175 // end-sanitize-vrXXXX
176 // start-sanitize-vr4320
178 // end-sanitize-vr4320
179 // start-sanitze-vr5400
181 // end-sanitze-vr5400
182 // start-sanitize-vrXXXX
184 SET_MulAcc (SD_, 0 + SignedMultiply (SD_, GPR[RS], GPR[RT]));
185 GPR[RD] = High32Bits (SD_, MulAcc (SD_));
189 // end-sanitize-vrXXXX
190 // start-sanitize-vrXXXX
191 // Unsigned Multiply and Move HI.
192 000000,5.RS,5.RT,5.RD,01101,101000::::MULHIU
193 "mulhiu r<RD>, r<RS>, r<RT>"
194 // end-sanitize-vrXXXX
195 // start-sanitize-vr4320
197 // end-sanitize-vr4320
198 // start-sanitze-vr5400
200 // end-sanitze-vr5400
201 // start-sanitize-vrXXXX
203 SET_MulAcc (SD_, 0 + UnsignedMultiply (SD_, GPR[RS], GPR[RT]));
204 GPR[RD] = High32Bits (SD_, MulAcc (SD_));
208 // end-sanitize-vrXXXX
209 // start-sanitze-vr5400
210 // Multiply, Negate and Move LO.
211 000000,5.RS,5.RT,5.RD,00011,011000::::MULS
212 "muls r<RD>, r<RS>, r<RT>"
213 // end-sanitze-vr5400
214 // start-sanitze-vr5400
216 // end-sanitze-vr5400
217 // start-sanitze-vr5400
219 SET_MulAcc (SD_, 0 - SignedMultiply (SD_, GPR[RS], GPR[RT]));
220 GPR[RD] = Low32Bits (SD_, MulAcc (SD_));
224 // end-sanitze-vr5400
225 // start-sanitze-vr5400
226 // Unsigned Multiply, Negate and Move LO.
227 000000,5.RS,5.RT,5.RD,00011,011001::::MULSU
228 "mulsu r<RD>, r<RS>, r<RT>"
229 // end-sanitze-vr5400
230 // start-sanitze-vr5400
232 // end-sanitze-vr5400
233 // start-sanitze-vr5400
235 SET_MulAcc (SD_, 0 - UnsignedMultiply (SD_, GPR[RS], GPR[RT]));
236 GPR[RD] = Low32Bits (SD_, MulAcc (SD_));
240 // end-sanitze-vr5400
241 // start-sanitze-vr5400
242 // Multiply, Negate and Move HI.
243 000000,5.RS,5.RT,5.RD,01011,011000::::MULSHI
244 "mulshi r<RD>, r<RS>, r<RT>"
245 // end-sanitze-vr5400
246 // start-sanitze-vr5400
248 // end-sanitze-vr5400
249 // start-sanitze-vr5400
251 SET_MulAcc (SD_, 0 - SignedMultiply (SD_, GPR[RS], GPR[RT]));
252 GPR[RD] = High32Bits (SD_, MulAcc (SD_));
256 // end-sanitze-vr5400
257 // start-sanitze-vr5400
258 // Unsigned Multiply, Negate and Move HI.
259 000000,5.RS,5.RT,5.RD,01011,011001::::MULSHIU
260 "mulshiu r<RD>, r<RS>, r<RT>"
261 // end-sanitze-vr5400
262 // start-sanitze-vr5400
264 // end-sanitze-vr5400
265 // start-sanitze-vr5400
267 SET_MulAcc (SD_, 0 - UnsignedMultiply (SD_, GPR[RS], GPR[RT]));
268 GPR[RD] = High32Bits (SD_, MulAcc (SD_));
275 // end-sanitze-vr5400
276 // Multiply, Accumulate and Move LO.
277 000000,5.RS,5.RT,5.RD,00010,101000::::MACC
278 "macc r<RD>, r<RS>, r<RT>"
279 // start-sanitize-vr4320
281 // end-sanitize-vr4320
282 // start-sanitze-vr5400
284 // end-sanitze-vr5400
286 SET_MulAcc (SD_, MulAcc (SD_) + SignedMultiply (SD_, GPR[RS], GPR[RT]));
287 GPR[RD] = Low32Bits (SD_, MulAcc (SD_));
291 // end-sanitize-vr4320
292 // start-sanitize-vrXXXX
293 // Unsigned Multiply, Accumulate and Move LO.
294 000000,5.RS,5.RT,5.RD,00011,101000::::MACCU
295 "maccu r<RD>, r<RS>, r<RT>"
296 // end-sanitize-vrXXXX
297 // start-sanitize-vr4320
299 // end-sanitize-vr4320
300 // start-sanitze-vr5400
302 // end-sanitze-vr5400
303 // start-sanitize-vrXXXX
305 SET_MulAcc (SD_, MulAcc (SD_) + UnsignedMultiply (SD_, GPR[RS], GPR[RT]));
306 GPR[RD] = Low32Bits (SD_, MulAcc (SD_));
310 // end-sanitize-vrXXXX
311 // start-sanitize-vrXXXX
312 // Multiply, Accumulate and Move HI.
313 000000,5.RS,5.RT,5.RD,01010,101000::::MACCHI
314 "macchi r<RD>, r<RS>, r<RT>"
315 // end-sanitize-vrXXXX
316 // start-sanitize-vr4320
318 // end-sanitize-vr4320
319 // start-sanitze-vr5400
321 // end-sanitze-vr5400
322 // start-sanitize-vrXXXX
324 SET_MulAcc (SD_, MulAcc (SD_) + SignedMultiply (SD_, GPR[RS], GPR[RT]));
325 GPR[RD] = High32Bits (SD_, MulAcc (SD_));
329 // end-sanitize-vrXXXX
330 // start-sanitize-vrXXXX
331 // Unsigned Multiply, Accumulate and Move HI.
332 000000,5.RS,5.RT,5.RD,01011,101000::::MACCHIU
333 "macchiu r<RD>, r<RS>, r<RT>"
334 // start-sanitize-vr4320
336 // end-sanitize-vr4320
337 // start-sanitze-vr5400
339 // end-sanitze-vr5400
341 SET_MulAcc (SD_, MulAcc (SD_) + UnsignedMultiply (SD_, GPR[RS], GPR[RT]));
342 GPR[RD] = High32Bits (SD_, MulAcc (SD_));
348 // end-sanitize-vrXXXX
349 // start-sanitize-vr5400
350 // Multiply, Negate, Accumulate and Move LO.
351 000000,5.RS,5.RT,5.RD,00111,011000::::MSAC
352 "msac r<RD>, r<RS>, r<RT>"
353 // end-sanitize-vr5400
354 // start-sanitize-vr5400
356 // end-sanitize-vr5400
357 // start-sanitize-vr5400
359 SET_MulAcc (SD_, MulAcc (SD_) - SignedMultiply (SD_, GPR[RS], GPR[RT]));
360 GPR[RD] = Low32Bits (SD_, MulAcc (SD_));
364 // end-sanitize-vr5400
365 // start-sanitize-vr5400
366 // Unsigned Multiply, Negate, Accumulate and Move LO.
367 000000,5.RS,5.RT,5.RD,00111,011001::::MSACU
368 "msacu r<RD>, r<RS>, r<RT>"
369 // end-sanitize-vr5400
370 // start-sanitize-vr5400
372 // end-sanitize-vr5400
373 // start-sanitize-vr5400
375 SET_MulAcc (SD_, MulAcc (SD_) - UnsignedMultiply (SD_, GPR[RS], GPR[RT]));
376 GPR[RD] = Low32Bits (SD_, MulAcc (SD_));
380 // end-sanitize-vr5400
381 // start-sanitize-vr5400
382 // Multiply, Negate, Accumulate and Move HI.
383 000000,5.RS,5.RT,5.RD,01111,011000::::MSACHI
384 "msachi r<RD>, r<RS>, r<RT>"
385 // end-sanitize-vr5400
386 // start-sanitize-vr5400
388 // end-sanitize-vr5400
389 // start-sanitize-vr5400
391 SET_MulAcc (SD_, MulAcc (SD_) - SignedMultiply (SD_, GPR[RS], GPR[RT]));
392 GPR[RD] = High32Bits (SD_, MulAcc (SD_));
395 // end-sanitize-vr5400
396 // start-sanitize-vr5400
397 // Unsigned Multiply, Negate, Accumulate and Move HI.
398 000000,5.RS,5.RT,5.RD,01111,011001::::MSACHIU
399 "msachiu r<RD>, r<RS>, r<RT>"
400 // end-sanitize-vr5400
401 // start-sanitize-vr5400
403 // end-sanitize-vr5400
404 // start-sanitize-vr5400
406 SET_MulAcc (SD_, MulAcc (SD_) - UnsignedMultiply (SD_, GPR[RS], GPR[RT]));
407 GPR[RD] = High32Bits (SD_, MulAcc (SD_));
411 // end-sanitize-vr5400
412 // start-sanitize-vr5400
414 000000,00001,5.RT,5.RD,5.SHIFT,000010::::ROR
415 "ror r<RD>, r<RT>, <SHIFT>"
416 // end-sanitize-vr5400
417 // start-sanitize-vr5400
419 // end-sanitize-vr5400
420 // start-sanitize-vr5400
423 GPR[RD] = ROTR32 (GPR[RT], s);
427 // end-sanitize-vr5400
428 // start-sanitize-vr5400
429 // Rotate Right Variable.
430 000000,5.RS,5.RT,5.RD,00001,000110::::RORV
431 "rorv r<RD>, r<RT>, <RS>"
432 // end-sanitize-vr5400
433 // start-sanitize-vr5400
435 // end-sanitize-vr5400
436 // start-sanitize-vr5400
438 int s = MASKED (GPR[RS], 4, 0);
439 GPR[RD] = ROTR32 (GPR[RT], s);
443 // end-sanitize-vr5400
444 // start-sanitize-vr5400
445 // Double Rotate Right.
446 000000,00001,5.RT,5.RD,5.SHIFT,111010::::DROR
447 "dror r<RD>, r<RT>, <SHIFT>"
448 // end-sanitize-vr5400
449 // start-sanitize-vr5400
451 // end-sanitize-vr5400
452 // start-sanitize-vr5400
455 GPR[RD] = ROTR64 (GPR[RT], s);
459 // end-sanitize-vr5400
460 // start-sanitize-vr5400
461 // Double Rotate Right Plus 32.
462 000000,00001,5.RT,5.RD,5.SHIFT,111110::::DROR32
463 "dror32 r<RD>, r<RT>, <SHIFT>"
464 // end-sanitize-vr5400
465 // start-sanitize-vr5400
467 // end-sanitize-vr5400
468 // start-sanitize-vr5400
471 GPR[RD] = ROTR64 (GPR[RT], s);
475 // end-sanitize-vr5400
476 // start-sanitize-vr5400
477 // Double Rotate Right Variable.
478 000000,5.RS,5.RT,5.RD,00001,010110::::DRORV
479 "drorv r<RD>, r<RT>, <RS>"
480 // end-sanitize-vr5400
481 // start-sanitize-vr5400
483 // end-sanitize-vr5400
484 // start-sanitize-vr5400
486 int s = MASKED (GPR[RS], 5, 0);
487 GPR[RD] = ROTR64 (GPR[RT], s);
491 // end-sanitize-vr5400