// -*- C -*- // // toshiba specific instructions. // 011100,5.RS,5.RT,5.RD,00000000000:MMINORM:::MADD "madd r<RS>, r<RT>":RD == 0 "madd r<RD>, r<RS>, r<RT>" *r3900 { signed64 prod = (U8_4 (VL4_8 (HI), VL4_8 (LO)) + ((signed64) EXTEND32 (GPR[RT]) * (signed64) EXTEND32 (GPR[RS]))); check_mult_hilo (SD_, HIHISTORY, LOHISTORY); TRACE_ALU_INPUT2 (GPR[RS], GPR[RT]); LO = EXTEND32 (prod); HI = EXTEND32 (VH4_8 (prod)); TRACE_ALU_RESULT2 (HI, LO); if(RD != 0 ) GPR[RD] = LO; } 011100,5.RS,5.RT,5.RD,00000000001:MMINORM:::MADDU "maddu r<RS>, r<RT>":RD == 0 "maddu r<RD>, r<RS>, r<RT>" *r3900 { unsigned64 prod = (U8_4 (VL4_8 (HI), VL4_8 (LO)) + ((unsigned64) VL4_8 (GPR[RS]) * (unsigned64) VL4_8 (GPR[RT]))); check_mult_hilo (SD_, HIHISTORY, LOHISTORY); TRACE_ALU_INPUT2 (GPR[RS], GPR[RT]); LO = EXTEND32 (prod); HI = EXTEND32 (VH4_8 (prod)); TRACE_ALU_RESULT2 (HI, LO); if(RD != 0) GPR[RD] = LO; } 000000,CODE.20,001110::CO1:::SDBBP "sdbbp" *r3900: { SignalException (DebugBreakPoint, instruction); } |