

## Addressing Modes

### → Indirect Addressing Mode

Mov A, 30h ] → Mov R0, #30h  
 Mov A, @R0

### Syntax

Mov A, @Rp

Mov @Rp, A

Mov @Rp, #n

Mov @Rp, addr

Mov addr, @Rp

Mov addr, @R,

// ALP to copy the data from 70h ~~to R0 to R2~~ to R0 to R2

Mov 70h, #11h

Mov R0, 70h

Mov R1, 70h

Mov R2, 70h

Mov R3, 70h

Mov R4, 70h

// ALP to copy data from R0 to 30h to 33h

Mov R0, #30h

Mov R1, #31h

Mov 31h, @R0

Mov A, @R1

Mov @R1, 31h

Mov @R0, A

→ Direct Addressing Mode

Mov R<sub>i</sub>, addrs

Mov A, addrs

Mov addrs, R<sub>j</sub>

Mov addrs, #n

Mov addrs1, addrs2

Mov addrs, \*

→ Immediate Addressing Mode

The operand is present in instruction

Mov A, #n

Mov R<sub>i</sub>, #n

Mov DPTR, #nn

↳ 16 bit

→ Register Addressing Mode

Mov A, #30H

Mov R<sub>0</sub>, A

Mov R<sub>1</sub>, A

}

Mov R<sub>2</sub>, \*

## Indirect Addressing Mode



Mov R<sub>1</sub>, #40h

R<sub>1</sub> ← 40h

Mov A, #33h

A ← 33h

Mov @R<sub>1</sub>, A

Mov A, 30h ] → Mov R<sub>0</sub>, #30h  
Mov A, @R<sub>0</sub>

## Syntax

Mov A, @R<sub>p</sub>

Mov @R<sub>p</sub>, A

Mov @R<sub>p</sub>, #n

Mov @R<sub>p</sub>, addr

Mov addr, @R<sub>p</sub>

Mov @R<sub>p</sub>, @R<sub>p</sub>

// Alp to copy data at 30h to R0 to R2

Mov 30h, #30h

Mov R0, 30h

Mov R1, 30h

Mov R2, 30h

Mov R3, 30h

// Alp to copy data from R0 to 30h to 33h

Mov 30h, R0

Mov 33h, R0

Mov 30h, R0

Mov 33h, R0

END

// Alp to load immediate value in register

Mov R1, #30h

Mov R0, #301h

TOD

// Alp using indirect addressing mode & exchange the  
contents of 30h to 40h

direct → // Mov 31h, 20h

Mov 30h, 40h

Mov 40h, 31h

Indirect Addressing Mode  $\rightarrow //$

Mov R<sub>0</sub>, #30h

Mov R<sub>1</sub>, #40h

Mov A, @R<sub>0</sub>

Mov B, @R<sub>1</sub>

Mov @R<sub>0</sub>, B

Mov @R<sub>1</sub>, A

DJ

Mov R<sub>0</sub>, #30h

Mov A, @R<sub>0</sub>

Mov @R<sub>0</sub>, 40h

Mov 40h, A

END

$\rightarrow$  Transfer 5 bytes of data from 30h to 40h onwards  
using direct mode

Mov A, 30h

Mov 30h, 40h

Mov 40h, A

Mov A, 31h

!

## Byte level → Logical Operations

AND

AND A, #n

AND A, Rn

AND A, add

AND A, @Rp

AND add, A

AND add, #n

n → Any value (Hexadecimal)

addr → Internal RAM Address

eg - MOV A, #54H

54H → 0101 0100

MOV R0, #32H

32H → 0011 0010 &amp;

AND A, R0

0001 0000

A ← 10H

ORL

ORL A, #n

ORL A, Rn

ORL A, add

ORL A, @Rp

ORL add, A

ORL add, #n

→ eg - MOV A, #54H

0101 0100

MOV R1, #10H

0001 0010

ORL A, R0

0101 0110

A ← 5310

XOR : operations

XORL A, #n

XORL A, @Rp

XORL A, add

XORL add, A

XORL A, Rn

XORL add, #n

NOT operation

CPL A

clear operation

CLR A

→ HALP program that will Invert/Complement  
bit of R<sub>6</sub> of bank0

Mov R<sub>6</sub>, #10H

Mov A, R<sub>6</sub>

CPL A

Mov R<sub>6</sub>, A

END

XOR anything with FFH, we will get its complement

→ XRL 06H, #0FFH

→ ORB The contents of Port1 & Port2, put result into  
0100H (Pictorial RAM)

