

A photograph of a young man with dark hair and a mustache, smiling at the camera. He is wearing a black zip-up hoodie over a green t-shirt with a red and white graphic. The background shows a sandy beach with ocean waves crashing onto it under a clear blue sky.

Note by : Roshan Bist  
=Siddhanath Science  
Campus,Mahendranagar

Subject : Microprocessor

Email :  
[roshanbist900@gmail.com](mailto:roshanbist900@gmail.com)

Contact : 9806470952

## Unit-2

### Basic Architecture

Date \_\_\_\_\_  
Page No. \_\_\_\_\_

- \* Introduction to 8085 microprocessor with its Architecture (or Block diagram).

The 8085 microprocessor is 8-bit general purpose microprocessor capable of addressing 16K of memory. The device has 40 pins which required +5V single phase power supply and can operate with 3MHz single phase clock.

The 8085 is an enhanced/improved version of its previous model 8080. Its instruction is upward compatible with that of 8080. It was most popular microprocessor for commercial purpose of 8-bit.

This microprocessor contains 3 buses Address, Data and Control. Address bus is of 16 Bit i.e.  $2^{16} = 64\text{kb}$  of data can be recognized by at a single cycle in single operation by address bus. Data bus carries data required from recognized bus and control bus will help for the read/write operation. The size of data bus is 8-bit, therefore 8085 microprocessor is also called 8-bit microprocessor. All the signals in 8085 microprocessor can be classified into six groups.

- i) Address bus.
- ii) Data bus
- iii) Control and status signal.
- iv) Power supply and frequency signal.
- v) Externally initiated signals.
- vi) Serial I/O ports.

The block diagram of 8085 is as follows:-

PIN  
configuration  
of 8085



Architecture of 8085 microprocessor.

## \* Address, Data & Control Buses of 8085 microprocessor:

The microprocessor has 16 signal lines (pins) that are used as address bus which one are grouped into two segment A<sub>8</sub>-A<sub>15</sub> and A<sub>0</sub>-A<sub>7</sub>. The eight signal lines A<sub>8</sub>-A<sub>15</sub> are unidirectional and used for most significant bits, called the higher order address and the signals A<sub>0</sub>-A<sub>7</sub> are bidirectional and used for dual purpose, while address as well as data. While executing an instruction these bits are used as lower address bus and during lower part of cycle these lines are used as data bus. This is known as multiplexing of bus.

The group of signals includes two control signals RD and WR, three status signals I<sub>O/M</sub>, S<sub>0</sub> & S<sub>1</sub> to identify the nature of operation and one special signal ALE (Address Latch Enable) to indicate the beginning of operation.

ALE is positive going pulse generated everytime the microprocessor begins an operation, which indicate that the bits A<sub>0</sub>-A<sub>7</sub> are address bits.

$\overline{RD}$  control signal (active low) indicates that the selected I/O for memory device is to be read and data are available on data bus.

$\overline{WR}$  control signal (active low) indicates that data on the bus are to be written into memory or I/O Location. I<sub>O/M</sub> status signal is used to differentiate between I/O and memory location. When it is high it indicates I/O operation & when it is

These are also generations of control signals

low it indicates memory operation. S0 and S1 status signal are similar to IO/M which can identify various operations but they are rarely used in small program.

### \* Internal data operations and Registers:

The ALU performs the computing functions which are mathematical and logical and which includes accumulator, temporary register and flag register which are used to hold data during arithmetic logic operation. The result of operation is stored in accumulator and flags are used to indicate the status of accumulator and other register after the completion of operation. These flip-flops are set or reset according to the data condition of the result in accumulator. Five flags are used in 8085 microprocessor which are described below:-

i) Sign flag (S) → It indicates whether the result of operation is positive or negative. If the result is positive the flag will reset (i.e. S=0) and if the result is negative the flag will set (i.e. S=1).

ii) Zero flag (Z) → It indicates whether the result of operation is zero or not. If the result of current operation is zero the flag will be set (i.e. Z=1) otherwise the flag will be reset (i.e. Z=0).

iii) Auxiliary carry (AC) → In operation when the carry is generated by bit  $D_3$  and passes onto bit  $D_4$  the AC flag will be set (i.e.  $AC=1$ ) otherwise AC flag will be reset.

iv) Parity flag (P) → This flag indicates whether the current result is even parity or odd parity. If there is even parity parity flag (P) will be set and reset for odd parity.

v) Carry flag (V) → This flag indicates whether carry is generated or borrow is generated during addition or subtraction operation. If carry or borrow is generated the flag will be set otherwise reset.

