

| Von-Niemann Architecture                                                     | Harvard Architecture.                                                                      |
|------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|
| → It is a theoretical design based on the stored-program computer concept.   | → It is a modern computer architecture based on the Harvard Mark I relay-based comp model. |
| → It uses same physical memory address for instructions and data.            | → It uses separate memory address for instructions and data.                               |
| → Processor needs two clock cycles to execute an instruction.                | → Processor needs one cycle to complete an instruction.                                    |
| → Simpler control unit design and development of one is cheaper and faster.  | → Control unit for two buses is more complicated which adds to the development cost.       |
| → Data transfers and instruction fetches cannot be performed simultaneously. | → Data transfers and instruction fetches can be performed at the same time.                |
| → Used in personal computers, laptops and workstations                       | → Used in micro controllers and signal processing.                                         |

## CHAPTER 2 : Introduction to 8085 CPU

Features :

1. Introduced in 1976
2. 40-pin DIP (Dual Inline Package)
3. 8-bit MP
- Data bus width = 8-bit
- Address bus " = 16-bit
- Total Addressable memory  $= 2^{16} = 65536 \text{ bytes}$   
 $= 64 \text{ KB}$
4. It uses single +5V power supply.
5. Operating frequency (max) = 5 MHz.
6. Upward compatible with 8080A
7. Supports large no. of instructions.



Fig. PIN Diagram of 8085A.



Fig Block diagram of 8085A

- # Flag Register of 8085
- Flags are indicators that indicate the operation ongoing inside ALU.
  - Flag register are always associated with ALU.
  - There are five flags of 8085.



|                                         | Fig Flag register of 8085                                                                                               | SV |
|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------|----|
| D <sub>7</sub> → set ; -ve → 1 → is set | D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> |    |
| 1. Sign Flag → 0 → +ve                  | 1 0 1 0 1 0 1 0                                                                                                         |    |
| 2. Zero Flag → 0 .., 0 → 0 → 1          | 1 1 0 0 0 1 0 1 0                                                                                                       |    |
| 3. Auxiliary Carry → Flag               | 1 0 0 1 1 0 1 0 0                                                                                                       |    |
| 4. Parity Flag → 0                      | Even number of 1 can bane<br>set = 1                                                                                    |    |
| 5. Carry Flag → 1                       |                                                                                                                         |    |

## 8085 Instructions

- An instruction is a command to the microprocessor to perform a given task.
- A collection of instructions constitutes a program.
- It consists of two parts:
  1. Opcode (Operation code)

It is the first part of the instruction that represents the what kind of operation or task to be performed.

### 2. Operand :

- Operands are the 2<sup>nd</sup> part of the instruction.
- This indicates the data to be operated in the instruction.

classmate  
Date \_\_\_\_\_  
Page \_\_\_\_\_

सुगम स्टेटमेंट सलाहकारी एवं कारोबारी संसद  
कानूनमात्रा, लियल्पुर १८७९५९९९९९९  
NCLT College



## 8085 Sets Instruction

### Types of Instruction (According to byte size)

- Three categories of IA
- 8085 instructions can be grouped into five basic categories
  1. Data Transfer Instructions
  2. Arithmetic Instructions
  3. Logic & bit manipulation Instructions
  4. Branching Instruction
  5. Machine control Instruction

### 1. Data Transfer Instructions :

- This instruction transfer or copies the instruction from one location (source) to another location (destination).
- These locations may be registers or memory locations or I/O.
- Memory to memory transfer is not supported.
- Register pair (BC, DE, HL) is used for 16-bit data transfer.

Address: 0000H to FFFFH  
↑  
Data (8-bit)

\* Note : The I/O port or memory is address

सुगम स्टेटमेंट सलाहकारी एवं कारोबारी संसद  
कानूनमात्रा, लियल्पुर १८७९५९९९९९९९९  
NCLT College

| Instruction |                        | Function                                                                                                                            | Example                                 |
|-------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
| 1           | MVI Rd, data           | This instruction immediately copies the 8-bit data into the register.                                                               | MVI A, 25H,<br>MVI B, 3A H              |
| 2           | MOV Rd, Rs             | This instruction copies the content of some Register into destination                                                               | MOV A, B,<br>MOV B, H                   |
| 3           | LXI Rp, 16-bit data    | This instruction immediately loads the 16-bit data into register pair (BC, DE and HL)                                               | LXI B, 2019H<br>LXI H, 2076H            |
| 4           | IN 8-bit (port-addr)   | This instruction copies the data byte from the port address specified in the instruction into Accumulator (A).                      | IN 03H<br>8-bit data                    |
| 5           | OUT 8-bit (port addr)  | This instruction copies the data byte from the Accumulator into the port address specified in the instruction.                      | OUT 01H                                 |
| 6           | STA 16-bit SIA address | This instruction copies the data byte from the Accumulator into the memory location specified by 16-bit address in the Accumulator. | STA 2050H<br>A → 2050H<br>8-bit data    |
| 7           | LDA 16-bit address     | This copies the data type from the memory location specified by 16-bit address in the instruction into the Accumulator.             | LDA 2050H<br>2050H<br>LDA 8-bit data(A) |

