beautypg.com

Break, Terminate the loop and branch, Operation assembler syntax – Freescale Semiconductor StarCore SC140 User Manual

Page 417

background image

BREAK

SC140 DSP Core Reference Manual

A-103

BREAK

Terminate the Loop and Branch

BREAK

to an Address (AGU)

Description

Status and Conditions that Affect Instruction

Status and Conditions Changed by Instruction

Example

break _label

Note:

The assembler has calculated the displacement $C to increment the program counter from its value
at the BREAK ($0000 0014) to its value at _label ($0000 0020). LF3 is cleared by the break.

Operation

Assembler Syntax

PC + displacement

→ PC

0

→ LFn

BREAK label

BREAK label

Exits the active loop n unconditionally before the active loop counter (LCn) equals one, and clears the
active loop flag. The program execution continues at “label.” The displacement, calculated by the
assembler and linker, is a two’s complement integer that represents the relative distance from the current
PC to the destination label. Some programming rules apply to the use of this instruction. If no loops are
enabled, this instruction is undefined.

Register Address

Bit Name

Description

SR[30:27]

LF[3:0]

Determines which loop is active.

Register Address

Bit Name

Description

SR[30:27]

LF[3:0]

Clear active loop flag.

Register/Memory Address

Before

After

_label (displacement)

$0000 000C

PC

$0000 0014

$0000 0020

SR

$40E0 0000

$00E0 0000