Mov A, 90H

ORL A, 0100H

Mov DPTR, #0100H

Movx @DPTR, A

END

→ ALP to swap ~~high nibble of Ro & R~~<sup>Nibbles</sup>, so that low nibble of Ro swaps with high nibble of R<sub>1</sub> & high nibble of R<sub>0</sub> swaps with low nibble of R<sub>1</sub>

SWAP A

A → 32

SWAP 32

= 23

Mov R<sub>0</sub>, #00H

Mov A, R<sub>0</sub>

SWAP A, Mov R<sub>0</sub>, A

Mov R<sub>1</sub>, #23H

Mov A, R<sub>1</sub>

SWAP A

XCH A, #00H

Mov R<sub>1</sub>, A

END

O ↗

Mov R<sub>0</sub>, #10H

Mov R<sub>1</sub>, #20H

Mov A, R<sub>0</sub>

SWAP A

XCH A, R<sub>1</sub>

SWAP A

Mov R<sub>0</sub>, A

END

→ Store most significant nibble of A in both  
nibbles of R5.

Mov A, #10H

~~ANL~~ R5, A, #0F0H

Mov R5, A

SWAP A

ORL A, 00H

Mov R5, A

END

## Arithmetic Operations

Increment operator (INC dest)

|                    |                     |         |
|--------------------|---------------------|---------|
| INC A              | INC @R <sub>p</sub> | INC add |
| INC R <sub>s</sub> | INC D PTR X         |         |

Decrement operator (DEC dest)

|                    |                     |         |
|--------------------|---------------------|---------|
| DEC A              | DEC @R <sub>p</sub> | DEC add |
| DEC R <sub>s</sub> | DEC D PTR X         |         |

## Addition Instruction

|                        |                         |
|------------------------|-------------------------|
| ADD A, #n              | ADDC A, #n              |
| ADD A, R <sub>s</sub>  | ADDC A, R <sub>s</sub>  |
| ADD A, add             | ADDC A, add             |
| ADD A, @R <sub>p</sub> | ADDC A, @R <sub>p</sub> |

// ALP to add bytes in RAM location 34h 435h & store result in R<sub>s</sub> LSB in R<sub>6</sub> MSB

Mov A, 34h

Mov A, 35h

XOR R<sub>6</sub>, R<sub>6</sub>

ADD A, 35h

ADD A, 35h

Mov R<sub>s</sub>, A

Mov R<sub>s</sub>, A

CLR A

CLR A

ADDC A, #00h

RLC A

(00) Mov R<sub>6</sub>, A

Mov R<sub>6</sub>, A

END

|     |      |      |
|-----|------|------|
| 11h | 0001 | 0001 |
| 45h | 0100 | 0101 |
|     | 0101 | 0110 |
|     | 56h  |      |

|      |        |      |
|------|--------|------|
| T-#h | 1111   | 0001 |
| F5h  | 1111   | 0101 |
|      | 11110  | 0110 |
|      | 7 E 6h |      |

carry = 1

low byte = 66

high byte = 7

→ Add the bytes in register R<sub>3</sub> & R<sub>4</sub>, put result in  
RAM location 4Ah LSB, 4Bh MSB.

```

Mov R3, #10h
Mov R4, #11h
Mov A, R3
ADD A, R4
Mov 4Ah, A
CLR A
RLC A
Mov 4Bh, A
END

```

→ Subtraction

|                        |                         |
|------------------------|-------------------------|
| SUBB A, #0             | SUBB A, @R <sub>p</sub> |
| SUBB A, R <sub>3</sub> |                         |
| SUBB A, carry          |                         |

→ MULTIPLICATION

~~MOVUL A, B → MSByte~~

~~LSByte~~

→ Division

Div AB :- A/B

quotient → A

remainder → B

Subtract the no. 84h from RAM location 17h  
if 0 → result in R<sub>1</sub>LSB, R<sub>1</sub>MSB

→ Subtract contents of R<sub>1</sub> from R<sub>0</sub>, put back to R<sub>1</sub>

2) MOV R<sub>0</sub>, #10h

MOV R<sub>1</sub>, #20h

~~MOV R<sub>0</sub>, #10h~~

SUBR A, R<sub>1</sub>

MOV R<sub>1</sub>, A

$$\begin{array}{r}
 13h \\
 - 12h \\
 \hline
 1h
 \end{array}
 \quad
 \begin{array}{r}
 0001 \quad 0011 \\
 0001 \quad 0010 \\
 \hline
 0000 \quad 0001
 \end{array}$$