| Instruction | Function | From                                                                                                                                     | Example          |
|-------------|----------|------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 8           | STAX Rp  | This instruction copies the data type byte from Accumulator into the memory locations specified by the register pair in the instruction. | STAX B<br>STAX D |
| 9           | LDAX Rp  | This instruction copies the data byte from the memory location specified by register pair in the instruction into the Accumulator.       | LDAX B<br>LDAX D |
| 10          | MOV M, R | Copies the content of specified register into the memory location specified by HL pair.                                                  | MOV M, B         |
| 11          | SHLD     | Store H & L Register Direct                                                                                                              | SHLD 2050H       |
| 12          | LHLD     | Load H & L Register Direct                                                                                                               | LHLD 2050H       |
| 13          | XCHG     | Exchange the content of H & L with D & E.                                                                                                |                  |

## 2. Arithmetic Instruction:

These instructions are capable of performing arithmetic operations including adding, subtraction, increment, decrement etc. The basic instructions are as follows.

| Instruction       | Function                                                                                                                 | Example                                                                        |
|-------------------|--------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|
| 1. ADD R/M        | • The content of Register / Memory is added to A and the result is stored in A.<br>• Memory (M) is specified by HL pair. | ADD B<br>$A \leftarrow A+B$<br>ADD M<br>$A \leftarrow A+M$                     |
| 2. ADC R/M        | • The content of R/M is added to A along with carry flag (CF) and result is stored in A.                                 | ADC B<br>$A \leftarrow A+B+CF \rightarrow 1$<br>ADC M<br>$A \leftarrow A+M+CF$ |
| 3. ADI            | • The 8-bit data is immediately added to A and the result is stored in A.                                                | ADI 32H<br>$A \leftarrow A+32H$                                                |
| 4. ACI            | • The 8-bit data is added to A along CF.                                                                                 | ACI 32H<br>$A \leftarrow A+32H+CF$                                             |
| 5. SUB R/M        | • The content of R/M is subtracted from A and the result is stored in A.                                                 | SUB C<br>$A \leftarrow A-C$                                                    |
| 6. SBB R/M        | • The content of R/M is subtracted from A along with borrow & the result is stored in A.                                 | SBB C<br>$A \leftarrow A-C-BF$                                                 |
| 7. SUI 8-bit data | • The 8-bit data is subtracted from A and the result is stored in A                                                      | SUI 25H<br>$A \leftarrow A-25H$                                                |
| 8. INR R/M        | • It increments the content of Register or Memory by 1                                                                   | INR C<br>$C \leftarrow C+1$                                                    |

| Instruction | Function                                | Example                     |
|-------------|-----------------------------------------|-----------------------------|
| 9. DCR R/M  | • It decrements the content of R/M by 1 | DCR D<br>$D \leftarrow D-1$ |

| Instruction | Function                                           | Example                       |
|-------------|----------------------------------------------------|-------------------------------|
| 10. INX Rp  | • It increments the content of Register Pair by 1. | INX B<br>$BC \leftarrow BC+1$ |

| Instruction | Function                                           | Example                       |
|-------------|----------------------------------------------------|-------------------------------|
| 11. DCX Rp  | • It decrements the content of Register Pair by 1. | DCX D<br>$DE \leftarrow DE-1$ |

## 3. Logic / Bit Manipulation Instruction

These instructions are capable of performing logical operations including logical multiplication (AND), logical addition (OR), XOR, complement (not), rotate compare etc.

| Instruction | Function                                                                                      | Example                           |
|-------------|-----------------------------------------------------------------------------------------------|-----------------------------------|
| 1. ANA R/M  | • The content of A are logically ANDed with the content of R/M and the result is stored in A. | ANA B<br>$A \leftarrow A \cdot B$ |

| 2. ANI 8-bit data | • The content of A are logically ANDed with the immediate data specified in the instruction and the result is stored in A. | ANI 25H |
|-------------------|----------------------------------------------------------------------------------------------------------------------------|---------|
|                   |                                                                                                                            |         |

