#### CS 223 Computer Architecture and Organization

#### 8085 Microprocessor



**Professor** 

Department of Computer Science & Engineering Indian Institute of Technology Guwahati, Assam.

## Intel 8085 CPU Block Diagram



### 8085 Microprocessor

- Data Bus: 8 bits
  - Size of register: 8 bits
  - can handle 16 bits
- Address Bus: 16 bits
  - memory is byte organized
  - Memory size: 64 KB (2<sup>16</sup>)
- Data bus and address bus are multiplexed

### Intel 8085 Pin Configuration



## Instruction Fetch Cycle



## Memory Read and Write Cycle



#### 8085 Instruction Format

One Byte



Two Bytes

| _ | <b>D7</b> | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Byte 1 |
|---|-----------|----|----|----|----|----|----|----|--------|
|   | D7        | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Byte 2 |

Three Bytes

| <b>D7</b> | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Byte 1 |
|-----------|----|----|----|----|----|----|----|--------|
| <br>D7    | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Byte 2 |
| D7        | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Byte 3 |

| SYMBOLS                                                          | MEANING                                                                                                                                                                                                                                                                                                         |                                 |  |  |  |
|------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|--|--|--|
| accumulator addr data data 16 byte 2 byte 3 port r,r1,r2 DDD,SSS | Register A 16-bit address quantity 8-bit quantity 16-bit data quantity The second byte of the instruction The third byte of the instruction 8-bit address of an I/O device One of the registers A,B,C,D,E,H,L The bit pattern designating one of the registers A,B,C,D,E,H,L (DDD = destination, SSS = source): |                                 |  |  |  |
|                                                                  | DDD or SSS                                                                                                                                                                                                                                                                                                      | REGISTER NAME                   |  |  |  |
|                                                                  | 111<br>000<br>001<br>010<br>011<br>100<br>101                                                                                                                                                                                                                                                                   | A<br>B<br>C<br>D<br>E<br>H<br>L |  |  |  |