### Register:

8085 microprocessor has 8 bit registers B, C, D, E, H, L, A (Accumulator) and F (Flags) and 16-bit registers PC (Program Counter), SP (Stack pointer), IR (Instruction Register). These registers are classified into two groups general purpose register and specific purpose register.

B, C, D, E, H, L are 8-bit general purpose registers and can be used either singly or as paired 16-bit registers as BC, DE and HL. The content of these register is called higher order bytes and lower order bytes. The register pair HL function as data pointer. Accumulator and Flag are 8-bit special purpose registers whereas PC, SP and IR are 16-bit special purpose registers.

## (\*) Externally initiated operations of 8085 μp:

8085 microprocessor support some externally initiated operations, which are also known as peripheral operations. Different external input / output devices or signals can initiate these type of operations. Following are some externally initiated operations.

i) RESET → This reset key is used to clear the program counter and update with 0000H memory location. When this RESET pin is activated by any external key, then all the internal operations are suspended for that time. After that the execution of the program can begin at the zero memory address.

ii) Interrupt → 8085 microprocessor chip have some pins for interrupt like trap, TRAP, RST 5.5, RST 6.5 and RST 7.5. The microprocessor can be interrupted from the normal instructions and asked to perform some other emergency operations, which are also known as Service routine. The microprocessor resumes its operation after the completion of Service routine.

iii) READY → The 8085 microprocessor has a pin called READY. If the signal at this pin is in low state then the microprocessor enters into the wait state. The Input / Output devices connected to microprocessor are of different speed, which need to be synchronized with the speed of microprocessor.

v) HOLD → When HOLD pin is activated by an external signal, the microprocessor relinquishes control buses and allows the external peripheral to use them. For example, the HOLD signal is used in Direct memory access (DMA) data transfer. In this DMA, the external Input/Output device are directly communicating with the memory without interfering the processor every time.

### ✓ \* Addressing Modes : (V.Imp)

The 8085 microprocessor have 5 types of addressing modes which are described below with examples.

a) Immediate Addressing Mode → In immediate addressing mode the source operand is always data. If the data is 8-bit, then the instruction will be of 2 bytes, if the data is of 16-bit then the instruction will be of 3 bytes.

Examples:

a) MVI B 45 (i.e. move the data 45H immediately to register B).

b) LXI H 3050 (i.e. load the H-L pair with the operand 3050H immediately).

c) JMP address (i.e. jump to the operand address immediately).

v) Register Addressing Mode → In register addressing mode, the data to be operated is available inside the registers and registers are operands. Therefore the operation is performed within various registers of the microprocessor.

Examples:

- (a) MOV A, B (move the contents of register B to register A).
- (b) ADD AB (add contents of registers A and B and store the result in register A)
- (c) INR A (increment the contents of register A by one).

iii) Direct Addressing Mode → In direct addressing mode, the data to be operated is available inside a memory location and that memory location is directly specified as an operand. The operand is directly available in the instruction itself.

Examples:

- (a) LDA 2050 (load the contents of memory location into accumulator A).
- (b) IN 35 (read the data from port whose address is 01).

iv) Register Indirect Addressing Mode → In register indirect addressing mode, the data to be operated is available inside a memory location and that memory location is indirectly specified by a register pair.

Examples:

- (a) MOV A, M (move the contents of the memory location pointed by the H-L pair to the Accumulator).
- (b) LDAX B (move contents of B-C pair register to the accumulator).

v) Implied / Implicit / Inherent Addressing Mode →

In this addressing mode, the operand is hidden and the data to be operated is available in the instruction itself.

### Examples:

