tx.igen 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. // -*- C -*-
  2. //
  3. // toshiba specific instructions.
  4. //
  5. 011100,5.RS,5.RT,5.RD,00000000000:MMINORM:::MADD
  6. "madd r<RS>, r<RT>":RD == 0
  7. "madd r<RD>, r<RS>, r<RT>"
  8. *r3900
  9. {
  10. int64_t prod = (U8_4 (VL4_8 (HI), VL4_8 (LO))
  11. + ((int64_t) EXTEND32 (GPR[RT])
  12. * (int64_t) EXTEND32 (GPR[RS])));
  13. check_mult_hilo (SD_, HIHISTORY, LOHISTORY);
  14. TRACE_ALU_INPUT2 (GPR[RS], GPR[RT]);
  15. LO = EXTEND32 (prod);
  16. HI = EXTEND32 (VH4_8 (prod));
  17. TRACE_ALU_RESULT2 (HI, LO);
  18. if (RD != 0)
  19. GPR[RD] = LO;
  20. }
  21. 011100,5.RS,5.RT,5.RD,00000000001:MMINORM:::MADDU
  22. "maddu r<RS>, r<RT>":RD == 0
  23. "maddu r<RD>, r<RS>, r<RT>"
  24. *r3900
  25. {
  26. uint64_t prod = (U8_4 (VL4_8 (HI), VL4_8 (LO))
  27. + ((uint64_t) VL4_8 (GPR[RS])
  28. * (uint64_t) VL4_8 (GPR[RT])));
  29. check_mult_hilo (SD_, HIHISTORY, LOHISTORY);
  30. TRACE_ALU_INPUT2 (GPR[RS], GPR[RT]);
  31. LO = EXTEND32 (prod);
  32. HI = EXTEND32 (VH4_8 (prod));
  33. TRACE_ALU_RESULT2 (HI, LO);
  34. if (RD != 0)
  35. GPR[RD] = LO;
  36. }
  37. 000000,CODE.20,001110::CO1:::SDBBP
  38. "sdbbp"
  39. *r3900:
  40. {
  41. SignalException (DebugBreakPoint, instruction);
  42. }