4 loop sequencing rules, Loop sequencing rules -55, Active lcn write at the start of a loop -55 – Freescale Semiconductor StarCore SC140 User Manual
Page 305: Active san write at the end of long loops -55

LPMARK Rules
SC140 DSP Core Reference Manual
7-55
LPMARK Rule L.L.6
A MOVE-like instruction that writes the SR register is not allowed at LPA-2, LPA-1, LPB-2 or LPB-1 of a
short loop.
7.8.3.4 Loop Sequencing Rules
LPMARK Rule L.D.2 + L.D.3
The minimum number of VLES between the following instructions that write the active LCn register and
LPA or LPB of a loop is:
•
DOENn/DOENSHn Rn or #x: one VLES (address register or immediate value)
•
DOENn/DOENSHn Dn: two VLES (data register)
•
MOVE-like instruction that writes the active LCn register: two VLES
Example 7-95. Active LCn Write at the Start of a Loop
move.w #3,d0
doensh0 d0
;allowed
move.l d1,lc0
;not allowed
move.w #2,d2
inc d1
{lpmarka set}
move.w #3,r8
dosetup1 label1
doen1 r8
;not allowed
label1 inc d3
{lpmarkb set}
inc d4
inc d5
LPMARK Rule L.D.6
At least one VLES is required between an instruction that writes the active SAn register and LPA or LPB
of a long loop.
Example 7-96. Active SAn Write at the End of Long Loops
doen0 #5
dosetup0 label
;not allowed
label
inc d2
{lpmarkb set}
inc d1
inc d0
LPMARK Rule L.D.8 + L.D.9
At least one VLES is required between a MOVE-like instruction that reads the active LCn register and
LPA or LPB of a loop.