①   
 MOV A, #17h  
 SUBB A, #04h  
 MOV R<sub>2</sub>, A  
 CLR A  
 RLC A  
 MOV R<sub>4</sub>, A  
 END

→ ALP to perform 16 bit Addition stored in R<sub>3</sub> & R<sub>4</sub>  
 with RAM location 44h & 45h. Put result in R<sub>4</sub> MSB, 31h  
 Middle byte of 32h LSB.  
 30h



MOV A, R<sub>4</sub>  
 ADDC A, R<sub>45h</sub>

MOV 32h, A

MOV A, R<sub>3</sub>

ADDC A, 44h

MOV 31h, A

CLR A

ADDC A, #00h

MOV 30h, A

END

→ Multiply data from 22h by gram location 15h, put result  
in 19h LSB, 18h MSB

Mov A, 22h

Mov B, 15h

NWL AB

Mov 19h, A

Mov 18h, B

END 4

→ Square the contents of R5, result into R0 MSB

R1 LSB

Divide the data in RAM 3Eh by number 12h, put  
quotient in R4, remainder R5

Mov A, R5 | Mov B, R5

Ator NWL A~~B~~

Mov R0, B

Mov R1, A

END 1

Mov A, 3Eh

Mov B, #12h

Div AB

Mov R4, d

Mov R5, B

END

Lab - 5

14/2/2020

(Interfacing LCD with 8051)

16x2 LCD Module is very common type

→ 16 characters, 2 rows  
pixel dimension is  $5 \times 7$  or  $5 \times 8$  dot



| LCD     | Signal Name                     | Port line                             |
|---------|---------------------------------|---------------------------------------|
| Pin No. |                                 |                                       |
| 1       | GND                             | GND                                   |
| 2       | V <sub>cc</sub>                 | V <sub>cc</sub>                       |
| 3       | V <sub>ref</sub> (LCD contrast) | P <sub>9</sub> (10 <sup>th</sup> pin) |
| 4       | RS Line                         | P <sub>2.7</sub>                      |
| 5       | R/S Line                        | P <sub>2.5</sub>                      |
| 6       | EN Line                         | P <sub>2.6</sub>                      |
| 7       | Data D <sub>0</sub>             | NC                                    |
| 8       | Data D <sub>1</sub>             | NC                                    |
| 9       | Data D <sub>2</sub>             | NC                                    |
| 10      | Data D <sub>3</sub>             | NC                                    |
| 11      | Data D <sub>4</sub>             | P <sub>2.0</sub>                      |
| 12      | Data D <sub>5</sub>             | P <sub>2.1</sub>                      |
| 13      | Data D <sub>6</sub>             | P <sub>2.2</sub>                      |
| 14      | Data D <sub>7</sub>             | P <sub>2.3</sub>                      |
| 15      | V <sub>cc</sub>                 | 21V                                   |

## LCD Interfacing

P.S = 1 for sending command to LCD

P.S = 0 for sending data to LCD

R/W = 1 for reading from LCD

R/W = 0 for writing to LCD



→ EP - enable pin

4.7kΩ

Enable puller

→ LCD Commands

Command

0x01

0x02

0x04

0x06

0x07

0x09

Instructions

clear display screen

return home

decrement cursor (shift cursor left)

increment cursor (shift cursor right)

shift display left

Display off, cursor off

0x02

4 bit function set 2 lines 4 5x7 dots

0x28

Ponc

X

X

0x80

0x00

0x0F

Display ON, cursor n blinking

0x28

4 bit function set 2 lines 4 5x7 dots

0x80

Force cursor to beginning of 1<sup>st</sup> line

0x00

Force cursor to beginning of 2<sup>nd</sup> line

mid lcd cmd - wr (char cmd)

char temp = cmd;

temp = temp &lt; , 4;

temp = temp | 0x40;

P2 = temp;

delay(450);

temp = temp + 0x0F;

P2 = temp;

delay(100);

temp = cmd;

temp = temp + 0x0F;

temp = temp | 0x40;

P2 = temp;

delay(450);

temp = temp + 0x0F;

P2 = temp;

delay(100);

void lcd\_data\_wr (char data)

```

    {
        char temp = data;
        temp = temp >> 4;
        temp = temp | 0x00;
        P2 = temp;
        delay (450);
        temp = temp & 0x8F;
        P2 = temp;
        delay (100);
        temp = data;
        temp = temp & 0x0F;
        temp = temp | 0x00;
        P2 = temp;
        delay (450);
        temp = temp & 0x8F;
        P2 = temp;
        delay (100);
    }

```

