Automatic date update in version.in
[external/binutils.git] / sim / mn10300 / am33.igen
1 // Helper:            
2 //
3 // Given an extended register number, translate it into an index into the
4 // register array.  This is necessary as the upper 8 extended registers are
5 // actually synonyms for the d0-d3/a0-a3 registers.
6 //
7 //
8
9 :function:::int:translate_rreg:int rreg
10 {
11   
12   /* The higher register numbers actually correspond to the
13      basic machine's address and data registers.  */
14   if (rreg > 7 && rreg < 12)
15     return REG_A0 + rreg - 8;
16   else if (rreg > 11 && rreg < 16)
17     return REG_D0 + rreg - 12;
18   else
19     return REG_E0 + rreg;
20 }
21
22 :function:::int:translate_xreg:int xreg
23 {
24   switch (xreg)
25     {
26     case 0:
27       return REG_SP;
28     case 1:
29       return REG_MDRQ;
30     case 2:
31       return REG_MCRH;
32     case 3:
33       return REG_MCRL;
34     case 4:
35       return REG_MCVF;
36     default:
37       sim_engine_abort (SD, CPU, cia, "%s:%d: bad switch\n", __FILE__, __LINE__);
38     }
39 }
40
41 // 1111 0000 0010 00An; mov USP,An
42 8.0xf0+4.0x2,00,2.AN0:D0m:::mov
43 "mov"
44 *am33
45 *am33_2
46 {
47   PC = cia;
48   State.regs[REG_A0 + AN0] = State.regs[REG_USP];
49 }
50
51
52 // 1111 0000 0010 01An; mov SSP,An
53 8.0xf0+4.0x2,01,2.AN0:D0n:::mov
54 "mov"
55 *am33
56 *am33_2
57 {
58   PC = cia;
59   State.regs[REG_A0 + AN0] = State.regs[REG_SSP];
60 }
61
62
63 // 1111 0000 0010 10An; mov MSP,An
64 8.0xf0+4.0x2,10,2.AN0:D0o:::mov
65 "mov"
66 *am33
67 *am33_2
68 {
69   PC = cia;
70   State.regs[REG_A0 + AN0] = State.regs[REG_MSP];
71 }
72
73
74 // 1111 0000 0010 11An; mov PC,An
75 8.0xf0+4.0x2,11,2.AN0:D0p:::mov
76 "mov"
77 *am33
78 *am33_2
79 {
80   PC = cia;
81   State.regs[REG_A0 + AN0] = PC;
82 }
83
84
85 // 1111 0000 0011 Am00; mov Am,USP
86 8.0xf0+4.0x3,2.AM1,00:D0q:::mov
87 "mov"
88 *am33
89 *am33_2
90 {
91   PC = cia;
92   State.regs[REG_USP] = State.regs[REG_A0 + AM1];
93 }
94
95 // 1111 0000 0011 Am01; mov Am,SSP
96 8.0xf0+4.0x3,2.AM1,01:D0r:::mov
97 "mov"
98 *am33
99 *am33_2
100 {
101   PC = cia;
102   State.regs[REG_SSP] = State.regs[REG_A0 + AM1];
103 }
104
105 // 1111 0000 0011 Am10; mov Am,MSP
106 8.0xf0+4.0x3,2.AM1,10:D0s:::mov
107 "mov"
108 *am33
109 *am33_2
110 {
111   PC = cia;
112   State.regs[REG_MSP] = State.regs[REG_A0 + AM1];
113 }
114
115
116 // 1111 0000 1110 imm4; syscall
117 8.0xf0+4.0xe,IMM4:D0t:::syscall
118 "syscall"
119 *am33
120 *am33_2
121 {
122   unsigned32 sp, next_pc;
123
124   PC = cia;
125   sp = State.regs[REG_SP];
126   next_pc = State.regs[REG_PC] + 2;
127   store_word (sp - 4, next_pc);
128   store_word (sp - 8, PSW);
129   State.regs[REG_PC] = 0x40000000 + IMM4 * 8;
130   nia = PC;
131 }
132
133
134 // 1111 0010 1110 11Dn; mov EPSW,Dn
135 8.0xf2+4.0xe,11,2.DN0:D0u:::mov
136 "mov"
137 *am33
138 *am33_2
139 {
140   PC = cia;
141   State.regs[REG_D0 + DN0] = PSW;
142 }
143
144
145 // 1111 0010 1111 Dm01; mov Dm,EPSW
146 8.0xf2+4.0xf,2.DM1,01:D0v:::mov
147 "mov"
148 *am33
149 *am33_2
150 {
151   PC = cia;
152   PSW = State.regs[REG_D0 + DM1];
153 }
154
155 // 1111 0101 00Am Rn; mov Am,Rn
156 8.0xf5+00,2.AM1,4.RN0:D0w:::mov
157 "mov"
158 *am33
159 *am33_2
160 {
161   int destreg = translate_rreg (SD_, RN0);
162
163   PC = cia;
164   State.regs[destreg] = State.regs[REG_A0 + AM1];
165 }
166
167 // 1111 0101 01Dm Rn; mov Dm,Rn
168 8.0xf5+01,2.DM1,4.RN0:D0x:::mov
169 "mov"
170 *am33
171 *am33_2
172 {
173   int destreg = translate_rreg (SD_, RN0);
174
175   PC = cia;
176   State.regs[destreg] = State.regs[REG_D0 + DM1];
177 }
178
179 // 1111 0101 10Rm An; mov Rm,An
180 8.0xf5+10,4.RM1,2.AN0:D0y:::mov
181 "mov"
182 *am33
183 *am33_2
184 {
185   int destreg = translate_rreg (SD_, RM1);
186
187   PC = cia;
188   State.regs[REG_A0 + AN0] = State.regs[destreg];
189 }
190
191 // 1111 0101 11Rm Dn; mov Rm,Dn
192 8.0xf5+11,4.RM1,2.DN0:D0z:::mov
193 "mov"
194 *am33
195 *am33_2
196 {
197   int destreg = translate_rreg (SD_, RM1);
198
199   PC = cia;
200   State.regs[REG_D0 + DN0] = State.regs[destreg];
201 }
202
203
204 // 1111 1000 1100 1110 regs....; movm (USP),regs
205 8.0xf8+8.0xce+8.REGS:D1a:::movm
206 "movm"
207 *am33
208 *am33_2
209 {
210   unsigned32 usp = State.regs[REG_USP];
211   unsigned32 mask;
212
213   PC = cia;
214   mask = REGS;
215
216   if (mask & 0x8)
217     {
218       usp += 4;
219       State.regs[REG_LAR] = load_word (usp);
220       usp += 4;
221       State.regs[REG_LIR] = load_word (usp);
222       usp += 4;
223       State.regs[REG_MDR] = load_word (usp);
224       usp += 4;
225       State.regs[REG_A0 + 1] = load_word (usp);
226       usp += 4;
227       State.regs[REG_A0] = load_word (usp);
228       usp += 4;
229       State.regs[REG_D0 + 1] = load_word (usp);
230       usp += 4;
231       State.regs[REG_D0] = load_word (usp);
232       usp += 4;
233     }
234
235   if (mask & 0x10)
236     {
237       State.regs[REG_A0 + 3] = load_word (usp);
238       usp += 4;
239     }
240
241   if (mask & 0x20)
242     {
243       State.regs[REG_A0 + 2] = load_word (usp);
244       usp += 4;
245     }
246
247   if (mask & 0x40)
248     {
249       State.regs[REG_D0 + 3] = load_word (usp);
250       usp += 4;
251     }
252
253   if (mask & 0x80)
254     {
255       State.regs[REG_D0 + 2] = load_word (usp);
256       usp += 4;
257     }
258
259   if (STATE_ARCHITECTURE (sd)->mach == bfd_mach_am33
260       || STATE_ARCHITECTURE (sd)->mach == bfd_mach_am33_2
261       )
262     {
263       if (mask & 0x1)
264         {
265           /* Need to restore MDQR, MCRH, MCRL, and MCVF */
266           usp += 16;
267           State.regs[REG_E0 + 1] = load_word (usp);
268           usp += 4;
269           State.regs[REG_E0 + 0] = load_word (usp);
270           usp += 4;
271         }
272
273       if (mask & 0x2)
274         {
275           State.regs[REG_E0 + 7] = load_word (usp);
276           usp += 4;
277           State.regs[REG_E0 + 6] = load_word (usp);
278           usp += 4;
279           State.regs[REG_E0 + 5] = load_word (usp);
280           usp += 4;
281           State.regs[REG_E0 + 4] = load_word (usp);
282           usp += 4;
283         }
284
285       if (mask & 0x4)
286         {
287           State.regs[REG_E0 + 3] = load_word (usp);
288           usp += 4;
289           State.regs[REG_E0 + 2] = load_word (usp);
290           usp += 4;
291         }
292     }
293
294   /* And make sure to update the stack pointer.  */
295   State.regs[REG_USP] = usp;
296 }
297
298 // 1111 1000 1100 1111 regs....; movm (USP),regs
299 8.0xf8+8.0xcf+8.REGS:D1b:::movm
300 "movm"
301 *am33
302 *am33_2
303 {
304   unsigned32 usp = State.regs[REG_USP];
305   unsigned32 mask;
306
307   PC = cia;
308   mask = REGS;
309
310   if (STATE_ARCHITECTURE (sd)->mach == bfd_mach_am33
311       || STATE_ARCHITECTURE (sd)->mach == bfd_mach_am33_2
312       )
313     {
314       if (mask & 0x4)
315         {
316           usp -= 4;
317           store_word (usp, State.regs[REG_E0 + 2]);
318           usp -= 4;
319           store_word (usp, State.regs[REG_E0 + 3]);
320         }
321
322       if (mask & 0x2)
323         {
324           usp -= 4;
325           store_word (usp, State.regs[REG_E0 + 4]);
326           usp -= 4;
327           store_word (usp, State.regs[REG_E0 + 5]);
328           usp -= 4;
329           store_word (usp, State.regs[REG_E0 + 6]);
330           usp -= 4;
331           store_word (usp, State.regs[REG_E0 + 7]);
332         }
333
334       if (mask & 0x1)
335         {
336           usp -= 4;
337           store_word (usp, State.regs[REG_E0 + 0]);
338           usp -= 4;
339           store_word (usp, State.regs[REG_E0 + 1]);
340           usp -= 16;
341           /* Need to save MDQR, MCRH, MCRL, and MCVF */
342         }
343     }
344
345   if (mask & 0x80)
346     {
347       usp -= 4;
348       store_word (usp, State.regs[REG_D0 + 2]);
349     }
350
351   if (mask & 0x40)
352     {
353       usp -= 4;
354       store_word (usp, State.regs[REG_D0 + 3]);
355     }
356
357   if (mask & 0x20)
358     {
359       usp -= 4;
360       store_word (usp, State.regs[REG_A0 + 2]);
361     }
362
363   if (mask & 0x10)
364     {
365       usp -= 4;
366       store_word (usp, State.regs[REG_A0 + 3]);
367     }
368
369   if (mask & 0x8)
370     {
371       usp -= 4;
372       store_word (usp, State.regs[REG_D0]);
373       usp -= 4;
374       store_word (usp, State.regs[REG_D0 + 1]);
375       usp -= 4;
376       store_word (usp, State.regs[REG_A0]);
377       usp -= 4;
378       store_word (usp, State.regs[REG_A0 + 1]);
379       usp -= 4;
380       store_word (usp, State.regs[REG_MDR]);
381       usp -= 4;
382       store_word (usp, State.regs[REG_LIR]);
383       usp -= 4;
384       store_word (usp, State.regs[REG_LAR]);
385       usp -= 4;
386     }
387
388   /* And make sure to update the stack pointer.  */
389   State.regs[REG_USP] = usp;
390 }
391
392 // 1111 1100 1111 1100 imm32...; and imm32,EPSW 
393 8.0xfc+8.0xfc+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:4a:::and
394 "and"
395 *am33
396 *am33_2
397 {
398   PC = cia;
399   PSW &= FETCH32(IMM32A, IMM32B, IMM32C, IMM32D);
400 }
401
402 // 1111 1100 1111 1101 imm32...; or imm32,EPSW 
403 8.0xfc+8.0xfd+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D4a:::or
404 "or"
405 *am33
406 *am33_2
407 {
408   PC = cia;
409   PSW |= FETCH32(IMM32A, IMM32B, IMM32C, IMM32D);
410 }
411
412 // 1111 1001 0000 1000 Rm Rn; mov Rm,Rn (Rm != Rn)
413 8.0xf9+8.0x08+4.RM2,4.RN0!RM2:D1g:::mov
414 "mov"
415 *am33
416 *am33_2
417 {
418   int srcreg, dstreg;
419
420   PC = cia;
421
422   srcreg = translate_rreg (SD_, RM2);
423   dstreg = translate_rreg (SD_, RN0);
424   State.regs[dstreg] = State.regs[srcreg];
425 }
426
427 // 1111 1001 0001 1000 Rn Rn; ext Rn
428 8.0xf9+8.0x18+4.RN0,4.RN2=RN0:D1:::ext
429 "mov"
430 *am33
431 *am33_2
432 {
433   int srcreg;
434
435   PC = cia;
436   srcreg = translate_rreg (SD_, RN0);
437   if (State.regs[srcreg] & 0x80000000)
438     State.regs[REG_MDR] = -1;
439   else
440     State.regs[REG_MDR] = 0;
441 }
442
443 // 1111 1001 0010 1000 Rm Rn; extb Rm,Rn
444 8.0xf9+8.0x28+4.RM2,4.RN0!RM2:D1:::extb
445 "extb"
446 *am33
447 *am33_2
448 {
449   int srcreg, dstreg;
450
451   PC = cia;
452   srcreg = translate_rreg (SD_, RM2);
453   dstreg = translate_rreg (SD_, RN0);
454   State.regs[dstreg] = EXTEND8 (State.regs[srcreg]);
455 }
456
457 // 1111 1001 0011 1000 Rm Rn; extbu Rm,Rn
458 8.0xf9+8.0x38+4.RM2,4.RN0!RM2:D1:::extbu
459 "extbu"
460 *am33
461 *am33_2
462 {
463   int srcreg, dstreg;
464
465   PC = cia;
466   srcreg = translate_rreg (SD_, RM2);
467   dstreg = translate_rreg (SD_, RN0);
468   State.regs[dstreg] = State.regs[srcreg] & 0xff;
469 }
470
471 // 1111 1001 0100 1000 Rm Rn; exth Rm,Rn
472 8.0xf9+8.0x48+4.RM2,4.RN0!RM2:D1:::exth
473 "exth"
474 *am33
475 *am33_2
476 {
477   int srcreg, dstreg;
478
479   PC = cia;
480   srcreg = translate_rreg (SD_, RM2);
481   dstreg = translate_rreg (SD_, RN0);
482   State.regs[dstreg] = EXTEND16 (State.regs[srcreg]);
483 }
484
485 // 1111 1001 0101 1000 Rm Rn; exthu Rm,Rn
486 8.0xf9+8.0x58+4.RM2,4.RN0!RM2:D1:::exthu
487 "exthu"
488 *am33
489 *am33_2
490 {
491   int srcreg, dstreg;
492
493   PC = cia;
494   srcreg = translate_rreg (SD_, RM2);
495   dstreg = translate_rreg (SD_, RN0);
496   State.regs[dstreg] = State.regs[srcreg] & 0xffff;
497 }
498
499 // 1111 1001 0110 1000 Rn Rn; clr Rn
500 8.0xf9+8.0x68+4.RM2,4.RN0=RM2:D1:::clr
501 "clr"
502 *am33
503 *am33_2
504 {
505   int dstreg;
506
507   PC = cia;
508   dstreg = translate_rreg (SD_, RN0);
509   State.regs[dstreg] = 0;
510   PSW |= PSW_Z;
511   PSW &= ~(PSW_V | PSW_C | PSW_N);
512 }
513
514 // 1111 1001 0111 1000 Rm Rn; add Rm,Rn
515 8.0xf9+8.0x78+4.RM2,4.RN0:D1b:::add
516 "add"
517 *am33
518 *am33_2
519 {
520   int srcreg, dstreg;
521
522   PC = cia;
523   srcreg = translate_rreg (SD_, RM2);
524   dstreg = translate_rreg (SD_, RN0);
525   genericAdd (State.regs[srcreg], dstreg);
526 }
527
528 // 1111 1001 1000 1000 Rm Rn; addc Rm,Rn
529 8.0xf9+8.0x88+4.RM2,4.RN0:D1b:::addc
530 "addc"
531 *am33
532 *am33_2
533 {
534   int srcreg, dstreg;
535   int z, c, n, v;
536   unsigned32 reg1, reg2, sum;
537
538   PC = cia;
539   srcreg = translate_rreg (SD_, RM2);
540   dstreg = translate_rreg (SD_, RN0);
541
542   reg1 = State.regs[srcreg];
543   reg2 = State.regs[dstreg];
544   sum = reg1 + reg2 + ((PSW & PSW_C) != 0);
545   State.regs[dstreg] = sum;
546
547   z = ((PSW & PSW_Z) != 0) && (sum == 0);
548   n = (sum & 0x80000000);
549   c = (sum < reg1) || (sum < reg2);
550   v = ((reg2 & 0x80000000) == (reg1 & 0x80000000)
551        && (reg2 & 0x80000000) != (sum & 0x80000000));
552
553   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
554   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0)
555           | (c ? PSW_C : 0) | (v ? PSW_V : 0));
556 }
557
558 // 1111 1001 1001 1000 Rm Rn; sub Rm,Rn
559 8.0xf9+8.0x98+4.RM2,4.RN0:D1b:::sub
560 "sub"
561 *am33
562 *am33_2
563 {
564   int srcreg, dstreg;
565
566   PC = cia;
567   srcreg = translate_rreg (SD_, RM2);
568   dstreg = translate_rreg (SD_, RN0);
569   genericSub (State.regs[srcreg], dstreg);
570 }
571
572 // 1111 1001 1010 1000 Rm Rn; subc Rm,Rn
573 8.0xf9+8.0xa8+4.RM2,4.RN0:D1b:::subc
574 "subc"
575 *am33
576 *am33_2
577 {
578   int srcreg, dstreg;
579   int z, c, n, v;
580   unsigned32 reg1, reg2, difference;
581
582   PC = cia;
583   srcreg = translate_rreg (SD_, RM2);
584   dstreg = translate_rreg (SD_, RN0);
585
586   reg1 = State.regs[srcreg];
587   reg2 = State.regs[dstreg];
588   difference = reg2 - reg1 - ((PSW & PSW_C) != 0);
589   State.regs[dstreg] = difference;
590
591   z = ((PSW & PSW_Z) != 0) && (difference == 0);
592   n = (difference & 0x80000000);
593   c = (reg1 > reg2);
594   v = ((reg2 & 0x80000000) == (reg1 & 0x80000000)
595        && (reg2 & 0x80000000) != (difference & 0x80000000));
596
597   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
598   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0)
599           | (c ? PSW_C : 0) | (v ? PSW_V : 0));
600 }
601
602 // 1111 1001 1011 1000 Rn Rn; inc Rn
603 8.0xf9+8.0xb8+4.RN0,4.RN2=RN0:D1:::inc
604 "inc"
605 *am33
606 *am33_2
607 {
608   int dstreg;
609
610   PC = cia;
611   dstreg = translate_rreg (SD_, RN0);
612   genericAdd (1, dstreg);
613 }
614
615 // 1111 1001 1101 1000 Rn Rn; inc Rn
616 8.0xf9+8.0xc8+4.RN0,4.RN2=RN0:D1:::inc4
617 "inc4"
618 *am33
619 *am33_2
620 {
621   int dstreg;
622
623   PC = cia;
624   dstreg = translate_rreg (SD_, RN0);
625   genericAdd (4, dstreg);
626 }
627
628 // 1111 1001 1101 1000 Rm Rn; cmp Rm,Rn
629 8.0xf9+8.0xd8+4.RM2,4.RN0:D1:::cmp
630 "cmp"
631 *am33
632 *am33_2
633 {
634   int srcreg1, srcreg2;
635
636   PC = cia;
637   srcreg1 = translate_rreg (SD_, RN0);
638   srcreg2 = translate_rreg (SD_, RM2);
639   genericCmp (State.regs[srcreg2], State.regs[srcreg1]);
640 }
641
642 // 1111 1001 1110 1000 XRm Rn; mov XRm,Rn
643 8.0xf9+8.0xe8+4.XRM2,4.RN0:D1l:::mov
644 "mov"
645 *am33
646 *am33_2
647 {
648   int dstreg, srcreg;
649
650   PC = cia;
651   dstreg = translate_rreg (SD_, RN0);
652   srcreg = translate_xreg (SD_, XRM2);
653
654   State.regs[dstreg] = State.regs[srcreg];
655 }
656
657 // 1111 1001 1111 1000 Rm XRn; mov Rm,XRn
658 8.0xf9+8.0xf8+4.RM2,4.XRN0:D1m:::mov
659 "mov"
660 *am33
661 *am33_2
662 {
663   int srcreg, dstreg;
664
665   PC = cia;
666   srcreg = translate_rreg (SD_, RM2);
667   dstreg = translate_xreg (SD_, XRN0);
668
669   State.regs[dstreg] = State.regs[srcreg];
670 }
671
672 // 1111 1001 0000 1001 Rm Rn; and Rm,Rn
673 8.0xf9+8.0x09+4.RM2,4.RN0:D1a:::and
674 "and"
675 *am33
676 *am33_2
677 {
678   int srcreg, dstreg;
679   int z, n;
680
681   PC = cia;
682
683   srcreg = translate_rreg (SD_, RM2);
684   dstreg = translate_rreg (SD_, RN0);
685
686   State.regs[dstreg] &= State.regs[srcreg];
687   z = (State.regs[dstreg] == 0);
688   n = (State.regs[dstreg] & 0x80000000) != 0;
689   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
690   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
691 }
692
693 // 1111 1001 0001 1001 Rm Rn; or Rm,Rn
694 8.0xf9+8.0x19+4.RM2,4.RN0:D1a:::or
695 "or"
696 *am33
697 *am33_2
698 {
699   int srcreg, dstreg;
700   int z, n;
701
702   PC = cia;
703   srcreg = translate_rreg (SD_, RM2);
704   dstreg = translate_rreg (SD_, RN0);
705
706   State.regs[dstreg] |= State.regs[srcreg];
707   z = (State.regs[dstreg] == 0);
708   n = (State.regs[dstreg] & 0x80000000) != 0;
709   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
710   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
711 }
712
713 // 1111 1001 0010 1001 Rm Rn; xor Rm,Rn
714 8.0xf9+8.0x29+4.RM2,4.RN0:D1a:::xor
715 "xor"
716 *am33
717 *am33_2
718 {
719   int srcreg, dstreg;
720   int z, n;
721
722   PC = cia;
723   srcreg = translate_rreg (SD_, RM2);
724   dstreg = translate_rreg (SD_, RN0);
725
726   State.regs[dstreg] ^= State.regs[srcreg];
727   z = (State.regs[dstreg] == 0);
728   n = (State.regs[dstreg] & 0x80000000) != 0;
729   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
730   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
731 }
732
733 // 1111 1001 0011 1001 Rn Rn; not Rn
734 8.0xf9+8.0x39+4.RM2,4.RN0=RM2:D1:::not
735 "not"
736 *am33
737 *am33_2
738 {
739   int dstreg;
740   int z, n;
741
742   PC = cia;
743   dstreg = translate_rreg (SD_, RN0);
744
745   State.regs[dstreg] = ~State.regs[dstreg];
746   z = (State.regs[dstreg] == 0);
747   n = (State.regs[dstreg] & 0x80000000) != 0;
748   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
749   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
750 }
751
752 // 1111 1001 0100 1001 Rm Rn; asr Rm,Rn
753 8.0xf9+8.0x49+4.RM2,4.RN0:D1a:::asr
754 "asr"
755 *am33
756 *am33_2
757 {
758   int srcreg, dstreg;
759   signed32 temp;
760   int c, z, n;
761
762   PC = cia;
763   srcreg = translate_rreg (SD_, RM2);
764   dstreg = translate_rreg (SD_, RN0);
765
766   temp = State.regs[dstreg];
767   c = temp & 1;
768   temp >>= State.regs[srcreg];
769   State.regs[dstreg] = temp;
770   z = (State.regs[dstreg] == 0);
771   n = (State.regs[dstreg] & 0x80000000) != 0;
772   PSW &= ~(PSW_Z | PSW_N | PSW_C);
773   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0) | (c ? PSW_C : 0));
774 }
775
776 // 1111 1001 0101 1001 Rm Rn; lsr Rm,Rn
777 8.0xf9+8.0x59+4.RM2,4.RN0:D1a:::lsr
778 "lsr"
779 *am33
780 *am33_2
781 {
782   int srcreg, dstreg;
783   int z, n, c;
784
785   PC = cia;
786
787   srcreg = translate_rreg (SD_, RM2);
788   dstreg = translate_rreg (SD_, RN0);
789
790   c = State.regs[dstreg] & 1;
791   State.regs[dstreg] >>= State.regs[srcreg];
792   z = (State.regs[dstreg] == 0);
793   n = (State.regs[dstreg] & 0x80000000) != 0;
794   PSW &= ~(PSW_Z | PSW_N | PSW_C);
795   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0) | (c ? PSW_C : 0));
796 }
797
798 // 1111 1001 0110 1001 Rm Rn; asl Rm,Rn
799 8.0xf9+8.0x69+4.RM2,4.RN0:D1a:::asl
800 "asl"
801 *am33
802 *am33_2
803 {
804   int srcreg, dstreg;
805   int z, n;
806
807   PC = cia;
808   srcreg = translate_rreg (SD_, RM2);
809   dstreg = translate_rreg (SD_, RN0);
810
811   State.regs[dstreg] <<= State.regs[srcreg];
812   z = (State.regs[dstreg] == 0);
813   n = (State.regs[dstreg] & 0x80000000) != 0;
814   PSW &= ~(PSW_Z | PSW_N);
815   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
816 }
817
818 // 1111 1001 0111 1001 Rn Rn; asl2 Rn
819 8.0xf9+8.0x79+4.RM2,4.RN0=RM2:D1:::asl2
820 "asl2"
821 *am33
822 *am33_2
823 {
824   int dstreg;
825   int n, z;
826
827   PC = cia;
828   dstreg = translate_rreg (SD_, RN0);
829
830   State.regs[dstreg] <<= 2;
831   z = (State.regs[dstreg] == 0);
832   n = (State.regs[dstreg] & 0x80000000) != 0;
833   PSW &= ~(PSW_Z | PSW_N);
834   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
835 }
836
837 // 1111 1001 1000 1001 Rn Rn; ror Rn
838 8.0xf9+8.0x89+4.RM2,4.RN0=RM2:D1:::ror
839 "ror"
840 *am33
841 *am33_2
842 {
843   int dstreg;
844   int c, n, z;
845   unsigned32 value;
846
847   PC = cia;
848   dstreg = translate_rreg (SD_, RN0);
849
850   value = State.regs[dstreg];
851   c = (value & 0x1);
852
853   value >>= 1;
854   value |= ((PSW & PSW_C) != 0) ? 0x80000000 : 0;
855   State.regs[dstreg] = value;
856   z = (value == 0);
857   n = (value & 0x80000000) != 0;
858   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
859   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0) | (c ? PSW_C : 0));
860 }
861
862 // 1111 1001 1001 1001 Rn Rn; rol Rn
863 8.0xf9+8.0x99+4.RM2,4.RN0=RM2:D1:::rol
864 "rol"
865 *am33
866 *am33_2
867 {
868   int dstreg;
869   int c, n, z;
870   unsigned32 value;
871
872   PC = cia;
873   dstreg = translate_rreg (SD_, RN0);
874
875   value = State.regs[dstreg];
876   c = (value & 0x80000000) ? 1 : 0;
877
878   value <<= 1;
879   value |= ((PSW & PSW_C) != 0);
880   State.regs[dstreg] = value;
881   z = (value == 0);
882   n = (value & 0x80000000) != 0;
883   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
884   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0) | (c ? PSW_C : 0));
885 }
886
887 // 1111 1001 1010 1001 Rm Rn; mul Rm,Rn
888 8.0xf9+8.0xa9+4.RM2,4.RN0:D1b:::mul
889 "mul"
890 *am33
891 *am33_2
892 {
893   int srcreg, dstreg;
894   unsigned64 temp;
895   int n, z;
896
897   PC = cia;
898   srcreg = translate_rreg (SD_, RM2);
899   dstreg = translate_rreg (SD_, RN0);
900
901   temp = ((signed64)(signed32)State.regs[dstreg]
902           *  (signed64)(signed32)State.regs[srcreg]);
903   State.regs[dstreg] = temp & 0xffffffff;
904   State.regs[REG_MDR] = (temp & 0xffffffff00000000LL) >> 32;
905   z = (State.regs[dstreg] == 0);
906   n = (State.regs[dstreg] & 0x80000000) != 0;
907   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
908   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
909 }
910
911 // 1111 1001 1011 1001 Rm Rn; mulu Rm,Rn
912 8.0xf9+8.0xb9+4.RM2,4.RN0:D1b:::mulu
913 "mulu"
914 *am33
915 *am33_2
916 {
917   int srcreg, dstreg;
918   unsigned64 temp;
919   int n, z;
920
921   PC = cia;
922   srcreg = translate_rreg (SD_, RM2);
923   dstreg = translate_rreg (SD_, RN0);
924
925   temp = ((unsigned64)State.regs[dstreg]
926           * (unsigned64)State.regs[srcreg]);
927   State.regs[dstreg] = temp & 0xffffffff;
928   State.regs[REG_MDR] = (temp & 0xffffffff00000000LL) >> 32;
929   z = (State.regs[dstreg] == 0);
930   n = (State.regs[dstreg] & 0x80000000) != 0;
931   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
932   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
933 }
934
935 // 1111 1001 1100 1001 Rm Rn; div Rm,Rn
936 8.0xf9+8.0xc9+4.RM2,4.RN0:D1b:::div
937 "div"
938 *am33
939 *am33_2
940 {
941   int srcreg, dstreg;
942   signed64 temp;
943   int n, z;
944
945   PC = cia;
946   srcreg = translate_rreg (SD_, RM2);
947   dstreg = translate_rreg (SD_, RN0);
948
949   temp = State.regs[REG_MDR];
950   temp <<= 32;
951   temp |= State.regs[dstreg];
952   State.regs[REG_MDR] = temp % (signed32)State.regs[srcreg];
953   temp /= (signed32)State.regs[srcreg];
954   State.regs[dstreg] = temp & 0xffffffff;
955   z = (State.regs[dstreg] == 0);
956   n = (State.regs[dstreg] & 0x80000000) != 0;
957   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
958   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
959 }
960
961 // 1111 1001 1101 1001 Rm Rn; divu Rm,Rn
962 8.0xf9+8.0xd9+4.RM2,4.RN0:D1b:::divu
963 "divu"
964 *am33
965 *am33_2
966 {
967   int srcreg, dstreg;
968   unsigned64 temp;
969   int n, z;
970
971   PC = cia;
972   srcreg = translate_rreg (SD_, RM2);
973   dstreg = translate_rreg (SD_, RN0);
974
975   temp = State.regs[REG_MDR];
976   temp <<= 32;
977   temp |= State.regs[dstreg];
978   State.regs[REG_MDR] = temp % State.regs[srcreg];
979   temp /= State.regs[srcreg];
980   State.regs[dstreg] = temp & 0xffffffff;
981   z = (State.regs[dstreg] == 0);
982   n = (State.regs[dstreg] & 0x80000000) != 0;
983   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
984   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
985 }
986
987
988 // 1111 1001 0000 1010 Rm Rn; mov (Rm),Rn
989 8.0xf9+8.0x0a+4.RN2,4.RM0:D1h:::mov
990 "mov"
991 *am33
992 *am33_2
993 {
994   int srcreg, dstreg;
995
996   PC = cia;
997   srcreg = translate_rreg (SD_, RM0);
998   dstreg = translate_rreg (SD_, RN2);
999   State.regs[dstreg] = load_word (State.regs[srcreg]);
1000 }
1001
1002 // 1111 1001 0001 1010 Rm Rn; mov Rm,(Rn)
1003 8.0xf9+8.0x1a+4.RM2,4.RN0:D1i:::mov
1004 "mov"
1005 *am33
1006 *am33_2
1007 {
1008   int srcreg, dstreg;
1009
1010   PC = cia;
1011   srcreg = translate_rreg (SD_, RM2);
1012   dstreg = translate_rreg (SD_, RN0);
1013   store_word (State.regs[dstreg], State.regs[srcreg]);
1014 }
1015
1016 // 1111 1001 0010 1010 Rm Rn; movbu (Rm),Rn
1017 8.0xf9+8.0x2a+4.RN2,4.RM0:D1g:::movbu
1018 "movbu"
1019 *am33
1020 *am33_2
1021 {
1022   int srcreg, dstreg;
1023
1024   PC = cia;
1025   srcreg = translate_rreg (SD_, RM0);
1026   dstreg = translate_rreg (SD_, RN2);
1027   State.regs[dstreg] = load_byte (State.regs[srcreg]);
1028 }
1029
1030 // 1111 1001 0011 1010 Rm Rn; movbu Rm,(Rn)
1031 8.0xf9+8.0x3a+4.RM2,4.RN0:D1i:::movbu
1032 "movbu"
1033 *am33
1034 *am33_2
1035 {
1036   int srcreg, dstreg;
1037
1038   PC = cia;
1039   srcreg = translate_rreg (SD_, RM2);
1040   dstreg = translate_rreg (SD_, RN0);
1041   store_byte (State.regs[dstreg], State.regs[srcreg]);
1042 }
1043
1044 // 1111 1001 0100 1010 Rm Rn; movhu (Rm),Rn
1045 8.0xf9+8.0x4a+4.RN2,4.RM0:D1g:::movhu
1046 "movhu"
1047 *am33
1048 *am33_2
1049 {
1050   int srcreg, dstreg;
1051
1052   PC = cia;
1053   srcreg = translate_rreg (SD_, RM0);
1054   dstreg = translate_rreg (SD_, RN2);
1055   State.regs[dstreg] = load_half (State.regs[srcreg]);
1056 }
1057
1058 // 1111 1001 0101 1010 Rm Rn; movhu Rm,(Rn)
1059 8.0xf9+8.0x5a+4.RM2,4.RN0:D1i:::movhu
1060 "movhu"
1061 *am33
1062 *am33_2
1063 {
1064   int srcreg, dstreg;
1065
1066   PC = cia;
1067   srcreg = translate_rreg (SD_, RM2);
1068   dstreg = translate_rreg (SD_, RN0);
1069   store_half (State.regs[dstreg], State.regs[srcreg]);
1070 }
1071
1072 // 1111 1001 0110 1010 Rm Rn; mov (Rm+),Rn
1073 8.0xf9+8.0x6a+4.RN2,4.RM0!RN2:D1y:::mov
1074 "mov"
1075 *am33
1076 *am33_2
1077 {
1078   int srcreg, dstreg;
1079
1080   PC = cia;
1081   srcreg = translate_rreg (SD_, RM0);
1082   dstreg = translate_rreg (SD_, RN2);
1083   State.regs[dstreg] = load_word (State.regs[srcreg]);
1084   State.regs[srcreg] += 4;
1085 }
1086
1087 // 1111 1001 0111 1010 Rm Rn; mov Rm,(Rn+)
1088 8.0xf9+8.0x7a+4.RM2,4.RN0:D1z:::mov
1089 "mov"
1090 *am33
1091 *am33_2
1092 {
1093   int srcreg, dstreg;
1094
1095   PC = cia;
1096   srcreg = translate_rreg (SD_, RM2);
1097   dstreg = translate_rreg (SD_, RN0);
1098   store_word (State.regs[dstreg], State.regs[srcreg]);
1099   State.regs[dstreg] += 4;
1100 }
1101
1102 // 1111 1001 1000 1010 Rn 0000; mov (sp),Rn
1103 8.0xf9+8.0x8a+4.RN2,4.0000:D1j:::mov
1104 "mov"
1105 *am33
1106 *am33_2
1107 {
1108   int dstreg;
1109
1110   PC = cia;
1111   dstreg = translate_rreg (SD_, RN2);
1112   State.regs[dstreg] = load_word (State.regs[REG_SP]);
1113 }
1114
1115 // 1111 1001 1001 1010 Rm 0000; mov Rm, (sp)
1116 8.0xf9+8.0x9a+4.RM2,4.0000:D1k:::mov
1117 "mov"
1118 *am33
1119 *am33_2
1120 {
1121   int srcreg;
1122
1123   PC = cia;
1124   srcreg = translate_rreg (SD_, RM2);
1125   store_word (State.regs[REG_SP], State.regs[srcreg]);
1126 }
1127
1128 // 1111 1001 1010 1010 Rn 0000; mobvu (sp),Rn
1129 8.0xf9+8.0xaa+4.RN2,4.0000:D1j:::movbu
1130 "movbu"
1131 *am33
1132 *am33_2
1133 {
1134   int dstreg;
1135
1136   PC = cia;
1137   dstreg = translate_rreg (SD_, RN2);
1138   State.regs[dstreg] = load_byte (State.regs[REG_SP]);
1139 }
1140
1141 // 1111 1001 1011 1010 Rm 0000; movbu Rm, (sp)
1142 8.0xf9+8.0xba+4.RM2,4.0000:D1k:::movbu
1143 "movbu"
1144 *am33
1145 *am33_2
1146 {
1147   int srcreg;
1148
1149   PC = cia;
1150   srcreg = translate_rreg (SD_, RM2);
1151   store_byte (State.regs[REG_SP], State.regs[srcreg]);
1152 }
1153
1154 // 1111 1001 1000 1100 Rn 0000; movhu (sp),Rn
1155 8.0xf9+8.0xca+4.RN2,4.0000:D1j:::movhu
1156 "movhu"
1157 *am33
1158 *am33_2
1159 {
1160   int dstreg;
1161
1162   PC = cia;
1163   dstreg = translate_rreg (SD_, RN2);
1164   State.regs[dstreg] = load_half (State.regs[REG_SP]);
1165 }
1166
1167 // 1111 1001 1001 1101 Rm 0000; movhu Rm, (sp)
1168 8.0xf9+8.0xda+4.RM2,4.0000:D1k:::movhu
1169 "movhu"
1170 *am33
1171 *am33_2
1172 {
1173   int srcreg;
1174
1175   PC = cia;
1176   srcreg = translate_rreg (SD_, RM2);
1177   store_half (State.regs[REG_SP], State.regs[srcreg]);
1178 }
1179
1180 // 1111 1001 1110 1010 Rm Rn; movhu (Rm+),Rn
1181 8.0xf9+8.0xea+4.RN2,4.RM0!RN2:D1y:::movhu
1182 "movhu"
1183 *am33
1184 *am33_2
1185 {
1186   int srcreg, dstreg;
1187
1188   PC = cia;
1189   srcreg = translate_rreg (SD_, RM0);
1190   dstreg = translate_rreg (SD_, RN2);
1191   State.regs[dstreg] = load_half (State.regs[srcreg]);
1192   State.regs[srcreg] += 2;
1193 }
1194
1195 // 1111 1001 1111 1010 Rm Rn; movhu Rm,(Rn+)
1196 8.0xf9+8.0xfa+4.RM2,4.RN0:D1z:::movhu
1197 "movhu"
1198 *am33
1199 *am33_2
1200 {
1201   int srcreg, dstreg;
1202
1203   PC = cia;
1204   srcreg = translate_rreg (SD_, RM2);
1205   dstreg = translate_rreg (SD_, RN0);
1206   store_half (State.regs[dstreg], State.regs[srcreg]);
1207   State.regs[dstreg] += 2;
1208 }
1209
1210
1211 // 1111 1001 0000 1011 Rm Rn; mac Rm,Rn
1212 8.0xf9+8.0x0b+4.RM2,4.RN0:D1:::mac
1213 "mac"
1214 *am33
1215 *am33_2
1216 {
1217   int srcreg1, srcreg2;
1218   signed64 temp, sum;
1219   int c, v;
1220
1221   PC = cia;
1222   srcreg1 = translate_rreg (SD_, RM2);
1223   srcreg2 = translate_rreg (SD_, RN0);
1224
1225   temp = ((signed64)(signed32)State.regs[srcreg2]
1226           * (signed64)(signed32)State.regs[srcreg1]);
1227   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
1228   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
1229   State.regs[REG_MCRL] = sum;
1230   temp >>= 32;
1231   temp &= 0xffffffff;
1232   sum = State.regs[REG_MCRH] + temp + c;
1233   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
1234         && (temp & 0x80000000) != (sum & 0x80000000));
1235   State.regs[REG_MCRH] = sum;
1236   if (v)
1237     State.regs[REG_MCVF] = 1;
1238 }
1239
1240 // 1111 1001 0001 1011 Rm Rn; macu Rm,Rn
1241 8.0xf9+8.0x1b+4.RM2,4.RN0:D1:::macu
1242 "macu"
1243 *am33
1244 *am33_2
1245 {
1246   int srcreg1, srcreg2;
1247   unsigned64 temp, sum;
1248   int c, v;
1249
1250   PC = cia;
1251   srcreg1 = translate_rreg (SD_, RM2);
1252   srcreg2 = translate_rreg (SD_, RN0);
1253
1254   temp = ((unsigned64)State.regs[srcreg2]
1255           * (unsigned64)State.regs[srcreg1]);
1256   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
1257   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
1258   State.regs[REG_MCRL] = sum;
1259   temp >>= 32;
1260   temp &= 0xffffffff;
1261   sum = State.regs[REG_MCRH] + temp + c;
1262   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
1263         && (temp & 0x80000000) != (sum & 0x80000000));
1264   State.regs[REG_MCRH] = sum;
1265   if (v)
1266     State.regs[REG_MCVF] = 1;
1267 }
1268
1269 // 1111 1001 0010 1011 Rm Rn; macb Rm,Rn
1270 8.0xf9+8.0x2b+4.RM2,4.RN0:D1:::macb
1271 "macb"
1272 *am33
1273 *am33_2
1274 {
1275   int srcreg1, srcreg2;
1276   signed32 temp, sum;
1277   int v;
1278
1279   PC = cia;
1280   srcreg1 = translate_rreg (SD_, RM2);
1281   srcreg2 = translate_rreg (SD_, RN0);
1282
1283   temp = ((signed32)(signed8)(State.regs[srcreg2] & 0xff)
1284           * (signed32)(signed8)(State.regs[srcreg1] & 0xff));
1285   sum = State.regs[REG_MCRL] + temp;
1286   v = ((State.regs[REG_MCRL] & 0x80000000) == (temp & 0x80000000)
1287         && (temp & 0x80000000) != (sum & 0x80000000));
1288   State.regs[REG_MCRL] = sum;
1289   if (v)
1290     State.regs[REG_MCVF] = 1;
1291 }
1292
1293 // 1111 1001 0011 1011 Rm Rn; macbu Rm,Rn
1294 8.0xf9+8.0x3b+4.RM2,4.RN0:D1:::macbu
1295 "macbu"
1296 *am33
1297 *am33_2
1298 {
1299   int srcreg1, srcreg2;
1300   signed64 temp, sum;
1301   int v;
1302
1303   PC = cia;
1304   srcreg1 = translate_rreg (SD_, RM2);
1305   srcreg2 = translate_rreg (SD_, RN0);
1306
1307   temp = ((unsigned32)(State.regs[srcreg2] & 0xff)
1308           * (unsigned32)(State.regs[srcreg1] & 0xff));
1309   sum = State.regs[REG_MCRL] + temp;
1310   v = ((State.regs[REG_MCRL] & 0x80000000) == (temp & 0x80000000)
1311         && (temp & 0x80000000) != (sum & 0x80000000));
1312   State.regs[REG_MCRL] = sum;
1313   if (v)
1314     State.regs[REG_MCVF] = 1;
1315 }
1316
1317 // 1111 1001 0100 1011 Rm Rn; mach Rm,Rn
1318 8.0xf9+8.0x4b+4.RM2,4.RN0:D1:::mach
1319 "mach"
1320 *am33
1321 *am33_2
1322 {
1323   int srcreg1, srcreg2;
1324   signed64 temp, sum;
1325   int c, v;
1326
1327   PC = cia;
1328   srcreg1 = translate_rreg (SD_, RM2);
1329   srcreg2 = translate_rreg (SD_, RN0);
1330
1331   temp = ((unsigned64)(signed16)(State.regs[srcreg2] & 0xffff)
1332           * (unsigned64)(signed16)(State.regs[srcreg1] & 0xffff));
1333   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
1334   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
1335   State.regs[REG_MCRL] = sum;
1336   temp >>= 32;
1337   temp &= 0xffffffff;
1338   sum = State.regs[REG_MCRH] + temp + c;
1339   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
1340         && (temp & 0x80000000) != (sum & 0x80000000));
1341   State.regs[REG_MCRH] = sum;
1342   if (v)
1343     State.regs[REG_MCVF] = 1;
1344 }
1345
1346 // 1111 1001 0101 1011 Rm Rn; machu Rm,Rn
1347 8.0xf9+8.0x5b+4.RM2,4.RN0:D1:::machu
1348 "machu"
1349 *am33
1350 *am33_2
1351 {
1352   int srcreg1, srcreg2;
1353   signed64 temp, sum;
1354   int c, v;
1355
1356   PC = cia;
1357   srcreg1 = translate_rreg (SD_, RM2);
1358   srcreg2 = translate_rreg (SD_, RN0);
1359
1360   temp = ((unsigned64)(State.regs[srcreg2] & 0xffff)
1361           * (unsigned64)(State.regs[srcreg1] & 0xffff));
1362   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
1363   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
1364   State.regs[REG_MCRL] = sum;
1365   temp >>= 32;
1366   temp &= 0xffffffff;
1367   sum = State.regs[REG_MCRH] + temp + c;
1368   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
1369         && (temp & 0x80000000) != (sum & 0x80000000));
1370   State.regs[REG_MCRH] = sum;
1371   if (v)
1372     State.regs[REG_MCVF] = 1;
1373 }
1374
1375 // 1111 1001 0110 1011 Rm Rn; dmach Rm,Rn
1376 8.0xf9+8.0x6b+4.RM2,4.RN0:D1:::dmach
1377 "dmach"
1378 *am33
1379 *am33_2
1380 {
1381   int srcreg1, srcreg2;
1382   signed32 temp, temp2, sum;
1383   int v;
1384
1385   PC = cia;
1386   srcreg1 = translate_rreg (SD_, RM2);
1387   srcreg2 = translate_rreg (SD_, RN0);
1388
1389   temp = ((signed32)(signed16)(State.regs[srcreg2] & 0xffff)
1390           * (signed32)(signed16)(State.regs[srcreg1] & 0xffff));
1391   temp2 = ((signed32)(signed16)((State.regs[srcreg1] >> 16) & 0xffff)
1392            * (signed32)(signed16)((State.regs[srcreg2] >> 16) & 0xffff));
1393   sum = temp + temp2 + State.regs[REG_MCRL];
1394   v = ((State.regs[REG_MCRL] & 0x80000000) == (temp & 0x80000000)
1395         && (temp & 0x80000000) != (sum & 0x80000000));
1396   State.regs[REG_MCRL] = sum;
1397   if (v)
1398     State.regs[REG_MCVF] = 1;
1399 }
1400
1401 // 1111 1001 0111 1011 Rm Rn; dmachu Rm,Rn
1402 8.0xf9+8.0x7b+4.RM2,4.RN0:D1:::dmachu
1403 "dmachu"
1404 *am33
1405 *am33_2
1406 {
1407   int srcreg1, srcreg2;
1408   unsigned32 temp, temp2, sum;
1409   int v;
1410
1411   PC = cia;
1412   srcreg1 = translate_rreg (SD_, RM2);
1413   srcreg2 = translate_rreg (SD_, RN0);
1414
1415   temp = ((unsigned32)(State.regs[srcreg2] & 0xffff)
1416           * (unsigned32)(State.regs[srcreg1] & 0xffff));
1417   temp2 = ((unsigned32)((State.regs[srcreg1] >> 16) & 0xffff)
1418            * (unsigned32)((State.regs[srcreg2] >> 16) & 0xffff));
1419   sum = temp + temp2 + State.regs[REG_MCRL];
1420   v = ((State.regs[REG_MCRL] & 0x80000000) == (temp & 0x80000000)
1421         && (temp & 0x80000000) != (sum & 0x80000000));
1422   State.regs[REG_MCRL] = sum;
1423   if (v)
1424     State.regs[REG_MCVF] = 1;
1425 }
1426
1427 // 1111 1001 1000 1011 Rm Rn; dmulh Rm,Rn
1428 8.0xf9+8.0x8b+4.RM2,4.RN0:D1:::dmulh
1429 "dmulh"
1430 *am33
1431 *am33_2
1432 {
1433   int srcreg, dstreg;
1434   signed32 temp;
1435
1436   PC = cia;
1437   srcreg = translate_rreg (SD_, RM2);
1438   dstreg = translate_rreg (SD_, RN0);
1439
1440   temp = ((signed32)(signed16)(State.regs[dstreg] & 0xffff)
1441           * (signed32)(signed16)(State.regs[srcreg] & 0xffff));
1442   State.regs[REG_MDRQ] = temp;
1443   temp = ((signed32)(signed16)((State.regs[dstreg] >> 16) & 0xffff)
1444           * (signed32)(signed16)((State.regs[srcreg] >>16) & 0xffff));
1445   State.regs[dstreg] = temp;
1446 }
1447
1448 // 1111 1001 1001 1011 Rm Rn; dmulhu Rm,Rn
1449 8.0xf9+8.0x9b+4.RM2,4.RN0:D1:::dumachu
1450 "dmachu"
1451 *am33
1452 *am33_2
1453 {
1454   int srcreg, dstreg;
1455   unsigned32 temp;
1456
1457   PC = cia;
1458   srcreg = translate_rreg (SD_, RM2);
1459   dstreg = translate_rreg (SD_, RN0);
1460
1461   temp = ((unsigned32)(State.regs[dstreg] & 0xffff)
1462           * (unsigned32)(State.regs[srcreg] & 0xffff));
1463   State.regs[REG_MDRQ] = temp;
1464   temp = ((unsigned32)((State.regs[dstreg] >> 16) & 0xffff)
1465           * (unsigned32)((State.regs[srcreg] >>16) & 0xffff));
1466   State.regs[dstreg] = temp;
1467 }
1468
1469 // 1111 1001 1010 1011 Rm Rn; sat16 Rm,Rn
1470 8.0xf9+8.0xab+4.RM2,4.RN0:D1:::sat16
1471 "sat16"
1472 *am33
1473 *am33_2
1474 {
1475   int srcreg, dstreg;
1476   int value, z, n;
1477
1478   PC = cia;
1479   srcreg = translate_rreg (SD_, RM2);
1480   dstreg = translate_rreg (SD_, RN0);
1481
1482   value = State.regs[srcreg];
1483
1484   if (value >= 0x7fff)
1485     State.regs[dstreg] = 0x7fff;
1486   else if (value <= 0xffff8000)
1487     State.regs[dstreg] = 0xffff8000;
1488   else
1489     State.regs[dstreg] = value;
1490
1491   n = (State.regs[dstreg] & 0x8000) != 0;
1492   z = (State.regs[dstreg] == 0);
1493   PSW &= ~(PSW_Z | PSW_N);
1494   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
1495 }
1496
1497 // 1111 1001 1011 1011 Rm Rn; mcste Rm,Rn 
1498 8.0xf9+8.0xbb+4.RM2,4.RN0:D1:::mcste
1499 "mcste"
1500 *am33
1501 *am33_2
1502 {
1503   int srcreg, dstreg;
1504
1505   PC = cia;
1506   srcreg = translate_rreg (SD_, RM2);
1507   dstreg = translate_rreg (SD_, RN0);
1508
1509   PSW &= ~(PSW_V | PSW_C);
1510   PSW |= (State.regs[REG_MCVF] ? PSW_V : 0);
1511   
1512   /* 32bit saturation.  */
1513   if (State.regs[srcreg] == 0x20)
1514     {
1515       signed64 tmp;
1516
1517       tmp = State.regs[REG_MCRH];
1518       tmp <<= 32;
1519       tmp += State.regs[REG_MCRL];
1520
1521       if (tmp > 0x7fffffff)    
1522         State.regs[dstreg] = 0x7fffffff;
1523       else if (tmp < 0xffffffff80000000LL)
1524         State.regs[dstreg] = 0x80000000;
1525       else
1526         State.regs[dstreg] = tmp;
1527     }
1528   /* 16bit saturation */
1529   else if (State.regs[srcreg] == 0x10)
1530     {
1531       signed64 tmp;
1532
1533       tmp = State.regs[REG_MCRH];
1534       tmp <<= 32;
1535       tmp += State.regs[REG_MCRL];
1536
1537       if (tmp > 0x7fff)    
1538         State.regs[dstreg] = 0x7fff;
1539       else if (tmp < 0xffffffffffff8000LL)
1540         State.regs[dstreg] = 0x8000;
1541       else
1542         State.regs[dstreg] = tmp;
1543     }
1544   /* 8 bit saturation */
1545   else if (State.regs[srcreg] == 0x8)
1546     {
1547       signed64 tmp;
1548
1549       tmp = State.regs[REG_MCRH];
1550       tmp <<= 32;
1551       tmp += State.regs[REG_MCRL];
1552
1553       if (tmp > 0x7f)    
1554         State.regs[dstreg] = 0x7f;
1555       else if (tmp < 0xffffffffffffff80LL)
1556         State.regs[dstreg] = 0x80;
1557       else
1558         State.regs[dstreg] = tmp;
1559     }
1560   /* 9 bit saturation */
1561   else if (State.regs[srcreg] == 0x9)
1562     {
1563       signed64 tmp;
1564
1565       tmp = State.regs[REG_MCRH];
1566       tmp <<= 32;
1567       tmp += State.regs[REG_MCRL];
1568
1569       if (tmp > 0x80)    
1570         State.regs[dstreg] = 0x80;
1571       else if (tmp < 0xffffffffffffff81LL)
1572         State.regs[dstreg] = 0x81;
1573       else
1574         State.regs[dstreg] = tmp;
1575     }
1576   /* 9 bit saturation */
1577   else if (State.regs[srcreg] == 0x30)
1578     {
1579       signed64 tmp;
1580
1581       tmp = State.regs[REG_MCRH];
1582       tmp <<= 32;
1583       tmp += State.regs[REG_MCRL];
1584
1585       if (tmp > 0x7fffffffffffLL)    
1586         tmp = 0x7fffffffffffLL;
1587       else if (tmp < 0xffff800000000000LL)
1588         tmp = 0xffff800000000000LL;
1589
1590       tmp >>= 16;
1591       State.regs[dstreg] = tmp;
1592     }
1593 }
1594
1595 // 1111 1001 1100 1011 Rm Rn; swap Rm,Rn
1596 8.0xf9+8.0xcb+4.RM2,4.RN0:D1:::swap
1597 "swap"
1598 *am33
1599 *am33_2
1600 {
1601   int srcreg, dstreg;
1602
1603   PC = cia;
1604   srcreg = translate_rreg (SD_, RM2);
1605   dstreg = translate_rreg (SD_, RN0);
1606
1607   State.regs[dstreg] = (((State.regs[srcreg] & 0xff) << 24)
1608                         | (((State.regs[srcreg] >> 8) & 0xff) << 16)
1609                         | (((State.regs[srcreg] >> 16) & 0xff) << 8)
1610                         | ((State.regs[srcreg] >> 24) & 0xff));
1611 }
1612
1613 // 1111 1101 1101 1011 Rm Rn; swaph Rm,Rn
1614 8.0xf9+8.0xdb+4.RM2,4.RN0:D1:::swaph
1615 "swaph"
1616 *am33
1617 *am33_2
1618 {
1619   int srcreg, dstreg;
1620
1621   PC = cia;
1622   srcreg = translate_rreg (SD_, RM2);
1623   dstreg = translate_rreg (SD_, RN0);
1624
1625   State.regs[dstreg] = (((State.regs[srcreg] & 0xff) << 8)
1626                         | ((State.regs[srcreg] >> 8) & 0xff)
1627                         | (((State.regs[srcreg] >> 16) & 0xff) << 24)
1628                         | (((State.regs[srcreg] >> 24) & 0xff) << 16));
1629 }
1630
1631 // 1111 1001 1110 1011 Rm Rn; swhw Rm,Rn
1632 8.0xf9+8.0xeb+4.RM2,4.RN0:D1:::swhw
1633 "swhw"
1634 *am33
1635 *am33_2
1636 {
1637   int srcreg, dstreg;
1638
1639   PC = cia;
1640   srcreg = translate_rreg (SD_, RM2);
1641   dstreg = translate_rreg (SD_, RN0);
1642
1643   State.regs[dstreg] = (((State.regs[srcreg] & 0xffff) << 16)
1644                         | ((State.regs[srcreg] >> 16) & 0xffff));
1645 }
1646
1647 // 1111 1001 1111 1011 Rm Rn; bsch Rm,Rn
1648 8.0xf9+8.0xfb+4.RM2,4.RN0:D1:::bsch
1649 "bsch"
1650 *am33
1651 *am33_2
1652 {
1653   int temp, c, i;
1654   int srcreg, dstreg;
1655   int start;
1656
1657   PC = cia;
1658   srcreg = translate_rreg (SD_, RM2);
1659   dstreg = translate_rreg (SD_, RN0);
1660
1661   temp = State.regs[srcreg];
1662   start = (State.regs[dstreg] & 0x1f) - 1;
1663   if (start == -1)
1664     start = 31;
1665     
1666   c = 0;
1667   for (i = start; i >= 0; i--)
1668     {
1669       if (temp & (1 << i))
1670         {
1671           c = 1;
1672           State.regs[dstreg] = i;
1673           break;
1674         }
1675     }
1676
1677   if (i < 0)
1678     {
1679       c = 0;
1680       State.regs[dstreg] = 0;
1681     }
1682   PSW &= ~(PSW_C);
1683   PSW |= (c ? PSW_C : 0);
1684 }
1685
1686
1687 // 1111 1011 0000 1000 Rn Rn IMM8; mov IMM8,Rn
1688 8.0xfb+8.0x08+4.RM2,4.RN0=RM2+8.IMM8:D2j:::mov
1689 "mov"
1690 *am33
1691 *am33_2
1692 {
1693   int dstreg;
1694
1695   PC = cia;
1696   dstreg = translate_rreg (SD_, RN0);
1697   State.regs[dstreg] = EXTEND8 (IMM8);
1698 }
1699
1700 // 1111 1011 0001 1000 Rn Rn IMM8; movu IMM8,Rn
1701 8.0xfb+8.0x18+4.RM2,4.RN0=RM2+8.IMM8:D2:::movu
1702 "movu"
1703 *am33
1704 *am33_2
1705 {
1706   int dstreg;
1707
1708   PC = cia;
1709   dstreg = translate_rreg (SD_, RN0);
1710   State.regs[dstreg] = IMM8 & 0xff;
1711 }
1712
1713 // 1111 1011 0111 1000 Rn Rn IMM8; add IMM8,Rn
1714 8.0xfb+8.0x78+4.RM2,4.RN0=RM2+8.IMM8:D2d:::add
1715 "add"
1716 *am33
1717 *am33_2
1718 {
1719   int dstreg;
1720
1721   PC = cia;
1722   dstreg = translate_rreg (SD_, RN0);
1723   genericAdd (EXTEND8 (IMM8), dstreg);
1724 }
1725
1726 // 1111 1011 1000 1000 Rn Rn IMM8; addc IMM8,Rn
1727 8.0xfb+8.0x88+4.RM2,4.RN0=RM2+8.IMM8:D2d:::addc
1728 "addc"
1729 *am33
1730 *am33_2
1731 {
1732   int dstreg, imm;
1733   int z, c, n, v;
1734   unsigned32 reg2, sum;
1735
1736   PC = cia;
1737   dstreg = translate_rreg (SD_, RN0);
1738
1739   imm = EXTEND8 (IMM8);
1740   reg2 = State.regs[dstreg];
1741   sum = imm + reg2 + ((PSW & PSW_C) != 0);
1742   State.regs[dstreg] = sum;
1743
1744   z = ((PSW & PSW_Z) != 0) && (sum == 0);
1745   n = (sum & 0x80000000);
1746   c = (sum < imm) || (sum < reg2);
1747   v = ((reg2 & 0x80000000) == (imm & 0x80000000)
1748        && (reg2 & 0x80000000) != (sum & 0x80000000));
1749
1750   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
1751   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0)
1752           | (c ? PSW_C : 0) | (v ? PSW_V : 0));
1753 }
1754
1755 // 1111 1011 1001 1000 Rn Rn IMM8; sub IMM8,Rn
1756 8.0xfb+8.0x98+4.RM2,4.RN0=RM2+8.IMM8:D2d:::sub
1757 "sub"
1758 *am33
1759 *am33_2
1760 {
1761   int dstreg;
1762
1763   PC = cia;
1764   dstreg = translate_rreg (SD_, RN0);
1765
1766   genericSub (EXTEND8 (IMM8), dstreg);
1767 }
1768
1769 // 1111 1011 1010 1000 Rn Rn IMM8; subc IMM8,Rn
1770 8.0xfb+8.0xa8+4.RM2,4.RN0=RM2+8.IMM8:D2d:::subc
1771 "subc"
1772 *am33
1773 *am33_2
1774 {
1775   int imm, dstreg;
1776   int z, c, n, v;
1777   unsigned32 reg2, difference;
1778
1779   PC = cia;
1780   dstreg = translate_rreg (SD_, RN0);
1781
1782   imm = EXTEND8 (IMM8);
1783   reg2 = State.regs[dstreg];
1784   difference = reg2 - imm - ((PSW & PSW_C) != 0);
1785   State.regs[dstreg] = difference;
1786
1787   z = ((PSW & PSW_Z) != 0) && (difference == 0);
1788   n = (difference & 0x80000000);
1789   c = (imm > reg2);
1790   v = ((reg2 & 0x80000000) == (imm & 0x80000000)
1791        && (reg2 & 0x80000000) != (difference & 0x80000000));
1792
1793   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
1794   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0)
1795           | (c ? PSW_C : 0) | (v ? PSW_V : 0));
1796 }
1797
1798 // 1111 1011 1101 1000 Rn Rn IMM8; cmp IMM8,Rn
1799 8.0xfb+8.0xd8+4.RM2,4.RN0=RM2+8.IMM8:D2b:::cmp
1800 "cmp"
1801 *am33
1802 *am33_2
1803 {
1804   int srcreg;
1805
1806   PC = cia;
1807   srcreg = translate_rreg (SD_, RN0);
1808   genericCmp (EXTEND8 (IMM8), State.regs[srcreg]);
1809 }
1810
1811 // 1111 1011 1111 1000 XRn XRn IMM8; mov IMM8,XRn
1812 8.0xfb+8.0xf8+4.XRM2,4.XRN0=XRM2+8.IMM8:D2k:::mov
1813 "mov"
1814 *am33
1815 *am33_2
1816 {
1817   int dstreg;
1818
1819   PC = cia;
1820   dstreg = translate_xreg (SD_, XRN0);
1821
1822   State.regs[dstreg] = IMM8;
1823 }
1824
1825 // 1111 1011 0000 1001 Rn Rn IMM8; and IMM8,Rn
1826 8.0xfb+8.0x09+4.RM2,4.RN0=RM2+8.IMM8:D2d:::and
1827 "and"
1828 *am33
1829 *am33_2
1830 {
1831   int dstreg;
1832   int z, n;
1833
1834   PC = cia;
1835   dstreg = translate_rreg (SD_, RN0);
1836
1837   State.regs[dstreg] &= (IMM8 & 0xff);
1838   z = (State.regs[dstreg] == 0);
1839   n = (State.regs[dstreg] & 0x80000000) != 0;
1840   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
1841   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
1842 }
1843
1844 // 1111 1011 0001 1001 Rn Rn IMM8; or IMM8,Rn
1845 8.0xfb+8.0x19+4.RM2,4.RN0=RM2+8.IMM8:D2d:::or
1846 "or"
1847 *am33
1848 *am33_2
1849 {
1850   int dstreg;
1851   int z, n;
1852
1853   PC = cia;
1854   dstreg = translate_rreg (SD_, RN0);
1855
1856   State.regs[dstreg] |= (IMM8 & 0xff);
1857   z = (State.regs[dstreg] == 0);
1858   n = (State.regs[dstreg] & 0x80000000) != 0;
1859   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
1860   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
1861 }
1862
1863 // 1111 1011 0010 1001 Rn Rn IMM8; xor IMM8,Rn
1864 8.0xfb+8.0x29+4.RM2,4.RN0=RM2+8.IMM8:D2d:::xor
1865 "xor"
1866 *am33
1867 *am33_2
1868 {
1869   int dstreg;
1870   int z, n;
1871
1872   PC = cia;
1873   dstreg = translate_rreg (SD_, RN0);
1874
1875   State.regs[dstreg] ^= (IMM8 & 0xff);
1876   z = (State.regs[dstreg] == 0);
1877   n = (State.regs[dstreg] & 0x80000000) != 0;
1878   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
1879   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
1880 }
1881
1882 // 1111 1011 0100 1001 Rn Rn IMM8; asr IMM8,Rn
1883 8.0xfb+8.0x49+4.RM2,4.RN0=RM2+8.IMM8:D2a:::asr
1884 "asr"
1885 *am33
1886 *am33_2
1887 {
1888   int dstreg;
1889   signed32 temp;
1890   int c, z, n;
1891
1892   PC = cia;
1893   dstreg = translate_rreg (SD_, RN0);
1894
1895   temp = State.regs[dstreg];
1896   c = temp & 1;
1897   temp >>= (IMM8 & 0xff);
1898   State.regs[dstreg] = temp;
1899   z = (State.regs[dstreg] == 0);
1900   n = (State.regs[dstreg] & 0x80000000) != 0;
1901   PSW &= ~(PSW_Z | PSW_N | PSW_C);
1902   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0) | (c ? PSW_C : 0));
1903 }
1904
1905 // 1111 1011 0101 1001 Rn Rn IMM8; lsr IMM8,Rn
1906 8.0xfb+8.0x59+4.RM2,4.RN0=RM2+8.IMM8:D2a:::lsr
1907 "lsr"
1908 *am33
1909 *am33_2
1910 {
1911   int dstreg;
1912   int z, n, c;
1913
1914   PC = cia;
1915   dstreg = translate_rreg (SD_, RN0);
1916
1917   c = State.regs[dstreg] & 1;
1918   State.regs[dstreg] >>= (IMM8 & 0xff);
1919   z = (State.regs[dstreg] == 0);
1920   n = (State.regs[dstreg] & 0x80000000) != 0;
1921   PSW &= ~(PSW_Z | PSW_N | PSW_C);
1922   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0) | (c ? PSW_C : 0));
1923 }
1924
1925 // 1111 1011 0110 1001 Rn Rn IMM8; asl IMM8,Rn
1926 8.0xfb+8.0x69+4.RM2,4.RN0=RM2+8.IMM8:D2a:::asl
1927 "asl"
1928 *am33
1929 *am33_2
1930 {
1931   int dstreg;
1932   int z, n;
1933
1934   PC = cia;
1935   dstreg = translate_rreg (SD_, RN0);
1936
1937   State.regs[dstreg] <<= (IMM8 & 0xff);
1938   z = (State.regs[dstreg] == 0);
1939   n = (State.regs[dstreg] & 0x80000000) != 0;
1940   PSW &= ~(PSW_Z | PSW_N);
1941   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
1942 }
1943
1944 // 1111 1011 1010 1001 Rn Rn IMM8; mul IMM8,Rn
1945 8.0xfb+8.0xa9+4.RM2,4.RN0=RM2+8.IMM8:D2a:::mul
1946 "mul"
1947 *am33
1948 *am33_2
1949 {
1950   int dstreg;
1951   unsigned64 temp;
1952   int z, n;
1953
1954   PC = cia;
1955   dstreg = translate_rreg (SD_, RN0);
1956
1957   temp = ((signed64)(signed32)State.regs[dstreg]
1958           *  (signed64)(signed32)EXTEND8 (IMM8));
1959   State.regs[dstreg] = temp & 0xffffffff;
1960   State.regs[REG_MDR] = (temp & 0xffffffff00000000LL) >> 32;
1961   z = (State.regs[dstreg] == 0);
1962   n = (State.regs[dstreg] & 0x80000000) != 0;
1963   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
1964   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
1965 }
1966
1967 // 1111 1011 1011 1001 Rn Rn IMM8; mulu IMM8,Rn
1968 8.0xfb+8.0xb9+4.RM2,4.RN0=RM2+8.IMM8:D2a:::mulu
1969 "mulu"
1970 *am33
1971 *am33_2
1972 {
1973   int dstreg;
1974   unsigned64 temp;
1975   int z, n;
1976
1977   PC = cia;
1978   dstreg = translate_rreg (SD_, RN0);
1979
1980   temp = ((unsigned64)State.regs[dstreg]
1981           * (unsigned64)(IMM8 & 0xff));
1982   State.regs[dstreg] = temp & 0xffffffff;
1983   State.regs[REG_MDR] = (temp & 0xffffffff00000000LL) >> 32;
1984   z = (State.regs[dstreg] == 0);
1985   n = (State.regs[dstreg] & 0x80000000) != 0;
1986   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
1987   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
1988 }
1989
1990 // 1111 1011 1110 1001 Rn Rn IMM8; btst imm8,Rn
1991 8.0xfb+8.0xe9+4.RN2,4.RM0=RN2+8.IMM8:D2l:::btst
1992 "btst"
1993 *am33
1994 *am33_2
1995 {
1996   int srcreg;
1997
1998   PC = cia;
1999   srcreg = translate_rreg (SD_, RM0);
2000   genericBtst(IMM8, State.regs[srcreg]);
2001 }
2002
2003 // 1111 1011 0000 1010 Rn Rm IMM8; mov (d8,Rm),Rn
2004 8.0xfb+8.0x0a+4.RN2,4.RM0+8.IMM8:D2l:::mov
2005 "mov"
2006 *am33
2007 *am33_2
2008 {
2009   int srcreg, dstreg;
2010
2011   PC = cia;
2012   srcreg = translate_rreg (SD_, RM0);
2013   dstreg = translate_rreg (SD_, RN2);
2014   State.regs[dstreg] = load_word (State.regs[srcreg] + EXTEND8 (IMM8));
2015 }
2016
2017 // 1111 1011 0001 1010 Rn Rm IMM8; mov Rm,(d8,Rn)
2018 8.0xfb+8.0x1a+4.RM2,4.RN0+8.IMM8:D2m:::mov
2019 "mov"
2020 *am33
2021 *am33_2
2022 {
2023   int srcreg, dstreg;
2024
2025   PC = cia;
2026   srcreg = translate_rreg (SD_, RM2);
2027   dstreg = translate_rreg (SD_, RN0);
2028   store_word (State.regs[dstreg] + EXTEND8 (IMM8), State.regs[srcreg]);
2029 }
2030
2031 // 1111 1011 0010 1010 Rn Rm IMM8; movbu (d8,Rm),Rn
2032 8.0xfb+8.0x2a+4.RN2,4.RM0+8.IMM8:D2l:::movbu
2033 "movbu"
2034 *am33
2035 *am33_2
2036 {
2037   int srcreg, dstreg;
2038
2039   PC = cia;
2040   srcreg = translate_rreg (SD_, RM0);
2041   dstreg = translate_rreg (SD_, RN2);
2042   State.regs[dstreg] = load_byte (State.regs[srcreg] + EXTEND8 (IMM8));
2043 }
2044
2045 // 1111 1011 0011 1010 Rn Rm IMM8; movbu Rm,(d8,Rn)
2046 8.0xfb+8.0x3a+4.RM2,4.RN0+8.IMM8:D2m:::movbu
2047 "movbu"
2048 *am33
2049 *am33_2
2050 {
2051   int srcreg, dstreg;
2052
2053   PC = cia;
2054   srcreg = translate_rreg (SD_, RM2);
2055   dstreg = translate_rreg (SD_, RN0);
2056   store_byte (State.regs[dstreg] + EXTEND8 (IMM8), State.regs[srcreg]);
2057 }
2058
2059 // 1111 1011 0100 1010 Rn Rm IMM8; movhu (d8,Rm),Rn
2060 8.0xfb+8.0x4a+4.RN2,4.RM0+8.IMM8:D2l:::movhu
2061 "movhu"
2062 *am33
2063 *am33_2
2064 {
2065   int srcreg, dstreg;
2066
2067   PC = cia;
2068   srcreg = translate_rreg (SD_, RM0);
2069   dstreg = translate_rreg (SD_, RN2);
2070   State.regs[dstreg] = load_half (State.regs[srcreg] + EXTEND8 (IMM8));
2071 }
2072
2073 // 1111 1011 0101 1010 Rn Rm IMM8; movhu Rm,(d8,Rn)
2074 8.0xfb+8.0x5a+4.RM2,4.RN0+8.IMM8:D2m:::movhu
2075 "movhu"
2076 *am33
2077 *am33_2
2078 {
2079   int srcreg, dstreg;
2080
2081   PC = cia;
2082   srcreg = translate_rreg (SD_, RM2);
2083   dstreg = translate_rreg (SD_, RN0);
2084   store_half (State.regs[dstreg] + EXTEND8 (IMM8), State.regs[srcreg]);
2085 }
2086
2087 // 1111 1011 0110 1010 Rn Rm IMM8; mov (d8,Rm+),Rn
2088 8.0xfb+8.0x6a+4.RN2,4.RM0!RN2+8.IMM8:D2y:::mov
2089 "mov"
2090 *am33
2091 *am33_2
2092 {
2093   int srcreg, dstreg;
2094
2095   PC = cia;
2096   srcreg = translate_rreg (SD_, RM0);
2097   dstreg = translate_rreg (SD_, RN2);
2098   State.regs[dstreg] = load_word (State.regs[srcreg]);
2099   State.regs[srcreg] += EXTEND8 (IMM8);
2100 }
2101
2102 // 1111 1011 0111 1010 Rn Rm IMM8; mov Rm,(d8,Rn+)
2103 8.0xfb+8.0x7a+4.RM2,4.RN0+8.IMM8:D2z:::mov
2104 "mov"
2105 *am33
2106 *am33_2
2107 {
2108   int srcreg, dstreg;
2109
2110   PC = cia;
2111   srcreg = translate_rreg (SD_, RM2);
2112   dstreg = translate_rreg (SD_, RN0);
2113   store_word (State.regs[dstreg], State.regs[srcreg]);
2114   State.regs[dstreg] += EXTEND8 (IMM8);
2115 }
2116
2117
2118 // 1111 1011 1000 1010 Rn 0000 IMM8; mov (d8,sp),Rn
2119 8.0xfb+8.0x8a+4.RN2,4.0x0+8.IMM8:D2n:::mov
2120 "mov"
2121 *am33
2122 *am33_2
2123 {
2124   int dstreg;
2125
2126   PC = cia;
2127   dstreg = translate_rreg (SD_, RN2);
2128   State.regs[dstreg] = load_word (State.regs[REG_SP] + IMM8);
2129 }
2130
2131 // 1111 1011 1001 1010 Rm 0000 IMM8; mov Rm,(d8,sp)
2132 8.0xfb+8.0x9a+4.RM2,4.0x0+8.IMM8:D2o:::mov
2133 "mov"
2134 *am33
2135 *am33_2
2136 {
2137   int srcreg;
2138
2139   PC = cia;
2140   srcreg = translate_rreg (SD_, RM2);
2141   store_word (State.regs[REG_SP] + IMM8, State.regs[srcreg]);
2142 }
2143
2144 // 1111 1011 1010 1010 Rn Rm IMM8; movbu (d8,sp),Rn
2145 8.0xfb+8.0xaa+4.RN2,4.0x0+8.IMM8:D2n:::movbu
2146 "movbu"
2147 *am33
2148 *am33_2
2149 {
2150   int dstreg;
2151
2152   PC = cia;
2153   dstreg = translate_rreg (SD_, RN2);
2154   State.regs[dstreg] = load_byte (State.regs[REG_SP] + IMM8);
2155 }
2156
2157 // 1111 1011 1011 1010 Rn Rm IMM8; movbu Rm,(d8,sp)
2158 8.0xfb+8.0xba+4.RM2,4.0x0+8.IMM8:D2o:::movbu
2159 "movbu"
2160 *am33
2161 *am33_2
2162 {
2163   int srcreg;
2164
2165   PC = cia;
2166   srcreg = translate_rreg (SD_, RM2);
2167   store_byte (State.regs[REG_SP] + IMM8, State.regs[srcreg]);
2168 }
2169
2170 // 1111 1011 1100 1010 Rn Rm IMM8; movhu (d8,sp),Rn
2171 8.0xfb+8.0xca+4.RN2,4.0x0+8.IMM8:D2n:::movhu
2172 "movhu"
2173 *am33
2174 *am33_2
2175 {
2176   int dstreg;
2177
2178   PC = cia;
2179   dstreg = translate_rreg (SD_, RN2);
2180   State.regs[dstreg] = load_half (State.regs[REG_SP] + IMM8);
2181 }
2182
2183 // 1111 1011 1101 1010 Rn Rm IMM8; movhu Rm,(d8,sp)
2184 8.0xfb+8.0xda+4.RM2,4.0x0+8.IMM8:D2o:::movhu
2185 "movhu"
2186 *am33
2187 *am33_2
2188 {
2189   int srcreg;
2190
2191   PC = cia;
2192   srcreg = translate_rreg (SD_, RM2);
2193   store_half (State.regs[REG_SP] + IMM8, State.regs[srcreg]);
2194 }
2195
2196 // 1111 1011 1110 1010 Rn Rm IMM8; movhu (d8,Rm+),Rn
2197 8.0xfb+8.0xea+4.RN2,4.RM0!RN2+8.IMM8:D2y:::movhu
2198 "movhu"
2199 *am33
2200 *am33_2
2201 {
2202   int srcreg, dstreg;
2203
2204   PC = cia;
2205   srcreg = translate_rreg (SD_, RM0);
2206   dstreg = translate_rreg (SD_, RN2);
2207   State.regs[dstreg] = load_half (State.regs[srcreg]);
2208   State.regs[srcreg] += EXTEND8 (IMM8);
2209 }
2210
2211 // 1111 1011 1111 1010 Rn Rm IMM8; movhu Rm,(d8,Rn+)
2212 8.0xfb+8.0xfa+4.RM2,4.RN0+8.IMM8:D2z:::movhu
2213 "movhu"
2214 *am33
2215 *am33_2
2216 {
2217   int srcreg, dstreg;
2218
2219   PC = cia;
2220   srcreg = translate_rreg (SD_, RM2);
2221   dstreg = translate_rreg (SD_, RN0);
2222   store_half (State.regs[dstreg], State.regs[srcreg]);
2223   State.regs[dstreg] += EXTEND8 (IMM8);
2224 }
2225
2226
2227 // 1111 1011 0000 1011 Rn Rn IMM8; mac imm8,Rn
2228 8.0xfb+8.0x0b+4.RN2,4.RN0=RN2+8.IMM8:D2:::mac
2229 "mac"
2230 *am33
2231 *am33_2
2232 {
2233   int srcreg;
2234   signed64 temp, sum;
2235   int c, v;
2236
2237   PC = cia;
2238   srcreg = translate_rreg (SD_, RN2);
2239
2240   temp = ((signed64)(signed32)EXTEND8 (IMM8)
2241           * (signed64)(signed32)State.regs[srcreg]);
2242   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
2243   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
2244   State.regs[REG_MCRL] = sum;
2245   temp >>= 32;
2246   temp &= 0xffffffff;
2247   sum = State.regs[REG_MCRH] + temp + c;
2248   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
2249         && (temp & 0x80000000) != (sum & 0x80000000));
2250   State.regs[REG_MCRH] = sum;
2251   if (v)
2252     State.regs[REG_MCVF] = 1;
2253 }
2254
2255 // 1111 1011 0001 1011 Rn Rn IMM8; macu imm8,Rn
2256 8.0xfb+8.0x1b+4.RN2,4.RN0=RN2+8.IMM8:D2:::macu
2257 "macu"
2258 *am33
2259 *am33_2
2260 {
2261   int srcreg;
2262   signed64 temp, sum;
2263   int c, v;
2264
2265   PC = cia;
2266   srcreg = translate_rreg (SD_, RN2);
2267
2268   temp = ((unsigned64) (IMM8)
2269           * (unsigned64)State.regs[srcreg]);
2270   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
2271   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
2272   State.regs[REG_MCRL] = sum;
2273   temp >>= 32;
2274   temp &= 0xffffffff;
2275   sum = State.regs[REG_MCRH] + temp + c;
2276   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
2277         && (temp & 0x80000000) != (sum & 0x80000000));
2278   State.regs[REG_MCRH] = sum;
2279   if (v)
2280     State.regs[REG_MCVF] = 1;
2281 }
2282
2283 // 1111 1011 0010 1011 Rn Rn IMM8; macb imm8,Rn
2284 8.0xfb+8.0x2b+4.RN2,4.RN0=RN2+8.IMM8:D2:::macb
2285 "macb"
2286 *am33
2287 *am33_2
2288 {
2289   int srcreg;
2290   signed64 temp, sum;
2291   int c, v;
2292
2293   PC = cia;
2294   srcreg = translate_rreg (SD_, RN2);
2295
2296   temp = ((signed64)(signed8)EXTEND8 (IMM8)
2297           * (signed64)(signed8)State.regs[srcreg] & 0xff);
2298   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
2299   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
2300   State.regs[REG_MCRL] = sum;
2301   temp >>= 32;
2302   temp &= 0xffffffff;
2303   sum = State.regs[REG_MCRH] + temp + c;
2304   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
2305         && (temp & 0x80000000) != (sum & 0x80000000));
2306   State.regs[REG_MCRH] = sum;
2307   if (v)
2308     State.regs[REG_MCVF] = 1;
2309 }
2310
2311 // 1111 1011 0011 1011 Rn Rn IMM8; macbu imm8,Rn
2312 8.0xfb+8.0x3b+4.RN2,4.RN0=RN2+8.IMM8:D2:::macbu
2313 "macbu"
2314 *am33
2315 *am33_2
2316 {
2317   int srcreg;
2318   signed64 temp, sum;
2319   int c, v;
2320
2321   PC = cia;
2322   srcreg = translate_rreg (SD_, RN2);
2323
2324   temp = ((unsigned64) (IMM8)
2325           * (unsigned64)State.regs[srcreg] & 0xff);
2326   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
2327   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
2328   State.regs[REG_MCRL] = sum;
2329   temp >>= 32;
2330   temp &= 0xffffffff;
2331   sum = State.regs[REG_MCRH] + temp + c;
2332   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
2333         && (temp & 0x80000000) != (sum & 0x80000000));
2334   State.regs[REG_MCRH] = sum;
2335   if (v)
2336     State.regs[REG_MCVF] = 1;
2337 }
2338
2339 // 1111 1011 0100 1011 Rn Rn IMM8; mach imm8,Rn
2340 8.0xfb+8.0x4b+4.RN2,4.RN0=RN2+8.IMM8:D2:::mach
2341 "mach"
2342 *am33
2343 *am33_2
2344 {
2345   int srcreg;
2346   signed64 temp, sum;
2347   int c, v;
2348
2349   PC = cia;
2350   srcreg = translate_rreg (SD_, RN2);
2351
2352   temp = ((signed64)(signed16)EXTEND8 (IMM8)
2353           * (signed64)(signed16)State.regs[srcreg] & 0xffff);
2354   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
2355   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
2356   State.regs[REG_MCRL] = sum;
2357   temp >>= 32;
2358   temp &= 0xffffffff;
2359   sum = State.regs[REG_MCRH] + temp + c;
2360   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
2361         && (temp & 0x80000000) != (sum & 0x80000000));
2362   State.regs[REG_MCRH] = sum;
2363   if (v)
2364     State.regs[REG_MCVF] = 1;
2365 }
2366
2367 // 1111 1011 0101 1011 Rn Rn IMM8; machu imm8,Rn
2368 8.0xfb+8.0x5b+4.RN2,4.RN0=RN2+8.IMM8:D2:::machu
2369 "machu"
2370 *am33
2371 *am33_2
2372 {
2373   int srcreg;
2374   signed64 temp, sum;
2375   int c, v;
2376
2377   PC = cia;
2378   srcreg = translate_rreg (SD_, RN2);
2379
2380   temp = ((unsigned64) (IMM8)
2381           * (unsigned64)State.regs[srcreg] & 0xffff);
2382   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
2383   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
2384   State.regs[REG_MCRL] = sum;
2385   temp >>= 32;
2386   temp &= 0xffffffff;
2387   sum = State.regs[REG_MCRH] + temp + c;
2388   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
2389         && (temp & 0x80000000) != (sum & 0x80000000));
2390   State.regs[REG_MCRH] = sum;
2391   if (v)
2392     State.regs[REG_MCVF] = 1;
2393 }
2394
2395 // 1111 1011 1011 1011 Rn Rn IMM8; mcste imm8,Rn
2396 8.0xfb+8.0xbb+4.RN2,4.RN0=RN2+8.IMM8:D2:::mcste
2397 "mcste"
2398 *am33
2399 *am33_2
2400 {
2401   int dstreg;
2402
2403   PC = cia;
2404   dstreg = translate_rreg (SD_, RN0);
2405
2406   PSW &= ~(PSW_V | PSW_C);
2407   PSW |= (State.regs[REG_MCVF] ? PSW_V : 0);
2408   
2409   /* 32bit saturation.  */
2410   if (IMM8 == 0x20)
2411     {
2412       signed64 tmp;
2413
2414       tmp = State.regs[REG_MCRH];
2415       tmp <<= 32;
2416       tmp += State.regs[REG_MCRL];
2417
2418       if (tmp > 0x7fffffff)    
2419         State.regs[dstreg] = 0x7fffffff;
2420       else if (tmp < 0xffffffff80000000LL)
2421         State.regs[dstreg] = 0x80000000;
2422       else
2423         State.regs[dstreg] = tmp;
2424     }
2425   /* 16bit saturation */
2426   else if (IMM8 == 0x10)
2427     {
2428       signed64 tmp;
2429
2430       tmp = State.regs[REG_MCRH];
2431       tmp <<= 32;
2432       tmp += State.regs[REG_MCRL];
2433
2434       if (tmp > 0x7fff)    
2435         State.regs[dstreg] = 0x7fff;
2436       else if (tmp < 0xffffffffffff8000LL)
2437         State.regs[dstreg] = 0x8000;
2438       else
2439         State.regs[dstreg] = tmp;
2440     }
2441   /* 8 bit saturation */
2442   else if (IMM8 == 0x8)
2443     {
2444       signed64 tmp;
2445
2446       tmp = State.regs[REG_MCRH];
2447       tmp <<= 32;
2448       tmp += State.regs[REG_MCRL];
2449
2450       if (tmp > 0x7f)    
2451         State.regs[dstreg] = 0x7f;
2452       else if (tmp < 0xffffffffffffff80LL)
2453         State.regs[dstreg] = 0x80;
2454       else
2455         State.regs[dstreg] = tmp;
2456     }
2457   /* 9 bit saturation */
2458   else if (IMM8 == 0x9)
2459     {
2460       signed64 tmp;
2461
2462       tmp = State.regs[REG_MCRH];
2463       tmp <<= 32;
2464       tmp += State.regs[REG_MCRL];
2465
2466       if (tmp > 0x80)    
2467         State.regs[dstreg] = 0x80;
2468       else if (tmp < 0xffffffffffffff81LL)
2469         State.regs[dstreg] = 0x81;
2470       else
2471         State.regs[dstreg] = tmp;
2472     }
2473   /* 9 bit saturation */
2474   else if (IMM8 == 0x30)
2475     {
2476       signed64 tmp;
2477
2478       tmp = State.regs[REG_MCRH];
2479       tmp <<= 32;
2480       tmp += State.regs[REG_MCRL];
2481
2482       if (tmp > 0x7fffffffffffLL)    
2483         tmp = 0x7fffffffffffLL;
2484       else if (tmp < 0xffff800000000000LL)
2485         tmp = 0xffff800000000000LL;
2486
2487       tmp >>= 16;
2488       State.regs[dstreg] = tmp;
2489     }
2490 }
2491
2492 // 1111 1011 0111 1100 Rm Rn Rd; add Rm,Rn,Rd
2493 8.0xfb+8.0x7c+4.RM2,4.RN0+4.RD0,4.0x0:D2c:::add
2494 "add"
2495 *am33
2496 *am33_2
2497 {
2498   int z, c, n, v;
2499   unsigned32 sum, source1, source2;
2500   int srcreg1, srcreg2, dstreg;
2501
2502   PC = cia;
2503   srcreg1 = translate_rreg (SD_, RM2);
2504   srcreg2 = translate_rreg (SD_, RN0);
2505   dstreg = translate_rreg (SD_, RD0);
2506
2507   source1 = State.regs[srcreg1];
2508   source2 = State.regs[srcreg2];
2509   sum = source1 + source2;
2510   State.regs[dstreg] = sum;
2511
2512   z = (sum == 0);
2513   n = (sum & 0x80000000);
2514   c = (sum < source1) || (sum < source2);
2515   v = ((source1 & 0x80000000) == (source2 & 0x80000000)
2516        && (source1 & 0x80000000) != (sum & 0x80000000));
2517
2518   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
2519   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0)
2520           | (c ? PSW_C : 0) | (v ? PSW_V : 0));
2521 }
2522
2523 // 1111 1011 1000 1100 Rm Rn Rd; addc Rm,Rn,Rd
2524 8.0xfb+8.0x8c+4.RM2,4.RN0+4.RD0,4.0x0:D2c:::addc
2525 "addc"
2526 *am33
2527 *am33_2
2528 {
2529   int z, c, n, v;
2530   unsigned32 sum, source1, source2;
2531   int srcreg1, srcreg2, dstreg;
2532
2533   PC = cia;
2534   srcreg1 = translate_rreg (SD_, RM2);
2535   srcreg2 = translate_rreg (SD_, RN0);
2536   dstreg = translate_rreg (SD_, RD0);
2537
2538   source1 = State.regs[srcreg1];
2539   source2 = State.regs[srcreg2];
2540   sum = source1 + source2 + ((PSW & PSW_C) != 0);
2541   State.regs[dstreg] = sum;
2542
2543   z = ((PSW & PSW_Z) != 0) && (sum == 0);
2544   n = (sum & 0x80000000);
2545   c = (sum < source1) || (sum < source2);
2546   v = ((source1 & 0x80000000) == (source2 & 0x80000000)
2547        && (source1 & 0x80000000) != (sum & 0x80000000));
2548
2549   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
2550   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0)
2551           | (c ? PSW_C : 0) | (v ? PSW_V : 0));
2552 }
2553
2554 // 1111 1011 1001 1100 Rm Rn Rd; sub Rm,Rn,Rd
2555 8.0xfb+8.0x9c+4.RM2,4.RN0+4.RD0,4.0x0:D2c:::sub
2556 "sub"
2557 *am33
2558 *am33_2
2559 {
2560   int z, c, n, v;
2561   unsigned32 difference, source1, source2;
2562   int srcreg1, srcreg2, dstreg;
2563
2564   PC = cia;
2565   srcreg1 = translate_rreg (SD_, RM2);
2566   srcreg2 = translate_rreg (SD_, RN0);
2567   dstreg = translate_rreg (SD_, RD0);
2568
2569   source1 = State.regs[srcreg1];
2570   source2 = State.regs[srcreg2];
2571   difference = source2 - source1;
2572   State.regs[dstreg] = difference;
2573
2574   z = (difference == 0);
2575   n = (difference & 0x80000000);
2576   c = (source1 > source2);
2577   v = ((source1 & 0x80000000) == (source2 & 0x80000000)
2578        && (source1 & 0x80000000) != (difference & 0x80000000));
2579
2580   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
2581   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0)
2582           | (c ? PSW_C : 0) | (v ? PSW_V : 0));
2583 }
2584
2585 // 1111 1011 1010 1100 Rm Rn Rd; subc Rm,Rn,Rd
2586 8.0xfb+8.0xac+4.RM2,4.RN0+4.RD0,4.0x0:D2c:::subc
2587 "subc"
2588 *am33
2589 *am33_2
2590 {
2591   int z, c, n, v;
2592   unsigned32 difference, source1, source2;
2593   int srcreg1, srcreg2, dstreg;
2594
2595   PC = cia;
2596   srcreg1 = translate_rreg (SD_, RM2);
2597   srcreg2 = translate_rreg (SD_, RN0);
2598   dstreg = translate_rreg (SD_, RD0);
2599
2600   source1 = State.regs[srcreg1];
2601   source2 = State.regs[srcreg2];
2602   difference = source2 - source1 - ((PSW & PSW_C) != 0);
2603   State.regs[dstreg] = difference;
2604
2605   z = ((PSW & PSW_Z) != 0) && (difference == 0);
2606   n = (difference & 0x80000000);
2607   c = (source1 > source2);
2608   v = ((source1 & 0x80000000) == (source2 & 0x80000000)
2609        && (source1 & 0x80000000) != (difference & 0x80000000));
2610
2611   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
2612   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0)
2613           | (c ? PSW_C : 0) | (v ? PSW_V : 0));
2614 }
2615
2616 // 1111 1011 0000 1101 Rm Rn Rd; and Rm,Rn,Rd
2617 8.0xfb+8.0x0d+4.RM2,4.RN0+4.RD0,4.0x0:D2c:::and
2618 "and"
2619 *am33
2620 *am33_2
2621 {
2622   int z, n;
2623   int srcreg1, srcreg2, dstreg;
2624
2625   PC = cia;
2626   srcreg1 = translate_rreg (SD_, RM2);
2627   srcreg2 = translate_rreg (SD_, RN0);
2628   dstreg = translate_rreg (SD_, RD0);
2629
2630   State.regs[dstreg] = State.regs[srcreg1] & State.regs[srcreg2];
2631
2632   z = (State.regs[dstreg] == 0);
2633   n = (State.regs[dstreg] & 0x80000000);
2634
2635   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
2636   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0));
2637 }
2638
2639 // 1111 1011 0001 1101 Rm Rn Rd; or Rm,Rn,Rd
2640 8.0xfb+8.0x1d+4.RM2,4.RN0+4.RD0,4.0x0:D2c:::or
2641 "or"
2642 *am33
2643 *am33_2
2644 {
2645   int z, n;
2646   int srcreg1, srcreg2, dstreg;
2647
2648   PC = cia;
2649   srcreg1 = translate_rreg (SD_, RM2);
2650   srcreg2 = translate_rreg (SD_, RN0);
2651   dstreg = translate_rreg (SD_, RD0);
2652
2653   State.regs[dstreg] = State.regs[srcreg1] | State.regs[srcreg2];
2654
2655   z = (State.regs[dstreg] == 0);
2656   n = (State.regs[dstreg] & 0x80000000);
2657
2658   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
2659   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0));
2660 }
2661
2662 // 1111 1011 0010 1101 Rm Rn Rd; xor Rm,Rn,Rd
2663 8.0xfb+8.0x2d+4.RM2,4.RN0+4.RD0,4.0x0:D2c:::xor
2664 "xor"
2665 *am33
2666 *am33_2
2667 {
2668   int z, n;
2669   int srcreg1, srcreg2, dstreg;
2670
2671   PC = cia;
2672   srcreg1 = translate_rreg (SD_, RM2);
2673   srcreg2 = translate_rreg (SD_, RN0);
2674   dstreg = translate_rreg (SD_, RD0);
2675
2676   State.regs[dstreg] = State.regs[srcreg1] ^ State.regs[srcreg2];
2677
2678   z = (State.regs[dstreg] == 0);
2679   n = (State.regs[dstreg] & 0x80000000);
2680
2681   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
2682   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0));
2683 }
2684
2685 // 1111 1011 0100 1101 Rm Rn Rd; asr Rm,Rn,Rd
2686 8.0xfb+8.0x4d+4.RM2,4.RN0+4.RD0,4.0x0:D2c:::asr
2687 "asr"
2688 *am33
2689 *am33_2
2690 {
2691   int z, c, n;
2692   signed32 temp;
2693   int srcreg1, srcreg2, dstreg;
2694
2695   PC = cia;
2696   srcreg1 = translate_rreg (SD_, RM2);
2697   srcreg2 = translate_rreg (SD_, RN0);
2698   dstreg = translate_rreg (SD_, RD0);
2699
2700   temp = State.regs[srcreg2];
2701   c = temp & 1;
2702   temp >>= State.regs[srcreg1];
2703   State.regs[dstreg] = temp;
2704
2705   z = (State.regs[dstreg] == 0);
2706   n = (State.regs[dstreg] & 0x80000000);
2707
2708   PSW &= ~(PSW_Z | PSW_N | PSW_C);
2709   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0));
2710 }
2711
2712 // 1111 1011 0101 1101 Rm Rn Rd; lsr Rm,Rn,Rd
2713 8.0xfb+8.0x5d+4.RM2,4.RN0+4.RD0,4.0x0:D2c:::lsr
2714 "lsr"
2715 *am33
2716 *am33_2
2717 {
2718   int z, c, n;
2719   int srcreg1, srcreg2, dstreg;
2720
2721   PC = cia;
2722   srcreg1 = translate_rreg (SD_, RM2);
2723   srcreg2 = translate_rreg (SD_, RN0);
2724   dstreg = translate_rreg (SD_, RD0);
2725
2726   c = State.regs[srcreg2] & 1;
2727   State.regs[dstreg] = State.regs[srcreg2] >> State.regs[srcreg1];
2728
2729   z = (State.regs[dstreg] == 0);
2730   n = (State.regs[dstreg] & 0x80000000);
2731
2732   PSW &= ~(PSW_Z | PSW_N | PSW_C);
2733   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0));
2734 }
2735
2736 // 1111 1011 0110 1101 Rm Rn Rd; asl Rm,Rn,Rd
2737 8.0xfb+8.0x6d+4.RM2,4.RN0+4.RD0,4.0x0:D2c:::asl
2738 "asl"
2739 *am33
2740 *am33_2
2741 {
2742   int z, n;
2743   int srcreg1, srcreg2, dstreg;
2744
2745   PC = cia;
2746   srcreg1 = translate_rreg (SD_, RM2);
2747   srcreg2 = translate_rreg (SD_, RN0);
2748   dstreg = translate_rreg (SD_, RD0);
2749
2750   State.regs[dstreg] = State.regs[srcreg2] << State.regs[srcreg1];
2751
2752   z = (State.regs[dstreg] == 0);
2753   n = (State.regs[dstreg] & 0x80000000);
2754
2755   PSW &= ~(PSW_Z | PSW_N | PSW_C);
2756   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0));
2757 }
2758
2759 // 1111 1011 1010 1101 Rm Rn Rd1 Rd2; mul Rm,Rn,Rd1,Rd2
2760 8.0xfb+8.0xad+4.RM2,4.RN0+4.RD0,4.RD2!RD0:D2c:::mul
2761 "mul"
2762 *am33
2763 *am33_2
2764 {
2765   int srcreg1, srcreg2, dstreg1, dstreg2;
2766   signed64 temp;
2767   int n, z;
2768
2769   PC = cia;
2770   srcreg1 = translate_rreg (SD_, RM2);
2771   srcreg2 = translate_rreg (SD_, RN0);
2772   dstreg1 = translate_rreg (SD_, RD0);
2773   dstreg2 = translate_rreg (SD_, RD2);
2774
2775   temp = ((signed64)(signed32)State.regs[srcreg1]
2776           *  (signed64)(signed32)State.regs[srcreg2]);
2777   State.regs[dstreg2] = temp & 0xffffffff;
2778   State.regs[dstreg1] = (temp & 0xffffffff00000000LL) >> 32;
2779
2780   z = (State.regs[dstreg1] == 0) && (State.regs[dstreg2] == 0);
2781   n = (State.regs[dstreg1] & 0x80000000);
2782
2783   PSW &= ~(PSW_Z | PSW_N);
2784   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0));
2785 }
2786
2787 // 1111 1011 1011 1101 Rm Rn Rd1 Rd2; mulu Rm,Rn,Rd1,Rd2
2788 8.0xfb+8.0xbd+4.RM2,4.RN0+4.RD0,4.RD2!RD0:D2c:::mulu
2789 "mulu"
2790 *am33
2791 *am33_2
2792 {
2793   int srcreg1, srcreg2, dstreg1, dstreg2;
2794   signed64 temp;
2795   int n, z;
2796
2797   PC = cia;
2798   srcreg1 = translate_rreg (SD_, RM2);
2799   srcreg2 = translate_rreg (SD_, RN0);
2800   dstreg1 = translate_rreg (SD_, RD0);
2801   dstreg2 = translate_rreg (SD_, RD2);
2802
2803   temp = ((unsigned64)State.regs[srcreg1]
2804           *  (unsigned64)State.regs[srcreg2]);
2805   State.regs[dstreg2] = temp & 0xffffffff;
2806   State.regs[dstreg1] = (temp & 0xffffffff00000000LL) >> 32;
2807
2808   z = (State.regs[dstreg1] == 0) && (State.regs[dstreg2] == 0);
2809   n = (State.regs[dstreg1] & 0x80000000);
2810
2811   PSW &= ~(PSW_Z | PSW_N);
2812   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0));
2813 }
2814
2815 // 1111 1011 0000 1110 Rn 0000 abs8 ; mov (abs8),Rn
2816 8.0xfb+8.0x0e+4.RN2,4.0x0+8.IMM8:D2p:::mov
2817 "mov"
2818 *am33
2819 *am33_2
2820 {
2821   int dstreg;
2822
2823   PC = cia;
2824   dstreg = translate_rreg (SD_, RN2);
2825   State.regs[dstreg] = load_word (IMM8);
2826 }
2827
2828 // 1111 1011 0001 1110 Rm 0000 abs8 ; mov Rn,(abs8)
2829 8.0xfb+8.0x1e+4.RM2,4.0x0+8.IMM8:D2q:::mov
2830 "mov"
2831 *am33
2832 *am33_2
2833 {
2834   int srcreg;
2835
2836   PC = cia;
2837   srcreg = translate_rreg (SD_, RM2);
2838   store_word (IMM8, State.regs[srcreg]);
2839 }
2840
2841 // 1111 1011 0010 1110 Rn 0000 abs8 ; movbu (abs8),Rn
2842 8.0xfb+8.0x2e+4.RN2,4.0x0+8.IMM8:D2p:::movbu
2843 "movbu"
2844 *am33
2845 *am33_2
2846 {
2847   int dstreg;
2848
2849   PC = cia;
2850   dstreg = translate_rreg (SD_, RN2);
2851   State.regs[dstreg] = load_byte (IMM8);
2852 }
2853
2854 // 1111 1011 0011 1110 Rm 0000 abs8 ; movbu Rn,(abs8)
2855 8.0xfb+8.0x3e+4.RM2,4.0x0+8.IMM8:D2q:::movbu
2856 "movbu"
2857 *am33
2858 *am33_2
2859 {
2860   int srcreg;
2861
2862   PC = cia;
2863   srcreg = translate_rreg (SD_, RM2);
2864   store_byte (IMM8, State.regs[srcreg]);
2865 }
2866
2867 // 1111 1011 0100 1110 Rn 0000 abs8 ; movhu (abs8),Rn
2868 8.0xfb+8.0x4e+4.RN2,4.0x0+8.IMM8:D2p:::movhu
2869 "movhu"
2870 *am33
2871 *am33_2
2872 {
2873   int dstreg;
2874
2875   PC = cia;
2876   dstreg = translate_rreg (SD_, RN2);
2877   State.regs[dstreg] = load_half (IMM8);
2878 }
2879
2880 // 1111 1011 0101 1110 Rm 0000 abs8 ; movhu Rn,(abs8)
2881 8.0xfb+8.0x5e+4.RM2,4.0x0+8.IMM8:D2q:::movhu
2882 "movhu"
2883 *am33
2884 *am33_2
2885 {
2886   int srcreg;
2887
2888   PC = cia;
2889   srcreg = translate_rreg (SD_, RM2);
2890   store_half (IMM8, State.regs[srcreg]);
2891 }
2892
2893 // 1111 1011 1000 1110 Ri Rm Rn; mov (Ri,Rm),Rn
2894 8.0xfb+8.0x8e+4.RI0,4.RM0+4.RN0,4.0x0:D2r:::mov
2895 "mov"
2896 *am33
2897 *am33_2
2898 {
2899   int srcreg1, srcreg2, dstreg;
2900
2901   PC = cia;
2902   srcreg1 = translate_rreg (SD_, RM0);
2903   srcreg2 = translate_rreg (SD_, RI0);
2904   dstreg = translate_rreg (SD_, RN0);
2905   State.regs[dstreg] = load_word (State.regs[srcreg1] + State.regs[srcreg2]);
2906 }
2907
2908 // 1111 1011 1001 1110 Ri Rm Rn; mov Rn,(Ri,Rm)
2909 8.0xfb+8.0x9e+4.RI0,4.RN0+4.RM0,4.0x0:D2s:::mov
2910 "mov"
2911 *am33
2912 *am33_2
2913 {
2914   int srcreg, dstreg1, dstreg2;
2915
2916   PC = cia;
2917   srcreg = translate_rreg (SD_, RM0);
2918   dstreg1 = translate_rreg (SD_, RI0);
2919   dstreg2 = translate_rreg (SD_, RN0);
2920   store_word (State.regs[dstreg1] + State.regs[dstreg2], State.regs[srcreg]);
2921 }
2922
2923 // 1111 1011 1010 1110 Ri Rm Rn; movbu (Ri,Rm),Rn
2924 8.0xfb+8.0xae+4.RI0,4.RM0+4.RN0,4.0x0:D2r:::movbu
2925 "movbu"
2926 *am33
2927 *am33_2
2928 {
2929   int srcreg1, srcreg2, dstreg;
2930
2931   PC = cia;
2932   srcreg1 = translate_rreg (SD_, RM0);
2933   srcreg2 = translate_rreg (SD_, RI0);
2934   dstreg = translate_rreg (SD_, RN0);
2935   State.regs[dstreg] = load_byte (State.regs[srcreg1] + State.regs[srcreg2]);
2936 }
2937
2938 // 1111 1011 1011 1110 Ri Rm Rn; movbu Rn,(Ri,Rm)
2939 8.0xfb+8.0xbe+4.RI0,4.RN0+4.RM0,4.0x0:D2s:::movbu
2940 "movbu"
2941 *am33
2942 *am33_2
2943 {
2944   int srcreg, dstreg1, dstreg2;
2945
2946   PC = cia;
2947   srcreg = translate_rreg (SD_, RM0);
2948   dstreg1 = translate_rreg (SD_, RI0);
2949   dstreg2 = translate_rreg (SD_, RN0);
2950   store_byte (State.regs[dstreg1] + State.regs[dstreg2], State.regs[srcreg]);
2951 }
2952
2953 // 1111 1011 1100 1110 Ri Rm Rn; movhu (Ri,Rm),Rn
2954 8.0xfb+8.0xce+4.RI0,4.RM0+4.RN0,4.0x0:D2r:::movhu
2955 "movhu"
2956 *am33
2957 *am33_2
2958 {
2959   int srcreg1, srcreg2, dstreg;
2960
2961   PC = cia;
2962   srcreg1 = translate_rreg (SD_, RM0);
2963   srcreg2 = translate_rreg (SD_, RI0);
2964   dstreg = translate_rreg (SD_, RN0);
2965   State.regs[dstreg] = load_half (State.regs[srcreg1] + State.regs[srcreg2]);
2966 }
2967
2968 // 1111 1011 1101 1110 Ri Rm Rn; movhu Rn,(Ri,Rm)
2969 8.0xfb+8.0xde+4.RI0,4.RN0+4.RM0,4.0x0:D2s:::movhu
2970 "movhu"
2971 *am33
2972 *am33_2
2973 {
2974   int srcreg, dstreg1, dstreg2;
2975
2976   PC = cia;
2977   srcreg = translate_rreg (SD_, RM0);
2978   dstreg1 = translate_rreg (SD_, RI0);
2979   dstreg2 = translate_rreg (SD_, RN0);
2980   store_half (State.regs[dstreg1] + State.regs[dstreg2], State.regs[srcreg]);
2981 }
2982
2983 // 1111 1011 0000 1111 Rm Rn Rd1 Rd2; mac Rm,Rn,Rd1,Rd2
2984 8.0xfb+8.0x0f+4.RM2,4.RN0+4.RD0,4.RD2!RD0:D2c:::mac
2985 "mac"
2986 *am33
2987 *am33_2
2988 {
2989   int srcreg1, srcreg2, dstreg1, dstreg2;
2990   signed64 temp;
2991   unsigned32 sum;
2992   int c, v;
2993
2994   PC = cia;
2995   srcreg1 = translate_rreg (SD_, RM2);
2996   srcreg2 = translate_rreg (SD_, RN0);
2997   dstreg1 = translate_rreg (SD_, RD0);
2998   dstreg2 = translate_rreg (SD_, RD2);
2999
3000   temp = ((signed64)(signed32)State.regs[srcreg1]
3001           *  (signed64)(signed32)State.regs[srcreg2]);
3002
3003   sum = State.regs[dstreg2] + (temp & 0xffffffff);
3004   c = (sum < State.regs[dstreg2]) || (sum < (temp & 0xffffffff));
3005   State.regs[dstreg2] = sum;
3006   temp >>= 32;
3007   temp &= 0xffffffff;
3008   sum = State.regs[dstreg1] + temp + c;
3009   v = ((State.regs[dstreg1] & 0x80000000) == (temp & 0x80000000)
3010         && (temp & 0x80000000) != (sum & 0x80000000));
3011   State.regs[dstreg1] = sum;
3012   if (v)
3013     {
3014       State.regs[REG_MCVF] = 1;
3015       PSW &= ~(PSW_V);
3016       PSW |= (( v ? PSW_V : 0));
3017     }
3018 }
3019
3020 // 1111 1011 0001 1111 Rm Rn Rd1 Rd2; macu Rm,Rn,Rd1,Rd2
3021 8.0xfb+8.0x1f+4.RM2,4.RN0+4.RD0,4.RD2!RD0:D2c:::macu
3022 "macu"
3023 *am33
3024 *am33_2
3025 {
3026   int srcreg1, srcreg2, dstreg1, dstreg2;
3027   signed64 temp;
3028   unsigned32 sum;
3029   int c, v;
3030
3031   PC = cia;
3032   srcreg1 = translate_rreg (SD_, RM2);
3033   srcreg2 = translate_rreg (SD_, RN0);
3034   dstreg1 = translate_rreg (SD_, RD0);
3035   dstreg2 = translate_rreg (SD_, RD2);
3036
3037   temp = ((unsigned64)State.regs[srcreg1]
3038           * (unsigned64)State.regs[srcreg2]);
3039
3040   sum = State.regs[dstreg2] + (temp & 0xffffffff);
3041   c = (sum < State.regs[dstreg2]) || (sum < (temp & 0xffffffff));
3042   State.regs[dstreg2] = sum;
3043   temp >>= 32;
3044   temp &= 0xffffffff;
3045   sum = State.regs[dstreg1] + temp + c;
3046   v = ((State.regs[dstreg1] & 0x80000000) == (temp & 0x80000000)
3047         && (temp & 0x80000000) != (sum & 0x80000000));
3048   State.regs[dstreg1] = sum;
3049   if (v)
3050     {
3051       State.regs[REG_MCVF] = 1;
3052       PSW &= ~(PSW_V);
3053       PSW |= (( v ? PSW_V : 0));
3054     }
3055 }
3056
3057 // 1111 1011 0010 1111 Rm Rn Rd1; macb Rm,Rn,Rd1
3058 8.0xfb+8.0x2f+4.RM2,4.RN0+4.RD0,4.0x0:D2c:::macb
3059 "macb"
3060 *am33
3061 *am33_2
3062 {
3063   int srcreg1, srcreg2, dstreg;
3064   signed32 temp, sum;
3065   int v;
3066
3067   PC = cia;
3068   srcreg1 = translate_rreg (SD_, RM2);
3069   srcreg2 = translate_rreg (SD_, RN0);
3070   dstreg = translate_rreg (SD_, RD0);
3071
3072   temp = ((signed32)(State.regs[srcreg2] & 0xff)
3073           * (signed32)(State.regs[srcreg1] & 0xff));
3074   sum = State.regs[dstreg] + temp;
3075   v = ((State.regs[dstreg] & 0x80000000) == (temp & 0x80000000)
3076         && (temp & 0x80000000) != (sum & 0x80000000));
3077   State.regs[dstreg] = sum;
3078   if (v)
3079     {
3080       State.regs[REG_MCVF] = 1;
3081       PSW &= ~(PSW_V);
3082       PSW |= ((v ? PSW_V : 0));
3083     }
3084 }
3085
3086 // 1111 1011 0011 1111 Rm Rn Rd1; macbu Rm,Rn,Rd1
3087 8.0xfb+8.0x3f+4.RM2,4.RN0+4.RD0,4.0x0:D2c:::macbu
3088 "macbu"
3089 *am33
3090 *am33_2
3091 {
3092   int srcreg1, srcreg2, dstreg;
3093   signed32 temp, sum;
3094   int v;
3095
3096   PC = cia;
3097   srcreg1 = translate_rreg (SD_, RM2);
3098   srcreg2 = translate_rreg (SD_, RN0);
3099   dstreg = translate_rreg (SD_, RD0);
3100
3101   temp = ((unsigned32)(State.regs[srcreg2] & 0xff)
3102           * (unsigned32)(State.regs[srcreg1] & 0xff));
3103   sum = State.regs[dstreg] + temp;
3104   v = ((State.regs[dstreg] & 0x80000000) == (temp & 0x80000000)
3105         && (temp & 0x80000000) != (sum & 0x80000000));
3106   State.regs[dstreg] = sum;
3107   if (v)
3108     {
3109       State.regs[REG_MCVF] = 1;
3110       PSW &= ~(PSW_V);
3111       PSW |= ((v ? PSW_V : 0));
3112     }
3113 }
3114
3115 // 1111 1011 0100 1111 Rm Rn Rd1; mach Rm,Rn,Rd1,Rd2
3116 8.0xfb+8.0x4f+4.RM2,4.RN0+4.RD0,4.RD2!RD0:D2c:::mach
3117 "mach"
3118 *am33
3119 *am33_2
3120 {
3121   int srcreg1, srcreg2, dstreg1, dstreg2;
3122   signed64 temp, sum;
3123   int v;
3124
3125   PC = cia;
3126   srcreg1 = translate_rreg (SD_, RM2);
3127   srcreg2 = translate_rreg (SD_, RN0);
3128   dstreg1 = translate_rreg (SD_, RD0);
3129   dstreg2 = translate_rreg (SD_, RD0);
3130
3131   temp = ((signed32)(State.regs[srcreg2] & 0xffff)
3132           * (signed32)(State.regs[srcreg1] & 0xffff));
3133   State.regs[dstreg2] += (temp & 0xffffffff);
3134   sum = State.regs[dstreg1] + ((temp >> 32) & 0xffffffff);
3135   v = ((State.regs[dstreg1] & 0x80000000) == (temp & 0x80000000)
3136         && (temp & 0x80000000) != (sum & 0x80000000));
3137   State.regs[dstreg1] = sum;
3138   if (v)
3139     {
3140       State.regs[REG_MCVF] = 1;
3141       PSW &= ~(PSW_V);
3142       PSW |= ((v ? PSW_V : 0));
3143     }
3144 }
3145
3146 // 1111 1011 0101 1111 Rm Rn Rd1; machu Rm,Rn,Rd1,Rd2
3147 8.0xfb+8.0x5f+4.RM2,4.RN0+4.RD0,4.RD2!RD0:D2c:::machu
3148 "machu"
3149 *am33
3150 *am33_2
3151 {
3152   int srcreg1, srcreg2, dstreg1, dstreg2;
3153   signed64 temp, sum;
3154   int v;
3155
3156   PC = cia;
3157   srcreg1 = translate_rreg (SD_, RM2);
3158   srcreg2 = translate_rreg (SD_, RN0);
3159   dstreg1 = translate_rreg (SD_, RD0);
3160   dstreg2 = translate_rreg (SD_, RD0);
3161
3162   temp = ((unsigned32)(State.regs[srcreg2] & 0xffff)
3163           * (unsigned32)(State.regs[srcreg1] & 0xffff));
3164   State.regs[dstreg2] += (temp & 0xffffffff);
3165   sum = State.regs[dstreg1] + ((temp >> 32) & 0xffffffff);
3166   v = ((State.regs[dstreg1] & 0x80000000) == (temp & 0x80000000)
3167         && (temp & 0x80000000) != (sum & 0x80000000));
3168   State.regs[dstreg1] = sum;
3169   if (v)
3170     {
3171       State.regs[REG_MCVF] = 1;
3172       PSW &= ~(PSW_V);
3173       PSW |= ((v ? PSW_V : 0));
3174     }
3175 }
3176
3177 // 1111 1011 0110 1111 Rm Rn Rd1; dmach Rm,Rn,Rd1
3178 8.0xfb+8.0x6f+4.RM2,4.RN0+4.RD0,4.0x0:D2c:::dmach
3179 "dmach"
3180 *am33
3181 *am33_2
3182 {
3183   int srcreg1, srcreg2, dstreg;
3184   signed32 temp, temp2, sum;
3185   int v;
3186
3187   PC = cia;
3188   srcreg1 = translate_rreg (SD_, RM2);
3189   srcreg2 = translate_rreg (SD_, RN0);
3190   dstreg = translate_rreg (SD_, RD0);
3191
3192   temp = ((signed32)(State.regs[srcreg2] & 0xffff)
3193           * (signed32)(State.regs[srcreg1] & 0xffff));
3194   temp2 = ((signed32)((State.regs[srcreg1] >> 16) & 0xffff)
3195            * (signed32)((State.regs[srcreg2] >> 16) & 0xffff));
3196   sum = temp + temp2 + State.regs[dstreg];
3197   v = ((State.regs[dstreg] & 0x80000000) == (temp & 0x80000000)
3198         && (temp & 0x80000000) != (sum & 0x80000000));
3199   State.regs[dstreg] = sum;
3200   if (v)
3201     {
3202       State.regs[REG_MCVF] = 1;
3203       PSW &= ~(PSW_V);
3204       PSW |= ((v ? PSW_V : 0));
3205     }
3206 }
3207
3208 // 1111 1011 0111 1111 Rm Rn Rd1; dmachu Rm,Rn,Rd1
3209 8.0xfb+8.0x7f+4.RM2,4.RN0+4.RD0,4.0x0:D2c:::dmachu
3210 "dmachu"
3211 *am33
3212 *am33_2
3213 {
3214   int srcreg1, srcreg2, dstreg;
3215   signed32 temp, temp2, sum;
3216   int v;
3217
3218   PC = cia;
3219   srcreg1 = translate_rreg (SD_, RM2);
3220   srcreg2 = translate_rreg (SD_, RN0);
3221   dstreg = translate_rreg (SD_, RD0);
3222
3223   temp = ((unsigned32)(State.regs[srcreg2] & 0xffff)
3224           * (unsigned32)(State.regs[srcreg1] & 0xffff));
3225   temp2 = ((unsigned32)((State.regs[srcreg1] >> 16) & 0xffff)
3226            * (unsigned32)((State.regs[srcreg2] >> 16) & 0xffff));
3227   sum = temp + temp2 + State.regs[dstreg];
3228   v = ((State.regs[dstreg] & 0x80000000) == (temp & 0x80000000)
3229         && (temp & 0x80000000) != (sum & 0x80000000));
3230   State.regs[dstreg] = sum;
3231   if (v)
3232     {
3233       State.regs[REG_MCVF] = 1;
3234       PSW &= ~(PSW_V);
3235       PSW |= ((v ? PSW_V : 0));
3236     }
3237 }
3238
3239 // 1111 1011 1000 1111 Rm Rn Rd1 Rd2; dmulh Rm,Rn,Rd1,Rd2
3240 8.0xfb+8.0x8f+4.RM2,4.RN0+4.RD0,4.RD2!RD0:D2c:::dmulh
3241 "dmulh"
3242 *am33
3243 *am33_2
3244 {
3245   int srcreg1, srcreg2, dstreg1, dstreg2;
3246   signed64 temp;
3247
3248   PC = cia;
3249   srcreg1 = translate_rreg (SD_, RM2);
3250   srcreg2 = translate_rreg (SD_, RN0);
3251   dstreg1 = translate_rreg (SD_, RD0);
3252   dstreg2 = translate_rreg (SD_, RD2);
3253
3254   temp = ((signed32)(State.regs[srcreg1] & 0xffff)
3255           * (signed32)(State.regs[srcreg1] & 0xffff));
3256   State.regs[dstreg2] = temp;
3257   temp = ((signed32)((State.regs[srcreg1] >> 16) & 0xffff)
3258           * (signed32)((State.regs[srcreg1] >>16) & 0xffff));
3259   State.regs[dstreg1] = temp;
3260 }
3261
3262 // 1111 1011 1001 1111 Rm Rn Rd1 Rd2; dmulhu Rm,Rn,Rd1,Rd2
3263 8.0xfb+8.0x9f+4.RM2,4.RN0+4.RD0,4.RD2!RD0:D2c:::dmulhu
3264 "dmulhu"
3265 *am33
3266 *am33_2
3267 {
3268   int srcreg1, srcreg2, dstreg1, dstreg2;
3269   signed64 temp;
3270
3271   PC = cia;
3272   srcreg1 = translate_rreg (SD_, RM2);
3273   srcreg2 = translate_rreg (SD_, RN0);
3274   dstreg1 = translate_rreg (SD_, RD0);
3275   dstreg2 = translate_rreg (SD_, RD2);
3276
3277   temp = ((unsigned32)(State.regs[srcreg1] & 0xffff)
3278           * (unsigned32)(State.regs[srcreg1] & 0xffff));
3279   State.regs[dstreg2] = temp;
3280   temp = ((unsigned32)((State.regs[srcreg1] >> 16) & 0xffff)
3281           * (unsigned32)((State.regs[srcreg1] >>16) & 0xffff));
3282   State.regs[dstreg1] = temp;
3283 }
3284
3285 // 1111 1011 1010 1111 Rm Rn; sat24 Rm,Rn
3286 8.0xfb+8.0xaf+4.RM2,4.RN0+8.0x0:D2:::sat24
3287 "sat24"
3288 *am33
3289 *am33_2
3290 {
3291   int srcreg, dstreg;
3292   int value, n, z;
3293
3294   PC = cia;
3295   srcreg = translate_rreg (SD_, RM2);
3296   dstreg = translate_rreg (SD_, RN0);
3297
3298   value = State.regs[srcreg];
3299
3300   if (value >= 0x7fffff)
3301     State.regs[dstreg] = 0x7fffff;
3302   else if (value <= 0xff800000)
3303     State.regs[dstreg] = 0xff800000;
3304   else
3305     State.regs[dstreg] = value;
3306
3307   n = (State.regs[dstreg] & 0x800000) != 0;
3308   z = (State.regs[dstreg] == 0);
3309   PSW &= ~(PSW_Z | PSW_N);
3310   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
3311 }
3312
3313 // 1111 1011 1111 1111 Rm Rn Rd1; bsch Rm,Rn,Rd1
3314 8.0xfb+8.0xff+4.RM2,4.RN0+4.RD0,4.0x0:D2c:::bsch
3315 "bsch"
3316 *am33
3317 *am33_2
3318 {
3319   int temp, c, i;
3320   int srcreg1, srcreg2, dstreg;
3321   int start;
3322
3323   PC = cia;
3324   srcreg1 = translate_rreg (SD_, RM2);
3325   srcreg2 = translate_rreg (SD_, RN0);
3326   dstreg = translate_rreg (SD_, RD0);
3327
3328   temp = State.regs[srcreg1];
3329   start = (State.regs[srcreg2] & 0x1f) - 1;
3330   if (start == -1)
3331     start = 31;
3332
3333   c = 0;    
3334   for (i = start; i >= 0; i--)
3335     {
3336       if (temp & (1 << i))
3337         {
3338           c = 1;
3339           State.regs[dstreg] = i;
3340           break;
3341         }
3342     }
3343
3344   if (i < 0)
3345     {
3346       c = 0;
3347       State.regs[dstreg] = 0;
3348     }
3349   PSW &= ~(PSW_C);
3350   PSW |= (c ? PSW_C : 0);
3351 }
3352
3353 // 1111 1101 0000 1000 Rn Rn IMM32; mov imm24,Rn
3354 8.0xfd+8.0x08+4.RM2,4.RN0=RM2+8.IMM24A+8.IMM24B+8.IMM24C:D4t:::mov
3355 "mov"
3356 *am33
3357 *am33_2
3358 {
3359   int dstreg;
3360
3361   PC = cia;
3362   dstreg = translate_rreg (SD_, RN0);
3363   State.regs[dstreg] = EXTEND24 (FETCH24 (IMM24A, IMM24B, IMM24C));
3364 }
3365
3366 // 1111 1101 0001 1000 Rn Rn IMM32; movu imm24,Rn
3367 8.0xfd+8.0x18+4.RM2,4.RN0=RM2+8.IMM24A+8.IMM24B+8.IMM24C:D4k:::movu
3368 "movu"
3369 *am33
3370 *am33_2
3371 {
3372   int dstreg;
3373
3374   PC = cia;
3375   dstreg = translate_rreg (SD_, RN0);
3376   State.regs[dstreg] = FETCH24 (IMM24A, IMM24B, IMM24C) & 0xffffff;
3377 }
3378
3379 // 1111 1101 0111 1000 Rn Rn IMM32; add imm24,Rn
3380 8.0xfd+8.0x78+4.RM2,4.RN0=RM2+8.IMM24A+8.IMM24B+8.IMM24C:D4c:::add
3381 "add"
3382 *am33
3383 *am33_2
3384 {
3385   int dstreg;
3386
3387   PC = cia;
3388   dstreg = translate_rreg (SD_, RN0);
3389   genericAdd (EXTEND24 (FETCH24 (IMM24A, IMM24B, IMM24C)), dstreg);
3390 }
3391
3392 // 1111 1101 1000 1000 Rn Rn IMM32; addc imm24,Rn
3393 8.0xfd+8.0x88+4.RM2,4.RN0=RM2+8.IMM24A+8.IMM24B+8.IMM24C:D4b:::addc
3394 "addc"
3395 *am33
3396 *am33_2
3397 {
3398   int dstreg, z, n, c, v;
3399   unsigned32 sum, imm, reg2;
3400
3401   PC = cia;
3402   dstreg = translate_rreg (SD_, RN0);
3403
3404   imm = EXTEND24 (FETCH24 (IMM24A, IMM24B, IMM24C));
3405   reg2 = State.regs[dstreg];
3406   sum = imm + reg2 + ((PSW & PSW_C) != 0);
3407   State.regs[dstreg] = sum;
3408
3409   z = ((PSW & PSW_Z) != 0) && (sum == 0);
3410   n = (sum & 0x80000000);
3411   c = (sum < imm) || (sum < reg2);
3412   v = ((reg2 & 0x80000000) == (imm & 0x80000000)
3413        && (reg2 & 0x80000000) != (sum & 0x80000000));
3414
3415   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
3416   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0)
3417           | (c ? PSW_C : 0) | (v ? PSW_V : 0));
3418 }
3419
3420 // 1111 1101 1001 1000 Rn Rn IMM32; sub imm24,Rn
3421 8.0xfd+8.0x98+4.RM2,4.RN0=RM2+8.IMM24A+8.IMM24B+8.IMM24C:D4b:::sub
3422 "sub"
3423 *am33
3424 *am33_2
3425 {
3426   int dstreg;
3427
3428   PC = cia;
3429   dstreg = translate_rreg (SD_, RN0);
3430   genericSub (EXTEND24 (FETCH24 (IMM24A, IMM24B, IMM24C)), dstreg);
3431 }
3432
3433 // 1111 1101 1010 1000 Rn Rn IMM32; subc imm24,Rn
3434 8.0xfd+8.0xa8+4.RM2,4.RN0=RM2+8.IMM24A+8.IMM24B+8.IMM24C:D4b:::subc
3435 "subc"
3436 *am33
3437 *am33_2
3438 {
3439   int dstreg, z, n, c, v;
3440   unsigned32 difference, imm, reg2;
3441
3442   PC = cia;
3443   dstreg = translate_rreg (SD_, RN0);
3444
3445   imm = EXTEND24 (FETCH24 (IMM24A, IMM24B, IMM24C));
3446   reg2 = State.regs[dstreg];
3447   difference = reg2 - imm - ((PSW & PSW_C) != 0);
3448   State.regs[dstreg] = difference;
3449
3450   z = ((PSW & PSW_Z) != 0) && (difference == 0);
3451   n = (difference & 0x80000000);
3452   c = (imm > reg2);
3453   v = ((reg2 & 0x80000000) == (imm & 0x80000000)
3454        && (reg2 & 0x80000000) != (difference & 0x80000000));
3455
3456   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
3457   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0)
3458           | (c ? PSW_C : 0) | (v ? PSW_V : 0));
3459 }
3460
3461 // 1111 1101 1101 1000 Rn Rn IMM32; cmp imm24,Rn
3462 8.0xfd+8.0xd8+4.RM2,4.RN0=RM2+8.IMM24A+8.IMM24B+8.IMM24C:D4b:::cmp
3463 "cmp"
3464 *am33
3465 *am33_2
3466 {
3467   int srcreg;
3468
3469   PC = cia;
3470   srcreg = translate_rreg (SD_, RN0);
3471   genericCmp (EXTEND24 (FETCH24 (IMM24A, IMM24B, IMM24C)), State.regs[srcreg]);
3472 }
3473
3474 // 1111 1101 1111 1000 XRn XRn IMM32; mov imm24,XRn
3475 8.0xfd+8.0xf8+4.XRM2,4.XRN0=XRM2+8.IMM24A+8.IMM24B+8.IMM24C:D4o:::mov
3476 "mov"
3477 *am33
3478 *am33_2
3479 {
3480   int dstreg;
3481
3482   PC = cia;
3483   dstreg = translate_xreg (SD_, XRN0);
3484
3485   State.regs[dstreg] = FETCH24 (IMM24A, IMM24B, IMM24C) & 0xffffff;
3486 }
3487
3488 // 1111 1101 0000 1001 Rn Rn IMM24; and imm24,Rn
3489 8.0xfd+8.0x09+4.RM2,4.RN0=RM2+8.IMM24A+8.IMM24B+8.IMM24C:D4b:::and
3490 "and"
3491 *am33
3492 *am33_2
3493 {
3494   int dstreg;
3495   int z,n;
3496
3497   PC = cia;
3498   dstreg = translate_rreg (SD_, RN0);
3499
3500   State.regs[dstreg] &= (FETCH24 (IMM24A, IMM24B, IMM24C) & 0xffffff);
3501   z = (State.regs[dstreg] == 0);
3502   n = (State.regs[dstreg] & 0x80000000) != 0;
3503   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
3504   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
3505 }
3506
3507 // 1111 1101 0001 1001 Rn Rn IMM24; or imm24,Rn
3508 8.0xfd+8.0x19+4.RM2,4.RN0=RM2+8.IMM24A+8.IMM24B+8.IMM24C:D4b:::or
3509 "or"
3510 *am33
3511 *am33_2
3512 {
3513   int dstreg;
3514   int z,n;
3515
3516   PC = cia;
3517   dstreg = translate_rreg (SD_, RN0);
3518
3519   State.regs[dstreg] |= (FETCH24 (IMM24A, IMM24B, IMM24C) & 0xffffff);
3520   z = (State.regs[dstreg] == 0);
3521   n = (State.regs[dstreg] & 0x80000000) != 0;
3522   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
3523   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
3524 }
3525
3526 // 1111 1101 0010 1001 Rn Rn IMM24; xor imm24,Rn
3527 8.0xfd+8.0x29+4.RM2,4.RN0=RM2+8.IMM24A+8.IMM24B+8.IMM24C:D4b:::xor
3528 "xor"
3529 *am33
3530 *am33_2
3531 {
3532   int dstreg;
3533   int z,n;
3534
3535   PC = cia;
3536   dstreg = translate_rreg (SD_, RN0);
3537
3538   State.regs[dstreg] ^= (FETCH24 (IMM24A, IMM24B, IMM24C) & 0xffffff);
3539   z = (State.regs[dstreg] == 0);
3540   n = (State.regs[dstreg] & 0x80000000) != 0;
3541   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
3542   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
3543 }
3544
3545 // 1111 1101 0100 1001 Rn Rn IMM24; asr imm24,Rn
3546 8.0xfd+8.0x49+4.RM2,4.RN0=RM2+8.IMM24A+8.IMM24B+8.IMM24C:D4b:::asr
3547 "asr"
3548 *am33
3549 *am33_2
3550 {
3551   int dstreg;
3552   signed32 temp;
3553   int c, z, n;
3554
3555   PC = cia;
3556   dstreg = translate_rreg (SD_, RN0);
3557
3558   temp = State.regs[dstreg];
3559   c = temp & 1;
3560   temp >>= (FETCH24 (IMM24A, IMM24B, IMM24C));
3561   State.regs[dstreg] = temp;
3562   z = (State.regs[dstreg] == 0);
3563   n = (State.regs[dstreg] & 0x80000000) != 0;
3564   PSW &= ~(PSW_Z | PSW_N | PSW_C);
3565   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0) | (c ? PSW_C : 0));
3566 }
3567
3568
3569 // 1111 1101 0101 1001 Rn Rn IMM24; lsr imm24,Rn
3570 8.0xfd+8.0x59+4.RM2,4.RN0=RM2+8.IMM24A+8.IMM24B+8.IMM24C:D4b:::lsr
3571 "lsr"
3572 *am33
3573 *am33_2
3574 {
3575   int dstreg;
3576   int z, n, c;
3577
3578   PC = cia;
3579   dstreg = translate_rreg (SD_, RN0);
3580
3581   c = State.regs[dstreg] & 1;
3582   State.regs[dstreg] >>= (FETCH24 (IMM24A, IMM24B, IMM24C));
3583   z = (State.regs[dstreg] == 0);
3584   n = (State.regs[dstreg] & 0x80000000) != 0;
3585   PSW &= ~(PSW_Z | PSW_N | PSW_C);
3586   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0) | (c ? PSW_C : 0));
3587 }
3588
3589 // 1111 1101 0110 1001 Rn Rn IMM24; asl imm24,Rn
3590 8.0xfd+8.0x69+4.RM2,4.RN0=RM2+8.IMM24A+8.IMM24B+8.IMM24C:D4b:::asl
3591 "asl"
3592 *am33
3593 *am33_2
3594 {
3595   int dstreg;
3596   int z, n;
3597
3598   PC = cia;
3599   dstreg = translate_rreg (SD_, RN0);
3600
3601   State.regs[dstreg] <<= (FETCH24 (IMM24A, IMM24B, IMM24C));
3602   z = (State.regs[dstreg] == 0);
3603   n = (State.regs[dstreg] & 0x80000000) != 0;
3604   PSW &= ~(PSW_Z | PSW_N);
3605   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
3606 }
3607
3608 // 1111 1101 1010 1001 Rn Rn IMM24; mul imm24,Rn
3609 8.0xfd+8.0xa9+4.RM2,4.RN0=RM2+8.IMM24A+8.IMM24B+8.IMM24C:D4b:::mul
3610 "mul"
3611 *am33
3612 *am33_2
3613 {
3614   int dstreg;
3615   unsigned64 temp;
3616   int z, n;
3617
3618   PC = cia;
3619   dstreg = translate_rreg (SD_, RN0);
3620
3621   temp = ((signed64)(signed32)State.regs[dstreg]
3622           *  (signed64)(signed32)EXTEND24 (FETCH24 (IMM24A, IMM24B, IMM24C)));
3623   State.regs[dstreg] = temp & 0xffffffff;
3624   State.regs[REG_MDR] = (temp & 0xffffffff00000000LL) >> 32;
3625   z = (State.regs[dstreg] == 0);
3626   n = (State.regs[dstreg] & 0x80000000) != 0;
3627   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
3628   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
3629 }
3630
3631 // 1111 1101 1011 1001 Rn Rn IMM24; mulu imm24,Rn
3632 8.0xfd+8.0xb9+4.RM2,4.RN0=RM2+8.IMM24A+8.IMM24B+8.IMM24C:D4b:::mulu
3633 "mulu"
3634 *am33
3635 *am33_2
3636 {
3637   int dstreg;
3638   unsigned64 temp;
3639   int z, n;
3640
3641   PC = cia;
3642   dstreg = translate_rreg (SD_, RN0);
3643
3644   temp = ((unsigned64)State.regs[dstreg]
3645           *  (unsigned64)EXTEND24 (FETCH24 (IMM24A, IMM24B, IMM24C)));
3646   State.regs[dstreg] = temp & 0xffffffff;
3647   State.regs[REG_MDR] = (temp & 0xffffffff00000000LL) >> 32;
3648   z = (State.regs[dstreg] == 0);
3649   n = (State.regs[dstreg] & 0x80000000) != 0;
3650   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
3651   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
3652 }
3653
3654 // 1111 1101 1110 1001 Rn Rn IMM24; btst imm24,,Rn
3655 8.0xfd+8.0xe9+4.RN2,4.RN0=RN2+8.IMM24A+8.IMM24B+8.IMM24C:D4p:::btst
3656 "btst"
3657 *am33
3658 *am33_2
3659 {
3660   int srcreg;
3661
3662   PC = cia;
3663   srcreg = translate_rreg (SD_, RN0);
3664   genericBtst (FETCH24 (IMM24A, IMM24B, IMM24C), State.regs[srcreg]);
3665 }
3666
3667 // 1111 1101 0000 1010 Rn Rm IMM24; mov (d24,Rm),Rn
3668 8.0xfd+8.0x0a+4.RN2,4.RM0+8.IMM24A+8.IMM24B+8.IMM24C:D4p:::mov
3669 "mov"
3670 *am33
3671 *am33_2
3672 {
3673   int srcreg, dstreg;
3674
3675   PC = cia;
3676   srcreg = translate_rreg (SD_, RM0);
3677   dstreg = translate_rreg (SD_, RN2);
3678   State.regs[dstreg] = load_word (State.regs[srcreg]
3679                                   + EXTEND24 (FETCH24 (IMM24A,
3680                                                        IMM24B, IMM24C)));
3681 }
3682
3683 // 1111 1101 0001 1010 Rm Rn IMM24; mov Rm,(d24,Rn)
3684 8.0xfd+8.0x1a+4.RM2,4.RN0+8.IMM24A+8.IMM24B+8.IMM24C:D4q:::mov
3685 "mov"
3686 *am33
3687 *am33_2
3688 {
3689   int srcreg, dstreg;
3690
3691   PC = cia;
3692   srcreg = translate_rreg (SD_, RM2);
3693   dstreg = translate_rreg (SD_, RN0);
3694   store_word (State.regs[dstreg] + EXTEND24 (FETCH24 (IMM24A, IMM24B, IMM24C)),
3695               State.regs[srcreg]);
3696 }
3697
3698 // 1111 1101 0010 1010 Rn Rm IMM24; movbu (d24,Rm),Rn
3699 8.0xfd+8.0x2a+4.RN2,4.RM0+8.IMM24A+8.IMM24B+8.IMM24C:D4p:::movbu
3700 "movbu"
3701 *am33
3702 *am33_2
3703 {
3704   int srcreg, dstreg;
3705
3706   PC = cia;
3707   srcreg = translate_rreg (SD_, RM0);
3708   dstreg = translate_rreg (SD_, RN2);
3709   State.regs[dstreg] = load_byte (State.regs[srcreg]
3710                                   + EXTEND24 (FETCH24 (IMM24A,
3711                                                        IMM24B, IMM24C)));
3712 }
3713
3714 // 1111 1101 0011 1010 Rm Rn IMM24; movbu Rm,(d24,Rn)
3715 8.0xfd+8.0x3a+4.RM2,4.RN0+8.IMM24A+8.IMM24B+8.IMM24C:D4q:::movbu
3716 "movbu"
3717 *am33
3718 *am33_2
3719 {
3720   int srcreg, dstreg;
3721
3722   PC = cia;
3723   srcreg = translate_rreg (SD_, RM2);
3724   dstreg = translate_rreg (SD_, RN0);
3725   store_byte (State.regs[dstreg] + EXTEND24 (FETCH24 (IMM24A, IMM24B, IMM24C)),
3726               State.regs[srcreg]);
3727 }
3728
3729 // 1111 1101 0100 1010 Rn Rm IMM24; movhu (d24,Rm),Rn
3730 8.0xfd+8.0x4a+4.RN2,4.RM0+8.IMM24A+8.IMM24B+8.IMM24C:D4p:::movhu
3731 "movhu"
3732 *am33
3733 *am33_2
3734 {
3735   int srcreg, dstreg;
3736
3737   PC = cia;
3738   srcreg = translate_rreg (SD_, RM0);
3739   dstreg = translate_rreg (SD_, RN2);
3740   State.regs[dstreg] = load_half (State.regs[srcreg]
3741                                   + EXTEND24 (FETCH24 (IMM24A,
3742                                               IMM24B, IMM24C)));
3743 }
3744
3745 // 1111 1101 0101 1010 Rm Rn IMM24; movhu Rm,(d24,Rn)
3746 8.0xfd+8.0x5a+4.RM2,4.RN0+8.IMM24A+8.IMM24B+8.IMM24C:D4q:::movhu
3747 "movhu"
3748 *am33
3749 *am33_2
3750 {
3751   int srcreg, dstreg;
3752
3753   PC = cia;
3754   srcreg = translate_rreg (SD_, RM2);
3755   dstreg = translate_rreg (SD_, RN0);
3756   store_half (State.regs[dstreg] + EXTEND24 (FETCH24 (IMM24A, IMM24B, IMM24C)),
3757               State.regs[srcreg]);
3758 }
3759
3760 // 1111 1101 0110 1010 Rn Rm IMM24; mov (d24,Rm+),Rn
3761 8.0xfd+8.0x6a+4.RN2,4.RM0!RN2+8.IMM24A+8.IMM24B+8.IMM24C:D4y:::mov
3762 "mov"
3763 *am33
3764 *am33_2
3765 {
3766   int srcreg, dstreg;
3767
3768   PC = cia;
3769   srcreg = translate_rreg (SD_, RM0);
3770   dstreg = translate_rreg (SD_, RN2);
3771   State.regs[dstreg] = load_word (State.regs[srcreg]);
3772   State.regs[srcreg] += EXTEND24 (FETCH24 (IMM24A, IMM24B, IMM24C));
3773 }
3774
3775 // 1111 1101 0111 1010 Rm Rn IMM24; mov Rm,(d24,Rn+)
3776 8.0xfd+8.0x7a+4.RM2,4.RN0+8.IMM24A+8.IMM24B+8.IMM24C:D4z:::mov
3777 "mov"
3778 *am33
3779 *am33_2
3780 {
3781   int srcreg, dstreg;
3782
3783   PC = cia;
3784   srcreg = translate_rreg (SD_, RM2);
3785   dstreg = translate_rreg (SD_, RN0);
3786   store_word (State.regs[dstreg], State.regs[srcreg]);
3787   State.regs[dstreg] += EXTEND24 (FETCH24 (IMM24A, IMM24B, IMM24C));
3788 }
3789
3790
3791 // 1111 1101 1000 1010 Rn 0000 IMM24; mov (d24,sp),Rn
3792 8.0xfd+8.0x8a+4.RN2,4.0x0+IMM24A+8.IMM24B+8.IMM24C:D4r:::mov
3793 "mov"
3794 *am33
3795 *am33_2
3796 {
3797   int dstreg;
3798
3799   PC = cia;
3800   dstreg = translate_rreg (SD_, RN2);
3801   State.regs[dstreg] = load_word (State.regs[REG_SP]
3802                                   + FETCH24 (IMM24A, IMM24B, IMM24C));
3803 }
3804
3805 // 1111 1101 1001 1010 Rm 0000 IMM24; mov Rm,(d24,sp)
3806 8.0xfd+8.0x9a+4.RM2,4.0x0+8.IMM24A+8.IMM24B+8.IMM24C:D4s:::mov
3807 "mov"
3808 *am33
3809 *am33_2
3810 {
3811   int srcreg;
3812
3813   PC = cia;
3814   srcreg = translate_rreg (SD_, RM2);
3815   store_word (State.regs[REG_SP] + FETCH24 (IMM24A, IMM24B, IMM24C),
3816               State.regs[srcreg]);
3817 }
3818
3819 // 1111 1101 1010 1010 Rn 0000 IMM24; movbu (d24,sp),Rn
3820 8.0xfd+8.0xaa+4.RN2,4.0x0+8.IMM24A+8.IMM24B+8.IMM24C:D4r:::movbu
3821 "movbu"
3822 *am33
3823 *am33_2
3824 {
3825   int dstreg;
3826
3827   PC = cia;
3828   dstreg = translate_rreg (SD_, RN2);
3829   State.regs[dstreg] = load_byte (State.regs[REG_SP]
3830                                   + FETCH24 (IMM24A, IMM24B, IMM24C));
3831 }
3832
3833 // 1111 1101 1011 1010 Rm 0000 IMM24; movbu Rm,(d24,sp)
3834 8.0xfd+8.0xba+4.RM2,4.0x0+8.IMM24A+8.IMM24B+8.IMM24C:D4s:::movbu
3835 "movbu"
3836 *am33
3837 *am33_2
3838 {
3839   int srcreg;
3840
3841   PC = cia;
3842   srcreg = translate_rreg (SD_, RM2);
3843   store_byte (State.regs[REG_SP] + FETCH24 (IMM24A, IMM24B, IMM24C),
3844               State.regs[srcreg]);
3845 }
3846
3847 // 1111 1101 1100 1010 Rn 0000 IMM24; movhu (d24,sp),Rn
3848 8.0xfd+8.0xca+4.RN2,4.0x0+8.IMM24A+8.IMM24B+8.IMM24C:D4r:::movhu
3849 "movhu"
3850 *am33
3851 *am33_2
3852 {
3853   int dstreg;
3854
3855   PC = cia;
3856   dstreg = translate_rreg (SD_, RN2);
3857   State.regs[dstreg] = load_half (State.regs[REG_SP]
3858                                   + FETCH24 (IMM24A, IMM24B, IMM24C));
3859 }
3860
3861 // 1111 1101 1101 1010 Rm Rn IMM24; movhu Rm,(d24,sp)
3862 8.0xfd+8.0xda+4.RM2,4.RN0+8.IMM24A+8.IMM24B+8.IMM24C:D4s:::movhu
3863 "movhu"
3864 *am33
3865 *am33_2
3866 {
3867   int srcreg;
3868
3869   PC = cia;
3870   srcreg = translate_rreg (SD_, RM2);
3871   store_half (State.regs[REG_SP] + FETCH24 (IMM24A, IMM24B, IMM24C),
3872               State.regs[srcreg]);
3873 }
3874
3875 // 1111 1101 1110 1010 Rn Rm IMM24; movhu (d24,Rm+),Rn
3876 8.0xfd+8.0xea+4.RN2,4.RM0!RN2+8.IMM24A+8.IMM24B+8.IMM24C:D4y:::movhu
3877 "movhu"
3878 *am33
3879 *am33_2
3880 {
3881   int srcreg, dstreg;
3882
3883   PC = cia;
3884   srcreg = translate_rreg (SD_, RM0);
3885   dstreg = translate_rreg (SD_, RN2);
3886   State.regs[dstreg] = load_half (State.regs[srcreg]);
3887   State.regs[dstreg] += EXTEND24 (FETCH24 (IMM24A, IMM24B, IMM24C));
3888 }
3889
3890 // 1111 1101 1111 1010 Rm Rn IMM24; movhu Rm,(d24,Rn+)
3891 8.0xfd+8.0xfa+4.RM2,4.RN0+8.IMM24A+8.IMM24B+8.IMM24C:D4z:::movhu
3892 "movhu"
3893 *am33
3894 *am33_2
3895 {
3896   int srcreg, dstreg;
3897
3898   PC = cia;
3899   srcreg = translate_rreg (SD_, RM2);
3900   dstreg = translate_rreg (SD_, RN0);
3901   store_half (State.regs[dstreg], State.regs[srcreg]);
3902   State.regs[srcreg] += EXTEND24 (FETCH24 (IMM24A, IMM24B, IMM24C));
3903 }
3904
3905 // 1111 1101 0000 1011 Rn IMM24; mac imm24,Rn
3906 8.0xfd+8.0x0b+4.RN2,4.RN0=RN2+8.IMM24A+8.IMM24B+8.IMM24C:D4z:::mac
3907 "mac"
3908 *am33
3909 *am33_2
3910 {
3911   int srcreg;
3912   signed64 temp, sum;
3913   int c, v;
3914
3915   PC = cia;
3916   srcreg = translate_rreg (SD_, RN2);
3917
3918   temp = ((signed64)EXTEND24 (FETCH24 (IMM24A, IMM24B, IMM24C))
3919           * (signed64)State.regs[srcreg]);
3920   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
3921   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
3922   State.regs[REG_MCRL] = sum;
3923   temp >>= 32;
3924   temp &= 0xffffffff;
3925   sum = State.regs[REG_MCRH] + temp + c;
3926   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
3927         && (temp & 0x80000000) != (sum & 0x80000000));
3928   State.regs[REG_MCRH] = sum;
3929   if (v)
3930     State.regs[REG_MCVF] = 1;
3931 }
3932
3933 // 1111 1101 0001 1011 Rn IMM24; macu imm24,Rn
3934 8.0xfd+8.0x1b+4.RN2,4.RN0=RN2+8.IMM24A+8.IMM24B+8.IMM24C:D4z:::macu
3935 "macu"
3936 *am33
3937 *am33_2
3938 {
3939   int srcreg;
3940   signed64 temp, sum;
3941   int c, v;
3942
3943   PC = cia;
3944   srcreg = translate_rreg (SD_, RN2);
3945
3946   temp = ((unsigned64) (FETCH24 (IMM24A, IMM24B, IMM24C))
3947           * (unsigned64)State.regs[srcreg]);
3948   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
3949   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
3950   State.regs[REG_MCRL] = sum;
3951   temp >>= 32;
3952   temp &= 0xffffffff;
3953   sum = State.regs[REG_MCRH] + temp + c;
3954   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
3955         && (temp & 0x80000000) != (sum & 0x80000000));
3956   State.regs[REG_MCRH] = sum;
3957   if (v)
3958     State.regs[REG_MCVF] = 1;
3959 }
3960
3961 // 1111 1101 0010 1011 Rn IMM24; macb imm24,Rn
3962 8.0xfd+8.0x2b+4.RN2,4.RN0=RN2+8.IMM24A+8.IMM24B+8.IMM24C:D4z:::macb
3963 "macb"
3964 *am33
3965 *am33_2
3966 {
3967   int srcreg;
3968   signed64 temp, sum;
3969   int c, v;
3970
3971   PC = cia;
3972   srcreg = translate_rreg (SD_, RN2);
3973
3974   temp = ((signed64)EXTEND8 (FETCH24 (IMM24A, IMM24B, IMM24C))
3975           * (signed64)State.regs[srcreg] & 0xff);
3976   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
3977   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
3978   State.regs[REG_MCRL] = sum;
3979   temp >>= 32;
3980   temp &= 0xffffffff;
3981   sum = State.regs[REG_MCRH] + temp + c;
3982   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
3983         && (temp & 0x80000000) != (sum & 0x80000000));
3984   State.regs[REG_MCRH] = sum;
3985   if (v)
3986     State.regs[REG_MCVF] = 1;
3987 }
3988
3989 // 1111 1101 0011 1011 Rn IMM24; macbu imm24,Rn
3990 8.0xfd+8.0x3b+4.RN2,4.RN0=RN2+8.IMM24A+8.IMM24B+8.IMM24C:D4z:::macbu
3991 "macbu"
3992 *am33
3993 *am33_2
3994 {
3995   int srcreg;
3996   signed64 temp, sum;
3997   int c, v;
3998
3999   PC = cia;
4000   srcreg = translate_rreg (SD_, RN2);
4001
4002   temp = ((unsigned64) (FETCH24 (IMM24A, IMM24B, IMM24C))
4003           * (unsigned64)State.regs[srcreg] & 0xff);
4004   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
4005   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
4006   State.regs[REG_MCRL] = sum;
4007   temp >>= 32;
4008   temp &= 0xffffffff;
4009   sum = State.regs[REG_MCRH] + temp + c;
4010   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
4011         && (temp & 0x80000000) != (sum & 0x80000000));
4012   State.regs[REG_MCRH] = sum;
4013   if (v)
4014     State.regs[REG_MCVF] = 1;
4015 }
4016
4017 // 1111 1101 0100 1011 Rn IMM24; mach imm24,Rn
4018 8.0xfd+8.0x4b+4.RN2,4.RN0=RN2+8.IMM24A+8.IMM24B+8.IMM24C:D4z:::mach
4019 "mach"
4020 *am33
4021 *am33_2
4022 {
4023   int srcreg;
4024   signed64 temp, sum;
4025   int c, v;
4026
4027   PC = cia;
4028   srcreg = translate_rreg (SD_, RN2);
4029
4030   temp = ((signed64)EXTEND16 (FETCH24 (IMM24A, IMM24B, IMM24C))
4031           * (signed64)State.regs[srcreg] & 0xffff);
4032   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
4033   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
4034   State.regs[REG_MCRL] = sum;
4035   temp >>= 32;
4036   temp &= 0xffffffff;
4037   sum = State.regs[REG_MCRH] + temp + c;
4038   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
4039         && (temp & 0x80000000) != (sum & 0x80000000));
4040   State.regs[REG_MCRH] = sum;
4041   if (v)
4042     State.regs[REG_MCVF] = 1;
4043 }
4044
4045 // 1111 1101 0101 1011 Rn IMM24; machu imm24,Rn
4046 8.0xfd+8.0x5b+4.RN2,4.RN0=RN2+8.IMM24A+8.IMM24B+8.IMM24C:D4z:::machu
4047 "machu"
4048 *am33
4049 *am33_2
4050 {
4051   int srcreg;
4052   signed64 temp, sum;
4053   int c, v;
4054
4055   PC = cia;
4056   srcreg = translate_rreg (SD_, RN2);
4057
4058   temp = ((unsigned64) (FETCH24 (IMM24A, IMM24B, IMM24C) & 0xffff)
4059           * (unsigned64)State.regs[srcreg] & 0xffff);
4060   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
4061   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
4062   State.regs[REG_MCRL] = sum;
4063   temp >>= 32;
4064   temp &= 0xffffffff;
4065   sum = State.regs[REG_MCRH] + temp + c;
4066   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
4067         && (temp & 0x80000000) != (sum & 0x80000000));
4068   State.regs[REG_MCRH] = sum;
4069   if (v)
4070     State.regs[REG_MCVF] = 1;
4071 }
4072
4073 // 1111 1101 0000 1110 Rn 0000 ABS24; mov (abs24),Rn
4074 8.0xfd+8.0x0e+4.RN2,4.0x0+8.IMM24A+8.IMM24B+8.IMM24C:D4u:::mov
4075 "mov"
4076 *am33
4077 *am33_2
4078 {
4079   int dstreg;
4080
4081   PC = cia;
4082   dstreg = translate_rreg (SD_, RN2);
4083   State.regs[dstreg] = load_word (FETCH24 (IMM24A, IMM24B, IMM24C));
4084 }
4085
4086 // 1111 1101 0001 1110 Rm 0000 ABS24; mov Rm,(abs24)
4087 8.0xfd+8.0x1e+4.RM2,4.0x0+8.IMM24A+8.IMM24B+8.IMM24C:D4v:::mov
4088 "mov"
4089 *am33
4090 *am33_2
4091 {
4092   int srcreg;
4093
4094   PC = cia;
4095   srcreg = translate_rreg (SD_, RM2);
4096   store_word (FETCH24 (IMM24A, IMM24B, IMM24C), State.regs[srcreg]);
4097 }
4098
4099
4100 // 1111 1101 0010 1110 Rn 0000 ABS24; movbu (abs24),Rn
4101 8.0xfd+8.0x2e+4.RN2,4.0x0+8.IMM24A+8.IMM24B+8.IMM24C:D4t:::movbu
4102 "movbu"
4103 *am33
4104 *am33_2
4105 {
4106   int dstreg;
4107
4108   PC = cia;
4109   dstreg = translate_rreg (SD_, RN2);
4110   State.regs[dstreg] = load_byte (FETCH24 (IMM24A, IMM24B, IMM24C));
4111 }
4112
4113 // 1111 1101 0011 1110 Rm 0000 ABS24; movbu Rm,(abs24)
4114 8.0xfd+8.0x3e+4.RM2,4.0x0+8.IMM24A+8.IMM24B+8.IMM24C:D4u:::movbu
4115 "movbu"
4116 *am33
4117 *am33_2
4118 {
4119   int srcreg;
4120
4121   PC = cia;
4122   srcreg = translate_rreg (SD_, RM2);
4123   store_byte (FETCH24 (IMM24A, IMM24B, IMM24C), State.regs[srcreg]);
4124 }
4125
4126
4127 // 1111 1101 0100 1110 Rn 0000 ABS24; movhu (abs24),Rn
4128 8.0xfd+8.0x4e+4.RN2,4.0x0+8.IMM24A+8.IMM24B+8.IMM24C:D4t:::movhu
4129 "movhu"
4130 *am33
4131 *am33_2
4132 {
4133   int dstreg;
4134
4135   PC = cia;
4136   dstreg = translate_rreg (SD_, RN2);
4137   State.regs[dstreg] = load_half (FETCH24 (IMM24A, IMM24B, IMM24C));
4138 }
4139
4140 // 1111 1101 0101 1110 Rm 0000 ABS24; movhu Rm,(abs24)
4141 8.0xfd+8.0x5e+4.RM2,4.0x0+8.IMM24A+8.IMM24B+8.IMM24C:D4u:::movhu
4142 "movhu"
4143 *am33
4144 *am33_2
4145 {
4146   int srcreg;
4147
4148   PC = cia;
4149   srcreg = translate_rreg (SD_, RM2);
4150   store_half (FETCH24 (IMM24A, IMM24B, IMM24C), State.regs[srcreg]);
4151 }
4152
4153
4154 // 1111 1110 0000 1000 Rn Rn IMM32; mov imm32,Rn
4155 8.0xfe+8.0x08+4.RM2,4.RN0=RM2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::mov
4156 "mov"
4157 *am33
4158 *am33_2
4159 {
4160   int dstreg;
4161
4162   PC = cia;
4163   dstreg = translate_rreg (SD_, RN0);
4164   State.regs[dstreg] = FETCH32(IMM32A, IMM32B, IMM32C, IMM32D);
4165 }
4166
4167 // 1111 1110 0001 1000 Rn Rn IMM32; movu imm32,Rn
4168 8.0xfe+8.0x18+4.RM2,4.RN0=RM2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::movu
4169 "movu"
4170 *am33
4171 *am33_2
4172 {
4173   int dstreg;
4174
4175   PC = cia;
4176   dstreg = translate_rreg (SD_, RN0);
4177   State.regs[dstreg] = FETCH32(IMM32A, IMM32B, IMM32C, IMM32D);
4178 }
4179
4180 // 1111 1110 0111 1000 Rn Rn IMM32; add imm32,Rn
4181 8.0xfe+8.0x78+4.RM2,4.RN0=RM2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::add
4182 "add"
4183 *am33
4184 *am33_2
4185 {
4186   int dstreg;
4187
4188   PC = cia;
4189   dstreg = translate_rreg (SD_, RN0);
4190   genericAdd (FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D), dstreg);
4191 }
4192
4193 // 1111 1110 1000 1000 Rn Rn IMM32; addc imm32,Rn
4194 8.0xfe+8.0x88+4.RM2,4.RN0=RM2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::addc
4195 "addc"
4196 *am33
4197 *am33_2
4198 {
4199   int dstreg;
4200   unsigned32 imm, reg2, sum;
4201   int z, n, c, v;
4202
4203   PC = cia;
4204   dstreg = translate_rreg (SD_, RN0);
4205
4206   imm = FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D);
4207   reg2 = State.regs[dstreg];
4208   sum = imm + reg2 + ((PSW & PSW_C) != 0);
4209   State.regs[dstreg] = sum;
4210
4211   z = ((PSW & PSW_Z) != 0) && (sum == 0);
4212   n = (sum & 0x80000000);
4213   c = (sum < imm) || (sum < reg2);
4214   v = ((reg2 & 0x80000000) == (imm & 0x80000000)
4215        && (reg2 & 0x80000000) != (sum & 0x80000000));
4216
4217   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
4218   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0)
4219           | (c ? PSW_C : 0) | (v ? PSW_V : 0));
4220 }
4221
4222 // 1111 1110 1001 1000 Rn Rn IMM32; sub imm32,Rn
4223 8.0xfe+8.0x98+4.RM2,4.RN0=RM2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::sub
4224 "sub"
4225 *am33
4226 *am33_2
4227 {
4228   int dstreg;
4229
4230   PC = cia;
4231   dstreg = translate_rreg (SD_, RN0);
4232   genericSub (FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D), dstreg);
4233 }
4234
4235 // 1111 1110 1010 1000 Rn Rn IMM32; subc imm32,Rn
4236 8.0xfe+8.0xa8+4.RM2,4.RN0=RM2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::subc
4237 "subc"
4238 *am33
4239 *am33_2
4240 {
4241   int dstreg;
4242   unsigned32 imm, reg2, difference;
4243   int z, n, c, v;
4244
4245   PC = cia;
4246   dstreg = translate_rreg (SD_, RN0);
4247
4248   imm = FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D);
4249   reg2 = State.regs[dstreg];
4250   difference = reg2 - imm - ((PSW & PSW_C) != 0);
4251   State.regs[dstreg] = difference;
4252
4253   z = ((PSW & PSW_Z) != 0) && (difference == 0);
4254   n = (difference & 0x80000000);
4255   c = (imm > reg2);
4256   v = ((reg2 & 0x80000000) == (imm & 0x80000000)
4257        && (reg2 & 0x80000000) != (difference & 0x80000000));
4258
4259   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
4260   PSW |= ((z ? PSW_Z : 0) | ( n ? PSW_N : 0)
4261           | (c ? PSW_C : 0) | (v ? PSW_V : 0));
4262 }
4263
4264 // 1111 1110 0111 1000 Rn Rn IMM32; cmp imm32,Rn
4265 8.0xfe+8.0xd8+4.RM2,4.RN0=RM2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::cmp
4266 "cmp"
4267 *am33
4268 *am33_2
4269 {
4270   int srcreg;
4271
4272   PC = cia;
4273   srcreg = translate_rreg (SD_, RN0);
4274   genericCmp (FETCH32(IMM32A, IMM32B, IMM32C, IMM32D), State.regs[srcreg]);
4275 }
4276
4277 // 1111 1110 1111 1000 XRn XRn IMM32; mov imm32,XRn
4278 8.0xfe+8.0xf8+4.XRM2,4.XRN0=XRM2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5b:::mov
4279 "mov"
4280 *am33
4281 *am33_2
4282 {
4283   int dstreg;
4284
4285   PC = cia;
4286   dstreg = translate_xreg (SD_, XRN0);
4287
4288   State.regs[dstreg] = FETCH32(IMM32A, IMM32B, IMM32C, IMM32D);
4289 }
4290
4291 // 1111 1110 0000 1001 Rn Rn IMM32; and imm32,Rn
4292 8.0xfe+8.0x09+4.RM2,4.RN0=RM2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::and
4293 "and"
4294 *am33
4295 *am33_2
4296 {
4297   int dstreg;
4298   int z,n;
4299
4300   PC = cia;
4301   dstreg = translate_rreg (SD_, RN0);
4302
4303   State.regs[dstreg] &= (FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D));
4304   z = (State.regs[dstreg] == 0);
4305   n = (State.regs[dstreg] & 0x80000000) != 0;
4306   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
4307   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
4308 }
4309
4310 // 1111 1110 0001 1001 Rn Rn IMM32; or imm32,Rn
4311 8.0xfe+8.0x19+4.RM2,4.RN0=RM2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::or
4312 "or"
4313 *am33
4314 *am33_2
4315 {
4316   int dstreg;
4317   int z,n;
4318
4319   PC = cia;
4320   dstreg = translate_rreg (SD_, RN0);
4321
4322   State.regs[dstreg] |= (FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D));
4323   z = (State.regs[dstreg] == 0);
4324   n = (State.regs[dstreg] & 0x80000000) != 0;
4325   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
4326   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
4327 }
4328
4329 // 1111 1110 0010 1001 Rn Rn IMM32; xor imm32,Rn
4330 8.0xfe+8.0x29+4.RM2,4.RN0=RM2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::xor
4331 "xor"
4332 *am33
4333 *am33_2
4334 {
4335   int dstreg;
4336   int z,n;
4337
4338   PC = cia;
4339   dstreg = translate_rreg (SD_, RN0);
4340
4341   State.regs[dstreg] ^= (FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D));
4342   z = (State.regs[dstreg] == 0);
4343   n = (State.regs[dstreg] & 0x80000000) != 0;
4344   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
4345   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
4346 }
4347
4348 // 1111 1110 0100 1001 Rn Rn IMM32; asr imm32,Rn
4349 8.0xfe+8.0x49+4.RM2,4.RN0=RM2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::asr
4350 "asr"
4351 *am33
4352 *am33_2
4353 {
4354   int dstreg;
4355   signed32 temp;
4356   int c, z, n;
4357
4358   PC = cia;
4359   dstreg = translate_rreg (SD_, RN0);
4360
4361   temp = State.regs[dstreg];
4362   c = temp & 1;
4363   temp >>= (FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D));
4364   State.regs[dstreg] = temp;
4365   z = (State.regs[dstreg] == 0);
4366   n = (State.regs[dstreg] & 0x80000000) != 0;
4367   PSW &= ~(PSW_Z | PSW_N | PSW_C);
4368   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0) | (c ? PSW_C : 0));
4369 }
4370
4371 // 1111 1110 0101 1001 Rn Rn IMM32; lsr imm32,Rn
4372 8.0xfe+8.0x59+4.RM2,4.RN0=RM2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::lsr
4373 "lsr"
4374 *am33
4375 *am33_2
4376 {
4377   int dstreg;
4378   int z, n, c;
4379
4380   PC = cia;
4381   dstreg = translate_rreg (SD_, RN0);
4382
4383   c = State.regs[dstreg] & 1;
4384   State.regs[dstreg] >>= (FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D));
4385   z = (State.regs[dstreg] == 0);
4386   n = (State.regs[dstreg] & 0x80000000) != 0;
4387   PSW &= ~(PSW_Z | PSW_N | PSW_C);
4388   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0) | (c ? PSW_C : 0));
4389 }
4390
4391 // 1111 1110 0110 1001 Rn Rn IMM32; asl imm32,Rn
4392 8.0xfe+8.0x69+4.RM2,4.RN0=RM2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::asl
4393 "asl"
4394 *am33
4395 *am33_2
4396 {
4397   int dstreg;
4398   int z, n;
4399
4400   PC = cia;
4401   dstreg = translate_rreg (SD_, RN0);
4402
4403   State.regs[dstreg] <<= (FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D));
4404   z = (State.regs[dstreg] == 0);
4405   n = (State.regs[dstreg] & 0x80000000) != 0;
4406   PSW &= ~(PSW_Z | PSW_N);
4407   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
4408 }
4409
4410 // 1111 1110 1010 1001 Rn Rn IMM32; mul imm32,Rn
4411 8.0xfe+8.0xa9+4.RM2,4.RN0=RM2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::mul
4412 "mul"
4413 *am33
4414 *am33_2
4415 {
4416   int dstreg;
4417   unsigned64 temp;
4418   int z, n;
4419
4420   PC = cia;
4421   dstreg = translate_rreg (SD_, RN0);
4422
4423   temp = ((signed64)(signed32)State.regs[dstreg]
4424           *  (signed64)(signed32)(FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D)));
4425   State.regs[dstreg] = temp & 0xffffffff;
4426   State.regs[REG_MDR] = (temp & 0xffffffff00000000LL) >> 32;
4427   z = (State.regs[dstreg] == 0);
4428   n = (State.regs[dstreg] & 0x80000000) != 0;
4429   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
4430   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
4431 }
4432
4433 // 1111 1110 1011 1001 Rn Rn IMM32; mulu imm32,Rn
4434 8.0xfe+8.0xb9+4.RM2,4.RN0=RM2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::mulu
4435 "mulu"
4436 *am33
4437 *am33_2
4438 {
4439   int dstreg;
4440   unsigned64 temp;
4441   int z, n;
4442
4443   PC = cia;
4444   dstreg = translate_rreg (SD_, RN0);
4445
4446   temp = ((unsigned64)State.regs[dstreg]
4447           *  (unsigned64) (FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D)));
4448   State.regs[dstreg] = temp & 0xffffffff;
4449   State.regs[REG_MDR] = (temp & 0xffffffff00000000LL) >> 32;
4450   z = (State.regs[dstreg] == 0);
4451   n = (State.regs[dstreg] & 0x80000000) != 0;
4452   PSW &= ~(PSW_Z | PSW_N | PSW_C | PSW_V);
4453   PSW |= ((z ? PSW_Z : 0) | (n ? PSW_N : 0));
4454 }
4455
4456 // 1111 1110 1110 1001 Rn Rn IMM32; btst imm32,Rn
4457 8.0xfe+8.0xe9+4.RM2,4.RN0=RM2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5a:::btst
4458 "btst"
4459 *am33
4460 *am33_2
4461 {
4462   int srcreg;
4463
4464   PC = cia;
4465   srcreg = translate_rreg (SD_, RN0);
4466   genericBtst (FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D), State.regs[srcreg]);
4467 }
4468
4469 // 1111 1110 0000 1010 Rn Rm IMM32; mov (d32,Rm),Rn
4470 8.0xfe+8.0x0a+4.RN2,4.RM0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5f:::mov
4471 "mov"
4472 *am33
4473 *am33_2
4474 {
4475   int srcreg, dstreg;
4476
4477   PC = cia;
4478   srcreg = translate_rreg (SD_, RM0);
4479   dstreg = translate_rreg (SD_, RN2);
4480   State.regs[dstreg] = load_word (State.regs[srcreg]
4481                                   + FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D));
4482 }
4483
4484 // 1111 1110 0001 1010 Rm Rn IMM32; mov Rm,(d32,Rn)
4485 8.0xfe+8.0x1a+4.RM2,4.RN0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5g:::mov
4486 "mov"
4487 *am33
4488 *am33_2
4489 {
4490   int srcreg, dstreg;
4491
4492   PC = cia;
4493   srcreg = translate_rreg (SD_, RM2);
4494   dstreg = translate_rreg (SD_, RN0);
4495   store_word (State.regs[dstreg] + FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D),
4496               State.regs[srcreg]);
4497 }
4498
4499 // 1111 1110 0010 1010 Rn Rm IMM32; movbu (d32,Rm),Rn
4500 8.0xfe+8.0x2a+4.RN2,4.RM0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::movbu
4501 "movbu"
4502 *am33
4503 *am33_2
4504 {
4505   int srcreg, dstreg;
4506
4507   PC = cia;
4508   srcreg = translate_rreg (SD_, RM0);
4509   dstreg = translate_rreg (SD_, RN2);
4510   State.regs[dstreg] = load_byte (State.regs[srcreg]
4511                                   + FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D));
4512 }
4513
4514 // 1111 1110 0011 1010 Rm Rn IMM32; movbu Rm,(d32,Rn)
4515 8.0xfe+8.0x3a+4.RM2,4.RN0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5b:::movbu
4516 "movbu"
4517 *am33
4518 *am33_2
4519 {
4520   int srcreg, dstreg;
4521
4522   PC = cia;
4523   srcreg = translate_rreg (SD_, RM2);
4524   dstreg = translate_rreg (SD_, RN0);
4525   store_byte (State.regs[dstreg] + FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D),
4526               State.regs[srcreg]);
4527 }
4528
4529 // 1111 1110 0100 1010 Rn Rm IMM32; movhu (d32,Rm),Rn
4530 8.0xfe+8.0x4a+4.RN2,4.RM0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::movhu
4531 "movhu"
4532 *am33
4533 *am33_2
4534 {
4535   int srcreg, dstreg;
4536
4537   PC = cia;
4538   srcreg = translate_rreg (SD_, RM0);
4539   dstreg = translate_rreg (SD_, RN2);
4540   State.regs[dstreg] = load_half (State.regs[srcreg]
4541                                   + FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D));
4542 }
4543
4544 // 1111 1110 0101 1010 Rm Rn IMM32; movhu Rm,(d32,Rn)
4545 8.0xfe+8.0x5a+4.RM2,4.RN0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5b:::movhu
4546 "movhu"
4547 *am33
4548 *am33_2
4549 {
4550   int srcreg, dstreg;
4551
4552   PC = cia;
4553   srcreg = translate_rreg (SD_, RM2);
4554   dstreg = translate_rreg (SD_, RN0);
4555   store_half (State.regs[dstreg] + FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D),
4556               State.regs[srcreg]);
4557 }
4558
4559 // 1111 1110 0110 1010 Rn Rm IMM32; mov (d32,Rm+),Rn
4560 8.0xfe+8.0x6a+4.RN2,4.RM0!RN2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5y:::mov
4561 "mov"
4562 *am33
4563 *am33_2
4564 {
4565   int srcreg, dstreg;
4566
4567   PC = cia;
4568   srcreg = translate_rreg (SD_, RM0);
4569   dstreg = translate_rreg (SD_, RN2);
4570   State.regs[dstreg] = load_word (State.regs[srcreg]);
4571   State.regs[srcreg] += FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D);
4572 }
4573
4574 // 1111 1110 0111 1010 Rm Rn IMM32; mov Rm,(d32,Rn+)
4575 8.0xfe+8.0x7a+4.RM2,4.RN0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5z:::mov
4576 "mov"
4577 *am33
4578 *am33_2
4579 {
4580   int srcreg, dstreg;
4581
4582   PC = cia;
4583   srcreg = translate_rreg (SD_, RM2);
4584   dstreg = translate_rreg (SD_, RN0);
4585   store_word (State.regs[dstreg], State.regs[srcreg]);
4586   State.regs[dstreg] += FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D);
4587 }
4588
4589
4590 // 1111 1110 1000 1010 Rn 0000 IMM32; mov (d32,sp),Rn
4591 8.0xfe+8.0x8a+4.RN2,4.0x0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5c:::mov
4592 "mov"
4593 *am33
4594 *am33_2
4595 {
4596   int dstreg;
4597
4598   PC = cia;
4599   dstreg = translate_rreg (SD_, RN2);
4600   State.regs[dstreg] = load_word (State.regs[REG_SP]
4601                                   + FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D));
4602 }
4603
4604 // 1111 1110 1001 1010 Rm 0000 IMM32; mov Rm,(d32,sp)
4605 8.0xfe+8.0x9a+4.RM2,4.0x0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5d:::mov
4606 "mov"
4607 *am33
4608 *am33_2
4609 {
4610   int srcreg;
4611
4612   PC = cia;
4613   srcreg = translate_rreg (SD_, RM2);
4614   store_word (State.regs[REG_SP] + FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D),
4615               State.regs[srcreg]);
4616 }
4617
4618 // 1111 1110 1010 1010 Rn 0000 IMM32; movbu (d32,sp),Rn
4619 8.0xfe+8.0xaa+4.RN2,4.0x0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5c:::movbu
4620 "movbu"
4621 *am33
4622 *am33_2
4623 {
4624   int dstreg;
4625
4626   PC = cia;
4627   dstreg = translate_rreg (SD_, RN2);
4628   State.regs[dstreg] = load_byte (State.regs[REG_SP]
4629                                   + FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D));
4630 }
4631
4632 // 1111 1110 1011 1010 Rm 0000 IMM32; movbu Rm,(d32,sp)
4633 8.0xfe+8.0xba+4.RM2,4.0x0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5d:::movbu
4634 "movbu"
4635 *am33
4636 *am33_2
4637 {
4638   int srcreg;
4639
4640   PC = cia;
4641   srcreg = translate_rreg (SD_, RM2);
4642   store_byte (State.regs[REG_SP] + FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D),
4643               State.regs[srcreg]);
4644 }
4645
4646 // 1111 1110 1100 1010 Rn 0000 IMM32; movhu (d32,sp),Rn
4647 8.0xfe+8.0xca+4.RN2,4.0x0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5c:::movhu
4648 "movhu"
4649 *am33
4650 *am33_2
4651 {
4652   int dstreg;
4653
4654   PC = cia;
4655   dstreg = translate_rreg (SD_, RN2);
4656   State.regs[dstreg] = load_half (State.regs[REG_SP]
4657                                   + FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D));
4658 }
4659
4660 // 1111 1110 1101 1010 Rm 0000 IMM32; movhu Rm,(d32,sp)
4661 8.0xfe+8.0xda+4.RM2,4.0x0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5d:::movhu
4662 "movhu"
4663 *am33
4664 *am33_2
4665 {
4666   int srcreg;
4667
4668   PC = cia;
4669   srcreg = translate_rreg (SD_, RM2);
4670   store_half (State.regs[REG_SP] + FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D),
4671               State.regs[srcreg]);
4672 }
4673
4674
4675 // 1111 1110 1110 1010 Rn Rm IMM32; movhu (d32,Rm+),Rn
4676 8.0xfe+8.0xea+4.RN2,4.RM0!RN2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5y:::movhu
4677 "movhu"
4678 *am33
4679 *am33_2
4680 {
4681   int srcreg, dstreg;
4682
4683   PC = cia;
4684   srcreg = translate_rreg (SD_, RM0);
4685   dstreg = translate_rreg (SD_, RN2);
4686   State.regs[dstreg] = load_half (State.regs[srcreg]);
4687   State.regs[srcreg] += FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D);
4688 }
4689
4690 // 1111 1110 1111 1010 Rm Rn IMM32; movhu Rm,(d32,Rn+)
4691 8.0xfe+8.0xfa+4.RM2,4.RN0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5f:::movhu
4692 "movhu"
4693 *am33
4694 *am33_2
4695 {
4696   int srcreg, dstreg;
4697
4698   PC = cia;
4699   srcreg = translate_rreg (SD_, RM2);
4700   dstreg = translate_rreg (SD_, RN0);
4701   store_half (State.regs[dstreg], State.regs[srcreg]);
4702   State.regs[dstreg] += FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D);
4703 }
4704
4705
4706 // 1111 1110 0000 1011 Rn Rn IMM32; mac imm32,Rn
4707 8.0xfe+8.0x0b+4.RN2,4.RN0=RN2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::mac
4708 "mac"
4709 *am33
4710 *am33_2
4711 {
4712   int srcreg, imm;
4713   signed64 temp, sum;
4714   int c, v;
4715
4716   PC = cia;
4717   srcreg = translate_rreg (SD_, RN0);
4718   imm = FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D);
4719
4720   temp = ((signed64)(signed32)State.regs[srcreg]
4721           * (signed64)(signed32)imm);
4722   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
4723   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
4724   State.regs[REG_MCRL] = sum;
4725   temp >>= 32;
4726   temp &= 0xffffffff;
4727   sum = State.regs[REG_MCRH] + temp + c;
4728   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
4729         && (temp & 0x80000000) != (sum & 0x80000000));
4730   State.regs[REG_MCRH] = sum;
4731   if (v)
4732     State.regs[REG_MCVF] = 1;
4733 }
4734
4735 // 1111 1110 0001 1011 Rn Rn IMM32; macu imm32,Rn
4736 8.0xfe+8.0x1b+4.RN2,4.RN0=RN2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::macu
4737 "macu"
4738 *am33
4739 *am33_2
4740 {
4741   int srcreg, imm;
4742   signed64 temp, sum;
4743   int c, v;
4744
4745   PC = cia;
4746   srcreg = translate_rreg (SD_, RN0);
4747   imm = FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D);
4748
4749   temp = ((unsigned64)State.regs[srcreg]
4750           * (unsigned64)imm);
4751   sum = State.regs[REG_MCRL] + (temp & 0xffffffff);
4752   c = (sum < State.regs[REG_MCRL]) || (sum < (temp & 0xffffffff));
4753   State.regs[REG_MCRL] = sum;
4754   temp >>= 32;
4755   temp &= 0xffffffff;
4756   sum = State.regs[REG_MCRH] + temp + c;
4757   v = ((State.regs[REG_MCRH] & 0x80000000) == (temp & 0x80000000)
4758         && (temp & 0x80000000) != (sum & 0x80000000));
4759   State.regs[REG_MCRH] = sum;
4760   if (v)
4761     State.regs[REG_MCVF] = 1;
4762 }
4763
4764 // 1111 1110 0010 1011 Rn Rn IMM32; macb imm32,Rn
4765 8.0xfe+8.0x2b+4.RN2,4.RN0=RN2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::macb
4766 "macb"
4767 *am33
4768 *am33_2
4769 {
4770   int srcreg, imm;
4771   signed32 temp, sum;
4772   int v;
4773
4774   PC = cia;
4775   srcreg = translate_rreg (SD_, RN0);
4776   imm = FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D);
4777
4778   temp = ((signed32)(signed8)(State.regs[srcreg] & 0xff)
4779           * (signed32)(signed8)(imm & 0xff));
4780   sum = State.regs[REG_MCRL] + temp;
4781   v = ((State.regs[REG_MCRL] & 0x80000000) == (temp & 0x80000000)
4782         && (temp & 0x80000000) != (sum & 0x80000000));
4783   State.regs[REG_MCRL] = sum;
4784   if (v)
4785     State.regs[REG_MCVF] = 1;
4786 }
4787
4788 // 1111 1110 0011 1011 Rn Rn IMM32; macbu imm32,Rn
4789 8.0xfe+8.0x3b+4.RN2,4.RN0=RN2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::macbu
4790 "macbu"
4791 *am33
4792 *am33_2
4793 {
4794   int srcreg, imm;
4795   signed32 temp, sum;
4796   int v;
4797
4798   PC = cia;
4799   srcreg = translate_rreg (SD_, RN0);
4800   imm = FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D);
4801
4802   temp = ((unsigned32)(State.regs[srcreg] & 0xff)
4803           * (unsigned32)(imm & 0xff));
4804   sum = State.regs[REG_MCRL] + temp;
4805   v = ((State.regs[REG_MCRL] & 0x80000000) == (temp & 0x80000000)
4806         && (temp & 0x80000000) != (sum & 0x80000000));
4807   State.regs[REG_MCRL] = sum;
4808   if (v)
4809     State.regs[REG_MCVF] = 1;
4810 }
4811
4812 // 1111 1110 0100 1011 Rn Rn IMM32; mach imm32,Rn
4813 8.0xfe+8.0x4b+4.RN2,4.RN0=RN2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::mach
4814 "mach"
4815 *am33
4816 *am33_2
4817 {
4818   int srcreg, imm;
4819   signed32 temp, sum;
4820   int v;
4821
4822   PC = cia;
4823   srcreg = translate_rreg (SD_, RN0);
4824   imm = FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D);
4825
4826   temp = ((signed32)(signed16)(State.regs[srcreg] & 0xffff)
4827           * (signed32)(signed16)(imm & 0xffff));
4828   sum = State.regs[REG_MCRL] + temp;
4829   v = ((State.regs[REG_MCRL] & 0x80000000) == (temp & 0x80000000)
4830         && (temp & 0x80000000) != (sum & 0x80000000));
4831   State.regs[REG_MCRL] = sum;
4832   if (v)
4833     State.regs[REG_MCVF] = 1;
4834 }
4835
4836 // 1111 1110 0101 1011 Rn Rn IMM32; machu imm32,Rn
4837 8.0xfe+8.0x5b+4.RN2,4.RN0=RN2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::machu
4838 "machu"
4839 *am33
4840 *am33_2
4841 {
4842   int srcreg, imm;
4843   signed32 temp, sum;
4844   int v;
4845
4846   PC = cia;
4847   srcreg = translate_rreg (SD_, RN0);
4848   imm = FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D);
4849
4850   temp = ((unsigned32)(State.regs[srcreg] & 0xffff)
4851           * (unsigned32)(imm & 0xffff));
4852   sum = State.regs[REG_MCRL] + temp;
4853   v = ((State.regs[REG_MCRL] & 0x80000000) == (temp & 0x80000000)
4854         && (temp & 0x80000000) != (sum & 0x80000000));
4855   State.regs[REG_MCRL] = sum;
4856   if (v)
4857     State.regs[REG_MCVF] = 1;
4858 }
4859
4860 // 1111 1110 0110 1011 Rn Rn IMM32; dmach imm32,Rn
4861 8.0xfe+8.0x6b+4.RN2,4.RN0=RN2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::dmach
4862 "dmach"
4863 *am33
4864 *am33_2
4865 {
4866   int srcreg, imm;
4867   signed32 temp, temp2, sum;
4868   int v;
4869
4870   PC = cia;
4871   srcreg = translate_rreg (SD_, RN0);
4872   imm = FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D);
4873
4874   temp = ((signed32)(signed16)(State.regs[srcreg] & 0xffff)
4875           * (signed32)(signed16)(imm & 0xffff));
4876   temp2 = ((signed32)(signed16)((State.regs[srcreg] >> 16) & 0xffff)
4877            * (signed32)(signed16)((imm >> 16) & 0xffff));
4878   sum = temp + temp2 + State.regs[REG_MCRL];
4879   v = ((State.regs[REG_MCRL] & 0x80000000) == (temp & 0x80000000)
4880         && (temp & 0x80000000) != (sum & 0x80000000));
4881   State.regs[REG_MCRL] = sum;
4882   if (v)
4883     State.regs[REG_MCVF] = 1;
4884 }
4885
4886 // 1111 1110 0111 1011 Rn Rn IMM32; dmachu imm32,Rn
4887 8.0xfe+8.0x7b+4.RN2,4.RN0=RN2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::dmachu
4888 "dmachu"
4889 *am33
4890 *am33_2
4891 {
4892   int srcreg, imm;
4893   signed32 temp, temp2, sum;
4894   int v;
4895
4896   PC = cia;
4897   srcreg = translate_rreg (SD_, RN0);
4898   imm = FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D);
4899
4900   temp = ((unsigned32)(State.regs[srcreg] & 0xffff)
4901           * (unsigned32)(imm & 0xffff));
4902   temp2 = ((unsigned32)((State.regs[srcreg] >> 16) & 0xffff)
4903            * (unsigned32)((imm >> 16) & 0xffff));
4904   sum = temp + temp2 + State.regs[REG_MCRL];
4905   v = ((State.regs[REG_MCRL] & 0x80000000) == (temp & 0x80000000)
4906         && (temp & 0x80000000) != (sum & 0x80000000));
4907   State.regs[REG_MCRL] = sum;
4908   if (v)
4909     State.regs[REG_MCVF] = 1;
4910 }
4911
4912 // 1111 1110 1000 1011 Rn Rn IMM32; dmulh imm32,Rn
4913 8.0xfe+8.0x8b+4.RN2,4.RN0=RN2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::dmulh
4914 "dmulh"
4915 *am33
4916 *am33_2
4917 {
4918   int imm, dstreg;
4919   signed32 temp;
4920
4921   PC = cia;
4922   dstreg = translate_rreg (SD_, RN0);
4923   imm = FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D);
4924
4925   temp = ((signed32)(signed16)(State.regs[dstreg] & 0xffff)
4926           * (signed32)(signed16)(imm & 0xffff));
4927   State.regs[REG_MDRQ] = temp;
4928   temp = ((signed32)(signed16)((State.regs[dstreg] >> 16) & 0xffff)
4929           * (signed32)(signed16)((imm>>16) & 0xffff));
4930   State.regs[dstreg] = temp;
4931 }
4932
4933 // 1111 1110 1001 1011 Rn Rn IMM32; dmulhu imm32,Rn
4934 8.0xfe+8.0x9b+4.RN2,4.RN0=RN2+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5:::dmulhu
4935 "dmulhu"
4936 *am33
4937 *am33_2
4938 {
4939   int imm, dstreg;
4940   signed32 temp;
4941
4942   PC = cia;
4943   dstreg = translate_rreg (SD_, RN0);
4944   imm = FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D);
4945
4946   temp = ((unsigned32)(State.regs[dstreg] & 0xffff)
4947           * (unsigned32)(imm & 0xffff));
4948   State.regs[REG_MDRQ] = temp;
4949   temp = ((unsigned32)((State.regs[dstreg] >> 16) & 0xffff)
4950           * (unsigned32)((imm >>16) & 0xffff));
4951   State.regs[dstreg] = temp;
4952 }
4953
4954 // 1111 1110 0000 1110 Rn 0000 IMM32; mov (abs32),Rn
4955 8.0xfe+8.0x0e+4.RN2,4.0x0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5h:::mov
4956 "mov"
4957 *am33
4958 *am33_2
4959 {
4960   int dstreg;
4961
4962   PC = cia;
4963   dstreg = translate_rreg (SD_, RN2);
4964   State.regs[dstreg] = load_word (FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D));
4965 }
4966
4967 // 1111 1110 0001 1110 Rm 0000 IMM32; mov Rn,(abs32)
4968 8.0xfe+8.0x1e+4.RM2,4.0x0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5e:::mov
4969 "mov"
4970 *am33
4971 *am33_2
4972 {
4973   int srcreg;
4974
4975   PC = cia;
4976   srcreg = translate_rreg (SD_, RM2);
4977   store_word (FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D), State.regs[srcreg]);
4978 }
4979
4980 // 1111 1110 0020 1110 Rn 0000 IMM32; movbu (abs32),Rn
4981 8.0xfe+8.0x2e+4.RN2,4.0x0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5i:::movbu
4982 "movbu"
4983 *am33
4984 *am33_2
4985 {
4986   int dstreg;
4987
4988   PC = cia;
4989   dstreg = translate_rreg (SD_, RN2);
4990   State.regs[dstreg] = load_byte (FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D));
4991 }
4992
4993 // 1111 1110 0011 1110 Rm 0000 IMM32; movbu Rn,(abs32)
4994 8.0xfe+8.0x3e+4.RM2,4.0x0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5e:::movbu
4995 "movbu"
4996 *am33
4997 *am33_2
4998 {
4999   int srcreg;
5000
5001   PC = cia;
5002   srcreg = translate_rreg (SD_, RM2);
5003   store_byte (FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D), State.regs[srcreg]);
5004 }
5005
5006 // 1111 1110 0100 1110 Rn 0000 IMM32; movhu (abs32),Rn
5007 8.0xfe+8.0x4e+4.RN2,4.0x0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5j:::movhu
5008 "movhu"
5009 *am33
5010 *am33_2
5011 {
5012   int dstreg;
5013
5014   PC = cia;
5015   dstreg = translate_rreg (SD_, RN2);
5016   State.regs[dstreg] = load_half (FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D));
5017 }
5018
5019 // 1111 1110 0101 1110 Rm 0000 IMM32; movhu Rn,(abs32)
5020 8.0xfe+8.0x5e+4.RM2,4.0x0+8.IMM32A+8.IMM32B+8.IMM32C+8.IMM32D:D5e:::movhu
5021 "movhu"
5022 *am33
5023 *am33_2
5024 {
5025   int srcreg;
5026
5027   PC = cia;
5028   srcreg = translate_rreg (SD_, RM2);
5029   store_half (FETCH32 (IMM32A, IMM32B, IMM32C, IMM32D), State.regs[srcreg]);
5030 }
5031
5032 // 1111 0111 0000 0000 Rm1 Rn1 Rm2 Rn2; add_add Rm1, Rn1, Rm2, Rn2
5033 8.0xf7+8.0x00+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::add_add
5034 "add_add"
5035 *am33
5036 *am33_2
5037 {
5038   int srcreg1, srcreg2, dstreg1, dstreg2;
5039   int result1;
5040
5041   PC = cia;
5042   srcreg1 = translate_rreg (SD_, RM1);
5043   srcreg2 = translate_rreg (SD_, RM2);
5044   dstreg1 = translate_rreg (SD_, RN1);
5045   dstreg2 = translate_rreg (SD_, RN2);
5046
5047   result1 = State.regs[dstreg1] + State.regs[srcreg1];
5048   State.regs[dstreg2] += State.regs[srcreg2];
5049   State.regs[dstreg1] = result1;
5050 }
5051
5052 // 1111 0111 0001 0000 Rm1 Rn1 imm4 Rn2; add_add Rm1, Rn1, imm4, Rn2
5053 8.0xf7+8.0x10+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::add_add
5054 "add_add"
5055 *am33
5056 *am33_2
5057 {
5058   int srcreg1, dstreg1, dstreg2;
5059   int result1;
5060
5061   PC = cia;
5062   srcreg1 = translate_rreg (SD_, RM1);
5063   dstreg1 = translate_rreg (SD_, RN1);
5064   dstreg2 = translate_rreg (SD_, RN2);
5065
5066   result1 = State.regs[dstreg1] + State.regs[srcreg1];
5067   State.regs[dstreg2] += EXTEND4 (IMM4);
5068   State.regs[dstreg1] = result1;
5069 }
5070   
5071 // 1111 0111 0010 0000 Rm1 Rn1 Rm2 Rn2; add_sub Rm1, Rn1, Rm2, Rn2
5072 8.0xf7+8.0x20+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::add_sub
5073 "add_sub"
5074 *am33
5075 *am33_2
5076 {
5077   int srcreg1, srcreg2, dstreg1, dstreg2;
5078   int result1;
5079
5080   PC = cia;
5081   srcreg1 = translate_rreg (SD_, RM1);
5082   srcreg2 = translate_rreg (SD_, RM2);
5083   dstreg1 = translate_rreg (SD_, RN1);
5084   dstreg2 = translate_rreg (SD_, RN2);
5085
5086   result1 = State.regs[dstreg1] + State.regs[srcreg1];
5087   State.regs[dstreg2] -= State.regs[srcreg2];
5088   State.regs[dstreg1] = result1;
5089 }
5090
5091 // 1111 0111 0011 0000 Rm1 Rn1 imm4 Rn2; add_sub Rm1, Rn1, imm4, Rn2
5092 8.0xf7+8.0x30+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::add_sub
5093 "add_sub"
5094 *am33
5095 *am33_2
5096 {
5097   int srcreg1, dstreg1, dstreg2;
5098   int result1;
5099
5100   PC = cia;
5101   srcreg1 = translate_rreg (SD_, RM1);
5102   dstreg1 = translate_rreg (SD_, RN1);
5103   dstreg2 = translate_rreg (SD_, RN2);
5104
5105   result1 = State.regs[dstreg1] + State.regs[srcreg1];
5106   State.regs[dstreg2] -= EXTEND4 (IMM4);
5107   State.regs[dstreg1] = result1;
5108 }
5109   
5110 // 1111 0111 0100 0000 Rm1 Rn1 Rm2 Rn2; add_cmp Rm1, Rn1, Rm2, Rn2
5111 8.0xf7+8.0x40+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::add_cmp
5112 "add_cmp"
5113 *am33
5114 *am33_2
5115 {
5116   int srcreg1, srcreg2, dstreg1, dstreg2;
5117
5118   PC = cia;
5119   srcreg1 = translate_rreg (SD_, RM1);
5120   srcreg2 = translate_rreg (SD_, RM2);
5121   dstreg1 = translate_rreg (SD_, RN1);
5122   dstreg2 = translate_rreg (SD_, RN2);
5123
5124   genericCmp (State.regs[srcreg2], State.regs[dstreg2]);
5125   State.regs[dstreg1] += State.regs[srcreg1];
5126 }
5127
5128 // 1111 0111 0101 0000 Rm1 Rn1 imm4 Rn2; add_cmp Rm1, Rn1, imm4, Rn2
5129 8.0xf7+8.0x50+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::add_cmp
5130 "add_cmp"
5131 *am33
5132 *am33_2
5133 {
5134   int srcreg1, dstreg1, dstreg2;
5135
5136   PC = cia;
5137   srcreg1 = translate_rreg (SD_, RM1);
5138   dstreg1 = translate_rreg (SD_, RN1);
5139   dstreg2 = translate_rreg (SD_, RN2);
5140
5141   genericCmp (EXTEND4 (IMM4), State.regs[dstreg2]);
5142   State.regs[dstreg1] += State.regs[srcreg1];
5143 }
5144   
5145 // 1111 0111 0110 0000 Rm1 Rn1 Rm2 Rn2; add_mov Rm1, Rn1, Rm2, Rn2
5146 8.0xf7+8.0x60+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::add_mov
5147 "add_mov"
5148 *am33
5149 *am33_2
5150 {
5151   int srcreg1, srcreg2, dstreg1, dstreg2;
5152   int result1;
5153
5154   PC = cia;
5155   srcreg1 = translate_rreg (SD_, RM1);
5156   srcreg2 = translate_rreg (SD_, RM2);
5157   dstreg1 = translate_rreg (SD_, RN1);
5158   dstreg2 = translate_rreg (SD_, RN2);
5159
5160   result1 = State.regs[dstreg1] + State.regs[srcreg1];
5161   State.regs[dstreg2] = State.regs[srcreg2];
5162   State.regs[dstreg1] = result1;
5163 }
5164
5165 // 1111 0111 0111 0000 Rm1 Rn1 imm4 Rn2; add_mov Rm1, Rn1, imm4, Rn2
5166 8.0xf7+8.0x70+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::add_mov
5167 "add_mov"
5168 *am33
5169 *am33_2
5170 {
5171   int srcreg1, dstreg1, dstreg2;
5172   int result1;
5173
5174   PC = cia;
5175   srcreg1 = translate_rreg (SD_, RM1);
5176   dstreg1 = translate_rreg (SD_, RN1);
5177   dstreg2 = translate_rreg (SD_, RN2);
5178
5179   result1 = State.regs[dstreg1] + State.regs[srcreg1];
5180   State.regs[dstreg2] = EXTEND4 (IMM4);
5181   State.regs[dstreg1] = result1;
5182 }
5183   
5184 // 1111 0111 1000 0000 Rm1 Rn1 Rm2 Rn2; add_asr Rm1, Rn1, Rm2, Rn2
5185 8.0xf7+8.0x80+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::add_asr
5186 "add_asr"
5187 *am33
5188 *am33_2
5189 {
5190   int srcreg1, srcreg2, dstreg1, dstreg2;
5191   int result1;
5192   signed int temp;
5193
5194   PC = cia;
5195   srcreg1 = translate_rreg (SD_, RM1);
5196   srcreg2 = translate_rreg (SD_, RM2);
5197   dstreg1 = translate_rreg (SD_, RN1);
5198   dstreg2 = translate_rreg (SD_, RN2);
5199
5200   result1 = State.regs[dstreg1] + State.regs[srcreg1];
5201   temp = State.regs[dstreg2];
5202   temp >>= State.regs[srcreg2];
5203   State.regs[dstreg2] = temp;
5204   State.regs[dstreg1] = result1;
5205 }
5206
5207 // 1111 0111 1001 0000 Rm1 Rn1 imm4 Rn2; add_asr Rm1, Rn1, imm4, Rn2
5208 8.0xf7+8.0x90+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::add_asr
5209 "add_asr"
5210 *am33
5211 *am33_2
5212 {
5213   int srcreg1, dstreg1, dstreg2;
5214   int result1;
5215   signed int temp;
5216
5217   PC = cia;
5218   srcreg1 = translate_rreg (SD_, RM1);
5219   dstreg1 = translate_rreg (SD_, RN1);
5220   dstreg2 = translate_rreg (SD_, RN2);
5221
5222   result1 = State.regs[dstreg1] + State.regs[srcreg1];
5223   temp = State.regs[dstreg2];
5224   temp >>= IMM4;
5225   State.regs[dstreg2] = temp;
5226   State.regs[dstreg1] = result1;
5227 }
5228   
5229 // 1111 0111 1010 0000 Rm1 Rn1 Rm2 Rn2; add_lsr Rm1, Rn1, Rm2, Rn2
5230 8.0xf7+8.0xa0+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::add_lsr
5231 "add_lsr"
5232 *am33
5233 *am33_2
5234 {
5235   int srcreg1, srcreg2, dstreg1, dstreg2;
5236   int result1;
5237
5238   PC = cia;
5239   srcreg1 = translate_rreg (SD_, RM1);
5240   srcreg2 = translate_rreg (SD_, RM2);
5241   dstreg1 = translate_rreg (SD_, RN1);
5242   dstreg2 = translate_rreg (SD_, RN2);
5243
5244   result1 = State.regs[dstreg1] + State.regs[srcreg1];
5245   State.regs[dstreg2] >>= State.regs[srcreg2];
5246   State.regs[dstreg1] = result1;
5247 }
5248
5249 // 1111 0111 1011 0000 Rm1 Rn1 imm4 Rn2; add_lsr Rm1, Rn1, imm4, Rn2
5250 8.0xf7+8.0xb0+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::add_lsr
5251 "add_lsr"
5252 *am33
5253 *am33_2
5254 {
5255   int srcreg1, dstreg1, dstreg2;
5256   int result1;
5257
5258   PC = cia;
5259   srcreg1 = translate_rreg (SD_, RM1);
5260   dstreg1 = translate_rreg (SD_, RN1);
5261   dstreg2 = translate_rreg (SD_, RN2);
5262
5263   result1 = State.regs[dstreg1] + State.regs[srcreg1];
5264   State.regs[dstreg2] >>= IMM4;
5265   State.regs[dstreg1] = result1;
5266 }
5267   
5268   
5269 // 1111 0111 1100 0000 Rm1 Rn1 Rm2 Rn2; add_asl Rm1, Rn1, Rm2, Rn2
5270 8.0xf7+8.0xc0+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::add_asl
5271 "add_asl"
5272 *am33
5273 *am33_2
5274 {
5275   int srcreg1, srcreg2, dstreg1, dstreg2;
5276   int result1;
5277
5278   PC = cia;
5279   srcreg1 = translate_rreg (SD_, RM1);
5280   srcreg2 = translate_rreg (SD_, RM2);
5281   dstreg1 = translate_rreg (SD_, RN1);
5282   dstreg2 = translate_rreg (SD_, RN2);
5283
5284   result1 = State.regs[dstreg1] + State.regs[srcreg1];
5285   State.regs[dstreg2] <<= State.regs[srcreg2];
5286   State.regs[dstreg1] = result1;
5287 }
5288
5289 // 1111 0111 1101 0000 Rm1 Rn1 imm4 Rn2; add_asl Rm1, Rn1, imm4, Rn2
5290 8.0xf7+8.0xd0+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::add_asl
5291 "add_asl"
5292 *am33
5293 *am33_2
5294 {
5295   int srcreg1, dstreg1, dstreg2;
5296   int result1;
5297
5298   PC = cia;
5299   srcreg1 = translate_rreg (SD_, RM1);
5300   dstreg1 = translate_rreg (SD_, RN1);
5301   dstreg2 = translate_rreg (SD_, RN2);
5302
5303   result1 = State.regs[dstreg1] + State.regs[srcreg1];
5304   State.regs[dstreg2] <<= IMM4;
5305   State.regs[dstreg1] = result1;
5306 }
5307   
5308 // 1111 0111 0000 0001 Rm1 Rn1 Rm2 Rn2; cmp_add Rm1, Rn1, Rm2, Rn2
5309 8.0xf7+8.0x01+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::cmp_add
5310 "cmp_add"
5311 *am33
5312 *am33_2
5313 {
5314   int srcreg1, srcreg2, dstreg1, dstreg2;
5315
5316   PC = cia;
5317   srcreg1 = translate_rreg (SD_, RM1);
5318   srcreg2 = translate_rreg (SD_, RM2);
5319   dstreg1 = translate_rreg (SD_, RN1);
5320   dstreg2 = translate_rreg (SD_, RN2);
5321
5322   genericCmp (State.regs[srcreg1], State.regs[dstreg1]);
5323   State.regs[dstreg2] += State.regs[srcreg2];
5324 }
5325
5326 // 1111 0111 0001 0001 Rm1 Rn1 imm4 Rn2; cmp_add Rm1, Rn1, imm4, Rn2
5327 8.0xf7+8.0x11+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::cmp_add
5328 "cmp_add"
5329 *am33
5330 *am33_2
5331 {
5332   int srcreg1, dstreg1, dstreg2;
5333
5334   PC = cia;
5335   srcreg1 = translate_rreg (SD_, RM1);
5336   dstreg1 = translate_rreg (SD_, RN1);
5337   dstreg2 = translate_rreg (SD_, RN2);
5338
5339   genericCmp (State.regs[srcreg1], State.regs[dstreg1]);
5340   State.regs[dstreg2] += EXTEND4 (IMM4);
5341 }
5342   
5343 // 1111 0111 0010 0001 Rm1 Rn1 Rm2 Rn2; cmp_sub Rm1, Rn1, Rm2, Rn2
5344 8.0xf7+8.0x21+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::cmp_sub
5345 "cmp_sub"
5346 *am33
5347 *am33_2
5348 {
5349   int srcreg1, srcreg2, dstreg1, dstreg2;
5350
5351   PC = cia;
5352   srcreg1 = translate_rreg (SD_, RM1);
5353   srcreg2 = translate_rreg (SD_, RM2);
5354   dstreg1 = translate_rreg (SD_, RN1);
5355   dstreg2 = translate_rreg (SD_, RN2);
5356
5357   genericCmp (State.regs[srcreg1], State.regs[dstreg1]);
5358   State.regs[dstreg2] -= State.regs[srcreg2];
5359 }
5360
5361 // 1111 0111 0011 0001 Rm1 Rn1 imm4 Rn2; cmp_sub Rm1, Rn1, imm4, Rn2
5362 8.0xf7+8.0x31+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::cmp_sub
5363 "cmp_sub"
5364 *am33
5365 *am33_2
5366 {
5367   int srcreg1, dstreg1, dstreg2;
5368
5369   PC = cia;
5370   srcreg1 = translate_rreg (SD_, RM1);
5371   dstreg1 = translate_rreg (SD_, RN1);
5372   dstreg2 = translate_rreg (SD_, RN2);
5373
5374   genericCmp (State.regs[srcreg1], State.regs[dstreg1]);
5375   State.regs[dstreg2] -= EXTEND4 (IMM4);
5376 }
5377   
5378 // 1111 0111 0110 0001 Rm1 Rn1 Rm2 Rn2; cmp_mov Rm1, Rn1, Rm2, Rn2
5379 8.0xf7+8.0x61+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::cmp_mov
5380 "cmp_mov"
5381 *am33
5382 *am33_2
5383 {
5384   int srcreg1, srcreg2, dstreg1, dstreg2;
5385
5386   PC = cia;
5387   srcreg1 = translate_rreg (SD_, RM1);
5388   srcreg2 = translate_rreg (SD_, RM2);
5389   dstreg1 = translate_rreg (SD_, RN1);
5390   dstreg2 = translate_rreg (SD_, RN2);
5391
5392   genericCmp (State.regs[srcreg1], State.regs[dstreg1]);
5393   State.regs[dstreg2] = State.regs[srcreg2];
5394 }
5395
5396 // 1111 0111 0111 0001 Rm1 Rn1 imm4 Rn2; cmp_mov Rm1, Rn1, imm4, Rn2
5397 8.0xf7+8.0x71+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::cmp_mov
5398 "cmp_mov"
5399 *am33
5400 *am33_2
5401 {
5402   int srcreg1, dstreg1, dstreg2;
5403
5404   PC = cia;
5405   srcreg1 = translate_rreg (SD_, RM1);
5406   dstreg1 = translate_rreg (SD_, RN1);
5407   dstreg2 = translate_rreg (SD_, RN2);
5408
5409   genericCmp (State.regs[srcreg1], State.regs[dstreg1]);
5410   State.regs[dstreg2] = EXTEND4 (IMM4);
5411 }
5412   
5413 // 1111 0111 1000 0001 Rm1 Rn1 Rm2 Rn2; cmp_asr Rm1, Rn1, Rm2, Rn2
5414 8.0xf7+8.0x81+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::cmp_asr
5415 "cmp_asr"
5416 *am33
5417 *am33_2
5418 {
5419   int srcreg1, srcreg2, dstreg1, dstreg2;
5420   signed int temp;
5421
5422   PC = cia;
5423   srcreg1 = translate_rreg (SD_, RM1);
5424   srcreg2 = translate_rreg (SD_, RM2);
5425   dstreg1 = translate_rreg (SD_, RN1);
5426   dstreg2 = translate_rreg (SD_, RN2);
5427
5428   genericCmp (State.regs[srcreg1], State.regs[dstreg1]);
5429   temp = State.regs[dstreg2];
5430   temp >>= State.regs[srcreg2];
5431   State.regs[dstreg2] = temp;
5432 }
5433
5434 // 1111 0111 1001 0001 Rm1 Rn1 imm4 Rn2; cmp_asr Rm1, Rn1, imm4, Rn2
5435 8.0xf7+8.0x91+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::cmp_asr
5436 "cmp_asr"
5437 *am33
5438 *am33_2
5439 {
5440   int srcreg1, dstreg1, dstreg2;
5441   signed int temp;
5442
5443   PC = cia;
5444   srcreg1 = translate_rreg (SD_, RM1);
5445   dstreg1 = translate_rreg (SD_, RN1);
5446   dstreg2 = translate_rreg (SD_, RN2);
5447
5448   genericCmp (State.regs[srcreg1], State.regs[dstreg1]);
5449   temp = State.regs[dstreg2];
5450   temp >>= IMM4;
5451   State.regs[dstreg2] = temp;
5452 }
5453
5454 // 1111 0111 1010 0001 Rm1 Rn1 Rm2 Rn2; cmp_lsr Rm1, Rn1, Rm2, Rn2
5455 8.0xf7+8.0xa1+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::cmp_lsr
5456 "cmp_lsr"
5457 *am33
5458 *am33_2
5459 {
5460   int srcreg1, srcreg2, dstreg1, dstreg2;
5461
5462   PC = cia;
5463   srcreg1 = translate_rreg (SD_, RM1);
5464   srcreg2 = translate_rreg (SD_, RM2);
5465   dstreg1 = translate_rreg (SD_, RN1);
5466   dstreg2 = translate_rreg (SD_, RN2);
5467
5468   genericCmp (State.regs[srcreg1], State.regs[dstreg1]);
5469   State.regs[dstreg2] >>= State.regs[srcreg2];
5470 }
5471
5472 // 1111 0111 1011 0001 Rm1 Rn1 imm4 Rn2; cmp_lsr Rm1, Rn1, imm4, Rn2
5473 8.0xf7+8.0xb1+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::cmp_lsr
5474 "cmp_lsr"
5475 *am33
5476 *am33_2
5477 {
5478   int srcreg1, dstreg1, dstreg2;
5479
5480   PC = cia;
5481   srcreg1 = translate_rreg (SD_, RM1);
5482   dstreg1 = translate_rreg (SD_, RN1);
5483   dstreg2 = translate_rreg (SD_, RN2);
5484
5485   genericCmp (State.regs[srcreg1], State.regs[dstreg1]);
5486   State.regs[dstreg2] >>= IMM4;
5487 }
5488   
5489   
5490 // 1111 0111 1100 0001 Rm1 Rn1 Rm2 Rn2; cmp_asl Rm1, Rn1, Rm2, Rn2
5491 8.0xf7+8.0xc1+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::cmp_asl
5492 "cmp_asl"
5493 *am33
5494 *am33_2
5495 {
5496   int srcreg1, srcreg2, dstreg1, dstreg2;
5497
5498   PC = cia;
5499   srcreg1 = translate_rreg (SD_, RM1);
5500   srcreg2 = translate_rreg (SD_, RM2);
5501   dstreg1 = translate_rreg (SD_, RN1);
5502   dstreg2 = translate_rreg (SD_, RN2);
5503
5504   genericCmp (State.regs[srcreg1], State.regs[dstreg1]);
5505   State.regs[dstreg2] <<= State.regs[srcreg2];
5506 }
5507
5508 // 1111 0111 1101 0001 Rm1 Rn1 imm4 Rn2; cmp_asl Rm1, Rn1, imm4, Rn2
5509 8.0xf7+8.0xd1+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::cmp_asl
5510 "cmp_asl"
5511 *am33
5512 *am33_2
5513 {
5514   int srcreg1, dstreg1, dstreg2;
5515
5516   PC = cia;
5517   srcreg1 = translate_rreg (SD_, RM1);
5518   dstreg1 = translate_rreg (SD_, RN1);
5519   dstreg2 = translate_rreg (SD_, RN2);
5520
5521   genericCmp (State.regs[srcreg1], State.regs[dstreg1]);
5522   State.regs[dstreg2] <<= IMM4;
5523 }
5524
5525 // 1111 0111 0000 0010 Rm1 Rn1 Rm2 Rn2; sub_add Rm1, Rn1, Rm2, Rn2
5526 8.0xf7+8.0x02+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::sub_add
5527 "sub_add"
5528 *am33
5529 *am33_2
5530 {
5531   int srcreg1, srcreg2, dstreg1, dstreg2;
5532   int result1;
5533
5534   PC = cia;
5535   srcreg1 = translate_rreg (SD_, RM1);
5536   srcreg2 = translate_rreg (SD_, RM2);
5537   dstreg1 = translate_rreg (SD_, RN1);
5538   dstreg2 = translate_rreg (SD_, RN2);
5539
5540   result1 = State.regs[dstreg1] - State.regs[srcreg1];
5541   State.regs[dstreg2] += State.regs[srcreg2];
5542   State.regs[dstreg1] = result1;
5543 }
5544
5545 // 1111 0111 0001 0010 Rm1 Rn1 imm4 Rn2; sub_add Rm1, Rn1, imm4, Rn2
5546 8.0xf7+8.0x12+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::sub_add
5547 "sub_add"
5548 *am33
5549 *am33_2
5550 {
5551   int srcreg1, dstreg1, dstreg2;
5552   int result1;
5553
5554   PC = cia;
5555   srcreg1 = translate_rreg (SD_, RM1);
5556   dstreg1 = translate_rreg (SD_, RN1);
5557   dstreg2 = translate_rreg (SD_, RN2);
5558
5559   result1 = State.regs[dstreg1] - State.regs[srcreg1];
5560   State.regs[dstreg2] += EXTEND4 (IMM4);
5561   State.regs[dstreg1] = result1;
5562 }
5563   
5564 // 1111 0111 0010 0010 Rm1 Rn1 Rm2 Rn2; sub_sub Rm1, Rn1, Rm2, Rn2
5565 8.0xf7+8.0x22+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::sub_sub
5566 "sub_sub"
5567 *am33
5568 *am33_2
5569 {
5570   int srcreg1, srcreg2, dstreg1, dstreg2;
5571   int result1;
5572
5573   PC = cia;
5574   srcreg1 = translate_rreg (SD_, RM1);
5575   srcreg2 = translate_rreg (SD_, RM2);
5576   dstreg1 = translate_rreg (SD_, RN1);
5577   dstreg2 = translate_rreg (SD_, RN2);
5578
5579   result1 = State.regs[dstreg1] - State.regs[srcreg1];
5580   State.regs[dstreg2] -= State.regs[srcreg2];
5581   State.regs[dstreg1] = result1;
5582 }
5583
5584 // 1111 0111 0011 0010 Rm1 Rn1 imm4 Rn2; sub_sub Rm1, Rn1, imm4, Rn2
5585 8.0xf7+8.0x32+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::sub_sub
5586 "sub_sub"
5587 *am33
5588 *am33_2
5589 {
5590   int srcreg1, dstreg1, dstreg2;
5591   int result1;
5592
5593   PC = cia;
5594   srcreg1 = translate_rreg (SD_, RM1);
5595   dstreg1 = translate_rreg (SD_, RN1);
5596   dstreg2 = translate_rreg (SD_, RN2);
5597
5598   result1 = State.regs[dstreg1] - State.regs[srcreg1];
5599   State.regs[dstreg2] -= EXTEND4 (IMM4);
5600   State.regs[dstreg1] = result1;
5601 }
5602   
5603 // 1111 0111 0100 0010 Rm1 Rn1 Rm2 Rn2; sub_cmp Rm1, Rn1, Rm2, Rn2
5604 8.0xf7+8.0x42+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::sub_cmp
5605 "sub_cmp"
5606 *am33
5607 *am33_2
5608 {
5609   int srcreg1, srcreg2, dstreg1, dstreg2;
5610
5611   PC = cia;
5612   srcreg1 = translate_rreg (SD_, RM1);
5613   srcreg2 = translate_rreg (SD_, RM2);
5614   dstreg1 = translate_rreg (SD_, RN1);
5615   dstreg2 = translate_rreg (SD_, RN2);
5616
5617   genericCmp (State.regs[srcreg2], State.regs[dstreg2]);
5618   State.regs[dstreg1] -= State.regs[srcreg1];
5619 }
5620
5621 // 1111 0111 0101 0010 Rm1 Rn1 imm4 Rn2; sub_cmp Rm1, Rn1, imm4, Rn2
5622 8.0xf7+8.0x52+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::sub_cmp
5623 "sub_cmp"
5624 *am33
5625 *am33_2
5626 {
5627   int srcreg1, dstreg1, dstreg2;
5628
5629   PC = cia;
5630   srcreg1 = translate_rreg (SD_, RM1);
5631   dstreg1 = translate_rreg (SD_, RN1);
5632   dstreg2 = translate_rreg (SD_, RN2);
5633
5634   genericCmp (EXTEND4 (IMM4), State.regs[dstreg2]);
5635   State.regs[dstreg1] -= State.regs[srcreg1];
5636 }
5637   
5638 // 1111 0111 0110 0010 Rm1 Rn1 Rm2 Rn2; sub_mov Rm1, Rn1, Rm2, Rn2
5639 8.0xf7+8.0x62+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::sub_mov
5640 "sub_mov"
5641 *am33
5642 *am33_2
5643 {
5644   int srcreg1, srcreg2, dstreg1, dstreg2;
5645   int result1;
5646
5647   PC = cia;
5648   srcreg1 = translate_rreg (SD_, RM1);
5649   srcreg2 = translate_rreg (SD_, RM2);
5650   dstreg1 = translate_rreg (SD_, RN1);
5651   dstreg2 = translate_rreg (SD_, RN2);
5652
5653   result1 = State.regs[dstreg1] - State.regs[srcreg1];
5654   State.regs[dstreg2] = State.regs[srcreg2];
5655   State.regs[dstreg1] = result1;
5656 }
5657
5658 // 1111 0111 0111 0010 Rm1 Rn1 imm4 Rn2; sub_mov Rm1, Rn1, imm4, Rn2
5659 8.0xf7+8.0x72+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::sub_mov
5660 "sub_mov"
5661 *am33
5662 *am33_2
5663 {
5664   int srcreg1, dstreg1, dstreg2;
5665   int result1;
5666
5667   PC = cia;
5668   srcreg1 = translate_rreg (SD_, RM1);
5669   dstreg1 = translate_rreg (SD_, RN1);
5670   dstreg2 = translate_rreg (SD_, RN2);
5671
5672   result1 = State.regs[dstreg1] - State.regs[srcreg1];
5673   State.regs[dstreg2] = EXTEND4 (IMM4);
5674   State.regs[dstreg1] = result1;
5675 }
5676   
5677 // 1111 0111 1000 0010 Rm1 Rn1 Rm2 Rn2; sub_asr Rm1, Rn1, Rm2, Rn2
5678 8.0xf7+8.0x82+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::sub_asr
5679 "sub_asr"
5680 *am33
5681 *am33_2
5682 {
5683   int srcreg1, srcreg2, dstreg1, dstreg2;
5684   int result1;
5685   signed int temp;
5686
5687   PC = cia;
5688   srcreg1 = translate_rreg (SD_, RM1);
5689   srcreg2 = translate_rreg (SD_, RM2);
5690   dstreg1 = translate_rreg (SD_, RN1);
5691   dstreg2 = translate_rreg (SD_, RN2);
5692
5693   result1 = State.regs[dstreg1] - State.regs[srcreg1];
5694   temp = State.regs[dstreg2];
5695   temp >>= State.regs[srcreg2];
5696   State.regs[dstreg2] = temp;
5697   State.regs[dstreg1] = result1;
5698 }
5699
5700 // 1111 0111 1001 0010 Rm1 Rn1 imm4 Rn2; sub_asr Rm1, Rn1, imm4, Rn2
5701 8.0xf7+8.0x92+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::sub_asr
5702 "sub_asr"
5703 *am33
5704 *am33_2
5705 {
5706   int srcreg1, dstreg1, dstreg2;
5707   int result1;
5708   signed int temp;
5709
5710   PC = cia;
5711   srcreg1 = translate_rreg (SD_, RM1);
5712   dstreg1 = translate_rreg (SD_, RN1);
5713   dstreg2 = translate_rreg (SD_, RN2);
5714
5715   result1 = State.regs[dstreg1] - State.regs[srcreg1];
5716   temp = State.regs[dstreg2];
5717   temp >>= IMM4;
5718   State.regs[dstreg2] = temp;
5719   State.regs[dstreg1] = result1;
5720 }
5721   
5722 // 1111 0111 1010 0010 Rm1 Rn1 Rm2 Rn2; sub_lsr Rm1, Rn1, Rm2, Rn2
5723 8.0xf7+8.0xa2+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::sub_lsr
5724 "sub_lsr"
5725 *am33
5726 *am33_2
5727 {
5728   int srcreg1, srcreg2, dstreg1, dstreg2;
5729   int result1;
5730
5731   PC = cia;
5732   srcreg1 = translate_rreg (SD_, RM1);
5733   srcreg2 = translate_rreg (SD_, RM2);
5734   dstreg1 = translate_rreg (SD_, RN1);
5735   dstreg2 = translate_rreg (SD_, RN2);
5736
5737   result1 = State.regs[dstreg1] - State.regs[srcreg1];
5738   State.regs[dstreg2] >>= State.regs[srcreg2];
5739   State.regs[dstreg1] = result1;
5740 }
5741
5742 // 1111 0111 1011 0010 Rm1 Rn1 imm4 Rn2; sub_lsr Rm1, Rn1, imm4, Rn2
5743 8.0xf7+8.0xb2+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::sub_lsr
5744 "sub_lsr"
5745 *am33
5746 *am33_2
5747 {
5748   int srcreg1, dstreg1, dstreg2;
5749   int result1;
5750
5751   PC = cia;
5752   srcreg1 = translate_rreg (SD_, RM1);
5753   dstreg1 = translate_rreg (SD_, RN1);
5754   dstreg2 = translate_rreg (SD_, RN2);
5755
5756   result1 = State.regs[dstreg1] - State.regs[srcreg1];
5757   State.regs[dstreg2] >>= IMM4;
5758   State.regs[dstreg1] = result1;
5759 }
5760   
5761   
5762 // 1111 0111 1100 0010 Rm1 Rn1 Rm2 Rn2; sub_asl Rm1, Rn1, Rm2, Rn2
5763 8.0xf7+8.0xc2+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::sub_asl
5764 "sub_asl"
5765 *am33
5766 *am33_2
5767 {
5768   int srcreg1, srcreg2, dstreg1, dstreg2;
5769   int result1;
5770
5771   PC = cia;
5772   srcreg1 = translate_rreg (SD_, RM1);
5773   srcreg2 = translate_rreg (SD_, RM2);
5774   dstreg1 = translate_rreg (SD_, RN1);
5775   dstreg2 = translate_rreg (SD_, RN2);
5776
5777   result1 = State.regs[dstreg1] - State.regs[srcreg1];
5778   State.regs[dstreg2] <<= State.regs[srcreg2];
5779   State.regs[dstreg1] = result1;
5780 }
5781
5782 // 1111 0111 1101 0010 Rm1 Rn1 imm4 Rn2; sub_asl Rm1, Rn1, imm4, Rn2
5783 8.0xf7+8.0xd2+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::sub_asl
5784 "sub_asl"
5785 *am33
5786 *am33_2
5787 {
5788   int srcreg1, dstreg1, dstreg2;
5789   int result1;
5790
5791   PC = cia;
5792   srcreg1 = translate_rreg (SD_, RM1);
5793   dstreg1 = translate_rreg (SD_, RN1);
5794   dstreg2 = translate_rreg (SD_, RN2);
5795
5796   result1 = State.regs[dstreg1] - State.regs[srcreg1];
5797   State.regs[dstreg2] <<= IMM4;
5798   State.regs[dstreg1] = result1;
5799 }
5800   
5801 // 1111 0111 0000 0011 Rm1 Rn1 Rm2 Rn2; mov_add Rm1, Rn1, Rm2, Rn2
5802 8.0xf7+8.0x03+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::mov_add
5803 "mov_add"
5804 *am33
5805 *am33_2
5806 {
5807   int srcreg1, srcreg2, dstreg1, dstreg2;
5808   int result1;
5809
5810   PC = cia;
5811   srcreg1 = translate_rreg (SD_, RM1);
5812   srcreg2 = translate_rreg (SD_, RM2);
5813   dstreg1 = translate_rreg (SD_, RN1);
5814   dstreg2 = translate_rreg (SD_, RN2);
5815
5816   result1 = State.regs[srcreg1];
5817   State.regs[dstreg2] += State.regs[srcreg2];
5818   State.regs[dstreg1] = result1;
5819 }
5820
5821 // 1111 0111 0001 0011 Rm1 Rn1 imm4 Rn2; mov_add Rm1, Rn1, imm4, Rn2
5822 8.0xf7+8.0x13+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::mov_add
5823 "mov_add"
5824 *am33
5825 *am33_2
5826 {
5827   int srcreg1, dstreg1, dstreg2;
5828   int result1;
5829
5830   PC = cia;
5831   srcreg1 = translate_rreg (SD_, RM1);
5832   dstreg1 = translate_rreg (SD_, RN1);
5833   dstreg2 = translate_rreg (SD_, RN2);
5834
5835   result1 = State.regs[srcreg1];
5836   State.regs[dstreg2] += EXTEND4 (IMM4);
5837   State.regs[dstreg1] = result1;
5838 }
5839   
5840 // 1111 0111 0010 0011 Rm1 Rn1 Rm2 Rn2; mov_sub Rm1, Rn1, Rm2, Rn2
5841 8.0xf7+8.0x23+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::mov_sub
5842 "mov_sub"
5843 *am33
5844 *am33_2
5845 {
5846   int srcreg1, srcreg2, dstreg1, dstreg2;
5847   int result1;
5848
5849   PC = cia;
5850   srcreg1 = translate_rreg (SD_, RM1);
5851   srcreg2 = translate_rreg (SD_, RM2);
5852   dstreg1 = translate_rreg (SD_, RN1);
5853   dstreg2 = translate_rreg (SD_, RN2);
5854
5855   result1 = State.regs[srcreg1];
5856   State.regs[dstreg2] -= State.regs[srcreg2];
5857   State.regs[dstreg1] = result1;
5858 }
5859
5860 // 1111 0111 0011 0011 Rm1 Rn1 imm4 Rn2; mov_sub Rm1, Rn1, imm4, Rn2
5861 8.0xf7+8.0x33+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::mov_sub
5862 "mov_sub"
5863 *am33
5864 *am33_2
5865 {
5866   int srcreg1, dstreg1, dstreg2;
5867   int result1;
5868
5869   PC = cia;
5870   srcreg1 = translate_rreg (SD_, RM1);
5871   dstreg1 = translate_rreg (SD_, RN1);
5872   dstreg2 = translate_rreg (SD_, RN2);
5873
5874   result1 = State.regs[srcreg1];
5875   State.regs[dstreg2] -= EXTEND4 (IMM4);
5876   State.regs[dstreg1] = result1;
5877 }
5878   
5879 // 1111 0111 0100 0011 Rm1 Rn1 Rm2 Rn2; mov_cmp Rm1, Rn1, Rm2, Rn2
5880 8.0xf7+8.0x43+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::mov_cmp
5881 "mov_cmp"
5882 *am33
5883 *am33_2
5884 {
5885   int srcreg1, srcreg2, dstreg1, dstreg2;
5886
5887   PC = cia;
5888   srcreg1 = translate_rreg (SD_, RM1);
5889   srcreg2 = translate_rreg (SD_, RM2);
5890   dstreg1 = translate_rreg (SD_, RN1);
5891   dstreg2 = translate_rreg (SD_, RN2);
5892
5893   genericCmp (State.regs[srcreg2], State.regs[dstreg2]);
5894   State.regs[dstreg1] = State.regs[srcreg1];
5895 }
5896
5897 // 1111 0111 0101 0011 Rm1 Rn1 imm4 Rn2; mov_cmp Rm1, Rn1, imm4, Rn2
5898 8.0xf7+8.0x53+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::mov_cmp
5899 "mov_cmp"
5900 *am33
5901 *am33_2
5902 {
5903   int srcreg1, dstreg1, dstreg2;
5904
5905   PC = cia;
5906   srcreg1 = translate_rreg (SD_, RM1);
5907   dstreg1 = translate_rreg (SD_, RN1);
5908   dstreg2 = translate_rreg (SD_, RN2);
5909
5910   genericCmp (EXTEND4 (IMM4), State.regs[dstreg2]);
5911   State.regs[dstreg1] = State.regs[srcreg1];
5912 }
5913   
5914 // 1111 0111 0110 0011 Rm1 Rn1 Rm2 Rn2; mov_mov Rm1, Rn1, Rm2, Rn2
5915 8.0xf7+8.0x63+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::mov_mov
5916 "mov_mov"
5917 *am33
5918 *am33_2
5919 {
5920   int srcreg1, srcreg2, dstreg1, dstreg2;
5921   int result1;
5922
5923   PC = cia;
5924   srcreg1 = translate_rreg (SD_, RM1);
5925   srcreg2 = translate_rreg (SD_, RM2);
5926   dstreg1 = translate_rreg (SD_, RN1);
5927   dstreg2 = translate_rreg (SD_, RN2);
5928
5929   result1 = State.regs[srcreg1];
5930   State.regs[dstreg2] = State.regs[srcreg2];
5931   State.regs[dstreg1] = result1;
5932 }
5933
5934 // 1111 0111 0111 0011 Rm1 Rn1 imm4 Rn2; mov_mov Rm1, Rn1, imm4, Rn2
5935 8.0xf7+8.0x73+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::mov_mov
5936 "mov_mov"
5937 *am33
5938 *am33_2
5939 {
5940   int srcreg1, dstreg1, dstreg2;
5941   int result1;
5942
5943   PC = cia;
5944   srcreg1 = translate_rreg (SD_, RM1);
5945   dstreg1 = translate_rreg (SD_, RN1);
5946   dstreg2 = translate_rreg (SD_, RN2);
5947
5948   result1 = State.regs[srcreg1];
5949   State.regs[dstreg2] = EXTEND4 (IMM4);
5950   State.regs[dstreg1] = result1;
5951 }
5952   
5953 // 1111 0111 1000 0011 Rm1 Rn1 Rm2 Rn2; mov_asr Rm1, Rn1, Rm2, Rn2
5954 8.0xf7+8.0x83+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::mov_asr
5955 "mov_asr"
5956 *am33
5957 *am33_2
5958 {
5959   int srcreg1, srcreg2, dstreg1, dstreg2;
5960   int result1;
5961   signed int temp;
5962
5963   PC = cia;
5964   srcreg1 = translate_rreg (SD_, RM1);
5965   srcreg2 = translate_rreg (SD_, RM2);
5966   dstreg1 = translate_rreg (SD_, RN1);
5967   dstreg2 = translate_rreg (SD_, RN2);
5968
5969   result1 = State.regs[srcreg1];
5970   temp = State.regs[dstreg2];
5971   temp >>= State.regs[srcreg2];
5972   State.regs[dstreg2] = temp;
5973   State.regs[dstreg1] = result1;
5974 }
5975
5976 // 1111 0111 1001 0011 Rm1 Rn1 imm4 Rn2; mov_asr Rm1, Rn1, imm4, Rn2
5977 8.0xf7+8.0x93+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::mov_asr
5978 "mov_asr"
5979 *am33
5980 *am33_2
5981 {
5982   int srcreg1, dstreg1, dstreg2;
5983   int result1;
5984   signed int temp;
5985
5986   PC = cia;
5987   srcreg1 = translate_rreg (SD_, RM1);
5988   dstreg1 = translate_rreg (SD_, RN1);
5989   dstreg2 = translate_rreg (SD_, RN2);
5990
5991   result1 = State.regs[srcreg1];
5992   temp = State.regs[dstreg2];
5993   temp >>= IMM4;
5994   State.regs[dstreg2] = temp;
5995   State.regs[dstreg1] = result1;
5996 }
5997   
5998 // 1111 0111 1010 0011 Rm1 Rn1 Rm2 Rn2; mov_lsr Rm1, Rn1, Rm2, Rn2
5999 8.0xf7+8.0xa3+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::mov_lsr
6000 "mov_lsr"
6001 *am33
6002 *am33_2
6003 {
6004   int srcreg1, srcreg2, dstreg1, dstreg2;
6005   int result1;
6006
6007   PC = cia;
6008   srcreg1 = translate_rreg (SD_, RM1);
6009   srcreg2 = translate_rreg (SD_, RM2);
6010   dstreg1 = translate_rreg (SD_, RN1);
6011   dstreg2 = translate_rreg (SD_, RN2);
6012
6013   result1 = State.regs[srcreg1];
6014   State.regs[dstreg2] >>= State.regs[srcreg2];
6015   State.regs[dstreg1] = result1;
6016 }
6017
6018 // 1111 0111 1011 0011 Rm1 Rn1 imm4 Rn2; mov_lsr Rm1, Rn1, imm4, Rn2
6019 8.0xf7+8.0xb3+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::mov_lsr
6020 "mov_lsr"
6021 *am33
6022 *am33_2
6023 {
6024   int srcreg1, dstreg1, dstreg2;
6025   int result1;
6026
6027   PC = cia;
6028   srcreg1 = translate_rreg (SD_, RM1);
6029   dstreg1 = translate_rreg (SD_, RN1);
6030   dstreg2 = translate_rreg (SD_, RN2);
6031
6032   result1 = State.regs[srcreg1];
6033   State.regs[dstreg2] >>= IMM4;
6034   State.regs[dstreg1] = result1;
6035 }
6036   
6037   
6038 // 1111 0111 1100 0011 Rm1 Rn1 Rm2 Rn2; mov_asl Rm1, Rn1, Rm2, Rn2
6039 8.0xf7+8.0xc3+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::mov_asl
6040 "mov_asl"
6041 *am33
6042 *am33_2
6043 {
6044   int srcreg1, srcreg2, dstreg1, dstreg2;
6045   int result1;
6046
6047   PC = cia;
6048   srcreg1 = translate_rreg (SD_, RM1);
6049   srcreg2 = translate_rreg (SD_, RM2);
6050   dstreg1 = translate_rreg (SD_, RN1);
6051   dstreg2 = translate_rreg (SD_, RN2);
6052
6053   result1 = State.regs[srcreg1];
6054   State.regs[dstreg2] <<= State.regs[srcreg2];
6055   State.regs[dstreg1] = result1;
6056 }
6057
6058 // 1111 0111 1101 0011 Rm1 Rn1 imm4 Rn2; mov_asl Rm1, Rn1, imm4, Rn2
6059 8.0xf7+8.0xd3+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::mov_asl
6060 "mov_asl"
6061 *am33
6062 *am33_2
6063 {
6064   int srcreg1, dstreg1, dstreg2;
6065   int result1;
6066
6067   PC = cia;
6068   srcreg1 = translate_rreg (SD_, RM1);
6069   dstreg1 = translate_rreg (SD_, RN1);
6070   dstreg2 = translate_rreg (SD_, RN2);
6071
6072   result1 = State.regs[srcreg1];
6073   State.regs[dstreg2] <<= IMM4;
6074   State.regs[dstreg1] = result1;
6075 }
6076   
6077 // 1111 0111 0000 0100 imm4 Rn1 Rm2 Rn2; add_add imm4, Rn1, Rm2, Rn2
6078 8.0xf7+8.0x04+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::add_add
6079 "add_add"
6080 *am33
6081 *am33_2
6082 {
6083   int srcreg2, dstreg1, dstreg2;
6084   int result1;
6085
6086   PC = cia;
6087   srcreg2 = translate_rreg (SD_, RM2);
6088   dstreg1 = translate_rreg (SD_, RN1);
6089   dstreg2 = translate_rreg (SD_, RN2);
6090
6091   result1 = State.regs[dstreg1] + EXTEND4 (IMM4A);
6092   State.regs[dstreg2] += State.regs[srcreg2];
6093   State.regs[dstreg1] = result1;
6094 }
6095
6096 // 1111 0111 0001 0100 imm4 Rn1 imm4 Rn2; add_add imm4, Rn1, imm4, Rn2
6097 8.0xf7+8.0x14+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::add_add
6098 "add_add"
6099 *am33
6100 *am33_2
6101 {
6102   int dstreg1, dstreg2;
6103   int result1;
6104
6105   PC = cia;
6106   dstreg1 = translate_rreg (SD_, RN1);
6107   dstreg2 = translate_rreg (SD_, RN2);
6108
6109   result1 = State.regs[dstreg1] + EXTEND4 (IMM4A);
6110   State.regs[dstreg2] += EXTEND4 (IMM4);
6111   State.regs[dstreg1] = result1;
6112 }
6113   
6114 // 1111 0111 0010 0100 imm4 Rn1 Rm2 Rn2; add_sub imm4, Rn1, Rm2, Rn2
6115 8.0xf7+8.0x24+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::add_sub
6116 "add_sub"
6117 *am33
6118 *am33_2
6119 {
6120   int srcreg2, dstreg1, dstreg2;
6121   int result1;
6122
6123   PC = cia;
6124   srcreg2 = translate_rreg (SD_, RM2);
6125   dstreg1 = translate_rreg (SD_, RN1);
6126   dstreg2 = translate_rreg (SD_, RN2);
6127
6128   result1 = State.regs[dstreg1] + EXTEND4 (IMM4A);
6129   State.regs[dstreg2] -= State.regs[srcreg2];
6130   State.regs[dstreg1] = result1;
6131 }
6132
6133 // 1111 0111 0011 0100 imm4 Rn1 imm4 Rn2; add_sub imm4, Rn1, imm4, Rn2
6134 8.0xf7+8.0x34+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::add_sub
6135 "add_sub"
6136 *am33
6137 *am33_2
6138 {
6139   int dstreg1, dstreg2;
6140   int result1;
6141
6142   PC = cia;
6143   dstreg1 = translate_rreg (SD_, RN1);
6144   dstreg2 = translate_rreg (SD_, RN2);
6145
6146   result1 = State.regs[dstreg1] + EXTEND4 (IMM4A);
6147   State.regs[dstreg2] -= EXTEND4 (IMM4);
6148   State.regs[dstreg1] = result1;
6149 }
6150   
6151 // 1111 0111 0100 0100 imm4 Rn1 Rm2 Rn2; add_cmp imm4, Rn1, Rm2, Rn2
6152 8.0xf7+8.0x44+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::add_cmp
6153 "add_cmp"
6154 *am33
6155 *am33_2
6156 {
6157   int srcreg2, dstreg1, dstreg2;
6158
6159   PC = cia;
6160   srcreg2 = translate_rreg (SD_, RM2);
6161   dstreg1 = translate_rreg (SD_, RN1);
6162   dstreg2 = translate_rreg (SD_, RN2);
6163
6164   genericCmp (State.regs[srcreg2], State.regs[dstreg2]);
6165   State.regs[dstreg1] += EXTEND4 (IMM4A);
6166 }
6167
6168 // 1111 0111 0101 0100 imm4 Rn1 imm4 Rn2; add_cmp imm4, Rn1, imm4, Rn2
6169 8.0xf7+8.0x54+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::add_cmp
6170 "add_cmp"
6171 *am33
6172 *am33_2
6173 {
6174   int dstreg1, dstreg2;
6175
6176   PC = cia;
6177   dstreg1 = translate_rreg (SD_, RN1);
6178   dstreg2 = translate_rreg (SD_, RN2);
6179
6180   genericCmp (EXTEND4 (IMM4), State.regs[dstreg2]);
6181   State.regs[dstreg1] += EXTEND4 (IMM4A);
6182 }
6183   
6184 // 1111 0111 0110 0100 imm4 Rn1 Rm2 Rn2; add_mov imm4, Rn1, Rm2, Rn2
6185 8.0xf7+8.0x64+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::add_mov
6186 "add_mov"
6187 *am33
6188 *am33_2
6189 {
6190   int srcreg2, dstreg1, dstreg2;
6191   int result1;
6192
6193   PC = cia;
6194   srcreg2 = translate_rreg (SD_, RM2);
6195   dstreg1 = translate_rreg (SD_, RN1);
6196   dstreg2 = translate_rreg (SD_, RN2);
6197
6198   result1 = State.regs[dstreg1] + EXTEND4 (IMM4A);
6199   State.regs[dstreg2] = State.regs[srcreg2];
6200   State.regs[dstreg1] = result1;
6201 }
6202
6203 // 1111 0111 0111 0100 imm4 Rn1 imm4 Rn2; add_mov imm4, Rn1, imm4, Rn2
6204 8.0xf7+8.0x74+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::add_mov
6205 "add_mov"
6206 *am33
6207 *am33_2
6208 {
6209   int dstreg1, dstreg2;
6210   int result1;
6211
6212   PC = cia;
6213   dstreg1 = translate_rreg (SD_, RN1);
6214   dstreg2 = translate_rreg (SD_, RN2);
6215
6216   result1 = State.regs[dstreg1] + EXTEND4 (IMM4A);
6217   State.regs[dstreg2] = EXTEND4 (IMM4);
6218   State.regs[dstreg1] = result1;
6219 }
6220   
6221 // 1111 0111 1000 0100 imm4 Rn1 Rm2 Rn2; add_asr imm4, Rn1, Rm2, Rn2
6222 8.0xf7+8.0x84+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::add_asr
6223 "add_asr"
6224 *am33
6225 *am33_2
6226 {
6227   int srcreg2, dstreg1, dstreg2;
6228   int result1;
6229   signed int temp;
6230
6231   PC = cia;
6232   srcreg2 = translate_rreg (SD_, RM2);
6233   dstreg1 = translate_rreg (SD_, RN1);
6234   dstreg2 = translate_rreg (SD_, RN2);
6235
6236   result1 = State.regs[dstreg1] + EXTEND4 (IMM4A);
6237   temp = State.regs[dstreg2];
6238   temp >>= State.regs[srcreg2];
6239   State.regs[dstreg2] = temp;
6240   State.regs[dstreg1] = result1;
6241 }
6242
6243 // 1111 0111 1001 0100 imm4 Rn1 imm4 Rn2; add_asr imm4, Rn1, imm4, Rn2
6244 8.0xf7+8.0x94+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::add_asr
6245 "add_asr"
6246 *am33
6247 *am33_2
6248 {
6249   int dstreg1, dstreg2;
6250   int result1;
6251   signed int temp;
6252
6253   PC = cia;
6254   dstreg1 = translate_rreg (SD_, RN1);
6255   dstreg2 = translate_rreg (SD_, RN2);
6256
6257   result1 = State.regs[dstreg1] + EXTEND4 (IMM4A);
6258   temp = State.regs[dstreg2];
6259   temp >>= IMM4;
6260   State.regs[dstreg2] = temp;
6261   State.regs[dstreg1] = result1;
6262 }
6263   
6264 // 1111 0111 1010 0100 imm4 Rn1 Rm2 Rn2; add_lsr imm4, Rn1, Rm2, Rn2
6265 8.0xf7+8.0xa4+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::add_lsr
6266 "add_lsr"
6267 *am33
6268 *am33_2
6269 {
6270   int srcreg2, dstreg1, dstreg2;
6271   int result1;
6272
6273   PC = cia;
6274   srcreg2 = translate_rreg (SD_, RM2);
6275   dstreg1 = translate_rreg (SD_, RN1);
6276   dstreg2 = translate_rreg (SD_, RN2);
6277
6278   result1 = State.regs[dstreg1] + EXTEND4 (IMM4A);
6279   State.regs[dstreg2] >>= State.regs[srcreg2];
6280   State.regs[dstreg1] = result1;
6281 }
6282
6283 // 1111 0111 1011 0100 imm4 Rn1 imm4 Rn2; add_lsr imm4, Rn1, imm4, Rn2
6284 8.0xf7+8.0xb4+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::add_lsr
6285 "add_lsr"
6286 *am33
6287 *am33_2
6288 {
6289   int dstreg1, dstreg2;
6290   int result1;
6291
6292   PC = cia;
6293   dstreg1 = translate_rreg (SD_, RN1);
6294   dstreg2 = translate_rreg (SD_, RN2);
6295
6296   result1 = State.regs[dstreg1] + EXTEND4 (IMM4A);
6297   State.regs[dstreg2] >>= IMM4;
6298   State.regs[dstreg1] = result1;
6299 }
6300   
6301   
6302 // 1111 0111 1100 0100 imm4 Rn1 Rm2 Rn2; add_asl imm4, Rn1, Rm2, Rn2
6303 8.0xf7+8.0xc4+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::add_asl
6304 "add_asl"
6305 *am33
6306 *am33_2
6307 {
6308   int srcreg2, dstreg1, dstreg2;
6309   int result1;
6310
6311   PC = cia;
6312   srcreg2 = translate_rreg (SD_, RM2);
6313   dstreg1 = translate_rreg (SD_, RN1);
6314   dstreg2 = translate_rreg (SD_, RN2);
6315
6316   result1 = State.regs[dstreg1] + EXTEND4 (IMM4A);
6317   State.regs[dstreg2] <<= State.regs[srcreg2];
6318   State.regs[dstreg1] = result1;
6319 }
6320
6321 // 1111 0111 1101 0100 imm4 Rn1 imm4 Rn2; add_asl imm4, Rn1, imm4, Rn2
6322 8.0xf7+8.0xd4+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::add_asl
6323 "add_asl"
6324 *am33
6325 *am33_2
6326 {
6327   int dstreg1, dstreg2;
6328   int result1;
6329
6330   PC = cia;
6331   dstreg1 = translate_rreg (SD_, RN1);
6332   dstreg2 = translate_rreg (SD_, RN2);
6333
6334   result1 = State.regs[dstreg1] + EXTEND4 (IMM4A);
6335   State.regs[dstreg2] <<= IMM4;
6336   State.regs[dstreg1] = result1;
6337 }
6338   
6339 // 1111 0111 0000 0101 imm4 Rn1 Rm2 Rn2; cmp_add imm4, Rn1, Rm2, Rn2
6340 8.0xf7+8.0x05+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::cmp_add
6341 "cmp_add"
6342 *am33
6343 *am33_2
6344 {
6345   int srcreg2, dstreg1, dstreg2;
6346
6347   PC = cia;
6348   srcreg2 = translate_rreg (SD_, RM2);
6349   dstreg1 = translate_rreg (SD_, RN1);
6350   dstreg2 = translate_rreg (SD_, RN2);
6351
6352   genericCmp (EXTEND4 (IMM4A), State.regs[dstreg1]);
6353   State.regs[dstreg2] += State.regs[srcreg2];
6354 }
6355
6356 // 1111 0111 0001 0101 imm4 Rn1 imm4 Rn2; cmp_add imm4, Rn1, imm4, Rn2
6357 8.0xf7+8.0x15+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::cmp_add
6358 "cmp_add"
6359 *am33
6360 *am33_2
6361 {
6362   int dstreg1, dstreg2;
6363
6364   PC = cia;
6365   dstreg1 = translate_rreg (SD_, RN1);
6366   dstreg2 = translate_rreg (SD_, RN2);
6367
6368   genericCmp (EXTEND4 (IMM4A), State.regs[dstreg1]);
6369   State.regs[dstreg2] += EXTEND4 (IMM4);
6370 }
6371   
6372 // 1111 0111 0010 0101 imm4 Rn1 Rm2 Rn2; cmp_sub imm4, Rn1, Rm2, Rn2
6373 8.0xf7+8.0x25+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::cmp_sub
6374 "cmp_sub"
6375 *am33
6376 *am33_2
6377 {
6378   int srcreg2, dstreg1, dstreg2;
6379
6380   PC = cia;
6381   srcreg2 = translate_rreg (SD_, RM2);
6382   dstreg1 = translate_rreg (SD_, RN1);
6383   dstreg2 = translate_rreg (SD_, RN2);
6384
6385   genericCmp (EXTEND4 (IMM4A), State.regs[dstreg1]);
6386   State.regs[dstreg2] -= State.regs[srcreg2];
6387 }
6388
6389 // 1111 0111 0011 0101 imm4 Rn1 imm4 Rn2; cmp_sub imm4, Rn1, imm4, Rn2
6390 8.0xf7+8.0x35+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::cmp_sub
6391 "cmp_sub"
6392 *am33
6393 *am33_2
6394 {
6395   int dstreg1, dstreg2;
6396
6397   PC = cia;
6398   dstreg1 = translate_rreg (SD_, RN1);
6399   dstreg2 = translate_rreg (SD_, RN2);
6400
6401   genericCmp (EXTEND4 (IMM4A), State.regs[dstreg1]);
6402   State.regs[dstreg2] -= EXTEND4 (IMM4);
6403 }
6404   
6405 // 1111 0111 0110 0101 imm4 Rn1 Rm2 Rn2; cmp_mov imm4, Rn1, Rm2, Rn2
6406 8.0xf7+8.0x65+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::cmp_mov
6407 "cmp_mov"
6408 *am33
6409 *am33_2
6410 {
6411   int srcreg2, dstreg1, dstreg2;
6412
6413   PC = cia;
6414   srcreg2 = translate_rreg (SD_, RM2);
6415   dstreg1 = translate_rreg (SD_, RN1);
6416   dstreg2 = translate_rreg (SD_, RN2);
6417
6418   genericCmp (EXTEND4 (IMM4A), State.regs[dstreg1]);
6419   State.regs[dstreg2] = State.regs[srcreg2];
6420 }
6421
6422 // 1111 0111 0111 0101 imm4 Rn1 imm4 Rn2; cmp_mov imm4, Rn1, imm4, Rn2
6423 8.0xf7+8.0x75+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::cmp_mov
6424 "cmp_mov"
6425 *am33
6426 *am33_2
6427 {
6428   int dstreg1, dstreg2;
6429
6430   PC = cia;
6431   dstreg1 = translate_rreg (SD_, RN1);
6432   dstreg2 = translate_rreg (SD_, RN2);
6433
6434   genericCmp (EXTEND4 (IMM4A), State.regs[dstreg1]);
6435   State.regs[dstreg2] = EXTEND4 (IMM4);
6436 }
6437   
6438 // 1111 0111 1000 0101 imm4 Rn1 Rm2 Rn2; cmp_asr imm4, Rn1, Rm2, Rn2
6439 8.0xf7+8.0x85+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::cmp_asr
6440 "cmp_asr"
6441 *am33
6442 *am33_2
6443 {
6444   int srcreg2, dstreg1, dstreg2;
6445   signed int temp;
6446
6447   PC = cia;
6448   srcreg2 = translate_rreg (SD_, RM2);
6449   dstreg1 = translate_rreg (SD_, RN1);
6450   dstreg2 = translate_rreg (SD_, RN2);
6451
6452   genericCmp (EXTEND4 (IMM4A), State.regs[dstreg1]);
6453   temp = State.regs[dstreg2];
6454   temp >>= State.regs[srcreg2];
6455   State.regs[dstreg2] = temp;
6456 }
6457
6458 // 1111 0111 1001 0101 imm4 Rn1 imm4 Rn2; cmp_asr imm4, Rn1, imm4, Rn2
6459 8.0xf7+8.0x95+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::cmp_asr
6460 "cmp_asr"
6461 *am33
6462 *am33_2
6463 {
6464   int dstreg1, dstreg2;
6465   signed int temp;
6466
6467   PC = cia;
6468   dstreg1 = translate_rreg (SD_, RN1);
6469   dstreg2 = translate_rreg (SD_, RN2);
6470
6471   genericCmp (EXTEND4 (IMM4A), State.regs[dstreg1]);
6472   temp = State.regs[dstreg2];
6473   temp >>= IMM4;
6474   State.regs[dstreg2] = temp;
6475 }
6476   
6477 // 1111 0111 1010 0101 imm4 Rn1 Rm2 Rn2; cmp_lsr imm4, Rn1, Rm2, Rn2
6478 8.0xf7+8.0xa5+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::cmp_lsr
6479 "cmp_lsr"
6480 *am33
6481 *am33_2
6482 {
6483   int srcreg2, dstreg1, dstreg2;
6484
6485   PC = cia;
6486   srcreg2 = translate_rreg (SD_, RM2);
6487   dstreg1 = translate_rreg (SD_, RN1);
6488   dstreg2 = translate_rreg (SD_, RN2);
6489
6490   genericCmp (EXTEND4 (IMM4A), State.regs[dstreg1]);
6491   State.regs[dstreg2] >>= State.regs[srcreg2];
6492 }
6493
6494 // 1111 0111 1011 0101 imm4 Rn1 imm4 Rn2; cmp_lsr imm4, Rn1, imm4, Rn2
6495 8.0xf7+8.0xb5+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::cmp_lsr
6496 "cmp_lsr"
6497 *am33
6498 *am33_2
6499 {
6500   int dstreg1, dstreg2;
6501
6502   PC = cia;
6503   dstreg1 = translate_rreg (SD_, RN1);
6504   dstreg2 = translate_rreg (SD_, RN2);
6505
6506   genericCmp (EXTEND4 (IMM4A), State.regs[dstreg1]);
6507   State.regs[dstreg2] >>= IMM4;
6508 }
6509   
6510   
6511 // 1111 0111 1100 0101 imm4 Rn1 Rm2 Rn2; cmp_asl imm4, Rn1, Rm2, Rn2
6512 8.0xf7+8.0xc5+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::cmp_asl
6513 "cmp_asl"
6514 *am33
6515 *am33_2
6516 {
6517   int srcreg2, dstreg1, dstreg2;
6518
6519   PC = cia;
6520   srcreg2 = translate_rreg (SD_, RM2);
6521   dstreg1 = translate_rreg (SD_, RN1);
6522   dstreg2 = translate_rreg (SD_, RN2);
6523
6524   genericCmp (EXTEND4 (IMM4A), State.regs[dstreg1]);
6525   State.regs[dstreg2] <<= State.regs[srcreg2];
6526 }
6527
6528 // 1111 0111 1101 0101 imm4 Rn1 imm4 Rn2; cmp_asl imm4, Rn1, imm4, Rn2
6529 8.0xf7+8.0xd5+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::cmp_asl
6530 "cmp_asl"
6531 *am33
6532 *am33_2
6533 {
6534   int dstreg1, dstreg2;
6535
6536   PC = cia;
6537   dstreg1 = translate_rreg (SD_, RN1);
6538   dstreg2 = translate_rreg (SD_, RN2);
6539
6540   genericCmp (EXTEND4 (IMM4A), State.regs[dstreg1]);
6541   State.regs[dstreg2] <<= IMM4;
6542 }
6543
6544 // 1111 0111 0000 0110 imm4 Rn1 Rm2 Rn2; sub_add imm4, Rn1, Rm2, Rn2
6545 8.0xf7+8.0x06+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::sub_add
6546 "sub_add"
6547 *am33
6548 *am33_2
6549 {
6550   int srcreg2, dstreg1, dstreg2;
6551   int result1;
6552
6553   PC = cia;
6554   srcreg2 = translate_rreg (SD_, RM2);
6555   dstreg1 = translate_rreg (SD_, RN1);
6556   dstreg2 = translate_rreg (SD_, RN2);
6557
6558   result1 = State.regs[dstreg1] - EXTEND4 (IMM4A);
6559   State.regs[dstreg2] += State.regs[srcreg2];
6560   State.regs[dstreg1] = result1;
6561 }
6562
6563 // 1111 0111 0001 0110 imm4 Rn1 imm4 Rn2; sub_add imm4, Rn1, imm4, Rn2
6564 8.0xf7+8.0x16+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::sub_add
6565 "sub_add"
6566 *am33
6567 *am33_2
6568 {
6569   int dstreg1, dstreg2;
6570   int result1;
6571
6572   PC = cia;
6573   dstreg1 = translate_rreg (SD_, RN1);
6574   dstreg2 = translate_rreg (SD_, RN2);
6575
6576   result1 = State.regs[dstreg1] - EXTEND4 (IMM4A);
6577   State.regs[dstreg2] += EXTEND4 (IMM4);
6578   State.regs[dstreg1] = result1;
6579 }
6580   
6581 // 1111 0111 0010 0110 imm4 Rn1 Rm2 Rn2; sub_sub imm4, Rn1, Rm2, Rn2
6582 8.0xf7+8.0x26+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::sub_sub
6583 "sub_sub"
6584 *am33
6585 *am33_2
6586 {
6587   int srcreg2, dstreg1, dstreg2;
6588   int result1;
6589
6590   PC = cia;
6591   srcreg2 = translate_rreg (SD_, RM2);
6592   dstreg1 = translate_rreg (SD_, RN1);
6593   dstreg2 = translate_rreg (SD_, RN2);
6594
6595   result1 = State.regs[dstreg1] - EXTEND4 (IMM4A);
6596   State.regs[dstreg2] -= State.regs[srcreg2];
6597   State.regs[dstreg1] = result1;
6598 }
6599
6600 // 1111 0111 0011 0110 imm4 Rn1 imm4 Rn2; sub_sub imm4, Rn1, imm4, Rn2
6601 8.0xf7+8.0x36+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::sub_sub
6602 "sub_sub"
6603 *am33
6604 *am33_2
6605 {
6606   int dstreg1, dstreg2;
6607   int result1;
6608
6609   PC = cia;
6610   dstreg1 = translate_rreg (SD_, RN1);
6611   dstreg2 = translate_rreg (SD_, RN2);
6612
6613   result1 = State.regs[dstreg1] - EXTEND4 (IMM4A);
6614   State.regs[dstreg2] -= EXTEND4 (IMM4);
6615   State.regs[dstreg1] = result1;
6616 }
6617   
6618 // 1111 0111 0100 0110 imm4 Rn1 Rm2 Rn2; sub_cmp imm4, Rn1, Rm2, Rn2
6619 8.0xf7+8.0x46+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::sub_cmp
6620 "sub_cmp"
6621 *am33
6622 *am33_2
6623 {
6624   int srcreg2, dstreg1, dstreg2;
6625
6626   PC = cia;
6627   srcreg2 = translate_rreg (SD_, RM2);
6628   dstreg1 = translate_rreg (SD_, RN1);
6629   dstreg2 = translate_rreg (SD_, RN2);
6630
6631   genericCmp (State.regs[srcreg2], State.regs[dstreg2]);
6632   State.regs[dstreg1] -= EXTEND4 (IMM4A);
6633 }
6634
6635 // 1111 0111 0101 0110 imm4 Rn1 imm4 Rn2; sub_cmp imm4, Rn1, imm4, Rn2
6636 8.0xf7+8.0x56+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::sub_cmp
6637 "sub_cmp"
6638 *am33
6639 *am33_2
6640 {
6641   int dstreg1, dstreg2;
6642
6643   PC = cia;
6644   dstreg1 = translate_rreg (SD_, RN1);
6645   dstreg2 = translate_rreg (SD_, RN2);
6646
6647   genericCmp (EXTEND4 (IMM4), State.regs[dstreg2]);
6648   State.regs[dstreg1] -= EXTEND4 (IMM4A);
6649 }
6650   
6651 // 1111 0111 0110 0110 imm4 Rn1 Rm2 Rn2; sub_mov imm4, Rn1, Rm2, Rn2
6652 8.0xf7+8.0x66+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::sub_mov
6653 "sub_mov"
6654 *am33
6655 *am33_2
6656 {
6657   int srcreg2, dstreg1, dstreg2;
6658   int result1;
6659
6660   PC = cia;
6661   srcreg2 = translate_rreg (SD_, RM2);
6662   dstreg1 = translate_rreg (SD_, RN1);
6663   dstreg2 = translate_rreg (SD_, RN2);
6664
6665   result1 = State.regs[dstreg1] - EXTEND4 (IMM4A);
6666   State.regs[dstreg2] = State.regs[srcreg2];
6667   State.regs[dstreg1] = result1;
6668 }
6669
6670 // 1111 0111 0111 0110 imm4 Rn1 imm4 Rn2; sub_mov imm4, Rn1, imm4, Rn2
6671 8.0xf7+8.0x76+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::sub_mov
6672 "sub_mov"
6673 *am33
6674 *am33_2
6675 {
6676   int dstreg1, dstreg2;
6677   int result1;
6678
6679   PC = cia;
6680   dstreg1 = translate_rreg (SD_, RN1);
6681   dstreg2 = translate_rreg (SD_, RN2);
6682
6683   result1 = State.regs[dstreg1] - EXTEND4 (IMM4A);
6684   State.regs[dstreg2] = EXTEND4 (IMM4);
6685   State.regs[dstreg1] = result1;
6686 }
6687   
6688 // 1111 0111 1000 0110 imm4 Rn1 Rm2 Rn2; sub_asr imm4, Rn1, Rm2, Rn2
6689 8.0xf7+8.0x86+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::sub_asr
6690 "sub_asr"
6691 *am33
6692 *am33_2
6693 {
6694   int srcreg2, dstreg1, dstreg2;
6695   int result1;
6696   signed int temp;
6697
6698   PC = cia;
6699   srcreg2 = translate_rreg (SD_, RM2);
6700   dstreg1 = translate_rreg (SD_, RN1);
6701   dstreg2 = translate_rreg (SD_, RN2);
6702
6703   result1 = State.regs[dstreg1] - EXTEND4 (IMM4A);
6704   temp = State.regs[dstreg2];
6705   temp >>= State.regs[srcreg2];
6706   State.regs[dstreg2] = temp;
6707   State.regs[dstreg1] = result1;
6708 }
6709
6710 // 1111 0111 1001 0110 imm4 Rn1 imm4 Rn2; sub_asr imm4, Rn1, imm4, Rn2
6711 8.0xf7+8.0x96+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::sub_asr
6712 "sub_asr"
6713 *am33
6714 *am33_2
6715 {
6716   int dstreg1, dstreg2;
6717   int result1;
6718   signed int temp;
6719
6720   PC = cia;
6721   dstreg1 = translate_rreg (SD_, RN1);
6722   dstreg2 = translate_rreg (SD_, RN2);
6723
6724   result1 = State.regs[dstreg1] - EXTEND4 (IMM4A);
6725   temp = State.regs[dstreg2];
6726   temp >>= IMM4;
6727   State.regs[dstreg2] = temp;
6728   State.regs[dstreg1] = result1;
6729 }
6730   
6731 // 1111 0111 1010 0110 imm4 Rn1 Rm2 Rn2; sub_lsr imm4, Rn1, Rm2, Rn2
6732 8.0xf7+8.0xa6+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::sub_lsr
6733 "sub_lsr"
6734 *am33
6735 *am33_2
6736 {
6737   int srcreg2, dstreg1, dstreg2;
6738   int result1;
6739
6740   PC = cia;
6741   srcreg2 = translate_rreg (SD_, RM2);
6742   dstreg1 = translate_rreg (SD_, RN1);
6743   dstreg2 = translate_rreg (SD_, RN2);
6744
6745   result1 = State.regs[dstreg1] - EXTEND4 (IMM4A);
6746   State.regs[dstreg2] >>= State.regs[srcreg2];
6747   State.regs[dstreg1] = result1;
6748 }
6749
6750 // 1111 0111 1011 0110 imm4 Rn1 imm4 Rn2; sub_lsr imm4, Rn1, imm4, Rn2
6751 8.0xf7+8.0xb6+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::sub_lsr
6752 "sub_lsr"
6753 *am33
6754 *am33_2
6755 {
6756   int dstreg1, dstreg2;
6757   int result1;
6758
6759   PC = cia;
6760   dstreg1 = translate_rreg (SD_, RN1);
6761   dstreg2 = translate_rreg (SD_, RN2);
6762
6763   result1 = State.regs[dstreg1] - EXTEND4 (IMM4A);
6764   State.regs[dstreg2] >>= IMM4;
6765   State.regs[dstreg1] = result1;
6766 }
6767   
6768   
6769 // 1111 0111 1100 0110 imm4 Rn1 Rm2 Rn2; sub_asl imm4, Rn1, Rm2, Rn2
6770 8.0xf7+8.0xc6+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::sub_asl
6771 "sub_asl"
6772 *am33
6773 *am33_2
6774 {
6775   int srcreg2, dstreg1, dstreg2;
6776   int result1;
6777
6778   PC = cia;
6779   srcreg2 = translate_rreg (SD_, RM2);
6780   dstreg1 = translate_rreg (SD_, RN1);
6781   dstreg2 = translate_rreg (SD_, RN2);
6782
6783   result1 = State.regs[dstreg1] - EXTEND4 (IMM4A);
6784   State.regs[dstreg2] <<= State.regs[srcreg2];
6785   State.regs[dstreg1] = result1;
6786 }
6787
6788 // 1111 0111 1101 0110 imm4 Rn1 imm4 Rn2; sub_asl imm4, Rn1, imm4, Rn2
6789 8.0xf7+8.0xd6+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::sub_asl
6790 "sub_asl"
6791 *am33
6792 *am33_2
6793 {
6794   int dstreg1, dstreg2;
6795   int result1;
6796
6797   PC = cia;
6798   dstreg1 = translate_rreg (SD_, RN1);
6799   dstreg2 = translate_rreg (SD_, RN2);
6800
6801   result1 = State.regs[dstreg1] - EXTEND4 (IMM4A);
6802   State.regs[dstreg2] <<= IMM4;
6803   State.regs[dstreg1] = result1;
6804 }
6805   
6806 // 1111 0111 0000 0111 imm4 Rn1 Rm2 Rn2; mov_add imm4, Rn1, Rm2, Rn2
6807 8.0xf7+8.0x07+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::mov_add
6808 "mov_add"
6809 *am33
6810 *am33_2
6811 {
6812   int srcreg2, dstreg1, dstreg2;
6813   int result1;
6814
6815   PC = cia;
6816   srcreg2 = translate_rreg (SD_, RM2);
6817   dstreg1 = translate_rreg (SD_, RN1);
6818   dstreg2 = translate_rreg (SD_, RN2);
6819
6820   result1 = EXTEND4 (IMM4A);
6821   State.regs[dstreg2] += State.regs[srcreg2];
6822   State.regs[dstreg1] = result1;
6823 }
6824
6825 // 1111 0111 0001 0111 imm4 Rn1 imm4 Rn2; mov_add imm4, Rn1, imm4, Rn2
6826 8.0xf7+8.0x17+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::mov_add
6827 "mov_add"
6828 *am33
6829 *am33_2
6830 {
6831   int dstreg1, dstreg2;
6832   int result1;
6833
6834   PC = cia;
6835   dstreg1 = translate_rreg (SD_, RN1);
6836   dstreg2 = translate_rreg (SD_, RN2);
6837
6838   result1 = EXTEND4 (IMM4A);
6839   State.regs[dstreg2] += EXTEND4 (IMM4);
6840   State.regs[dstreg1] = result1;
6841 }
6842   
6843 // 1111 0111 0010 0111 imm4 Rn1 Rm2 Rn2; mov_sub imm4, Rn1, Rm2, Rn2
6844 8.0xf7+8.0x27+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::mov_sub
6845 "mov_sub"
6846 *am33
6847 *am33_2
6848 {
6849   int srcreg2, dstreg1, dstreg2;
6850   int result1;
6851
6852   PC = cia;
6853   srcreg2 = translate_rreg (SD_, RM2);
6854   dstreg1 = translate_rreg (SD_, RN1);
6855   dstreg2 = translate_rreg (SD_, RN2);
6856
6857   result1 = EXTEND4 (IMM4A);
6858   State.regs[dstreg2] -= State.regs[srcreg2];
6859   State.regs[dstreg1] = result1;
6860 }
6861
6862 // 1111 0111 0011 0111 imm4 Rn1 imm4 Rn2; mov_sub imm4, Rn1, imm4, Rn2
6863 8.0xf7+8.0x37+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::mov_sub
6864 "mov_sub"
6865 *am33
6866 *am33_2
6867 {
6868   int dstreg1, dstreg2;
6869   int result1;
6870
6871   PC = cia;
6872   dstreg1 = translate_rreg (SD_, RN1);
6873   dstreg2 = translate_rreg (SD_, RN2);
6874
6875   result1 = EXTEND4 (IMM4A);
6876   State.regs[dstreg2] -= EXTEND4 (IMM4);
6877   State.regs[dstreg1] = result1;
6878 }
6879   
6880 // 1111 0111 0100 0111 imm4 Rn1 Rm2 Rn2; mov_cmp imm4, Rn1, Rm2, Rn2
6881 8.0xf7+8.0x47+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::mov_cmp
6882 "mov_cmp"
6883 *am33
6884 *am33_2
6885 {
6886   int srcreg2, dstreg1, dstreg2;
6887
6888   PC = cia;
6889   srcreg2 = translate_rreg (SD_, RM2);
6890   dstreg1 = translate_rreg (SD_, RN1);
6891   dstreg2 = translate_rreg (SD_, RN2);
6892
6893   genericCmp (State.regs[srcreg2], State.regs[dstreg2]);
6894   State.regs[dstreg1] = EXTEND4 (IMM4A);
6895 }
6896
6897 // 1111 0111 0101 0111 imm4 Rn1 imm4 Rn2; mov_cmp imm4, Rn1, imm4, Rn2
6898 8.0xf7+8.0x57+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::mov_cmp
6899 "mov_cmp"
6900 *am33
6901 *am33_2
6902 {
6903   int dstreg1, dstreg2;
6904
6905   PC = cia;
6906   dstreg1 = translate_rreg (SD_, RN1);
6907   dstreg2 = translate_rreg (SD_, RN2);
6908
6909   genericCmp (EXTEND4 (IMM4), State.regs[dstreg2]);
6910   State.regs[dstreg1] = EXTEND4 (IMM4A);
6911 }
6912   
6913 // 1111 0111 0110 0111 imm4 Rn1 Rm2 Rn2; mov_mov imm4, Rn1, Rm2, Rn2
6914 8.0xf7+8.0x67+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::mov_mov
6915 "mov_mov"
6916 *am33
6917 *am33_2
6918 {
6919   int srcreg2, dstreg1, dstreg2;
6920   int result1;
6921
6922   PC = cia;
6923   srcreg2 = translate_rreg (SD_, RM2);
6924   dstreg1 = translate_rreg (SD_, RN1);
6925   dstreg2 = translate_rreg (SD_, RN2);
6926
6927   result1 = EXTEND4 (IMM4A);
6928   State.regs[dstreg2] = State.regs[srcreg2];
6929   State.regs[dstreg1] = result1;
6930 }
6931
6932 // 1111 0111 0111 0111 imm4 Rn1 imm4 Rn2; mov_mov imm4, Rn1, imm4, Rn2
6933 8.0xf7+8.0x77+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::mov_mov
6934 "mov_mov"
6935 *am33
6936 *am33_2
6937 {
6938   int dstreg1, dstreg2;
6939   int result1;
6940
6941   PC = cia;
6942   dstreg1 = translate_rreg (SD_, RN1);
6943   dstreg2 = translate_rreg (SD_, RN2);
6944
6945   result1 = EXTEND4 (IMM4A);
6946   State.regs[dstreg2] = EXTEND4 (IMM4);
6947   State.regs[dstreg1] = result1;
6948 }
6949   
6950 // 1111 0111 1000 0111 imm4 Rn1 Rm2 Rn2; mov_asr imm4, Rn1, Rm2, Rn2
6951 8.0xf7+8.0x87+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::mov_asr
6952 "mov_asr"
6953 *am33
6954 *am33_2
6955 {
6956   int srcreg2, dstreg1, dstreg2;
6957   int result1;
6958   signed int temp;
6959
6960   PC = cia;
6961   srcreg2 = translate_rreg (SD_, RM2);
6962   dstreg1 = translate_rreg (SD_, RN1);
6963   dstreg2 = translate_rreg (SD_, RN2);
6964
6965   result1 = EXTEND4 (IMM4A);
6966   temp = State.regs[dstreg2];
6967   temp >>= State.regs[srcreg2];
6968   State.regs[dstreg2] = temp;
6969   State.regs[dstreg1] = result1;
6970 }
6971
6972 // 1111 0111 1001 0111 imm4 Rn1 imm4 Rn2; mov_asr imm4, Rn1, imm4, Rn2
6973 8.0xf7+8.0x97+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::mov_asr
6974 "mov_asr"
6975 *am33
6976 *am33_2
6977 {
6978   int dstreg1, dstreg2;
6979   int result1;
6980   signed int temp;
6981
6982   PC = cia;
6983   dstreg1 = translate_rreg (SD_, RN1);
6984   dstreg2 = translate_rreg (SD_, RN2);
6985
6986   result1 = EXTEND4 (IMM4A);
6987   temp = State.regs[dstreg2];
6988   temp >>= IMM4;
6989   State.regs[dstreg2] = temp;
6990   State.regs[dstreg1] = result1;
6991 }
6992   
6993 // 1111 0111 1010 0111 imm4 Rn1 Rm2 Rn2; mov_lsr imm4, Rn1, Rm2, Rn2
6994 8.0xf7+8.0xa7+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::mov_lsr
6995 "mov_lsr"
6996 *am33
6997 *am33_2
6998 {
6999   int srcreg2, dstreg1, dstreg2;
7000   int result1;
7001
7002   PC = cia;
7003   srcreg2 = translate_rreg (SD_, RM2);
7004   dstreg1 = translate_rreg (SD_, RN1);
7005   dstreg2 = translate_rreg (SD_, RN2);
7006
7007   result1 = EXTEND4 (IMM4A);
7008   State.regs[dstreg2] >>= State.regs[srcreg2];
7009   State.regs[dstreg1] = result1;
7010 }
7011
7012 // 1111 0111 1011 0111 imm4 Rn1 imm4 Rn2; mov_lsr imm4, Rn1, imm4, Rn2
7013 8.0xf7+8.0xb7+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::mov_lsr
7014 "mov_lsr"
7015 *am33
7016 *am33_2
7017 {
7018   int dstreg1, dstreg2;
7019   int result1;
7020
7021   PC = cia;
7022   dstreg1 = translate_rreg (SD_, RN1);
7023   dstreg2 = translate_rreg (SD_, RN2);
7024
7025   result1 = EXTEND4 (IMM4A);
7026   State.regs[dstreg2] >>= IMM4;
7027   State.regs[dstreg1] = result1;
7028 }
7029   
7030   
7031 // 1111 0111 1100 0111 imm4 Rn1 Rm2 Rn2; mov_asl imm4, Rn1, Rm2, Rn2
7032 8.0xf7+8.0xc7+4.IMM4A,4.RN1+4.RM2,4.RN2!RN1:D2c:::mov_asl
7033 "mov_asl"
7034 *am33
7035 *am33_2
7036 {
7037   int srcreg2, dstreg1, dstreg2;
7038   int result1;
7039
7040   PC = cia;
7041   srcreg2 = translate_rreg (SD_, RM2);
7042   dstreg1 = translate_rreg (SD_, RN1);
7043   dstreg2 = translate_rreg (SD_, RN2);
7044
7045   result1 = EXTEND4 (IMM4A);
7046   State.regs[dstreg2] <<= State.regs[srcreg2];
7047   State.regs[dstreg1] = result1;
7048 }
7049
7050 // 1111 0111 1101 0111 imm4 Rn1 imm4 Rn2; mov_asl imm4, Rn1, imm4, Rn2
7051 8.0xf7+8.0xd7+4.IMM4A,4.RN1+4.IMM4,4.RN2!RN1:D2d:::mov_asl
7052 "mov_asl"
7053 *am33
7054 *am33_2
7055 {
7056   int dstreg1, dstreg2;
7057   int result1;
7058
7059   PC = cia;
7060   dstreg1 = translate_rreg (SD_, RN1);
7061   dstreg2 = translate_rreg (SD_, RN2);
7062
7063   result1 = EXTEND4 (IMM4A);
7064   State.regs[dstreg2] <<= IMM4;
7065   State.regs[dstreg1] = result1;
7066 }
7067  
7068 // 1111 0111 0000 1000 Rm1 Rn1 Rm2 Rn2; and_add Rm1, Rn1, Rm2, Rn2
7069 8.0xf7+8.0x08+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::and_add
7070 "and_add"
7071 *am33
7072 *am33_2
7073 {
7074   int srcreg1, srcreg2, dstreg1, dstreg2;
7075   int result1;
7076
7077   PC = cia;
7078   srcreg1 = translate_rreg (SD_, RM1);
7079   srcreg2 = translate_rreg (SD_, RM2);
7080   dstreg1 = translate_rreg (SD_, RN1);
7081   dstreg2 = translate_rreg (SD_, RN2);
7082
7083   result1 = State.regs[dstreg1] & State.regs[srcreg1];
7084   State.regs[dstreg2] += State.regs[srcreg2];
7085   State.regs[dstreg1] = result1;
7086 }
7087
7088 // 1111 0111 0001 1000 Rm1 Rn1 imm4 Rn2; and_add Rm1, Rn1, imm4, Rn2
7089 8.0xf7+8.0x18+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::and_add
7090 "and_add"
7091 *am33
7092 *am33_2
7093 {
7094   int srcreg1, dstreg1, dstreg2;
7095   int result1;
7096
7097   PC = cia;
7098   srcreg1 = translate_rreg (SD_, RM1);
7099   dstreg1 = translate_rreg (SD_, RN1);
7100   dstreg2 = translate_rreg (SD_, RN2);
7101
7102   result1 = State.regs[dstreg1] & State.regs[srcreg1];
7103   State.regs[dstreg2] += EXTEND4 (IMM4);
7104   State.regs[dstreg1] = result1;
7105 }
7106   
7107 // 1111 0111 0010 1000 Rm1 Rn1 Rm2 Rn2; and_sub Rm1, Rn1, Rm2, Rn2
7108 8.0xf7+8.0x28+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::and_sub
7109 "and_sub"
7110 *am33
7111 *am33_2
7112 {
7113   int srcreg1, srcreg2, dstreg1, dstreg2;
7114   int result1;
7115
7116   PC = cia;
7117   srcreg1 = translate_rreg (SD_, RM1);
7118   srcreg2 = translate_rreg (SD_, RM2);
7119   dstreg1 = translate_rreg (SD_, RN1);
7120   dstreg2 = translate_rreg (SD_, RN2);
7121
7122   result1 = State.regs[dstreg1] & State.regs[srcreg1];
7123   State.regs[dstreg2] -= State.regs[srcreg2];
7124   State.regs[dstreg1] = result1;
7125 }
7126
7127 // 1111 0111 0011 1000 Rm1 Rn1 imm4 Rn2; and_sub Rm1, Rn1, imm4, Rn2
7128 8.0xf7+8.0x38+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::and_sub
7129 "and_sub"
7130 *am33
7131 *am33_2
7132 {
7133   int srcreg1, dstreg1, dstreg2;
7134   int result1;
7135
7136   PC = cia;
7137   srcreg1 = translate_rreg (SD_, RM1);
7138   dstreg1 = translate_rreg (SD_, RN1);
7139   dstreg2 = translate_rreg (SD_, RN2);
7140
7141   result1 = State.regs[dstreg1] & State.regs[srcreg1];
7142   State.regs[dstreg2] -= EXTEND4 (IMM4);
7143   State.regs[dstreg1] = result1;
7144 }
7145   
7146 // 1111 0111 0100 1000 Rm1 Rn1 Rm2 Rn2; and_cmp Rm1, Rn1, Rm2, Rn2
7147 8.0xf7+8.0x48+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::and_cmp
7148 "and_cmp"
7149 *am33
7150 *am33_2
7151 {
7152   int srcreg1, srcreg2, dstreg1, dstreg2;
7153
7154   PC = cia;
7155   srcreg1 = translate_rreg (SD_, RM1);
7156   srcreg2 = translate_rreg (SD_, RM2);
7157   dstreg1 = translate_rreg (SD_, RN1);
7158   dstreg2 = translate_rreg (SD_, RN2);
7159
7160   genericCmp (State.regs[srcreg2], State.regs[dstreg2]);
7161   State.regs[dstreg1] &= State.regs[srcreg1];
7162 }
7163
7164 // 1111 0111 0101 1000 Rm1 Rn1 imm4 Rn2; and_cmp Rm1, Rn1, imm4, Rn2
7165 8.0xf7+8.0x58+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::and_cmp
7166 "and_cmp"
7167 *am33
7168 *am33_2
7169 {
7170   int srcreg1, dstreg1, dstreg2;
7171
7172   PC = cia;
7173   srcreg1 = translate_rreg (SD_, RM1);
7174   dstreg1 = translate_rreg (SD_, RN1);
7175   dstreg2 = translate_rreg (SD_, RN2);
7176
7177   genericCmp (EXTEND4 (IMM4), State.regs[dstreg2]);
7178   State.regs[dstreg1] &= State.regs[srcreg1];
7179 }
7180   
7181 // 1111 0111 0110 1000 Rm1 Rn1 Rm2 Rn2; and_mov Rm1, Rn1, Rm2, Rn2
7182 8.0xf7+8.0x68+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::and_mov
7183 "and_mov"
7184 *am33
7185 *am33_2
7186 {
7187   int srcreg1, srcreg2, dstreg1, dstreg2;
7188   int result1;
7189
7190   PC = cia;
7191   srcreg1 = translate_rreg (SD_, RM1);
7192   srcreg2 = translate_rreg (SD_, RM2);
7193   dstreg1 = translate_rreg (SD_, RN1);
7194   dstreg2 = translate_rreg (SD_, RN2);
7195
7196   result1 = State.regs[dstreg1] & State.regs[srcreg1];
7197   State.regs[dstreg2] = State.regs[srcreg2];
7198   State.regs[dstreg1] = result1;
7199 }
7200
7201 // 1111 0111 0111 1000 Rm1 Rn1 imm4 Rn2; and_mov Rm1, Rn1, imm4, Rn2
7202 8.0xf7+8.0x78+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::and_mov
7203 "and_mov"
7204 *am33
7205 *am33_2
7206 {
7207   int srcreg1, dstreg1, dstreg2;
7208   int result1;
7209
7210   PC = cia;
7211   srcreg1 = translate_rreg (SD_, RM1);
7212   dstreg1 = translate_rreg (SD_, RN1);
7213   dstreg2 = translate_rreg (SD_, RN2);
7214
7215   result1 = State.regs[dstreg1] & State.regs[srcreg1];
7216   State.regs[dstreg2] = EXTEND4 (IMM4);
7217   State.regs[dstreg1] = result1;
7218 }
7219   
7220 // 1111 0111 1000 1000 Rm1 Rn1 Rm2 Rn2; and_asr Rm1, Rn1, Rm2, Rn2
7221 8.0xf7+8.0x88+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::and_asr
7222 "and_asr"
7223 *am33
7224 *am33_2
7225 {
7226   int srcreg1, srcreg2, dstreg1, dstreg2;
7227   int result1;
7228   signed int temp;
7229
7230   PC = cia;
7231   srcreg1 = translate_rreg (SD_, RM1);
7232   srcreg2 = translate_rreg (SD_, RM2);
7233   dstreg1 = translate_rreg (SD_, RN1);
7234   dstreg2 = translate_rreg (SD_, RN2);
7235
7236   result1 = State.regs[dstreg1] & State.regs[srcreg1];
7237   temp = State.regs[dstreg2];
7238   temp >>= State.regs[srcreg2];
7239   State.regs[dstreg2] = temp;
7240   State.regs[dstreg1] = result1;
7241 }
7242
7243 // 1111 0111 1001 1000 Rm1 Rn1 imm4 Rn2; and_asr Rm1, Rn1, imm4, Rn2
7244 8.0xf7+8.0x98+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::and_asr
7245 "and_asr"
7246 *am33
7247 *am33_2
7248 {
7249   int srcreg1, dstreg1, dstreg2;
7250   int result1;
7251   signed int temp;
7252
7253   PC = cia;
7254   srcreg1 = translate_rreg (SD_, RM1);
7255   dstreg1 = translate_rreg (SD_, RN1);
7256   dstreg2 = translate_rreg (SD_, RN2);
7257
7258   result1 = State.regs[dstreg1] & State.regs[srcreg1];
7259   temp = State.regs[dstreg2];
7260   temp >>= IMM4;
7261   State.regs[dstreg2] = temp;
7262   State.regs[dstreg1] = result1;
7263 }
7264   
7265 // 1111 0111 1010 1000 Rm1 Rn1 Rm2 Rn2; and_lsr Rm1, Rn1, Rm2, Rn2
7266 8.0xf7+8.0xa8+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::and_lsr
7267 "and_lsr"
7268 *am33
7269 *am33_2
7270 {
7271   int srcreg1, srcreg2, dstreg1, dstreg2;
7272   int result1;
7273
7274   PC = cia;
7275   srcreg1 = translate_rreg (SD_, RM1);
7276   srcreg2 = translate_rreg (SD_, RM2);
7277   dstreg1 = translate_rreg (SD_, RN1);
7278   dstreg2 = translate_rreg (SD_, RN2);
7279
7280   result1 = State.regs[dstreg1] & State.regs[srcreg1];
7281   State.regs[dstreg2] >>= State.regs[srcreg2];
7282   State.regs[dstreg1] = result1;
7283 }
7284
7285 // 1111 0111 1011 1000 Rm1 Rn1 imm4 Rn2; and_lsr Rm1, Rn1, imm4, Rn2
7286 8.0xf7+8.0xb8+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::and_lsr
7287 "and_lsr"
7288 *am33
7289 *am33_2
7290 {
7291   int srcreg1, dstreg1, dstreg2;
7292   int result1;
7293
7294   PC = cia;
7295   srcreg1 = translate_rreg (SD_, RM1);
7296   dstreg1 = translate_rreg (SD_, RN1);
7297   dstreg2 = translate_rreg (SD_, RN2);
7298
7299   result1 = State.regs[dstreg1] & State.regs[srcreg1];
7300   State.regs[dstreg2] >>= IMM4;
7301   State.regs[dstreg1] = result1;
7302 }
7303   
7304   
7305 // 1111 0111 1100 1000 Rm1 Rn1 Rm2 Rn2; and_asl Rm1, Rn1, Rm2, Rn2
7306 8.0xf7+8.0xc8+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::and_asl
7307 "and_asl"
7308 *am33
7309 *am33_2
7310 {
7311   int srcreg1, srcreg2, dstreg1, dstreg2;
7312   int result1;
7313
7314   PC = cia;
7315   srcreg1 = translate_rreg (SD_, RM1);
7316   srcreg2 = translate_rreg (SD_, RM2);
7317   dstreg1 = translate_rreg (SD_, RN1);
7318   dstreg2 = translate_rreg (SD_, RN2);
7319
7320   result1 = State.regs[dstreg1] & State.regs[srcreg1];
7321   State.regs[dstreg2] <<= State.regs[srcreg2];
7322   State.regs[dstreg1] = result1;
7323 }
7324
7325 // 1111 0111 1101 1000 Rm1 Rn1 imm4 Rn2; and_asl Rm1, Rn1, imm4, Rn2
7326 8.0xf7+8.0xd8+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::and_asl
7327 "and_asl"
7328 *am33
7329 *am33_2
7330 {
7331   int srcreg1, dstreg1, dstreg2;
7332   int result1;
7333
7334   PC = cia;
7335   srcreg1 = translate_rreg (SD_, RM1);
7336   dstreg1 = translate_rreg (SD_, RN1);
7337   dstreg2 = translate_rreg (SD_, RN2);
7338
7339   result1 = State.regs[dstreg1] & State.regs[srcreg1];
7340   State.regs[dstreg2] <<= IMM4;
7341   State.regs[dstreg1] = result1;
7342 }
7343
7344 // 1111 0111 0000 1001 Rm1 Rn1 Rm2 Rn2; dmach_add Rm1, Rn1, Rm2, Rn2
7345 8.0xf7+8.0x09+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::dmach_add
7346 "dmach_add"
7347 *am33
7348 *am33_2
7349 {
7350   int srcreg1, srcreg2, dstreg1, dstreg2;
7351   signed32 temp, temp2, sum;
7352
7353   PC = cia;
7354   srcreg1 = translate_rreg (SD_, RM1);
7355   srcreg2 = translate_rreg (SD_, RM2);
7356   dstreg1 = translate_rreg (SD_, RN1);
7357   dstreg2 = translate_rreg (SD_, RN2);
7358
7359   temp = ((signed32)(signed16)(State.regs[dstreg1] & 0xffff)
7360           * (signed32)(signed16)(State.regs[srcreg1] & 0xffff));
7361   temp2 = ((signed32)(signed16)((State.regs[srcreg1] >> 16) & 0xffff)
7362            * (signed32)(signed16)((State.regs[dstreg1] >> 16) & 0xffff));
7363   sum = temp + temp2 + State.regs[REG_MCRL];
7364
7365   State.regs[dstreg2] += State.regs[srcreg2];
7366   State.regs[dstreg1] = sum;
7367 }
7368
7369 // 1111 0111 0001 1001 Rm1 Rn1 imm4 Rn2; dmach_add Rm1, Rn1, imm4, Rn2
7370 8.0xf7+8.0x19+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::dmach_add
7371 "dmach_add"
7372 *am33
7373 *am33_2
7374 {
7375   int srcreg1, dstreg1, dstreg2;
7376   signed32 temp, temp2, sum;
7377
7378   PC = cia;
7379   srcreg1 = translate_rreg (SD_, RM1);
7380   dstreg1 = translate_rreg (SD_, RN1);
7381   dstreg2 = translate_rreg (SD_, RN2);
7382
7383   temp = ((signed32)(signed16)(State.regs[dstreg1] & 0xffff)
7384           * (signed32)(signed16)(State.regs[srcreg1] & 0xffff));
7385   temp2 = ((signed32)(signed16)((State.regs[srcreg1] >> 16) & 0xffff)
7386            * (signed32)(signed16)((State.regs[dstreg1] >> 16) & 0xffff));
7387   sum = temp + temp2 + State.regs[REG_MCRL];
7388
7389   State.regs[dstreg2] += EXTEND4 (IMM4);
7390   State.regs[dstreg1] = sum;
7391 }
7392   
7393 // 1111 0111 0010 1001 Rm1 Rn1 Rm2 Rn2; dmach_sub Rm1, Rn1, Rm2, Rn2
7394 8.0xf7+8.0x29+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::dmach_sub
7395 "dmach_sub"
7396 *am33
7397 *am33_2
7398 {
7399   int srcreg1, srcreg2, dstreg1, dstreg2;
7400   signed32 temp, temp2, sum;
7401
7402   PC = cia;
7403   srcreg1 = translate_rreg (SD_, RM1);
7404   srcreg2 = translate_rreg (SD_, RM2);
7405   dstreg1 = translate_rreg (SD_, RN1);
7406   dstreg2 = translate_rreg (SD_, RN2);
7407
7408   temp = ((signed32)(signed16)(State.regs[dstreg1] & 0xffff)
7409           * (signed32)(signed16)(State.regs[srcreg1] & 0xffff));
7410   temp2 = ((signed32)(signed16)((State.regs[srcreg1] >> 16) & 0xffff)
7411            * (signed32)(signed16)((State.regs[dstreg1] >> 16) & 0xffff));
7412   sum = temp + temp2 + State.regs[REG_MCRL];
7413
7414   State.regs[dstreg2] -= State.regs[srcreg2];
7415   State.regs[dstreg1] = sum;
7416 }
7417
7418 // 1111 0111 0011 1001 Rm1 Rn1 imm4 Rn2; dmach_sub Rm1, Rn1, imm4, Rn2
7419 8.0xf7+8.0x39+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::dmach_sub
7420 "dmach_sub"
7421 *am33
7422 *am33_2
7423 {
7424   int srcreg1, dstreg1, dstreg2;
7425   signed32 temp, temp2, sum;
7426
7427   PC = cia;
7428   srcreg1 = translate_rreg (SD_, RM1);
7429   dstreg1 = translate_rreg (SD_, RN1);
7430   dstreg2 = translate_rreg (SD_, RN2);
7431
7432   temp = ((signed32)(signed16)(State.regs[dstreg1] & 0xffff)
7433           * (signed32)(signed16)(State.regs[srcreg1] & 0xffff));
7434   temp2 = ((signed32)(signed16)((State.regs[srcreg1] >> 16) & 0xffff)
7435            * (signed32)(signed16)((State.regs[dstreg1] >> 16) & 0xffff));
7436   sum = temp + temp2 + State.regs[REG_MCRL];
7437
7438   State.regs[dstreg2] -= EXTEND4 (IMM4);
7439   State.regs[dstreg1] = sum;
7440 }
7441   
7442 // 1111 0111 0100 1001 Rm1 Rn1 Rm2 Rn2; dmach_cmp Rm1, Rn1, Rm2, Rn2
7443 8.0xf7+8.0x49+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::dmach_cmp
7444 "dmach_cmp"
7445 *am33
7446 *am33_2
7447 {
7448   int srcreg1, srcreg2, dstreg1, dstreg2;
7449   signed32 temp, temp2, sum;
7450
7451   PC = cia;
7452   srcreg1 = translate_rreg (SD_, RM1);
7453   srcreg2 = translate_rreg (SD_, RM2);
7454   dstreg1 = translate_rreg (SD_, RN1);
7455   dstreg2 = translate_rreg (SD_, RN2);
7456
7457   temp = ((signed32)(signed16)(State.regs[dstreg1] & 0xffff)
7458           * (signed32)(signed16)(State.regs[srcreg1] & 0xffff));
7459   temp2 = ((signed32)(signed16)((State.regs[srcreg1] >> 16) & 0xffff)
7460            * (signed32)(signed16)((State.regs[dstreg1] >> 16) & 0xffff));
7461   sum = temp + temp2 + State.regs[REG_MCRL];
7462
7463   genericCmp (State.regs[srcreg2], State.regs[dstreg2]);
7464   State.regs[dstreg1] = sum;
7465 }
7466
7467 // 1111 0111 0101 1001 Rm1 Rn1 imm4 Rn2; dmach_cmp Rm1, Rn1, imm4, Rn2
7468 8.0xf7+8.0x59+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::dmach_cmp
7469 "dmach_cmp"
7470 *am33
7471 *am33_2
7472 {
7473   int srcreg1, dstreg1, dstreg2;
7474   signed32 temp, temp2, sum;
7475
7476   PC = cia;
7477   srcreg1 = translate_rreg (SD_, RM1);
7478   dstreg1 = translate_rreg (SD_, RN1);
7479   dstreg2 = translate_rreg (SD_, RN2);
7480
7481   temp = ((signed32)(signed16)(State.regs[dstreg1] & 0xffff)
7482           * (signed32)(signed16)(State.regs[srcreg1] & 0xffff));
7483   temp2 = ((signed32)(signed16)((State.regs[srcreg1] >> 16) & 0xffff)
7484            * (signed32)(signed16)((State.regs[dstreg1] >> 16) & 0xffff));
7485   sum = temp + temp2 + State.regs[REG_MCRL];
7486
7487   genericCmp (EXTEND4 (IMM4), State.regs[dstreg2]);
7488   State.regs[dstreg1] = sum;
7489 }
7490   
7491 // 1111 0111 0110 1001 Rm1 Rn1 Rm2 Rn2; dmach_mov Rm1, Rn1, Rm2, Rn2
7492 8.0xf7+8.0x69+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::dmach_mov
7493 "dmach_mov"
7494 *am33
7495 *am33_2
7496 {
7497   int srcreg1, srcreg2, dstreg1, dstreg2;
7498   signed32 temp, temp2, sum;
7499
7500   PC = cia;
7501   srcreg1 = translate_rreg (SD_, RM1);
7502   srcreg2 = translate_rreg (SD_, RM2);
7503   dstreg1 = translate_rreg (SD_, RN1);
7504   dstreg2 = translate_rreg (SD_, RN2);
7505
7506   temp = ((signed32)(signed16)(State.regs[dstreg1] & 0xffff)
7507           * (signed32)(signed16)(State.regs[srcreg1] & 0xffff));
7508   temp2 = ((signed32)(signed16)((State.regs[srcreg1] >> 16) & 0xffff)
7509            * (signed32)(signed16)((State.regs[dstreg1] >> 16) & 0xffff));
7510   sum = temp + temp2 + State.regs[REG_MCRL];
7511
7512   State.regs[dstreg2] = State.regs[srcreg2];
7513   State.regs[dstreg1] = sum;
7514 }
7515
7516 // 1111 0111 0111 1001 Rm1 Rn1 imm4 Rn2; dmach_mov Rm1, Rn1, imm4, Rn2
7517 8.0xf7+8.0x79+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::dmach_mov
7518 "dmach_mov"
7519 *am33
7520 *am33_2
7521 {
7522   int srcreg1, dstreg1, dstreg2;
7523   signed32 temp, temp2, sum;
7524
7525   PC = cia;
7526   srcreg1 = translate_rreg (SD_, RM1);
7527   dstreg1 = translate_rreg (SD_, RN1);
7528   dstreg2 = translate_rreg (SD_, RN2);
7529
7530   temp = ((signed32)(signed16)(State.regs[dstreg1] & 0xffff)
7531           * (signed32)(signed16)(State.regs[srcreg1] & 0xffff));
7532   temp2 = ((signed32)(signed16)((State.regs[srcreg1] >> 16) & 0xffff)
7533            * (signed32)(signed16)((State.regs[dstreg1] >> 16) & 0xffff));
7534   sum = temp + temp2 + State.regs[REG_MCRL];
7535
7536   State.regs[dstreg2] = EXTEND4 (IMM4);
7537   State.regs[dstreg1] = sum;
7538 }
7539   
7540 // 1111 0111 1000 1001 Rm1 Rn1 Rm2 Rn2; dmach_asr Rm1, Rn1, Rm2, Rn2
7541 8.0xf7+8.0x89+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::dmach_asr
7542 "dmach_asr"
7543 *am33
7544 *am33_2
7545 {
7546   int srcreg1, srcreg2, dstreg1, dstreg2;
7547   signed32 temp, temp2, sum;
7548
7549   PC = cia;
7550   srcreg1 = translate_rreg (SD_, RM1);
7551   srcreg2 = translate_rreg (SD_, RM2);
7552   dstreg1 = translate_rreg (SD_, RN1);
7553   dstreg2 = translate_rreg (SD_, RN2);
7554
7555   temp = ((signed32)(signed16)(State.regs[dstreg1] & 0xffff)
7556           * (signed32)(signed16)(State.regs[srcreg1] & 0xffff));
7557   temp2 = ((signed32)(signed16)((State.regs[srcreg1] >> 16) & 0xffff)
7558            * (signed32)(signed16)((State.regs[dstreg1] >> 16) & 0xffff));
7559   sum = temp + temp2 + State.regs[REG_MCRL];
7560
7561   temp = State.regs[dstreg2];
7562   temp >>= State.regs[srcreg2];
7563   State.regs[dstreg2] = temp;
7564   State.regs[dstreg1] = sum;
7565 }
7566
7567 // 1111 0111 1001 1001 Rm1 Rn1 imm4 Rn2; dmach_asr Rm1, Rn1, imm4, Rn2
7568 8.0xf7+8.0x99+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::dmach_asr
7569 "dmach_asr"
7570 *am33
7571 *am33_2
7572 {
7573   int srcreg1, dstreg1, dstreg2;
7574   signed32 temp, temp2, sum;
7575
7576   PC = cia;
7577   srcreg1 = translate_rreg (SD_, RM1);
7578   dstreg1 = translate_rreg (SD_, RN1);
7579   dstreg2 = translate_rreg (SD_, RN2);
7580
7581   temp = ((signed32)(signed16)(State.regs[dstreg1] & 0xffff)
7582           * (signed32)(signed16)(State.regs[srcreg1] & 0xffff));
7583   temp2 = ((signed32)(signed16)((State.regs[srcreg1] >> 16) & 0xffff)
7584            * (signed32)(signed16)((State.regs[dstreg1] >> 16) & 0xffff));
7585   sum = temp + temp2 + State.regs[REG_MCRL];
7586
7587   temp = State.regs[dstreg2];
7588   temp >>= IMM4;
7589   State.regs[dstreg2] = temp;
7590   State.regs[dstreg1] = sum;
7591 }
7592   
7593 // 1111 0111 1010 1001 Rm1 Rn1 Rm2 Rn2; dmach_lsr Rm1, Rn1, Rm2, Rn2
7594 8.0xf7+8.0xa9+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::dmach_lsr
7595 "dmach_lsr"
7596 *am33
7597 *am33_2
7598 {
7599   int srcreg1, srcreg2, dstreg1, dstreg2;
7600   signed32 temp, temp2, sum;
7601
7602   PC = cia;
7603   srcreg1 = translate_rreg (SD_, RM1);
7604   srcreg2 = translate_rreg (SD_, RM2);
7605   dstreg1 = translate_rreg (SD_, RN1);
7606   dstreg2 = translate_rreg (SD_, RN2);
7607
7608   temp = ((signed32)(signed16)(State.regs[dstreg1] & 0xffff)
7609           * (signed32)(signed16)(State.regs[srcreg1] & 0xffff));
7610   temp2 = ((signed32)(signed16)((State.regs[srcreg1] >> 16) & 0xffff)
7611            * (signed32)(signed16)((State.regs[dstreg1] >> 16) & 0xffff));
7612   sum = temp + temp2 + State.regs[REG_MCRL];
7613
7614   State.regs[dstreg2] >>= State.regs[srcreg2];
7615   State.regs[dstreg1] = sum;
7616 }
7617
7618 // 1111 0111 1011 1001 Rm1 Rn1 imm4 Rn2; dmach_lsr Rm1, Rn1, imm4, Rn2
7619 8.0xf7+8.0xb9+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::dmach_lsr
7620 "dmach_lsr"
7621 *am33
7622 *am33_2
7623 {
7624   int srcreg1, dstreg1, dstreg2;
7625   signed32 temp, temp2, sum;
7626
7627   PC = cia;
7628   srcreg1 = translate_rreg (SD_, RM1);
7629   dstreg1 = translate_rreg (SD_, RN1);
7630   dstreg2 = translate_rreg (SD_, RN2);
7631
7632   temp = ((signed32)(signed16)(State.regs[dstreg1] & 0xffff)
7633           * (signed32)(signed16)(State.regs[srcreg1] & 0xffff));
7634   temp2 = ((signed32)(signed16)((State.regs[srcreg1] >> 16) & 0xffff)
7635            * (signed32)(signed16)((State.regs[dstreg1] >> 16) & 0xffff));
7636   sum = temp + temp2 + State.regs[REG_MCRL];
7637
7638   State.regs[dstreg2] >>= IMM4;
7639   State.regs[dstreg1] = sum;
7640 }
7641   
7642   
7643 // 1111 0111 1100 1001 Rm1 Rn1 Rm2 Rn2; dmach_asl Rm1, Rn1, Rm2, Rn2
7644 8.0xf7+8.0xc9+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::dmach_asl
7645 "dmach_asl"
7646 *am33
7647 *am33_2
7648 {
7649   int srcreg1, srcreg2, dstreg1, dstreg2;
7650   signed32 temp, temp2, sum;
7651
7652   PC = cia;
7653   srcreg1 = translate_rreg (SD_, RM1);
7654   srcreg2 = translate_rreg (SD_, RM2);
7655   dstreg1 = translate_rreg (SD_, RN1);
7656   dstreg2 = translate_rreg (SD_, RN2);
7657
7658   temp = ((signed32)(signed16)(State.regs[dstreg1] & 0xffff)
7659           * (signed32)(signed16)(State.regs[srcreg1] & 0xffff));
7660   temp2 = ((signed32)(signed16)((State.regs[srcreg1] >> 16) & 0xffff)
7661            * (signed32)(signed16)((State.regs[dstreg1] >> 16) & 0xffff));
7662   sum = temp + temp2 + State.regs[REG_MCRL];
7663
7664   State.regs[dstreg2] <<= State.regs[srcreg2];
7665   State.regs[dstreg1] = sum;
7666 }
7667
7668 // 1111 0111 1101 1001 Rm1 Rn1 imm4 Rn2; dmach_asl Rm1, Rn1, imm4, Rn2
7669 8.0xf7+8.0xd9+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::dmach_asl
7670 "dmach_asl"
7671 *am33
7672 *am33_2
7673 {
7674   int srcreg1, dstreg1, dstreg2;
7675   signed32 temp, temp2, sum;
7676
7677   PC = cia;
7678   srcreg1 = translate_rreg (SD_, RM1);
7679   dstreg1 = translate_rreg (SD_, RN1);
7680   dstreg2 = translate_rreg (SD_, RN2);
7681
7682   temp = ((signed32)(signed16)(State.regs[dstreg1] & 0xffff)
7683           * (signed32)(signed16)(State.regs[srcreg1] & 0xffff));
7684   temp2 = ((signed32)(signed16)((State.regs[srcreg1] >> 16) & 0xffff)
7685            * (signed32)(signed16)((State.regs[dstreg1] >> 16) & 0xffff));
7686   sum = temp + temp2 + State.regs[REG_MCRL];
7687
7688   State.regs[dstreg2] <<= IMM4;
7689   State.regs[dstreg1] = sum;
7690 }
7691
7692 // 1111 0111 0000 1010 Rm1 Rn1 Rm2 Rn2; xor_add Rm1, Rn1, Rm2, Rn2
7693 8.0xf7+8.0x0a+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::xor_add
7694 "xor_add"
7695 *am33
7696 *am33_2
7697 {
7698   int srcreg1, srcreg2, dstreg1, dstreg2;
7699   int result1;
7700
7701   PC = cia;
7702   srcreg1 = translate_rreg (SD_, RM1);
7703   srcreg2 = translate_rreg (SD_, RM2);
7704   dstreg1 = translate_rreg (SD_, RN1);
7705   dstreg2 = translate_rreg (SD_, RN2);
7706
7707   result1 = State.regs[dstreg1] ^ State.regs[srcreg1];
7708   State.regs[dstreg2] += State.regs[srcreg2];
7709   State.regs[dstreg1] = result1;
7710 }
7711
7712 // 1111 0111 0001 1010 Rm1 Rn1 imm4 Rn2; xor_add Rm1, Rn1, imm4, Rn2
7713 8.0xf7+8.0x1a+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::xor_add
7714 "xor_add"
7715 *am33
7716 *am33_2
7717 {
7718   int srcreg1, dstreg1, dstreg2;
7719   int result1;
7720
7721   PC = cia;
7722   srcreg1 = translate_rreg (SD_, RM1);
7723   dstreg1 = translate_rreg (SD_, RN1);
7724   dstreg2 = translate_rreg (SD_, RN2);
7725
7726   result1 = State.regs[dstreg1] ^ State.regs[srcreg1];
7727   State.regs[dstreg2] += EXTEND4 (IMM4);
7728   State.regs[dstreg1] = result1;
7729 }
7730   
7731 // 1111 0111 0010 1010 Rm1 Rn1 Rm2 Rn2; xor_sub Rm1, Rn1, Rm2, Rn2
7732 8.0xf7+8.0x2a+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::xor_sub
7733 "xor_sub"
7734 *am33
7735 *am33_2
7736 {
7737   int srcreg1, srcreg2, dstreg1, dstreg2;
7738   int result1;
7739
7740   PC = cia;
7741   srcreg1 = translate_rreg (SD_, RM1);
7742   srcreg2 = translate_rreg (SD_, RM2);
7743   dstreg1 = translate_rreg (SD_, RN1);
7744   dstreg2 = translate_rreg (SD_, RN2);
7745
7746   result1 = State.regs[dstreg1] ^ State.regs[srcreg1];
7747   State.regs[dstreg2] -= State.regs[srcreg2];
7748   State.regs[dstreg1] = result1;
7749 }
7750
7751 // 1111 0111 0011 1010 Rm1 Rn1 imm4 Rn2; xor_sub Rm1, Rn1, imm4, Rn2
7752 8.0xf7+8.0x3a+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::xor_sub
7753 "xor_sub"
7754 *am33
7755 *am33_2
7756 {
7757   int srcreg1, dstreg1, dstreg2;
7758   int result1;
7759
7760   PC = cia;
7761   srcreg1 = translate_rreg (SD_, RM1);
7762   dstreg1 = translate_rreg (SD_, RN1);
7763   dstreg2 = translate_rreg (SD_, RN2);
7764
7765   result1 = State.regs[dstreg1] ^ State.regs[srcreg1];
7766   State.regs[dstreg2] -= EXTEND4 (IMM4);
7767   State.regs[dstreg1] = result1;
7768 }
7769   
7770 // 1111 0111 0100 1010 Rm1 Rn1 Rm2 Rn2; xor_cmp Rm1, Rn1, Rm2, Rn2
7771 8.0xf7+8.0x4a+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::xor_cmp
7772 "xor_cmp"
7773 *am33
7774 *am33_2
7775 {
7776   int srcreg1, srcreg2, dstreg1, dstreg2;
7777
7778   PC = cia;
7779   srcreg1 = translate_rreg (SD_, RM1);
7780   srcreg2 = translate_rreg (SD_, RM2);
7781   dstreg1 = translate_rreg (SD_, RN1);
7782   dstreg2 = translate_rreg (SD_, RN2);
7783
7784   genericCmp (State.regs[srcreg2], State.regs[dstreg2]);
7785   State.regs[dstreg1] ^= State.regs[srcreg1];
7786 }
7787
7788 // 1111 0111 0101 1010 Rm1 Rn1 imm4 Rn2; xor_cmp Rm1, Rn1, imm4, Rn2
7789 8.0xf7+8.0x5a+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::xor_cmp
7790 "xor_cmp"
7791 *am33
7792 *am33_2
7793 {
7794   int srcreg1, dstreg1, dstreg2;
7795
7796   PC = cia;
7797   srcreg1 = translate_rreg (SD_, RM1);
7798   dstreg1 = translate_rreg (SD_, RN1);
7799   dstreg2 = translate_rreg (SD_, RN2);
7800
7801   genericCmp (EXTEND4 (IMM4), State.regs[dstreg2]);
7802   State.regs[dstreg1] ^= State.regs[srcreg1];
7803 }
7804   
7805 // 1111 0111 0110 1010 Rm1 Rn1 Rm2 Rn2; xor_mov Rm1, Rn1, Rm2, Rn2
7806 8.0xf7+8.0x6a+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::xor_mov
7807 "xor_mov"
7808 *am33
7809 *am33_2
7810 {
7811   int srcreg1, srcreg2, dstreg1, dstreg2;
7812   int result1;
7813
7814   PC = cia;
7815   srcreg1 = translate_rreg (SD_, RM1);
7816   srcreg2 = translate_rreg (SD_, RM2);
7817   dstreg1 = translate_rreg (SD_, RN1);
7818   dstreg2 = translate_rreg (SD_, RN2);
7819
7820   result1 = State.regs[dstreg1] ^ State.regs[srcreg1];
7821   State.regs[dstreg2] = State.regs[srcreg2];
7822   State.regs[dstreg1] = result1;
7823 }
7824
7825 // 1111 0111 0111 1010 Rm1 Rn1 imm4 Rn2; xor_mov Rm1, Rn1, imm4, Rn2
7826 8.0xf7+8.0x7a+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::xor_mov
7827 "xor_mov"
7828 *am33
7829 *am33_2
7830 {
7831   int srcreg1, dstreg1, dstreg2;
7832   int result1;
7833
7834   PC = cia;
7835   srcreg1 = translate_rreg (SD_, RM1);
7836   dstreg1 = translate_rreg (SD_, RN1);
7837   dstreg2 = translate_rreg (SD_, RN2);
7838
7839   result1 = State.regs[dstreg1] ^ State.regs[srcreg1];
7840   State.regs[dstreg2] = EXTEND4 (IMM4);
7841   State.regs[dstreg1] = result1;
7842 }
7843   
7844 // 1111 0111 1000 1010 Rm1 Rn1 Rm2 Rn2; xor_asr Rm1, Rn1, Rm2, Rn2
7845 8.0xf7+8.0x8a+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::xor_asr
7846 "xor_asr"
7847 *am33
7848 *am33_2
7849 {
7850   int srcreg1, srcreg2, dstreg1, dstreg2;
7851   int result1;
7852   signed int temp;
7853
7854   PC = cia;
7855   srcreg1 = translate_rreg (SD_, RM1);
7856   srcreg2 = translate_rreg (SD_, RM2);
7857   dstreg1 = translate_rreg (SD_, RN1);
7858   dstreg2 = translate_rreg (SD_, RN2);
7859
7860   result1 = State.regs[dstreg1] ^ State.regs[srcreg1];
7861   temp = State.regs[dstreg2];
7862   temp >>= State.regs[srcreg2];
7863   State.regs[dstreg2] = temp;
7864   State.regs[dstreg1] = result1;
7865 }
7866
7867 // 1111 0111 1001 1010 Rm1 Rn1 imm4 Rn2; xor_asr Rm1, Rn1, imm4, Rn2
7868 8.0xf7+8.0x9a+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::xor_asr
7869 "xor_asr"
7870 *am33
7871 *am33_2
7872 {
7873   int srcreg1, dstreg1, dstreg2;
7874   int result1;
7875   signed int temp;
7876
7877   PC = cia;
7878   srcreg1 = translate_rreg (SD_, RM1);
7879   dstreg1 = translate_rreg (SD_, RN1);
7880   dstreg2 = translate_rreg (SD_, RN2);
7881
7882   result1 = State.regs[dstreg1] ^ State.regs[srcreg1];
7883   temp = State.regs[dstreg2];
7884   temp >>= IMM4;
7885   State.regs[dstreg2] = temp;
7886   State.regs[dstreg1] = result1;
7887 }
7888   
7889 // 1111 0111 1010 1010 Rm1 Rn1 Rm2 Rn2; xor_lsr Rm1, Rn1, Rm2, Rn2
7890 8.0xf7+8.0xaa+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::xor_lsr
7891 "xor_lsr"
7892 *am33
7893 *am33_2
7894 {
7895   int srcreg1, srcreg2, dstreg1, dstreg2;
7896   int result1;
7897
7898   PC = cia;
7899   srcreg1 = translate_rreg (SD_, RM1);
7900   srcreg2 = translate_rreg (SD_, RM2);
7901   dstreg1 = translate_rreg (SD_, RN1);
7902   dstreg2 = translate_rreg (SD_, RN2);
7903
7904   result1 = State.regs[dstreg1] ^ State.regs[srcreg1];
7905   State.regs[dstreg2] >>= State.regs[srcreg2];
7906   State.regs[dstreg1] = result1;
7907 }
7908
7909 // 1111 0111 1011 1010 Rm1 Rn1 imm4 Rn2; xor_lsr Rm1, Rn1, imm4, Rn2
7910 8.0xf7+8.0xba+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::xor_lsr
7911 "xor_lsr"
7912 *am33
7913 *am33_2
7914 {
7915   int srcreg1, dstreg1, dstreg2;
7916   int result1;
7917
7918   PC = cia;
7919   srcreg1 = translate_rreg (SD_, RM1);
7920   dstreg1 = translate_rreg (SD_, RN1);
7921   dstreg2 = translate_rreg (SD_, RN2);
7922
7923   result1 = State.regs[dstreg1] ^ State.regs[srcreg1];
7924   State.regs[dstreg2] >>= IMM4;
7925   State.regs[dstreg1] = result1;
7926 }
7927   
7928   
7929 // 1111 0111 1100 1010 Rm1 Rn1 Rm2 Rn2; xor_asl Rm1, Rn1, Rm2, Rn2
7930 8.0xf7+8.0xca+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::xor_asl
7931 "xor_asl"
7932 *am33
7933 *am33_2
7934 {
7935   int srcreg1, srcreg2, dstreg1, dstreg2;
7936   int result1;
7937
7938   PC = cia;
7939   srcreg1 = translate_rreg (SD_, RM1);
7940   srcreg2 = translate_rreg (SD_, RM2);
7941   dstreg1 = translate_rreg (SD_, RN1);
7942   dstreg2 = translate_rreg (SD_, RN2);
7943
7944   result1 = State.regs[dstreg1] ^ State.regs[srcreg1];
7945   State.regs[dstreg2] <<= State.regs[srcreg2];
7946   State.regs[dstreg1] = result1;
7947 }
7948
7949 // 1111 0111 1101 1010 Rm1 Rn1 imm4 Rn2; xor_asl Rm1, Rn1, imm4, Rn2
7950 8.0xf7+8.0xda+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::xor_asl
7951 "xor_asl"
7952 *am33
7953 *am33_2
7954 {
7955   int srcreg1, dstreg1, dstreg2;
7956   int result1;
7957
7958   PC = cia;
7959   srcreg1 = translate_rreg (SD_, RM1);
7960   dstreg1 = translate_rreg (SD_, RN1);
7961   dstreg2 = translate_rreg (SD_, RN2);
7962
7963   result1 = State.regs[dstreg1] ^ State.regs[srcreg1];
7964   State.regs[dstreg2] <<= IMM4;
7965   State.regs[dstreg1] = result1;
7966 }
7967
7968 // 1111 0111 0000 1011 Rm1 Rn1 Rm2 Rn2; swhw_add Rm1, Rn1, Rm2, Rn2
7969 8.0xf7+8.0x0b+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::swhw_add
7970 "swhw_add"
7971 *am33
7972 *am33_2
7973 {
7974   int srcreg1, srcreg2, dstreg1, dstreg2;
7975   int result1;
7976
7977   PC = cia;
7978   srcreg1 = translate_rreg (SD_, RM1);
7979   srcreg2 = translate_rreg (SD_, RM2);
7980   dstreg1 = translate_rreg (SD_, RN1);
7981   dstreg2 = translate_rreg (SD_, RN2);
7982
7983   result1 = State.regs[dstreg1] ^ State.regs[srcreg1];
7984   State.regs[dstreg2] += State.regs[srcreg2];
7985   State.regs[dstreg1] = result1;
7986 }
7987
7988 // 1111 0111 0001 1011 Rm1 Rn1 imm4 Rn2; swhw_add Rm1, Rn1, imm4, Rn2
7989 8.0xf7+8.0x1b+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::swhw_add
7990 "swhw_add"
7991 *am33
7992 *am33_2
7993 {
7994   int srcreg1, dstreg1, dstreg2;
7995   int result1;
7996
7997   PC = cia;
7998   srcreg1 = translate_rreg (SD_, RM1);
7999   dstreg1 = translate_rreg (SD_, RN1);
8000   dstreg2 = translate_rreg (SD_, RN2);
8001
8002   result1 = (((State.regs[srcreg1] & 0xffff) << 16)
8003                | ((State.regs[srcreg1] >> 16) & 0xffff));
8004   State.regs[dstreg2] += EXTEND4 (IMM4);
8005   State.regs[dstreg1] = result1;
8006 }
8007   
8008 // 1111 0111 0010 1011 Rm1 Rn1 Rm2 Rn2; swhw_sub Rm1, Rn1, Rm2, Rn2
8009 8.0xf7+8.0x2b+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::swhw_sub
8010 "swhw_sub"
8011 *am33
8012 *am33_2
8013 {
8014   int srcreg1, srcreg2, dstreg1, dstreg2;
8015   int result1;
8016
8017   PC = cia;
8018   srcreg1 = translate_rreg (SD_, RM1);
8019   srcreg2 = translate_rreg (SD_, RM2);
8020   dstreg1 = translate_rreg (SD_, RN1);
8021   dstreg2 = translate_rreg (SD_, RN2);
8022
8023   result1 = (((State.regs[srcreg1] & 0xffff) << 16)
8024                | ((State.regs[srcreg1] >> 16) & 0xffff));
8025   State.regs[dstreg2] -= State.regs[srcreg2];
8026   State.regs[dstreg1] = result1;
8027 }
8028
8029 // 1111 0111 0011 1011 Rm1 Rn1 imm4 Rn2; swhw_sub Rm1, Rn1, imm4, Rn2
8030 8.0xf7+8.0x3b+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::swhw_sub
8031 "swhw_sub"
8032 *am33
8033 *am33_2
8034 {
8035   int srcreg1, dstreg1, dstreg2;
8036   int result1;
8037
8038   PC = cia;
8039   srcreg1 = translate_rreg (SD_, RM1);
8040   dstreg1 = translate_rreg (SD_, RN1);
8041   dstreg2 = translate_rreg (SD_, RN2);
8042
8043   result1 = (((State.regs[srcreg1] & 0xffff) << 16)
8044                | ((State.regs[srcreg1] >> 16) & 0xffff));
8045   State.regs[dstreg2] -= EXTEND4 (IMM4);
8046   State.regs[dstreg1] = result1;
8047 }
8048   
8049 // 1111 0111 0100 1011 Rm1 Rn1 Rm2 Rn2; swhw_cmp Rm1, Rn1, Rm2, Rn2
8050 8.0xf7+8.0x4b+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::swhw_cmp
8051 "swhw_cmp"
8052 *am33
8053 *am33_2
8054 {
8055   int srcreg1, srcreg2, dstreg1, dstreg2;
8056
8057   PC = cia;
8058   srcreg1 = translate_rreg (SD_, RM1);
8059   srcreg2 = translate_rreg (SD_, RM2);
8060   dstreg1 = translate_rreg (SD_, RN1);
8061   dstreg2 = translate_rreg (SD_, RN2);
8062
8063   genericCmp (State.regs[srcreg2], State.regs[dstreg2]);
8064   State.regs[dstreg1] = (((State.regs[srcreg1] & 0xffff) << 16)
8065                          | ((State.regs[srcreg1] >> 16) & 0xffff));
8066 }
8067
8068 // 1111 0111 0101 1011 Rm1 Rn1 imm4 Rn2; swhw_cmp Rm1, Rn1, imm4, Rn2
8069 8.0xf7+8.0x5b+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::swhw_cmp
8070 "swhw_cmp"
8071 *am33
8072 *am33_2
8073 {
8074   int srcreg1, dstreg1, dstreg2;
8075
8076   PC = cia;
8077   srcreg1 = translate_rreg (SD_, RM1);
8078   dstreg1 = translate_rreg (SD_, RN1);
8079   dstreg2 = translate_rreg (SD_, RN2);
8080
8081   genericCmp (EXTEND4 (IMM4), State.regs[dstreg2]);
8082   State.regs[dstreg1] = (((State.regs[srcreg1] & 0xffff) << 16)
8083                          | ((State.regs[srcreg1] >> 16) & 0xffff));
8084 }
8085   
8086 // 1111 0111 0110 1011 Rm1 Rn1 Rm2 Rn2; swhw_mov Rm1, Rn1, Rm2, Rn2
8087 8.0xf7+8.0x6b+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::swhw_mov
8088 "swhw_mov"
8089 *am33
8090 *am33_2
8091 {
8092   int srcreg1, srcreg2, dstreg1, dstreg2;
8093   int result1;
8094
8095   PC = cia;
8096   srcreg1 = translate_rreg (SD_, RM1);
8097   srcreg2 = translate_rreg (SD_, RM2);
8098   dstreg1 = translate_rreg (SD_, RN1);
8099   dstreg2 = translate_rreg (SD_, RN2);
8100
8101   result1 = (((State.regs[srcreg1] & 0xffff) << 16)
8102                | ((State.regs[srcreg1] >> 16) & 0xffff));
8103   State.regs[dstreg2] = State.regs[srcreg2];
8104   State.regs[dstreg1] = result1;
8105 }
8106
8107 // 1111 0111 0111 1011 Rm1 Rn1 imm4 Rn2; swhw_mov Rm1, Rn1, imm4, Rn2
8108 8.0xf7+8.0x7b+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::swhw_mov
8109 "swhw_mov"
8110 *am33
8111 *am33_2
8112 {
8113   int srcreg1, dstreg1, dstreg2;
8114   int result1;
8115
8116   PC = cia;
8117   srcreg1 = translate_rreg (SD_, RM1);
8118   dstreg1 = translate_rreg (SD_, RN1);
8119   dstreg2 = translate_rreg (SD_, RN2);
8120
8121   result1 = (((State.regs[srcreg1] & 0xffff) << 16)
8122                | ((State.regs[srcreg1] >> 16) & 0xffff));
8123   State.regs[dstreg2] = EXTEND4 (IMM4);
8124   State.regs[dstreg1] = result1;
8125 }
8126   
8127 // 1111 0111 1000 1011 Rm1 Rn1 Rm2 Rn2; swhw_asr Rm1, Rn1, Rm2, Rn2
8128 8.0xf7+8.0x8b+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::swhw_asr
8129 "swhw_asr"
8130 *am33
8131 *am33_2
8132 {
8133   int srcreg1, srcreg2, dstreg1, dstreg2;
8134   int result1;
8135   signed int temp;
8136
8137   PC = cia;
8138   srcreg1 = translate_rreg (SD_, RM1);
8139   srcreg2 = translate_rreg (SD_, RM2);
8140   dstreg1 = translate_rreg (SD_, RN1);
8141   dstreg2 = translate_rreg (SD_, RN2);
8142
8143   result1 = (((State.regs[srcreg1] & 0xffff) << 16)
8144                | ((State.regs[srcreg1] >> 16) & 0xffff));
8145   temp = State.regs[dstreg2];
8146   temp >>= State.regs[srcreg2];
8147   State.regs[dstreg2] = temp;
8148   State.regs[dstreg1] = result1;
8149 }
8150
8151 // 1111 0111 1001 1011 Rm1 Rn1 imm4 Rn2; swhw_asr Rm1, Rn1, imm4, Rn2
8152 8.0xf7+8.0x9b+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::swhw_asr
8153 "swhw_asr"
8154 *am33
8155 *am33_2
8156 {
8157   int srcreg1, dstreg1, dstreg2;
8158   int result1;
8159   signed int temp;
8160
8161   PC = cia;
8162   srcreg1 = translate_rreg (SD_, RM1);
8163   dstreg1 = translate_rreg (SD_, RN1);
8164   dstreg2 = translate_rreg (SD_, RN2);
8165
8166   result1 = (((State.regs[srcreg1] & 0xffff) << 16)
8167                | ((State.regs[srcreg1] >> 16) & 0xffff));
8168   temp = State.regs[dstreg2];
8169   temp >>= IMM4;
8170   State.regs[dstreg2] = temp;
8171   State.regs[dstreg1] = result1;
8172 }
8173   
8174 // 1111 0111 1010 1011 Rm1 Rn1 Rm2 Rn2; swhw_lsr Rm1, Rn1, Rm2, Rn2
8175 8.0xf7+8.0xab+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::swhw_lsr
8176 "swhw_lsr"
8177 *am33
8178 *am33_2
8179 {
8180   int srcreg1, srcreg2, dstreg1, dstreg2;
8181   int result1;
8182
8183   PC = cia;
8184   srcreg1 = translate_rreg (SD_, RM1);
8185   srcreg2 = translate_rreg (SD_, RM2);
8186   dstreg1 = translate_rreg (SD_, RN1);
8187   dstreg2 = translate_rreg (SD_, RN2);
8188
8189   result1 = (((State.regs[srcreg1] & 0xffff) << 16)
8190                | ((State.regs[srcreg1] >> 16) & 0xffff));
8191   State.regs[dstreg2] >>= State.regs[srcreg2];
8192   State.regs[dstreg1] = result1;
8193 }
8194
8195 // 1111 0111 1011 1011 Rm1 Rn1 imm4 Rn2; swhw_lsr Rm1, Rn1, imm4, Rn2
8196 8.0xf7+8.0xbb+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::swhw_lsr
8197 "swhw_lsr"
8198 *am33
8199 *am33_2
8200 {
8201   int srcreg1, dstreg1, dstreg2;
8202   int result1;
8203
8204   PC = cia;
8205   srcreg1 = translate_rreg (SD_, RM1);
8206   dstreg1 = translate_rreg (SD_, RN1);
8207   dstreg2 = translate_rreg (SD_, RN2);
8208
8209   result1 = (((State.regs[srcreg1] & 0xffff) << 16)
8210                | ((State.regs[srcreg1] >> 16) & 0xffff));
8211   State.regs[dstreg2] >>= IMM4;
8212   State.regs[dstreg1] = result1;
8213 }
8214   
8215   
8216 // 1111 0111 1100 1011 Rm1 Rn1 Rm2 Rn2; swhw_asl Rm1, Rn1, Rm2, Rn2
8217 8.0xf7+8.0xcb+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::swhw_asl
8218 "swhw_asl"
8219 *am33
8220 *am33_2
8221 {
8222   int srcreg1, srcreg2, dstreg1, dstreg2;
8223   int result1;
8224
8225   PC = cia;
8226   srcreg1 = translate_rreg (SD_, RM1);
8227   srcreg2 = translate_rreg (SD_, RM2);
8228   dstreg1 = translate_rreg (SD_, RN1);
8229   dstreg2 = translate_rreg (SD_, RN2);
8230
8231   result1 = (((State.regs[srcreg1] & 0xffff) << 16)
8232                | ((State.regs[srcreg1] >> 16) & 0xffff));
8233   State.regs[dstreg2] <<= State.regs[srcreg2];
8234   State.regs[dstreg1] = result1;
8235 }
8236
8237 // 1111 0111 1101 1011 Rm1 Rn1 imm4 Rn2; swhw_asl Rm1, Rn1, imm4, Rn2
8238 8.0xf7+8.0xdb+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::swhw_asl
8239 "swhw_asl"
8240 *am33
8241 *am33_2
8242 {
8243   int srcreg1, dstreg1, dstreg2;
8244   int result1;
8245
8246   PC = cia;
8247   srcreg1 = translate_rreg (SD_, RM1);
8248   dstreg1 = translate_rreg (SD_, RN1);
8249   dstreg2 = translate_rreg (SD_, RN2);
8250
8251   result1 = (((State.regs[srcreg1] & 0xffff) << 16)
8252                | ((State.regs[srcreg1] >> 16) & 0xffff));
8253   State.regs[dstreg2] <<= IMM4;
8254   State.regs[dstreg1] = result1;
8255 }
8256
8257 // 1111 0111 0000 1100 Rm1 Rn1 Rm2 Rn2; or_add Rm1, Rn1, Rm2, Rn2
8258 8.0xf7+8.0x0c+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::or_add
8259 "or_add"
8260 *am33
8261 *am33_2
8262 {
8263   int srcreg1, srcreg2, dstreg1, dstreg2;
8264   int result1;
8265
8266   PC = cia;
8267   srcreg1 = translate_rreg (SD_, RM1);
8268   srcreg2 = translate_rreg (SD_, RM2);
8269   dstreg1 = translate_rreg (SD_, RN1);
8270   dstreg2 = translate_rreg (SD_, RN2);
8271
8272   result1 = State.regs[dstreg1] | State.regs[srcreg1];
8273   State.regs[dstreg2] += State.regs[srcreg2];
8274   State.regs[dstreg1] = result1;
8275 }
8276
8277 // 1111 0111 0001 1100 Rm1 Rn1 imm4 Rn2; or_add Rm1, Rn1, imm4, Rn2
8278 8.0xf7+8.0x1c+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::or_add
8279 "or_add"
8280 *am33
8281 *am33_2
8282 {
8283   int srcreg1, dstreg1, dstreg2;
8284   int result1;
8285
8286   PC = cia;
8287   srcreg1 = translate_rreg (SD_, RM1);
8288   dstreg1 = translate_rreg (SD_, RN1);
8289   dstreg2 = translate_rreg (SD_, RN2);
8290
8291   result1 = State.regs[dstreg1] | State.regs[srcreg1];
8292   State.regs[dstreg2] += EXTEND4 (IMM4);
8293   State.regs[dstreg1] = result1;
8294 }
8295   
8296 // 1111 0111 0010 1100 Rm1 Rn1 Rm2 Rn2; or_sub Rm1, Rn1, Rm2, Rn2
8297 8.0xf7+8.0x2c+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::or_sub
8298 "or_sub"
8299 *am33
8300 *am33_2
8301 {
8302   int srcreg1, srcreg2, dstreg1, dstreg2;
8303   int result1;
8304
8305   PC = cia;
8306   srcreg1 = translate_rreg (SD_, RM1);
8307   srcreg2 = translate_rreg (SD_, RM2);
8308   dstreg1 = translate_rreg (SD_, RN1);
8309   dstreg2 = translate_rreg (SD_, RN2);
8310
8311   result1 = State.regs[dstreg1] | State.regs[srcreg1];
8312   State.regs[dstreg2] -= State.regs[srcreg2];
8313   State.regs[dstreg1] = result1;
8314 }
8315
8316 // 1111 0111 0011 1100 Rm1 Rn1 imm4 Rn2; or_sub Rm1, Rn1, imm4, Rn2
8317 8.0xf7+8.0x3c+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::or_sub
8318 "or_sub"
8319 *am33
8320 *am33_2
8321 {
8322   int srcreg1, dstreg1, dstreg2;
8323   int result1;
8324
8325   PC = cia;
8326   srcreg1 = translate_rreg (SD_, RM1);
8327   dstreg1 = translate_rreg (SD_, RN1);
8328   dstreg2 = translate_rreg (SD_, RN2);
8329
8330   result1 = State.regs[dstreg1] | State.regs[srcreg1];
8331   State.regs[dstreg2] -= EXTEND4 (IMM4);
8332   State.regs[dstreg1] = result1;
8333 }
8334   
8335 // 1111 0111 0100 1100 Rm1 Rn1 Rm2 Rn2; or_cmp Rm1, Rn1, Rm2, Rn2
8336 8.0xf7+8.0x4c+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::or_cmp
8337 "or_cmp"
8338 *am33
8339 *am33_2
8340 {
8341   int srcreg1, srcreg2, dstreg1, dstreg2;
8342
8343   PC = cia;
8344   srcreg1 = translate_rreg (SD_, RM1);
8345   srcreg2 = translate_rreg (SD_, RM2);
8346   dstreg1 = translate_rreg (SD_, RN1);
8347   dstreg2 = translate_rreg (SD_, RN2);
8348
8349   genericCmp (State.regs[srcreg2], State.regs[dstreg2]);
8350   State.regs[dstreg1] |= State.regs[srcreg1];
8351 }
8352
8353 // 1111 0111 0101 1100 Rm1 Rn1 imm4 Rn2; or_cmp Rm1, Rn1, imm4, Rn2
8354 8.0xf7+8.0x5c+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::or_cmp
8355 "or_cmp"
8356 *am33
8357 *am33_2
8358 {
8359   int srcreg1, dstreg1, dstreg2;
8360
8361   PC = cia;
8362   srcreg1 = translate_rreg (SD_, RM1);
8363   dstreg1 = translate_rreg (SD_, RN1);
8364   dstreg2 = translate_rreg (SD_, RN2);
8365
8366   genericCmp (EXTEND4 (IMM4), State.regs[dstreg2]);
8367   State.regs[dstreg1] |= State.regs[srcreg1];
8368 }
8369   
8370 // 1111 0111 0110 1100 Rm1 Rn1 Rm2 Rn2; or_mov Rm1, Rn1, Rm2, Rn2
8371 8.0xf7+8.0x6c+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::or_mov
8372 "or_mov"
8373 *am33
8374 *am33_2
8375 {
8376   int srcreg1, srcreg2, dstreg1, dstreg2;
8377   int result1;
8378
8379   PC = cia;
8380   srcreg1 = translate_rreg (SD_, RM1);
8381   srcreg2 = translate_rreg (SD_, RM2);
8382   dstreg1 = translate_rreg (SD_, RN1);
8383   dstreg2 = translate_rreg (SD_, RN2);
8384
8385   result1 = State.regs[dstreg1] | State.regs[srcreg1];
8386   State.regs[dstreg2] = State.regs[srcreg2];
8387   State.regs[dstreg1] = result1;
8388 }
8389
8390 // 1111 0111 0111 1100 Rm1 Rn1 imm4 Rn2; or_mov Rm1, Rn1, imm4, Rn2
8391 8.0xf7+8.0x7c+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::or_mov
8392 "or_mov"
8393 *am33
8394 *am33_2
8395 {
8396   int srcreg1, dstreg1, dstreg2;
8397   int result1;
8398
8399   PC = cia;
8400   srcreg1 = translate_rreg (SD_, RM1);
8401   dstreg1 = translate_rreg (SD_, RN1);
8402   dstreg2 = translate_rreg (SD_, RN2);
8403
8404   result1 = State.regs[dstreg1] | State.regs[srcreg1];
8405   State.regs[dstreg2] = EXTEND4 (IMM4);
8406   State.regs[dstreg1] = result1;
8407 }
8408   
8409 // 1111 0111 1000 1100 Rm1 Rn1 Rm2 Rn2; or_asr Rm1, Rn1, Rm2, Rn2
8410 8.0xf7+8.0x8c+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::or_asr
8411 "or_asr"
8412 *am33
8413 *am33_2
8414 {
8415   int srcreg1, srcreg2, dstreg1, dstreg2;
8416   int result1;
8417   signed int temp;
8418
8419   PC = cia;
8420   srcreg1 = translate_rreg (SD_, RM1);
8421   srcreg2 = translate_rreg (SD_, RM2);
8422   dstreg1 = translate_rreg (SD_, RN1);
8423   dstreg2 = translate_rreg (SD_, RN2);
8424
8425   result1 = State.regs[dstreg1] | State.regs[srcreg1];
8426   temp = State.regs[dstreg2];
8427   temp >>= State.regs[srcreg2];
8428   State.regs[dstreg2] = temp;
8429   State.regs[dstreg1] = result1;
8430 }
8431
8432 // 1111 0111 1001 1100 Rm1 Rn1 imm4 Rn2; or_asr Rm1, Rn1, imm4, Rn2
8433 8.0xf7+8.0x9c+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::or_asr
8434 "or_asr"
8435 *am33
8436 *am33_2
8437 {
8438   int srcreg1, dstreg1, dstreg2;
8439   int result1;
8440   signed int temp;
8441
8442   PC = cia;
8443   srcreg1 = translate_rreg (SD_, RM1);
8444   dstreg1 = translate_rreg (SD_, RN1);
8445   dstreg2 = translate_rreg (SD_, RN2);
8446
8447   result1 = State.regs[dstreg1] | State.regs[srcreg1];
8448   temp = State.regs[dstreg2];
8449   temp >>= IMM4;
8450   State.regs[dstreg2] = temp;
8451   State.regs[dstreg1] = result1;
8452 }
8453   
8454 // 1111 0111 1010 1100 Rm1 Rn1 Rm2 Rn2; or_lsr Rm1, Rn1, Rm2, Rn2
8455 8.0xf7+8.0xac+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::or_lsr
8456 "or_lsr"
8457 *am33
8458 *am33_2
8459 {
8460   int srcreg1, srcreg2, dstreg1, dstreg2;
8461   int result1;
8462
8463   PC = cia;
8464   srcreg1 = translate_rreg (SD_, RM1);
8465   srcreg2 = translate_rreg (SD_, RM2);
8466   dstreg1 = translate_rreg (SD_, RN1);
8467   dstreg2 = translate_rreg (SD_, RN2);
8468
8469   result1 = State.regs[dstreg1] | State.regs[srcreg1];
8470   State.regs[dstreg2] >>= State.regs[srcreg2];
8471   State.regs[dstreg1] = result1;
8472 }
8473
8474 // 1111 0111 1011 1100 Rm1 Rn1 imm4 Rn2; or_lsr Rm1, Rn1, imm4, Rn2
8475 8.0xf7+8.0xbc+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::or_lsr
8476 "or_lsr"
8477 *am33
8478 *am33_2
8479 {
8480   int srcreg1, dstreg1, dstreg2;
8481   int result1;
8482
8483   PC = cia;
8484   srcreg1 = translate_rreg (SD_, RM1);
8485   dstreg1 = translate_rreg (SD_, RN1);
8486   dstreg2 = translate_rreg (SD_, RN2);
8487
8488   result1 = State.regs[dstreg1] | State.regs[srcreg1];
8489   State.regs[dstreg2] >>= IMM4;
8490   State.regs[dstreg1] = result1;
8491 }
8492   
8493   
8494 // 1111 0111 1100 1100 Rm1 Rn1 Rm2 Rn2; or_asl Rm1, Rn1, Rm2, Rn2
8495 8.0xf7+8.0xcc+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::or_asl
8496 "or_asl"
8497 *am33
8498 *am33_2
8499 {
8500   int srcreg1, srcreg2, dstreg1, dstreg2;
8501   int result1;
8502
8503   PC = cia;
8504   srcreg1 = translate_rreg (SD_, RM1);
8505   srcreg2 = translate_rreg (SD_, RM2);
8506   dstreg1 = translate_rreg (SD_, RN1);
8507   dstreg2 = translate_rreg (SD_, RN2);
8508
8509   result1 = State.regs[dstreg1] | State.regs[srcreg1];
8510   State.regs[dstreg2] <<= State.regs[srcreg2];
8511   State.regs[dstreg1] = result1;
8512 }
8513
8514 // 1111 0111 1101 1100 Rm1 Rn1 imm4 Rn2; or_asl Rm1, Rn1, imm4, Rn2
8515 8.0xf7+8.0xdc+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::or_asl
8516 "or_asl"
8517 *am33
8518 *am33_2
8519 {
8520   int srcreg1, dstreg1, dstreg2;
8521   int result1;
8522
8523   PC = cia;
8524   srcreg1 = translate_rreg (SD_, RM1);
8525   dstreg1 = translate_rreg (SD_, RN1);
8526   dstreg2 = translate_rreg (SD_, RN2);
8527
8528   result1 = State.regs[dstreg1] | State.regs[srcreg1];
8529   State.regs[dstreg2] <<= IMM4;
8530   State.regs[dstreg1] = result1;
8531 }
8532
8533 // 1111 0111 0000 1101 Rm1 Rn1 Rm2 Rn2; sat16_add Rm1, Rn1, Rm2, Rn2
8534 8.0xf7+8.0x0d+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::sat16_add
8535 "sat16_add"
8536 *am33
8537 *am33_2
8538 {
8539   int srcreg1, srcreg2, dstreg1, dstreg2;
8540   int result1;
8541
8542   PC = cia;
8543   srcreg1 = translate_rreg (SD_, RM1);
8544   srcreg2 = translate_rreg (SD_, RM2);
8545   dstreg1 = translate_rreg (SD_, RN1);
8546   dstreg2 = translate_rreg (SD_, RN2);
8547
8548   if (State.regs[srcreg1] >= 0x7fff)
8549     result1 = 0x7fff;
8550   else if (State.regs[srcreg1] <= 0xffff8000)
8551     result1 = 0xffff8000;
8552   else
8553     result1 = State.regs[srcreg1];
8554
8555   State.regs[dstreg2] += State.regs[srcreg2];
8556   State.regs[dstreg1] = result1;
8557 }
8558
8559 // 1111 0111 0001 1101 Rm1 Rn1 imm4 Rn2; sat16_add Rm1, Rn1, imm4, Rn2
8560 8.0xf7+8.0x1d+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::sat16_add
8561 "sat16_add"
8562 *am33
8563 *am33_2
8564 {
8565   int srcreg1, dstreg1, dstreg2;
8566   int result1;
8567
8568   PC = cia;
8569   srcreg1 = translate_rreg (SD_, RM1);
8570   dstreg1 = translate_rreg (SD_, RN1);
8571   dstreg2 = translate_rreg (SD_, RN2);
8572
8573   if (State.regs[srcreg1] >= 0x7fff)
8574     result1 = 0x7fff;
8575   else if (State.regs[srcreg1] <= 0xffff8000)
8576     result1 = 0xffff8000;
8577   else
8578     result1 = State.regs[srcreg1];
8579
8580   State.regs[dstreg2] += EXTEND4 (IMM4);
8581   State.regs[dstreg1] = result1;
8582 }
8583   
8584 // 1111 0111 0010 1101 Rm1 Rn1 Rm2 Rn2; sat16_sub Rm1, Rn1, Rm2, Rn2
8585 8.0xf7+8.0x2d+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::sat16_sub
8586 "sat16_sub"
8587 *am33
8588 *am33_2
8589 {
8590   int srcreg1, srcreg2, dstreg1, dstreg2;
8591   int result1;
8592
8593   PC = cia;
8594   srcreg1 = translate_rreg (SD_, RM1);
8595   srcreg2 = translate_rreg (SD_, RM2);
8596   dstreg1 = translate_rreg (SD_, RN1);
8597   dstreg2 = translate_rreg (SD_, RN2);
8598
8599   if (State.regs[srcreg1] >= 0x7fff)
8600     result1 = 0x7fff;
8601   else if (State.regs[srcreg1] <= 0xffff8000)
8602     result1 = 0xffff8000;
8603   else
8604     result1 = State.regs[srcreg1];
8605
8606   State.regs[dstreg2] -= State.regs[srcreg2];
8607   State.regs[dstreg1] = result1;
8608 }
8609
8610 // 1111 0111 0011 1101 Rm1 Rn1 imm4 Rn2; sat16_sub Rm1, Rn1, imm4, Rn2
8611 8.0xf7+8.0x3d+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::sat16_sub
8612 "sat16_sub"
8613 *am33
8614 *am33_2
8615 {
8616   int srcreg1, dstreg1, dstreg2;
8617   int result1;
8618
8619   PC = cia;
8620   srcreg1 = translate_rreg (SD_, RM1);
8621   dstreg1 = translate_rreg (SD_, RN1);
8622   dstreg2 = translate_rreg (SD_, RN2);
8623
8624   if (State.regs[srcreg1] >= 0x7fff)
8625     result1 = 0x7fff;
8626   else if (State.regs[srcreg1] <= 0xffff8000)
8627     result1 = 0xffff8000;
8628   else
8629     result1 = State.regs[srcreg1];
8630
8631   State.regs[dstreg2] -= EXTEND4 (IMM4);
8632   State.regs[dstreg1] = result1;
8633 }
8634   
8635 // 1111 0111 0100 1101 Rm1 Rn1 Rm2 Rn2; sat16_cmp Rm1, Rn1, Rm2, Rn2
8636 8.0xf7+8.0x4d+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::sat16_cmp
8637 "sat16_cmp"
8638 *am33
8639 *am33_2
8640 {
8641   int srcreg1, srcreg2, dstreg1, dstreg2;
8642
8643   PC = cia;
8644   srcreg1 = translate_rreg (SD_, RM1);
8645   srcreg2 = translate_rreg (SD_, RM2);
8646   dstreg1 = translate_rreg (SD_, RN1);
8647   dstreg2 = translate_rreg (SD_, RN2);
8648
8649   genericCmp (State.regs[dstreg2], State.regs[dstreg1]);
8650   if (State.regs[srcreg1] >= 0x7fff)
8651     State.regs[dstreg1] = 0x7fff;
8652   else if (State.regs[srcreg1] <= 0xffff8000)
8653     State.regs[dstreg1] = 0xffff8000;
8654   else
8655     State.regs[dstreg1] = State.regs[srcreg1];
8656 }
8657
8658 // 1111 0111 0101 1101 Rm1 Rn1 imm4 Rn2; sat16_cmp Rm1, Rn1, imm4, Rn2
8659 8.0xf7+8.0x5d+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::sat16_cmp
8660 "sat16_cmp"
8661 *am33
8662 *am33_2
8663 {
8664   int srcreg1, dstreg1, dstreg2;
8665
8666   PC = cia;
8667   srcreg1 = translate_rreg (SD_, RM1);
8668   dstreg1 = translate_rreg (SD_, RN1);
8669   dstreg2 = translate_rreg (SD_, RN2);
8670
8671   genericCmp (EXTEND4 (IMM4), State.regs[dstreg2]);
8672   if (State.regs[srcreg1] >= 0x7fff)
8673     State.regs[dstreg1] = 0x7fff;
8674   else if (State.regs[srcreg1] <= 0xffff8000)
8675     State.regs[dstreg1] = 0xffff8000;
8676   else
8677     State.regs[dstreg1] = State.regs[srcreg1];
8678 }
8679   
8680 // 1111 0111 0110 1101 Rm1 Rn1 Rm2 Rn2; sat16_mov Rm1, Rn1, Rm2, Rn2
8681 8.0xf7+8.0x6d+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::sat16_mov
8682 "sat16_mov"
8683 *am33
8684 *am33_2
8685 {
8686   int srcreg1, srcreg2, dstreg1, dstreg2;
8687   int result1;
8688
8689   PC = cia;
8690   srcreg1 = translate_rreg (SD_, RM1);
8691   srcreg2 = translate_rreg (SD_, RM2);
8692   dstreg1 = translate_rreg (SD_, RN1);
8693   dstreg2 = translate_rreg (SD_, RN2);
8694
8695   if (State.regs[srcreg1] >= 0x7fff)
8696     result1 = 0x7fff;
8697   else if (State.regs[srcreg1] <= 0xffff8000)
8698     result1 = 0xffff8000;
8699   else
8700     result1 = State.regs[srcreg1];
8701
8702   State.regs[dstreg2] = State.regs[srcreg2];
8703   State.regs[dstreg1] = result1;
8704 }
8705
8706 // 1111 0111 0111 1101 Rm1 Rn1 imm4 Rn2; sat16_mov Rm1, Rn1, imm4, Rn2
8707 8.0xf7+8.0x7d+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::sat16_mov
8708 "sat16_mov"
8709 *am33
8710 *am33_2
8711 {
8712   int srcreg1, dstreg1, dstreg2;
8713   int result1;
8714
8715   PC = cia;
8716   srcreg1 = translate_rreg (SD_, RM1);
8717   dstreg1 = translate_rreg (SD_, RN1);
8718   dstreg2 = translate_rreg (SD_, RN2);
8719
8720   if (State.regs[srcreg1] >= 0x7fff)
8721     result1 = 0x7fff;
8722   else if (State.regs[srcreg1] <= 0xffff8000)
8723     result1 = 0xffff8000;
8724   else
8725     result1 = State.regs[srcreg1];
8726
8727   State.regs[dstreg2] = EXTEND4 (IMM4);
8728   State.regs[dstreg1] = result1;
8729 }
8730   
8731 // 1111 0111 1000 1101 Rm1 Rn1 Rm2 Rn2; sat16_asr Rm1, Rn1, Rm2, Rn2
8732 8.0xf7+8.0x8d+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::sat16_asr
8733 "sat16_asr"
8734 *am33
8735 *am33_2
8736 {
8737   int srcreg1, srcreg2, dstreg1, dstreg2;
8738   int result1;
8739   signed int temp;
8740
8741   PC = cia;
8742   srcreg1 = translate_rreg (SD_, RM1);
8743   srcreg2 = translate_rreg (SD_, RM2);
8744   dstreg1 = translate_rreg (SD_, RN1);
8745   dstreg2 = translate_rreg (SD_, RN2);
8746
8747   if (State.regs[srcreg1] >= 0x7fff)
8748     result1 = 0x7fff;
8749   else if (State.regs[srcreg1] <= 0xffff8000)
8750     result1 = 0xffff8000;
8751   else
8752     result1 = State.regs[srcreg1];
8753
8754   temp = State.regs[dstreg2];
8755   temp >>= State.regs[srcreg2];
8756   State.regs[dstreg2] = temp;
8757   State.regs[dstreg1] = result1;
8758 }
8759
8760 // 1111 0111 1001 1101 Rm1 Rn1 imm4 Rn2; sat16_asr Rm1, Rn1, imm4, Rn2
8761 8.0xf7+8.0x9d+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::sat16_asr
8762 "sat16_asr"
8763 *am33
8764 *am33_2
8765 {
8766   int srcreg1, dstreg1, dstreg2;
8767   int result1;
8768   signed int temp;
8769
8770   PC = cia;
8771   srcreg1 = translate_rreg (SD_, RM1);
8772   dstreg1 = translate_rreg (SD_, RN1);
8773   dstreg2 = translate_rreg (SD_, RN2);
8774
8775   if (State.regs[srcreg1] >= 0x7fff)
8776     result1 = 0x7fff;
8777   else if (State.regs[srcreg1] <= 0xffff8000)
8778     result1 = 0xffff8000;
8779   else
8780     result1 = State.regs[srcreg1];
8781
8782   temp = State.regs[dstreg2];
8783   temp >>= IMM4;
8784   State.regs[dstreg2] = temp;
8785   State.regs[dstreg1] = result1;
8786 }
8787   
8788 // 1111 0111 1010 1101 Rm1 Rn1 Rm2 Rn2; sat16_lsr Rm1, Rn1, Rm2, Rn2
8789 8.0xf7+8.0xad+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::sat16_lsr
8790 "sat16_lsr"
8791 *am33
8792 *am33_2
8793 {
8794   int srcreg1, srcreg2, dstreg1, dstreg2;
8795   int result1;
8796
8797   PC = cia;
8798   srcreg1 = translate_rreg (SD_, RM1);
8799   srcreg2 = translate_rreg (SD_, RM2);
8800   dstreg1 = translate_rreg (SD_, RN1);
8801   dstreg2 = translate_rreg (SD_, RN2);
8802
8803   if (State.regs[srcreg1] >= 0x7fff)
8804     result1 = 0x7fff;
8805   else if (State.regs[srcreg1] <= 0xffff8000)
8806     result1 = 0xffff8000;
8807   else
8808     result1 = State.regs[srcreg1];
8809
8810   State.regs[dstreg2] >>= State.regs[srcreg2];
8811   State.regs[dstreg1] = result1;
8812 }
8813
8814 // 1111 0111 1011 1101 Rm1 Rn1 imm4 Rn2; sat16_lsr Rm1, Rn1, imm4, Rn2
8815 8.0xf7+8.0xbd+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::sat16_lsr
8816 "sat16_lsr"
8817 *am33
8818 *am33_2
8819 {
8820   int srcreg1, dstreg1, dstreg2;
8821   int result1;
8822
8823   PC = cia;
8824   srcreg1 = translate_rreg (SD_, RM1);
8825   dstreg1 = translate_rreg (SD_, RN1);
8826   dstreg2 = translate_rreg (SD_, RN2);
8827
8828   if (State.regs[srcreg1] >= 0x7fff)
8829     result1 = 0x7fff;
8830   else if (State.regs[srcreg1] <= 0xffff8000)
8831     result1 = 0xffff8000;
8832   else
8833     result1 = State.regs[srcreg1];
8834
8835   State.regs[dstreg2] >>= IMM4;
8836   State.regs[dstreg1] = result1;
8837 }
8838   
8839   
8840 // 1111 0111 1100 1101 Rm1 Rn1 Rm2 Rn2; sat16_asl Rm1, Rn1, Rm2, Rn2
8841 8.0xf7+8.0xcd+4.RM1,4.RN1+4.RM2,4.RN2!RN1:D2:::sat16_asl
8842 "sat16_asl"
8843 *am33
8844 *am33_2
8845 {
8846   int srcreg1, srcreg2, dstreg1, dstreg2;
8847   int result1;
8848
8849   PC = cia;
8850   srcreg1 = translate_rreg (SD_, RM1);
8851   srcreg2 = translate_rreg (SD_, RM2);
8852   dstreg1 = translate_rreg (SD_, RN1);
8853   dstreg2 = translate_rreg (SD_, RN2);
8854
8855   if (State.regs[srcreg1] >= 0x7fff)
8856     result1 = 0x7fff;
8857   else if (State.regs[srcreg1] <= 0xffff8000)
8858     result1 = 0xffff8000;
8859   else
8860     result1 = State.regs[srcreg1];
8861
8862   State.regs[dstreg2] <<= State.regs[srcreg2];
8863   State.regs[dstreg1] = result1;
8864 }
8865
8866 // 1111 0111 1101 1101 Rm1 Rn1 imm4 Rn2; sat16_asl Rm1, Rn1, imm4, Rn2
8867 8.0xf7+8.0xdd+4.RM1,4.RN1+4.IMM4,4.RN2!RN1:D2b:::sat16_asl
8868 "sat16_asl"
8869 *am33
8870 *am33_2
8871 {
8872   int srcreg1, dstreg1, dstreg2;
8873   int result1;
8874
8875   PC = cia;
8876   srcreg1 = translate_rreg (SD_, RM1);
8877   dstreg1 = translate_rreg (SD_, RN1);
8878   dstreg2 = translate_rreg (SD_, RN2);
8879
8880   if (State.regs[srcreg1] >= 0x7fff)
8881     result1 = 0x7fff;
8882   else if (State.regs[srcreg1] <= 0xffff8000)
8883     result1 = 0xffff8000;
8884   else
8885     result1 = State.regs[srcreg1];
8886
8887   State.regs[dstreg2] <<= IMM4;
8888   State.regs[dstreg1] = result1;
8889 }
8890
8891 // 1111 0111 1110 0000 Rm1 Rn1 imm4 0000; mov_llt (Rm+,imm4),Rn
8892 8.0xf7+8.0xe0+4.RN,4.RM!RN+4.IMM4,4.0x0:D2:::mov_llt
8893 "mov_llt"
8894 *am33
8895 *am33_2
8896 {
8897   int srcreg, dstreg;
8898
8899   PC = cia;
8900   srcreg = translate_rreg (SD_, RM);
8901   dstreg = translate_rreg (SD_, RN);
8902
8903   State.regs[dstreg] = load_word (State.regs[srcreg]);
8904   State.regs[srcreg] += EXTEND4 (IMM4);
8905
8906   if (((PSW & PSW_N) != 0) ^ ((PSW & PSW_V) != 0))
8907     {
8908       State.regs[REG_PC] = State.regs[REG_LAR] - 4;
8909       nia = PC;
8910     }
8911 }
8912
8913 // 1111 0111 1110 0000 Rm1 Rn1 imm4 0001; mov_lgt (Rm+,imm4),Rn
8914 8.0xf7+8.0xe0+4.RN,4.RM!RN+4.IMM4,4.0x1:D2:::mov_lgt
8915 "mov_lgt"
8916 *am33
8917 *am33_2
8918 {
8919   int srcreg, dstreg;
8920
8921   PC = cia;
8922   srcreg = translate_rreg (SD_, RM);
8923   dstreg = translate_rreg (SD_, RN);
8924
8925   State.regs[dstreg] = load_word (State.regs[srcreg]);
8926   State.regs[srcreg] += EXTEND4 (IMM4);
8927
8928   if (!((PSW & PSW_Z)
8929         || (((PSW & PSW_N) != 0) ^ ((PSW & PSW_V) != 0))))
8930     {
8931       State.regs[REG_PC] = State.regs[REG_LAR] - 4;
8932       nia = PC;
8933     }
8934 }
8935
8936 // 1111 0111 1110 0000 Rm1 Rn1 imm4 0010; mov_lge (Rm+,imm4),Rn
8937 8.0xf7+8.0xe0+4.RN,4.RM!RN+4.IMM4,4.0x2:D2:::mov_lge
8938 "mov_lge"
8939 *am33
8940 *am33_2
8941 {
8942   int srcreg, dstreg;
8943
8944   PC = cia;
8945   srcreg = translate_rreg (SD_, RM);
8946   dstreg = translate_rreg (SD_, RN);
8947
8948   State.regs[dstreg] = load_word (State.regs[srcreg]);
8949   State.regs[srcreg] += EXTEND4 (IMM4);
8950
8951   if (!(((PSW & PSW_N) != 0) ^ ((PSW & PSW_V) != 0)))
8952     {
8953       State.regs[REG_PC] = State.regs[REG_LAR] - 4;
8954       nia = PC;
8955     }
8956 }
8957
8958 // 1111 0111 1110 0000 Rm1 Rn1 imm4 0011; mov_lle (Rm+,imm4),Rn
8959 8.0xf7+8.0xe0+4.RN,4.RM!RN+4.IMM4,4.0x3:D2:::mov_lle
8960 "mov_lle"
8961 *am33
8962 *am33_2
8963 {
8964   int srcreg, dstreg;
8965
8966   PC = cia;
8967   srcreg = translate_rreg (SD_, RM);
8968   dstreg = translate_rreg (SD_, RN);
8969
8970   State.regs[dstreg] = load_word (State.regs[srcreg]);
8971   State.regs[srcreg] += EXTEND4 (IMM4);
8972
8973   if ((PSW & PSW_Z)
8974       || (((PSW & PSW_N) != 0) ^ ((PSW & PSW_V) != 0)))
8975     {
8976       State.regs[REG_PC] = State.regs[REG_LAR] - 4;
8977       nia = PC;
8978     }
8979 }
8980
8981 // 1111 0111 1110 0000 Rm1 Rn1 imm4 0100; mov_lcs (Rm+,imm4),Rn
8982 8.0xf7+8.0xe0+4.RN,4.RM!RN+4.IMM4,4.0x4:D2:::mov_lcs
8983 "mov_lcs"
8984 *am33
8985 *am33_2
8986 {
8987   int srcreg, dstreg;
8988
8989   PC = cia;
8990   srcreg = translate_rreg (SD_, RM);
8991   dstreg = translate_rreg (SD_, RN);
8992
8993   State.regs[dstreg] = load_word (State.regs[srcreg]);
8994   State.regs[srcreg] += EXTEND4 (IMM4);
8995
8996   if (PSW & PSW_C)
8997     {
8998       State.regs[REG_PC] = State.regs[REG_LAR] - 4;
8999       nia = PC;
9000     }
9001 }
9002
9003 // 1111 0111 1110 0000 Rm1 Rn1 imm4 0101; mov_lhi (Rm+,imm4),Rn
9004 8.0xf7+8.0xe0+4.RN,4.RM!RN+4.IMM4,4.0x5:D2:::mov_lhi
9005 "mov_lhi"
9006 *am33
9007 *am33_2
9008 {
9009   int srcreg, dstreg;
9010
9011   PC = cia;
9012   srcreg = translate_rreg (SD_, RM);
9013   dstreg = translate_rreg (SD_, RN);
9014
9015   State.regs[dstreg] = load_word (State.regs[srcreg]);
9016   State.regs[srcreg] += EXTEND4 (IMM4);
9017
9018   if (!(((PSW & PSW_C) != 0) || (PSW & PSW_Z) != 0))
9019     {
9020       State.regs[REG_PC] = State.regs[REG_LAR] - 4;
9021       nia = PC;
9022     }
9023 }
9024
9025 // 1111 0111 1110 0000 Rm1 Rn1 imm4 0110; mov_lcc (Rm+,imm4),Rn
9026 8.0xf7+8.0xe0+4.RN,4.RM!RN+4.IMM4,4.0x6:D2:::mov_lcc
9027 "mov_lcc"
9028 *am33
9029 *am33_2
9030 {
9031   int srcreg, dstreg;
9032
9033   PC = cia;
9034   srcreg = translate_rreg (SD_, RM);
9035   dstreg = translate_rreg (SD_, RN);
9036
9037   State.regs[dstreg] = load_word (State.regs[srcreg]);
9038   State.regs[srcreg] += EXTEND4 (IMM4);
9039
9040   if (!(PSW & PSW_C))
9041     {
9042       State.regs[REG_PC] = State.regs[REG_LAR] - 4;
9043       nia = PC;
9044     }
9045 }
9046
9047 // 1111 0111 1110 0000 Rm1 Rn1 imm4 0111; mov_lls (Rm+,imm4),Rn
9048 8.0xf7+8.0xe0+4.RN,4.RM!RN+4.IMM4,4.0x7:D2:::mov_lls
9049 "mov_lls"
9050 *am33
9051 *am33_2
9052 {
9053   int srcreg, dstreg;
9054
9055   PC = cia;
9056   srcreg = translate_rreg (SD_, RM);
9057   dstreg = translate_rreg (SD_, RN);
9058
9059   State.regs[dstreg] = load_word (State.regs[srcreg]);
9060   State.regs[srcreg] += EXTEND4 (IMM4);
9061
9062   if (((PSW & PSW_C) != 0) || (PSW & PSW_Z) != 0)
9063     {
9064       State.regs[REG_PC] = State.regs[REG_LAR] - 4;
9065       nia = PC;
9066     }
9067 }
9068
9069 // 1111 0111 1110 0000 Rm1 Rn1 imm4 1000; mov_leq (Rm+,imm4),Rn
9070 8.0xf7+8.0xe0+4.RN,4.RM!RN+4.IMM4,4.0x8:D2:::mov_leq
9071 "mov_leq"
9072 *am33
9073 *am33_2
9074 {
9075   int srcreg, dstreg;
9076
9077   PC = cia;
9078   srcreg = translate_rreg (SD_, RM);
9079   dstreg = translate_rreg (SD_, RN);
9080
9081   State.regs[dstreg] = load_word (State.regs[srcreg]);
9082   State.regs[srcreg] += EXTEND4 (IMM4);
9083
9084   if (PSW & PSW_Z)
9085     {
9086       State.regs[REG_PC] = State.regs[REG_LAR] - 4;
9087       nia = PC;
9088     }
9089 }
9090
9091 // 1111 0111 1110 0000 Rm1 Rn1 imm4 1001; mov_lne (Rm+,imm4),Rn
9092 8.0xf7+8.0xe0+4.RN,4.RM!RN+4.IMM4,4.0x9:D2:::mov_lne
9093 "mov_lne"
9094 *am33
9095 *am33_2
9096 {
9097   int srcreg, dstreg;
9098
9099   PC = cia;
9100   srcreg = translate_rreg (SD_, RM);
9101   dstreg = translate_rreg (SD_, RN);
9102
9103   State.regs[dstreg] = load_word (State.regs[srcreg]);
9104   State.regs[srcreg] += EXTEND4 (IMM4);
9105
9106   if (!(PSW & PSW_Z))
9107     {
9108       State.regs[REG_PC] = State.regs[REG_LAR] - 4;
9109       nia = PC;
9110     }
9111 }
9112
9113 // 1111 0111 1110 0000 Rm1 Rn1 imm4 1010; mov_lra (Rm+,imm4),Rn
9114 8.0xf7+8.0xe0+4.RN,4.RM!RN+4.IMM4,4.0xa:D2:::mov_lra
9115 "mov_lra"
9116 *am33
9117 *am33_2
9118 {
9119   int srcreg, dstreg;
9120
9121   PC = cia;
9122   srcreg = translate_rreg (SD_, RM);
9123   dstreg = translate_rreg (SD_, RN);
9124
9125   State.regs[dstreg] = load_word (State.regs[srcreg]);
9126   State.regs[srcreg] += EXTEND4 (IMM4);
9127
9128   State.regs[REG_PC] = State.regs[REG_LAR] - 4;
9129   nia = PC;
9130 }
9131
9132 :include::am33_2:am33-2.igen