|            |      |  |
|------------|------|--|
| 3. ORA R/M | • OR |  |
|            |      |  |

|                   |      |  |
|-------------------|------|--|
| 4. ORI 8-bit data | • OR |  |
|                   |      |  |

|            |       |  |
|------------|-------|--|
| 5. XRA R/M | • XOR |  |
|            |       |  |

|                   |       |  |
|-------------------|-------|--|
| 6. XRI 8-bit data | • XOR |  |
|                   |       |  |

Qn. IF A = 25H. What will be the result of execution of ANI 32H.

Ans;

$$\begin{array}{rcl}
 A & = & 25 \\
 & = & 00100101 \\
 32 & = & 00110010 \\
 \text{AND} & & \\
 \rightarrow 20H & & 
 \end{array}$$

$\begin{array}{r} 00100000 \\ 2 \quad 0 \end{array}$

Qn. What are the status of flag in this execution.

SF : Sign Flag  $\rightarrow 0$

CF : Carry Flag  $\rightarrow 0$

AF : Auxiliary Flag  $\rightarrow 0$

ZF : Zero Flag  $\rightarrow 0$

PF : Parity Flag  $\rightarrow 0$

#### 7. Rotate Instruction

@ RLC (Rotate Accumulator Left)

@ RRC (Rotate " Right)

@ RAL ( " Left with Carry)

@ RAR ( " Right " )

@ RLC

For A = 85H



A = 0BH



(b) RRC

For A = 85H



$\therefore A = C2H$



Qn. RAL

For A = 85H

A = 0AH



$CF = 1$



Qn. RAR

For A = 85H



$CF = 1$



#### 8. Compare Instruction

@ CMP R/M

This instruction compares the content of R/M with A. The result of comparison is:

If  $A < R/M$  : CF is set, ZF is reset

If  $A = R/M$  : ZF is set, CF is reset

If  $A > R/M$  : CF & ZF both are reset. Eg: CMP B

(b) CPI 8-bit data:

This instruction compares the immediate 8-bit data with A. The result of the comparison is:

If  $A < 8\text{-bit data}$  : CF is set, ZF is reset

If  $A = 8\text{-bit data}$  : ZF is set, CF is reset

If  $A > 8\text{-bit data}$  : CF and ZF both are reset. Eg: CPI 32H.

\* Stack = temporary memory

#### 4 Branching Instructions

These instructions are capable of transferring the program sequence from one location into another. It may be:

- I. Unconditional branch

| Instruction           | Function                                                                                                                             | Example.   |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------|------------|
| 1 JMP 16-bit address  | The program sequence is transferred to the memory location specified by 16-bit address                                               | JMP C050H  |
| 2 CALL 16-bit address | The program sequence is transferred to the subroutine program at the memory location specified by 16-bit address in the instruction. | CALL D050H |
| 3 RET                 | The program sequence is transferred from the subroutine program to the calling program                                               | RET        |



classmate  
Date \_\_\_\_\_  
Page \_\_\_\_\_

#### II Conditional Branch

| Instruction Illustration | Function                                      | Example   |
|--------------------------|-----------------------------------------------|-----------|
| JC 16-bit add            | Jump if Carry ( $CF \rightarrow 1$ )          | JC 2030H  |
| JNC "                    | Jump if no-Carry ( $CF \rightarrow 0$ )       | JNC 2020H |
| JP "                     | Jump if positive ( $SF \rightarrow 0$ )       |           |
| JM "                     | Jump if minus/negative ( $SF \rightarrow 1$ ) |           |
| JZ "                     | " " zero ( $ZF \rightarrow 1$ )               |           |
| JNZ "                    | " " not zero ( $ZF \rightarrow 0$ )           |           |
| JPE "                    | " " parity even ( $PF \rightarrow 1$ )        |           |
| JPO "                    | " " odd ( $PF \rightarrow 0$ )                |           |

#### 5 Machine Control Instructions

NOP → No operation is performed. e.g. NOP  
HLT → The CPU finishes executing the current instruction & stops any further execution e.g. HLT

# WAP to add two 8-bit numbers stored in memory location 2050H and 2060H respectively. Store the result in memory location 2070H.

| Program   | 2050 Data | 2060 Data  | 2070 Sum |
|-----------|-----------|------------|----------|
| LDA 2050H | A ← Data1 | 2060 Data2 |          |
| MOV B, A  | B ← Data1 | 2070 Sum   |          |
| LDA 2060H | A ← Data2 |            |          |
| ADD B     | A ← A + B |            |          |
| STA 2070H |           |            |          |
| HLT       |           |            |          |

# WAP to add two 8-bit numbers stored in memory location 2050H and 2060H respectively. Store the sum in memory location 2070H & Carry (if occurs) in 2071H.

→ Program

|           | 2050      | Data1    |
|-----------|-----------|----------|
| LDA 2050H | A ← Data1 |          |
|           | 2060      | Data2    |
| MOV B, A  | B ← Data1 | 2071 Sum |
|           | 2070      |          |
|           | 2071      | Carry    |

MVI C, 00H

LDA 2050H

MOV B, A

LDA 2060H

ADD B            A ← A + B

JNC loop

INR C

loop: STA 2070H

MOV A, C

STA 2071H

HLT

# WAP to multiply two immediate numbers. And store the result in C050H.

→ Program

MVI A, 00H

MVI B, 05H

MVI C, 03H

loop: ADD B, A ← 5 + 0 + 5 + 5

DCR C            C = 2, 1, 0

JNZ loop

STA EQU C050H

HLT

# Types of Instruction (on the basis of size)

① One byte - Instruction:

These instructions occupy a total memory of one byte. It includes the opcode & operand in the same byte. e.g.: ADD B, MOV A, B, RAL, ANA B, etc.

② Two-byte Instruction:

These instructions occupy a total memory of two bytes. The first byte specifies the opcode and the second byte specifies the operand.  
e.g.: MVI A, 32H, ADI 25H, IN 30H, etc.

③ Three byte Instructions:

These instructions occupy a total memory of three bytes. The first byte specifies the opcode and the remaining two bytes specifies the operand.  
e.g.: STA 2050H, JNC 3050H, LXI H, 2070H

Imp

# Addressing Modes of 8085:

- An instruction consists of opcode and operand. The way in which operands are expressed within an instruction is called addressing modes.
- Addressing modes explain how operands are addressed within an instruction.
- There are five addressing mode of 8085.

④ Immediate Addressing Mode:

If the 8-bit or 16-bit operands/data are immediately expressed within an instruction then it is called immediate addressing mode.  
e.g.: MVI A, 29H, LXI B, 2050H, ADI 32, ANI FFH

## ② Register Addressing Mode:

If the operands are stored in register and the operation is in between register that are expressed in the instruction then it is called Register Addressing Mode. Eg: MOV A, B, ADD B, ANA D.

## ③ Direct Addressing Mode:

If the operand's effective address (address where the operand is stored) is expressed within an instruction then it is called direct addressing mode.

Eg: STA 2050, LDA 3050H, SHLD 2050, IN 01H, OUT 03H.

## ④ Indirect Addressing Mode:

If the register pair which contains the address of the data is specified within an instruction, then it is called indirect addressing mode. Here, register pair holds the operation memory location. Eg: STAX D, LDAX B, MOV A, M.

## ⑤ Implied Addressing Mode:

If the opcode in an instruction tells about the operand & the operand is not visible within an instruction then it is called implied addressing mode.

Eg: HLT, RET, NOP, RAL, RRC, etc.

## # Timing Diagram of 8085 Instructions

### Related Terms:

1 Instruction Cycle: The time taken to complete the execution of an instruction is called instruction cycle. It is the combination of machine cycles

2 Machine Cycle: The time taken by the processor to access memory location, I/O ports, or to acknowledge an interrupt once is called machine cycle. It is combn of T-states.

3 T-state: It is the subdivision of operation performed in one clock cycle of the processor clock.

## # Machine Cycle & the Status Single

| Machine Cycle | Status Signal | T-states         |                |                |
|---------------|---------------|------------------|----------------|----------------|
|               |               | I <sub>O/M</sub> | S <sub>0</sub> | S <sub>1</sub> |
| Opcode Fetch  | 0             | 1                | 1              | 4T/6T          |
| Memory Read   | 0             | 0                | 1              | 3T             |
| Memory Write  | 0             | 1                | 0              | 3T             |
| I/O Read      | 1             | 0                | 1              | 3T             |
| I/O Write     | 1             | 1                | 0              | 3T             |

Other machine cycles may be Interrupt Acknowledge & Bus Idle.

Note: Timing diagram is a graphical representation of an instruction cycle that consists of fetch, decode and execute cycle.



State change @ falling edge of clock cycle.



#### 4 I/O READ



classmate

Date \_\_\_\_\_

Page \_\_\_\_\_

#### 5 I/O WRITE



classmate  
Date \_\_\_\_\_  
Page \_\_\_\_\_

### List of Instructions (along with machine cycles)

| Instruction               | Size   | Machine Cycle                                                  |
|---------------------------|--------|----------------------------------------------------------------|
| 1. MOV A, B               | 1 byte | 1. Opcode Fetch                                                |
| 2. MVI A, 32H             | 2 byte | 1. Opcode Fetch<br>2. Memory Read (MR)                         |
| 3. MVI M, 32H             | 2 byte | 1. Opcode Fetch<br>2. MR<br>3. MW                              |
| 4. STA 2065H<br>LDA 2050H | 3 byte | 1. Opcode Fetch 1 OF<br>2. MR 2 MR<br>3. MR 3 MR<br>4. MW 4 MR |
| 5. Mov A, M               | 1 byte | 1. Opcode Fetch 2. MR                                          |
| 6. MOV M, A               | 1 byte | 1. OF 2. MW                                                    |
| 7. IN 84H                 | 2 byte | 1. OF 2. MR 3. I/O Read                                        |
| 8. OUT 01H                | 2 byte | 1. OF 2. MR 3. I/O Write                                       |
| 9. ADJ 12H                | 2 byte | 1. OF 2. MR                                                    |
| 10. JNZ C050H             | 3 byte | 1. OF<br>2. MR<br>3. MR<br>4. If condition is true             |
| 11. STAX B                | 1 byte | 1. OF 2. MW                                                    |

classmate  
Date \_\_\_\_\_  
Page \_\_\_\_\_

### Timing Diagram of MVI A, 25H



The above timing diagram can be explained as

- 1 This instruction consists of two bytes. The first is opcode & the second is data byte. The MP need these bytes to be read from the memory and thus requires two machine cycles,

- I. Opcode Fetch
- II. Memory Read

- 2 At T<sub>1</sub>, the MP identifies that it is a opcode fetch cycle. It places I/O/M = 0, S<sub>0</sub> = 1, S<sub>1</sub> = 1. It places the memory address (say 2000H) from the program counter on the address bus A<sub>15</sub>-A<sub>8</sub> and A<sub>D7</sub>-A<sub>D0</sub> and increments the program counter to next memory address 2001H to point to the next machine code. The ALE goes high during T<sub>1</sub>. The 8085 asserts the RD

classmate  
Date \_\_\_\_\_  
Page \_\_\_\_\_

control signal which enables the memory and memory places the byte 3EH from location 2000H on the data bus. The 8085 places 2000H on the data bus. The 8085 places the opcode in the instruction register & disables the RD signal. The fetch cycle is completed in state T<sub>3</sub>. During T<sub>4</sub>, 8085 decodes the opcode and finds out that a second byte needs to be read. After T<sub>4</sub> state, the content of A<sub>15</sub> - A<sub>8</sub> are unknown and the data bus A<sub>D7</sub> - A<sub>D0</sub> goes into high impedance state.

3. After completion of opcode fetch cycle, the MP places the address 2001H on the address bus and increments the program counter at T<sub>5</sub>. The second machine cycle is identified as memory Read cycle according to the control signal generated i.e.  $I_{O/M} = 0$ ,  $S_0 = 0$ ,  $S_1 = 1$ . The ALE goes high during T<sub>5</sub> state. At T<sub>6</sub>, the RD signal becomes active and enable the memory chip.

4. Then the memory places the data byte 25H on the data bus, and the 8085 reads and store the byte in Accumulator during T<sub>7</sub>.

classmate  
Date \_\_\_\_\_  
Page \_\_\_\_\_

cpn Draw and explain the timing diagram for OUT 03H.



## Assembly Language Program

Qn. WAP to find the sum of 5 data bytes stored from memory 2000H and store the sum in memory location 2005H.

→ LXI H, 2000H  
MVI C, 05H

2000 → Data 1

:

2004 → Data 5

2005 → Sum.

~~MVI A, 00H  
LXI H, 2000H  
MVI C, 05H  
loop: ADD M  
DCR C  
JNZ loop      INX H  
STA~~

~~MVI A, 00H  
LXI H, 2000H  
MVI C, 05H  
loop: ADD M  
INX H  
DCR C  
JNZ loop  
STA 2005  
HLT~~

Qn. To transfer a block of 10 bytes of data stored from memory 2000H into another block of memory starting from 3000H.

→ LXI H, 2000H

LXI D, 3000H

MVI C, 0AH

loop: MOV A, M

STAX D

INX H

INX D

DCR C

JNZ loop

HLT