beautypg.com

Section 24 – instruction set, Section 24, Instruction set – Maxim Integrated DS4830 Optical Microcontroller User Manual

Page 192: Ds4830 user’s guide, Table 24-1. instruction set summary

background image

DS4830 User’s Guide

192

SECTION 24

– INSTRUCTION SET

Table 24-1. Instruction Set Summary

Mnemonic

Description

16-bit Instruction

Word

Status Bits

Affected

AP
INC/DEC

Notes

L

OG

IC

A

L

OP

E

R

A

T

ION

S

AND src

Acc  Acc AND src

f001 1010 ssss ssss

S, Z

Y

1

OR src

Acc  Acc OR src

f010 1010 ssss ssss

S, Z

Y

1

XOR src

Acc  Acc XOR src

f011 1010 ssss ssss

S, Z

Y

1

CPL

Acc  ~Acc

1000 1010 0001 1010

S, Z

Y

NEG

Acc  ~Acc + 1

1000 1010 1001 1010

S, Z

Y

SLA

Shift Acc left arithmetically

1000 1010 0010 1010

C, S, Z

Y

SLA2

Shift Acc left arithmetically twice

1000 1010 0011 1010

C, S, Z

Y

SLA4

Shift Acc left arithmetically four times

1000 1010 0110 1010

C, S, Z

Y

RL

Rotate Acc left (w/o C)

1000 1010 0100 1010

S

Y

RLC

Rotate Acc left (through C)

1000 1010 0101 1010

C, S, Z

Y

SRA

Shift Acc right arithmetically

1000 1010 1111 1010

C, Z

Y

SRA2

Shift Acc right arithmetically twice

1000 1010 1110 1010

C, Z

Y

SRA4

Shift Acc right arithmetically four times

1000 1010 1011 1010

C, Z

Y

SR

Shift Acc right (0  msbit)

1000 1010 1010 1010

C, S, Z

Y

RR

Rotate Acc right (w/o C)

1000 1010 1100 1010

S

Y

RRC

Rotate Acc right (though C)

1000 1010 1101 1010

C, S, Z

Y

B

IT

OP

E

R

A

TI

ON

S

MOVE C, Acc.

C  Acc.

1110 1010 bbbb 1010

C

MOVE C, #0

C  0

1101 1010 0000 1010

C

MOVE C, #1

C  1

1101 1010 0001 1010

C

CPL C

C  ~C

1101 1010 0010 1010

C

MOVE Acc., C

Acc.  C

1111 1010 bbbb 1010

S, Z

AND Acc.

C  C AND Acc.

1001 1010 bbbb 1010

C

OR Acc.

C  C OR Acc.

1010 1010 bbbb 1010

C

XOR Acc.

C  C XOR Acc.

1011 1010 bbbb 1010

C

MOVE dst., #1

dst.  1

1ddd dddd 1bbb 0111

C,E

2

MOVE dst., #0

dst.  0

1ddd dddd 0bbb 0111

C,E

2

MOVE C, src.

C  src.

fbbb 0111 ssss ssss

C

MA

TH

ADD src

Acc  Acc + src

f100 1010 ssss ssss

C, S, Z, OV

Y

1

ADDC src

Acc  Acc + (src + C)

f110 1010 ssss ssss

C, S, Z, OV

Y

1

SUB src

Acc  Acc

– src

f101 1010 ssss ssss

C, S, Z, OV

Y

1

SUBB src

Acc  Acc

– (src + C)

f111 1010 ssss ssss

C, S, Z, OV

Y

1

B

R

A

N

C

H

IN

G

{L/S}JUMP src

IP  IP + src or src

f000 1100 ssss ssss

6

{L/S}JUMP C, src

If C=1, IP  (IP + src) or src

f010 1100 ssss ssss

6

{L/S}JUMP NC, src

If C=0, IP  (IP + src) or src

f110 1100 ssss ssss

6

{L/S}JUMP Z, src

If Z=1, IP  (IP + src) or src

f001 1100 ssss ssss

6

{L/S}JUMP NZ, src

If Z=0, IP  (IP + src) or src

f101 1100 ssss ssss

6

{L/S}JUMP E, src

If E=1, IP  (IP + src) or src

0011 1100 ssss ssss

6

{L/S}JUMP NE, src

If E=0, IP  (IP + src) or src

0111 1100 ssss ssss

6

{L/S}JUMP S, src

If S=1, IP  (IP + src) or src

f100 1100 ssss ssss

6

{L/S}DJNZ LC[n], src

If --LC[n] <> 0, IP (IP + src) or src

f10n 1101 ssss ssss

6

{L/S}CALL src

@++SP  IP+1; IP  (IP+src) or src

f011 1101 ssss ssss

6,7

RET

IP  @SP--

1000 1100 0000 1101

RET C

If C=1, IP  @SP--

1010 1100 0000 1101

RET NC

If C=0, IP  @SP--

1110 1100 0000 1101

RET Z

If Z=1, IP  @SP--

1001 1100 0000 1101

RET NZ

If Z=0, IP  @SP--

1101 1100 0000 1101

RET S

If S=1, IP  @SP--

1100 1100 0000 1101

RETI

IP  @SP-- ; INS 0

1000 1100 1000 1101

RETI C

If C=1, IP  @SP-- ; INS 0

1010 1100 1000 1101

RETI NC

If C=0, IP  @SP-- ; INS 0

1110 1100 1000 1101

RETI Z

If Z=1, IP  @SP-- ; INS 0

1001 1100 1000 1101

RETI NZ

If Z=0, IP  @SP-- ; INS 0

1101 1100 1000 1101

RETI S

If S=1, IP  @SP-- ; INS 0

1100 1100 1000 1101

D

A

TA

TR

A

N

S

F

E

R

XCH

Swap Acc bytes

1000 1010 1000 1010

S

Y

XCHN

Swap nibbles in each Acc byte

1000 1010 0111 1010

S

Y

MOVE dst, src

dst  src

fddd dddd ssss ssss

C,S,Z,E

(Note 8)

7,8

PUSH src

@++SP  src

f000 1101 ssss ssss

7

POP dst

dst  @SP--

1ddd dddd 0000 1101

C,S,Z,E

7

POPI dst

dst  @SP-- ; INS  0

1ddd dddd 1000 1101

C,S,Z,E

7

CMP src

E  (Acc = src)

f111 1000 ssss ssss

E

NOP

No operation

1101 1010 0011 1010

Note 1: The active accumulator (Acc) is not allowed as the src in operations where it is the implicit destination.