- (a) EI (Enable interrupt)
- (b) STC (Set the carry flag)
- (c) NOP (No operation)
- (d) CMA (finds and stores the 1's complement of the contents of accumulator in A).

### \* Pin diagram of 8085 microprocessor with functions:

|                     |    |    |                   |
|---------------------|----|----|-------------------|
| $\overline{X_1}$ →  | 1  | 40 | → Vcc (+5V)       |
| $\overline{X_2}$ →  | 2  | 39 | ← HOLD            |
| Reset out ←         | 3  | 38 | → HLD A           |
| SOD ←               | 4  | 37 | → CLK (out)       |
| SID →               | 5  | 36 | ← Reset in        |
| Trap ←              | 6  | 35 | ← Ready           |
| RST 7.5 →           | 7  | 34 | → IO/M            |
| RST 6.5 ←           | 8  | 33 | → S <sub>1</sub>  |
| RST 5.5 →           | 9  | 32 | → RD              |
| INTR →              | 10 | 31 | → RW              |
| INTA ←              | 11 | 30 | → ALE             |
| AD <sub>0</sub> ← → | 12 | 29 | → S <sub>0</sub>  |
| AD <sub>1</sub> ← → | 13 | 28 | → A <sub>15</sub> |
| AD <sub>2</sub> ← → | 14 | 27 | → A <sub>14</sub> |
| AD <sub>3</sub> ← → | 15 | 26 | → A <sub>13</sub> |
| AD <sub>4</sub> ← → | 16 | 25 | → A <sub>12</sub> |
| AD <sub>5</sub> ← → | 17 | 24 | → A <sub>11</sub> |
| AD <sub>6</sub> ← → | 18 | 23 | → A <sub>10</sub> |
| AD <sub>7</sub> ← → | 19 | 22 | → A <sub>9</sub>  |
| Vss →               | 20 | 21 | → A <sub>8</sub>  |

## ② Demultiplexing Address Data bus:-



Given, the ALE operates as a pulse, during  $T_1$  we will be able to latch the address then when ALE goes low the address is saved and the  $AD_7 - AD_0$  lines can be used for their purpose as the bi-directional data bus lines.

## Demultiplexing the Bus $AD_7 - AD_0$

- The high order address is placed on the address bus and hold for 3 clk periods.
- The low order address is lost after the first clk period, this address needs to be hold however we need to use latch.
- The address  $AD_7 - AD_0$  is connected as inputs to the latch. 74LS373 (name of latch).
- The ALE signal is connected to the enable (G<sub>1</sub>) pin of the latch and the OC - output control of the latch is grounded.

## 8086 Microprocessor

8086 is 16-bit microprocessor which has arithmetic logic unit capable of processing 16-bit data. It has 16 internal registers and most of the instruction having size 16-bit. The 8086 microprocessor has 20-bit addresses so it can address any one of  $2^{20}$  memory locations. 8086 microprocessor is divided into two independent functional parts to speed up the processing namely BIU (Bus Interface Unit) and EU (Execution Unit).

BIU unit is responsible for all transfer of data and address on buses for execution unit as well as it fetches out instruction from memory, read/write data from/to ports & memory.

While execution unit is responsible for decoding & executing instruction & tells BIU where to fetch instruction and data from.

### Architecture / Block diagram of 8086 CPU



Es, CS, SS, DS  
Date \_\_\_\_\_  
Page No. \_\_\_\_\_

Physical address (PA) = Starting Segment address  $\times$  10H + Offset  
where H represents hexadecimal

## \* Segment registers / Memory Segmentation:-

Segmentation is the process in which the main memory of the computer is divided into different segments and each segment has its own base address. It is basically used to enhance the speed of execution of the computer system, so that processor is able to fetch and execute the data from the memory easily and fast.

Need for segmentation - The Bus Interface Unit (BIU) four 16-bit special purpose registers (mentioned below) called as Segment Registers.

- i) Code segment register (CS) → It is used for addressing memory location in the code segment of the memory, where the executable program is stored.
- ii) Data segment register (DS) → It points to the data segment of memory where the data is stored.
- iii) Extra Segment register (ES) → It also refers to a segment in the memory which is another data segment in the memory.
- iv) Stack Segment register (SS) → It is used for addressing stack segment of the memory. The stack segment is that segment of memory which is used to store stack data.

④ Instruction pointer (IP) → All program instructions located in the memory are pointed by using 20-bits which is the logical address that is the content of CS & IP. 16-bit content of CS will be shifted 4-bits to the left & then adding the 16-bit content of IP. Thus all instruction of program are relative content of IP.

⑤ Bus Interface Unit & Execution Unit:

⑥ Bus Interface Unit (BIU):

BIU takes care of all data and addresses transfers on the buses for the EU like sending addresses, fetching instructions from the memory as well as writing data to the ports and the memory. as well as writing data to EU has no direct connection with system buses so this is possible with the BIU. EU and BIU are connected with the Internal Bus. It has following functional parts.

⑦ Instruction queue → When EU is executing an instruction, bus will be idle at that time. BIU gets upto 6-bytes of instruction to be executed and place them in queue. In each time of execution of new instruction to be executed instead of sending address to system memory just pick up the fetched instruction byte from queue. This improves the overall execution speed.

Note → Fetching the next instruction while the current position instruction executes is called pipelining.

⑧ Segment registers → Already described before.

### (a) Execution Unit:-

