
CPU16
REFERENCE MANUAL
INSTRUCTION GLOSSARY
MOTOROLA
6-179
RMAC
Operation:
Repeating Multiply and Accumulate
RMAC
Repeat:
(AM)
+
((HR)
(IR))
AM
((IX)
≤
X MASK)
((IX)
+
xo)
≤
X MASK)
IX
((IY)
≤
Y MASK)
((IY)
+
yo)
≤
Y MASK)
IY
(M
:
M
+
1)
X
HR
(M
:
M
+
1)
Y
IR
(E)
$0001
EUntil (E)
<
$0000
Description:
Performs repeated multiplication of 16-bit signed fractional multipli-
cands in MAC register I by 16-bit signed fractional multipliers in MAC
register H. Each product is added to the content of accumulator M.
Accumulator D is used for temporary storage during multiplication. A
16-bit signed integer in accumulator E determines the number of
repetitions.
There are implied radix points between bits 15 and 14 of HR and IR.
Each product is left-shifted one place to align the radix point be-
tween bits 31 and 30 before addition to AM.
As multiply and accumulate operations take place, 4-bit offsets xo
and yo are sign-extended to 16 bits and used with X and Y masks to
qualify the X and Y index registers.
Writing a non-zero value into a mask register prior to RMAC execu-
tion enables modulo addressing. The TDMSK instruction writes
mask values. When a mask contains $0, modulo addressing is dis-
abled, and the sign-extended offset is added to the content of the
corresponding index register.
After accumulation, a word pointed to by XK : IX is loaded into HR,
and a word pointed to by YK : IY is loaded into IR, then the value in
E is decremented and tested. After execution, content of E is inde-
terminate.
F
Freescale Semiconductor, Inc.
For More Information On This Product,
Go to: www.freescale.com
n
.