main()

```

    lcd_cnd_wr (0x06);
    lcd_cnd_wr (0x28);
    lcd_cnd_wr (0x0F);
    lcd_cnd_wr (0x01);
    lcd_cnd_wr (0x80);
    char str = "EscN";
    for (int i=0; i<strlen(str); i++)
        lcd_data_wr (str[i]);
}

```

Movec Syntax

Movec A, @pc + A  
Movec A, @A + Dptr

|| ALP to copy contents of external code memory 0040H to IP register.

CLR A / Mov #00H  
Mov Dptr, #0040H  
Movec A, @Dptr + A  
Mov CF A / Mov 0A8H, A  
END

|| Copy the internal code byte at 0300H to external <sup>RAM</sup> memory 0300H.

CLR A  
Mov Dptr, #0300H  
Movec A, @Dptr + @x. // gets code byte  
Movx @Dptr, A // written into <sup>External RAM</sup> RAM.  
END.

|| ALP to copy program bytes 000H to 0102H to internal <sup>External RAM from program</sup> ROM to the location 20H to 28H

CLR A  
Mov Dptr, #0000H  
Movec A, @A + Dptr  
Mov 090H, A  
CLR A

Mov D PTR, #010H  
 Movc A, @A+D PTR  
 Mov 021H, A  
 CLR A

Mov D PTR, #010H  
 Movc A, @A+D PTR  
 Mov 022H, A

Q3

Mov D PTR, #0100H

Mov A, #000H

Movc A, @A+D PTR

Mov 00H, A

Mov A, #01H

Movc A, @A+D PTR

Mov 21H, A

Mov A, #02H

Movc A, @A+D PTR

Mov 22H, A

## PUSH & POP

push addn

pop addn

→ push 30H



increment after push data  
Pop data + the decrement

Content of 30H will be

stored in top's location

→ pop 10H

top's data will be stored

in address location

of 10H.

Swap contents R<sub>6</sub> & R<sub>7</sub> using push & pop

```
push R6 (yy)  
push R7 (yy)  
pop R6 (yy)  
pop R7 (yy)  
END.
```

3/1/2020

## || Logical Instructions

Bit level logical Instructions

|           |             |          |
|-----------|-------------|----------|
| for       | ANL C, #b   | Mov c, b |
| ADD       | ANL C, #b/b | Mov b, c |
| operation |             |          |

|           |          |       |            |
|-----------|----------|-------|------------|
| OR        | ORL C, b | CPL C | complement |
| operation | ORL C/b  | CPL b |            |

|       |       |        |                     |
|-------|-------|--------|---------------------|
| CLR C | reset | SETB b | sets the value to 1 |
| CLR b |       |        |                     |

e.g.: Write an Alp to clear bit 3 of RAM location 30H without affecting other bits

Mov 20H, 30H

CLR 03H // bit addressable

Mov 30H, 20H

END

SETB C } set the value to 1  
SETB b }

// ALP to Move bit 6 of R<sub>0</sub> to bit 3 of Part a

Mov 26h, R<sub>6</sub>

Mov C, 06H

Mov 83H, C

END

→ // Sequence of instructions to clear register R<sub>3</sub> of bank 1

CPL D3,

Mov R<sub>3</sub>, #00H

SETB 0D0, 3h } selected the Bank 1  
CLR 0D0, 4h }  
Mov R<sub>3</sub>, #00H

5/2/2020

## Rotate Instructions

RR A

Rotate Right

RRC A

Rotate Right with carry

RLC A

RL A

Date: / /  
Ex:- 80h

RL

1000 0000

0000 0000

~~00h~~ 0h

RR

1000 0000

0000 0000

40h

c<sup>=0</sup> 1000 0000

(RLC)

1000010000

00h

(RRC) c<sup>=0</sup>

1000 0000

00100 0000

RLC  $\rightarrow$  will double the value ( $\times$  by 2)

RRC  $\rightarrow$  will half the value ( $\div$  by 2)

To move R0 & R, as 16 bit register & rotate  $\rightarrow$  place to left  
bit 7 of R0 become bit 0 of R, & bit 7 of R, because  
bit 0 of R0



Mov A, R0

RLC  $\rightarrow$

Mov R0, A

Mov A, R,

RLC  $\rightarrow$

Mov ~~A~~, R, A

CLR A

RLC A

ORL 00h, A

