31.2. Syntax

31.2.1. Macros

The macro syntax used on the MSP 430 is like that described in the MSP 430 Family Assembler Specification. Normal as macros should still work.

Additional built-in macros are:

llo(exp)

Extracts least significant word from 32-bit expression 'exp'.

lhi(exp)

Extracts most significant word from 32-bit expression 'exp'.

hlo(exp)

Extracts 3rd word from 64-bit expression 'exp'.

hhi(exp)

Extracts 4rd word from 64-bit expression 'exp'.

They normally being used as an immediate source operand.
    mov	#llo(1), r10	;	== mov	#1, r10
    mov	#lhi(1), r10	;	== mov	#0, r10

31.2.2. Special Characters

; is the line comment character.

The character $ in jump instructions indicates current location and implemented only for TI syntax compatibility.

31.2.3. Register Names

General-purpose registers are represented by predefined symbols of the form rN (for global registers), where N represents a number between 0 and 15. The leading letters may be in either upper or lower case; for example, r13 and R7 are both valid register names.

Register names PC, SP and SR cannot be used as register names and will be treated as variables. Use r0, r1, and r2 instead.

31.2.4. Assembler Extensions

@rN

As destination operand being treated as 0(rn)

0(rN)

As source operand being treated as @rn

jCOND +N

Skips next N bytes followed by jump instruction and equivalent to jCOND $+N+2

Also, there are some instructions, which cannot be found in other assemblers. These are branch instructions, which has different opcodes upon jump distance. They all got PC relative addressing mode.

beq label

A polymorph instruction which is jeq label in case if jump distance within allowed range for cpu's jump instruction. If not, this unrolls into a sequence of
  jne $+6
  br  label

bne label

A polymorph instruction which is jne label or jeq +4; br label

blt label

A polymorph instruction which is jl label or jge +4; br label

bltn label

A polymorph instruction which is jn label or jn +2; jmp +4; br label

bltu label

A polymorph instruction which is jlo label or jhs +2; br label

bge label

A polymorph instruction which is jge label or jl +4; br label

bgeu label

A polymorph instruction which is jhs label or jlo +4; br label

bgt label

A polymorph instruction which is jeq +2; jge label or jeq +6; jl +4; br label

bgtu label

A polymorph instruction which is jeq +2; jhs label or jeq +6; jlo +4; br label

bleu label

A polymorph instruction which is jeq label; jlo label or jeq +2; jhs +4; br label

ble label

A polymorph instruction which is jeq label; jl label or jeq +2; jge +4; br label

jump label

A polymorph instruction which is jmp label or br label