3
3-69 M32R-FPU Software Manual (Rev.1.01)

MACHIMACHI

DSP function instruction

Multiply-accumulate high-order halfwords

[Mnemonic]

MACHI Rsrc1,Rsrc2

[Function]
Multiply and add
accumulator += (( signed) (Rsrc1 & 0xffff0000) * (signed short) (Rsrc2 >> 16));
[Description]
MACHI multiplies the high-order 16 bits of Rsrc1 and the high-order 16 bits of Rsrc2, then adds
the result to the low-order 56 bits in the accumulator.
The LSB of the multiplication result is aligned with bit 47 in the accumulator, and the portion
corresponding to bits 8 through 15 of the accumulator is sign-extended before addition. The
result of the addition is stored in the accumulator. The high-order 16 bits of Rsrc1 and Rsrc2 are
treated as signed values.
The condition bit (C) is unchanged.
[EIT occurrence]
None
[Encoding]

src10011 MACHI Rsrc1,Rsrc2src20100

Rsrc1
high-order 16 bits
Rsrc2
high-order 16 bits
x
0151631
0Result of the multiplication
Value in accumulator before the
execution of the MACHI instruction
Value in accumulator after the
execution of the MACHI instruction
Sign extension
Sign extension
+
01516313247486378
INSTRUCTIONS
3.2 Instruction description