Execution Unit gives instructions to BIU stating from where to fetch the data and then decode and execute those instructions. Its function is to control operations on data using the instruction decoder & ALU. EU has no direct connection with system buses. It performs operations over data through BIU.

Following are the functional parts of 8086 microprocessor.

- (a) Instruction decoder & ALU → Decoder in EU translates instruction phased from memory into series of action which the EU carries out. 16-bit ALU performs different operations like AND, OR, XOR, increments, decrements etc.

- (b) Flag register → It has 16-bit register that behaves like a flip-flop, i.e., it changes its status according to the result stored in the accumulator. It has 9 flags and divided into two groups - Conditional flags (6) and Control flags (3).

- Conditional flags → It represents the result of the last arithmetic or logical instruction executed. Following are the conditional flags:

Carry flag → This flag indicates an overflow condition for arithmetic operations.

Auxiliary flag → When the operation is performed at ALU, it results in a carry/borrow from lower nibble (i.e.  $D_0 - D_3$ ) to upper nibble (i.e.  $D_4 - D_7$ ), then this flag is set. i.e, carry given by  $D_3$  bit to  $D_4$  is AF flag. The processor uses this flag to perform binary to BCD conversion.

Parity flag → This flag is used to indicate the parity of the result. i.e, when the lower order 8-bits of the result contains even number of 1's, then the Parity Flag is set. For odd number of 1's, the Parity Flag is reset.

Zero flag → This flag is set to 1 when the result of arithmetic or logical operation is zero else it is set to 0.

Sign flag → This flag is set to 1 when the result of operation is negative, else set to 0. This flag holds the sign of the result.

Overflow flag → This flag represents the result when the system capacity is exceeded.

ii) Control flags → Control flags control the operations of the execution unit. Following is the list of control flags:

Trap flag → It is used for single step control and allows the user to execute one instruction at a time for debugging. If it is set, then the program can be run in single step mode.

Interrupt flag → It is used as an interrupt enable/disable flag. It is set to 0 for interrupt disabled condition.

Direction flag → It is used in string operation. As the name suggests when it is set then string bytes are accessed from the higher memory address to the lower memory address and vice-versa.

### ② General Purpose registers:

There are 8 general purpose registers i.e., AH, AL, BH, BL, CH, CL, DH and DL. These registers can be used individually to store 8-bit data and can be used in pairs to store 16-bit data. The valid register pairs are AH and AL, BH and BL, CH and CL, and DH and DL. It is referred to the AX, BX, CX and DX respectively.

AX register → It is also known as accumulator register. It is used to store operands for arithmetic operations.

BX register → It is used as a base register. It is used to store the starting base address of the memory area within the data segment.

CX register → It is referred to as counter. It is used in loop instruction to store the loop counter.

DX register → This register is used to hold I/O port address for I/O instruction.

#### ④ Stack pointer register:-

It is a 16-bit register, which holds the address from the start of the segment to the memory location, where a word was most recently stored on the stack.

#### ⑤ Pipelining : X (from assignment copy for better).

Pipelining is an implementation technique where multiple instructions are overlapped in execution. The computer pipeline is divided in stages. Each stage completes a part of an instruction in parallel. Pipelining does not decrease the time for individual instruction execution. Instead, it increases instruction throughput.

Pipelining is the process of fetching the next instruction when the present instruction is being executed. It has become possible due to the use of 6-byte queue. The advantages of pipelining are: it eliminates the waiting time of EU and speeds up the processing and the execution unit always reads the next instruction byte from the queue in BIU which is faster than sending out an address to the memory and waiting for the next instruction byte to come.

## Differences between 8085 and 8086

The differences between 8085 and 8086 microprocessor are as follows:-

| 8085 microprocessor                                           | 8086 microprocessor                                    |
|---------------------------------------------------------------|--------------------------------------------------------|
| <u>Size</u> → 8085 is 8-bit microprocessor.                   | 8086 is 16-bit microprocessor.                         |
| ii) 8085 microprocessor contain <u>address bus</u> of 16-bit. | ii) 8086 microprocessor contain address bus of 20-bit. |
| iii) It does not have <u>instruction queue</u> .              | iii) It have instruction queue.                        |
| iv) It does not support <u>pipelined architecture</u> .       | iv) It supports pipelined architecture.                |
| I/O → It can address $2^8 = 256$ I/O's.                       | v) It can address $2^{16} = 65,536$ I/O's.             |
| Cost → vi) 8085 microprocessor is of lower cost.              | vi) 8086 microprocessor is of higher cost.             |