beautypg.com

Subnc.w, Subtract without changing, Operation assembler syntax – Freescale Semiconductor StarCore SC140 User Manual

Page 712

background image

A-398

SC140 DSP Core Reference Manual

SUBNC.W

SUBNC.W

Subtract Without Changing

SUBNC.W

the Carry Bit (DALU)

Description

Status and Conditions that Affect Instruction

Status and Conditions Changed by Instruction

Example

subnc.w #$15,d0

Operation

Assembler Syntax

Dn – #s16

→ Dn

SUBNC.W #s16,Dn {–2

15

≤ s16 < 2

15

}

SUBNC.W #s16,Dn

Subtracts an immediate signed 16-bit value from a source data register (Dn) and stores the result in the
destination data register (Dn). The first operand is a 16-bit immediate data that is interpreted as a signed
integer. The 16 bits are sign-extended to form a 32-bit operand. The carry bit is not affected by this
instruction.

Register Address

Bit Name

Description

SR[2]

SM

If set, selects 32-bit arithmetic saturation mode.

SR[5:4]

S[1:0]

Scaling mode bits determine which bits in the result are used in the Ln
bit calculation.

Register Address

Bit Name

Description

EMR[2]

DOVF

Set if the result cannot be represented in 40 bits, or if the result
saturates to 32 bits in arithmetic saturation mode.

Ln

L

If not in arithmetic saturation mode (SR [SM] = 0), calculates and
updates the Ln bit in the destination register. If in arithmetic saturation
mode (SR [SM] = 1), clears the Ln bit in the destination register.

Register/Memory Address

Before

After

SR

$00E0 0000

$00E0 0000

Immediate

$0015

L0:D0

$0:$00 0000 0010

$0:$FF FFFF FFFB

EMR

$0000 0000