Mov ~~00h~~, R

Mov 00h, C

Mov R0, 20h

→ // ALP to rotate DPTR 1 place to the right  
DPTR (16 bit)

Mov A, DPL (82h)

RRC A

Mov DPL, A

Mov A, DPH (83h)

RRC A

Mov DPH, A

Mov 20h, DP~~H~~L

Mov 07h, C

Mov DP~~H~~, 20h

→ // ALP shifts B register content 1 place to the left &  
bit on zero

0100 0010  
  ^ P A

1000 0100



CLR C

Mov A, B

RLC A

Mov B, A

END

→ // ALP swaps every even numbered bit of R3 in bank 0 with every odd numbered bit to its left.

Mov A, R<sub>3</sub>

RR A

ANL A, #55h

Mov 30h, A [odd bit → even bit → 30h]

Mov A, R<sub>3</sub>

R<sub>2</sub> A (even bit → odd bit)

ANL A, #AAh

OPL A, 30h

Mov R<sub>3</sub>, A

END

9/2/2020

10h 0001 0000

99h 0000 1001

109h 1010 1001

A 9

+ 1 Add 6 circuit

109

μ<sub>0</sub>° should be within 00-99 → for B.Decimal

HALP to add R<sub>3</sub>, R<sub>4</sub>, store result in 30h & 31h.  
(LSB) (MSB)

Numbers are in BCD format.

Mov A, R<sub>3</sub>

ADD A, R<sub>4</sub>

adjust spcc

DA → decimal

DA A

Mov 30h, A

CLD A

Addc A, #00h

Mov 31h, A

CLR A

RLC A

II ALP to add Numbers found in 30h, 31h, 32h, store result in R<sub>3</sub> (LSB) R<sub>4</sub> (Mbyte), R<sub>5</sub> (MSB)

|                        |                        |                                      |
|------------------------|------------------------|--------------------------------------|
| Mov A, 30h             | Mov A, 30h             | Mov A, 30h                           |
| ADD A, 31h             | Add A, 31h             | Add A, 31h, Mov R <sub>3</sub> , A   |
| Mov R <sub>3</sub> , A | Addc A, 32h            | CLR A                                |
| CLD A                  | Mov R <sub>3</sub> , A | RLC A                                |
| ADDC A, H00h           | CLD A                  | Mov R <sub>3</sub> (Corrig.)         |
| Mov R <sub>4</sub> , A | RLC A                  | ADDE                                 |
| Mov A, 32h             | Mov R <sub>4</sub> , A | Mov A, 32h                           |
| ADD A, R <sub>2</sub>  | END                    | ADDC R <sub>3</sub> , R <sub>3</sub> |
| Mov R <sub>1</sub> , A |                        | Mov R <sub>3</sub> , A (LSR)         |
| Mov A, R <sub>4</sub>  |                        | CLD A                                |
| ADDC A, H00h           |                        | RLC A                                |
| Mov R <sub>4</sub> , A |                        | Adc R <sub>3</sub> , A               |
| END                    |                        | Mov R <sub>5</sub> , A               |
|                        |                        | END                                  |

→ 16 bit × 8 bit multiplication.

$$R_1, R_0 \rightarrow 16 \text{ bit No.}$$

$$R_2 \rightarrow 8 \text{ bit No.}$$

Store in 30h, 31h, 32h

10/2/2020

16 bit x 8 bit multiplication.

Mov A; R<sub>0</sub>

Mov OF0h, R<sub>1</sub>

MUL AB

Mov A3h, A → LSB.

Mov 31h, B

Mov A, R<sub>0</sub>

Mov OF0h, R<sub>1</sub>

MUL AB

[Mov 32h, B → HSB]

Mov

ADD A, 31h

Mov 31h, A → Middle byte

ABSCRMBCPRA CLR A

ADDA A, OF0h

ADDC A, OF0h // A + B + carry

Mov 32h, A // HSB

END.

? Subtract byte in the External Ram 02ch from the internal Ram 19h, put result into external memory location 0001 HSB

Mov A, 02ch

CLR C

SUBB A, 19h

Mov DPTR, #02ch

Movx A, @DPTR // AL

Mov DPTR, #0000

R<sub>0</sub>

Mov @DPTR, A

Mov A, 19h

ENCL DPTR

SUBB A, R<sub>0</sub>

Mov DPTR, #0000

Mov @DPTR, A

CLP  $\rightarrow$

RLC  $\rightarrow$

Inc Dptr

Mov @Dptr, A

END