| rp  | One of the register pairs:  B represents the B,C pair with B as the high-order           |                                          |  |  |  |
|-----|------------------------------------------------------------------------------------------|------------------------------------------|--|--|--|
|     | B represents the B,C                                                                     | , pair with B as the high-order          |  |  |  |
|     | register and C as the                                                                    | o low-order register,                    |  |  |  |
|     | D represents the D,E                                                                     | pair with D as the high-order            |  |  |  |
|     | register and E as the                                                                    | low-order register,                      |  |  |  |
|     | H represents the H,L pair with H as the hig<br>register and L as the low-order register; |                                          |  |  |  |
| 181 | register and L as the                                                                    | low-order register;                      |  |  |  |
|     | SP represents the 16                                                                     | 3-bit stack pointer register.            |  |  |  |
| RP  |                                                                                          | nating one on the register               |  |  |  |
|     | pairs B,D,H,SP:                                                                          |                                          |  |  |  |
|     | RP                                                                                       | REGISTER PAIR                            |  |  |  |
|     | 00                                                                                       | B-C                                      |  |  |  |
|     | 01                                                                                       | D-E                                      |  |  |  |
|     | 10                                                                                       | H-L                                      |  |  |  |
|     | 11                                                                                       | SP                                       |  |  |  |
| rh  | The first (high-order                                                                    | register of a designated register        |  |  |  |
|     | pair.                                                                                    |                                          |  |  |  |
| rl  | The second (low-ord                                                                      | der) register of a designated            |  |  |  |
|     | register pair.                                                                           |                                          |  |  |  |
| PC  | 16-bit program counter register (PCH and PCL are                                         |                                          |  |  |  |
|     | used to refer to the I                                                                   | nigh-order and low-order 8 bits          |  |  |  |
|     | respectively).                                                                           |                                          |  |  |  |
| SP  | 16-bit stack pointer                                                                     | register (SPH and SPL are used           |  |  |  |
|     | to refer to the high-order and low-order 8 bits                                          |                                          |  |  |  |
|     | respectively).                                                                           |                                          |  |  |  |
|     | Bit m of the register                                                                    | r (bits are number 7 through 0           |  |  |  |
| rm  | from left to right).                                                                     | * NTA ********************************** |  |  |  |

- 1. Data Transfer Group Moves data between registers or between memory locations and registers, includes moves, loads, stores, and exchanges. (See below).
- 2. Arithmetic Group Adds, subtracts, increments, or decrements data in registers or memory.
- 3. Logic Group ANDs, ORs, XORs, compares, rotates, or complements data in registers or between memory and a register.
- 4. Branch Group Initiates conditional or unconditional jumps, calls, returns, and restarts.
- 5. Stack, I/O, and Machine Control Group Includes instructions for maintaining the stack, reading from input ports, writing to output ports, setting and reading interrupt masks, and setting and clearing flags.





LXI rp, data 16 (Load register pair immediate)

 $(rh) \leftarrow (byte 3)$ 

 $(rl) \leftarrow (byte 2)$ 

Byte 3 of the instruction is moved into the high-order register (rh) of the register pair rp. Byte 2 of the instruction is moved into the low-order register

(rl) of the register pair rp.

| 0 | 0    | R    | P    | 0     | 0    | 0 | 1 |
|---|------|------|------|-------|------|---|---|
|   | ay e | low  | -orc | ler d | lata |   |   |
|   |      | hiol | 1-01 | der o | lata |   |   |

Cycles:

3

States:

10

Addressing:

immediate

Flags:

none

The bit pattern designating one on the register pairs B.D.H.SP:

| 2,2,11,011 | The section of the se |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RP         | REGISTER PAIR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 00         | B-C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 01         | D-E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 10         | H-L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 44         | SP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

(Load Accumulator direct) LDA addr  $(A) \leftarrow ((byte 3) (byte 2))$ The content of the memory location, whose address is specified in byte 2 and byte 3 of the instruction, is moved to register A. 0 0 1 1 1 1 0 Low-order addr high-order addr Cycles: 13 States: Addressing: direct Flags: none (Store Accumulator direct) STA addr  $((Byte 3) (byte 2)) \leftarrow (A)$ The content of the accumulator is moved to the memory location whose address is specified in byte 2 and byte 3 of the instruction. 0 1 1 0 0 1 0 low-order addr high-order addr Cycles: 13 States: Addressing: direct Flags: none

ADD r (Add Register)  $(A) \leftarrow (A) + (r)$ The content of register r is added to the content of the accumulator. The result is placed in the accumulator. Cycles: States: register Addressing: Z,S,P,CY,AC Flags: (Add memory)  $(A) \leftarrow (A) + ((H)(L))$ The content of the memory location whose address is contained in the H and L registers is added to the content of the accumulator. The result is placed in the accumulator. Cycles: States: reg. indirect Addressing: Z,S,P,CY, AC Flags:

```
CONDITION
                              CCC
NZ - not zero (Z = 0)
                              000
Z - zero (Z=1)
                              001
NC - no carry (CY=0)
                              010
C - carry (CY=1)
                              011
PO - parity odd (P=0)
PE - parity even (P=1)
                              101
P - plus (S=0)
                              110
M - minus (S=1)
```

JMP addr (Jump) (PC)  $\leftarrow$  (byte 3) (byte 2)

Control is transferred to the instruction whose address is specified in byte 3 and byte 2 of the current instruction.

| 1            | 1 | 0   | 0     | 0     | 0    | 1      | 1                 |
|--------------|---|-----|-------|-------|------|--------|-------------------|
|              |   | lov | v-ore | der a | ddr  |        |                   |
| TO THE PARTY |   | hig | h-or  | der a | addr | BANGE. | ( <b>.</b> 88.×.) |

Cycles: 3 States: 10

Addressing: immediate

Flags: none

J condition addr (Conditional jump)

If (CCC),

 $(PC) \leftarrow (byte 3)(byte 2)$ 

If the specified condition is true, control is transferred to the instruction whose address is specified in byte 3 and byte 2 of the current instruction; otherwise, control continues sequentially.

1 1 C C C 0 1 0

low-order addr

high-order addr

Cycles: States: 2/3 (8085), 3 (8080) 7/10 (8085), 10 (8080)

Addressing:

immediate

Flags:

none

```
CALL addr (Call)
((SP) - 1) ← (PCH)
((SP) - 2) ← (PCL)
((SP) - (SP) - 2
(PC) ← (byte 3) (byte 2)
```

The high-order eight bits of the next instruction address are moved to the memory location whose address is one less than the content of register SP. The low-order eight bits of the next instruction address are moved to the memory location whose address is two less than the cotent of register SP. the content of register SP is decremented by 2. Control is transferred to the instruction whose address is specified in byte 3 and byte 2 of the current instruction.

| 1 1 | 0 0 1 1 0 1     |
|-----|-----------------|
|     | low-order addr  |
|     | high-order addr |

Cycles: 5

States: 18 (8085), 17 (8080) immediate/

Addressing: reg. indirect

Flags: none

## Computer Program

Write a program segment to add 100 integers.

```
sum = 0;
for (i=100; i>0; i--)
sum = sum + a[i];
```

## Programming 8085

 Write a program to add 100 (64H) integers that are stored in consecutive memory locations stating from address 3000H and store the result in memory location 4000H

# Assembly Program: 8085

| Label | Assembly Code |  |
|-------|---------------|--|
|       | MVI B 64H     |  |
|       | LXI H 3000H   |  |
|       | MVI A 00H     |  |
| Loop  | ADD M         |  |
|       | INX H         |  |
|       | DCR B         |  |
|       | JNZ Loop      |  |
|       | STA 4000H     |  |
|       | HLT           |  |
|       |               |  |

#### Assembly Program with M/C Code:8085

| Label | Assembly    | M/C Code   | M/C Code in Hex |
|-------|-------------|------------|-----------------|
|       | MVI B 64H   | 00 000 110 | 06              |
|       | LXI H 3000H | 00 10 0001 | 21              |
|       | MVI A 00H   | 00 111 110 | 3E              |
| Loop  | ADD M       | 10000 110  | 86              |
|       | INX H       | 00 10 0011 | 23              |
|       | DCR B       | 00 000 101 | 05              |
|       | JNZ Loop    | 11 000 010 | C2              |
|       | STA 4000H   | 00 110 010 | 32              |
|       | HLT         | 0111 0110  | 76              |
|       |             |            |                 |

#### Memory Location of the program: 8085

| Memory | Op-Code     | M/C Code   | M/C in Hex, Data |
|--------|-------------|------------|------------------|
| 1000   | MVI B 64H   | 00 000 110 | 06 64            |
| 1002   | LXI H 3000H | 00 10 0001 | 21 00 30         |
| 1005   | MVI A 00H   | 00 111 110 | 3E 00            |
| 1007   | ADD M       | 10000 110  | 86               |
| 1008   | INX H       | 00 10 0011 | 23               |
| 1009   | DCR B       | 00 000 101 | 05               |
| 100A   | JNZ Loop    | 11 000 010 | C2 07 10         |
| 100D   | STA 4000H   | 00 110 010 | 32 00 40         |
| 1010   | HLT         | 0111 0110  | 76               |
|        |             |            |                  |