Jump

Bit

JC radd

(Jump on carry)

JNC radd

(Jump on no carry)

JB b, radd

If b=1 then jump

JNB b, radd

If b=0, then jump

JBc b, radd

If b=0, then jump, but before going  
it will clear the bit =0

Flags are not

affected by memory device

Affected.

Byte

CJNE A, radd, radd

Compare A with radd, if not equal, then go

CJNE A, #n, radd

Compare A with n, if not equal = Jump

CJNE Rr, #n, radd

CJNE @Rp, A, radd

A > 30h, C=0

A < 30h, C=1

//Alg to put a random no° in R3 & increment it until  
it equals a no° in b



Mov R<sub>3</sub>, #11h

bK, INC R<sub>3</sub>

CJNE R<sub>3</sub>, #0E1h, blk

// ALP to put a random no. in R<sub>3</sub> & decrement it until it becomes  
11h.

Mov R<sub>3</sub>, #11h

bK DEC R<sub>3</sub>

CJNE R<sub>3</sub>, #0E1h, blk

// ALP to count no. of 1's in numbers in Register B, put the  
Count in R<sub>5</sub>

Mov R<sub>5</sub>, #00h

Mov B, #50h

Mov A, B

blk; RLC A

JNC Next

INC R<sub>5</sub>

Next DJNZ R<sub>2</sub>, blk

END

// ALP Count no. of zeroes in R<sub>3</sub> & put in R<sub>5</sub>

Mov R<sub>5</sub>, #00h

Mov R<sub>2</sub>, #8h

Mov A, R<sub>3</sub>

blk, RLC A

JC Next

INC R<sub>5</sub>

Next DJNZ R<sub>2</sub>, blk

END

II ALP to exchange bank 0 content with bank 2.

II ALP to find biggest no. among R1 R2 R3 R4 & put it in R6

Bank 0

R0

R1

1

R2

R3

One register to count the values  
R0 - base address

Mov 0Dah, #0sh // select bank 1

Set bit 0Dah // 0Dah = address of PSW

clr 0Dah.4



Mov 0Dah, #0sh

bank 1

Mov R3, #3

PSW  $\rightarrow$  0Dah

Mov R0, #0oh

Mov A, @R0

II ALG-6

R0 - 16

inc R0 // R0 - 01

R1 - 5

Mov 30h, @R0 // 30h - 5

R2 - 13

CJNR A, 30h, L1

R3 - 2

SJMP L2

L1: JNC L2

CJNR,

Mov A, 30h

b7=5  $\therefore$  C=0

L2: DJNZ R3, back

get L2  $\therefore$  C=1

END



// ALP to find smaller no. (among array)  
of 20 element stored in memory location

not  
needed

Mov 0Doh, H0h

Mov R<sub>3</sub>, #13h (#19)

(20 elements)  $\Rightarrow$  19 compare

Mov R<sub>0</sub>, #40h

Mov A, @R<sub>0</sub>

back Inc R<sub>0</sub>

Mov 30h, @R<sub>0</sub>

CJNP A, 30h; L1

SJMP L2

L1: JC L2

Mov A, 30h

L2: DJNZ R<sub>3</sub>, back

END

L1: ~~JNC L2~~

L1: JNC L2

~~Mov 0Doh, H0h~~

L2: ~~Mov A, 30h~~

~~END~~

// exchange bank 0 content with bank 3

Mov 0Doh, #~~08h~~ //bank 1 (using bank 0 &  
<sup>08h</sup> <sup>00011000</sup>)

Mov R<sub>0</sub>, #00h //bank 0 starting address (use diff bank)

Mov R<sub>1</sub>, #10h //bank 2 starting address

Mov R<sub>3</sub>, #08h // 8 iteration

back: Mov A, @R<sub>0</sub>

Inc A, @R<sub>1</sub>

Mov @R<sub>0</sub>, A

Inc R<sub>0</sub>

Inc R<sub>1</sub>

DJNZ R<sub>3</sub>, back

END

1) ALP to check whether No. in R5 is even or odd.  
 if even store in FFh, else store 00h.

Mov A, R5  
 Mov B, #02h  
 Div A/B  
~~JNC~~

A → quotient    B → remainder

2) Mov A, R5  
 RRC A    // LSB is in Carry  
 JC L1  
 Mov P0, #FFh  
 SJMP last    (unconditional jump)  
 L2: Mov P0, #00h  
 last:  
 END

↑  
 SJMP → short  
 LJMP → long  
 AJMP → absolute