

## UNIT-1

i) Describe the architecture of 8086 Microprocessor with neat diagram.

Ans Architecture & Diagram of 8086

- \* 8086 employs parallel processing
- \* 8086 CPU have two parts which operate at the same time
  - Bus interface Unit
  - Execution Unit
- \* CPU functions.
  1. Fetch
  2. Decode
  3. Execute



## Bus Interface Unit

\* Main components are

- Instruction Queue
- Segment Registers
- Instruction pointers.

### BIU

- Sends out addresses for memory locations
- Fetches instructions from memory
- Reads/writes data to memory
- Sends out addresses for I/O ports
- Reads/writes data to Input / Output ports

## Execution Unit

- Tells BIU (addresses) where to fetch instructions or data
- Decodes & executes instructions
- Main Components are
  - Instruction Decoder
  - Control System
  - Arithmetic logic unit
  - General purpose Registers
  - Flag Register
  - pointer & Index registers.

Instruction Decoder: Translates instructions fetched from memory into a series of actions which EU carries out

Control System:- Generates timing and control signals to perform the internal operations of the microprocessor.

Arithmetic logic unit : 16 bit ALU with which can ADD, SUBTRACT, AND, OR, increment, decrement, complement or shift binary numbers

- 1 General Purpose Registers:- To store temporary data
- 2 Flag Register:- Flags tell about the status of the processor after any arithmetic or logic operations.
- 3 Pointer and Index Registers:- The pointers will always store some address or memory location. They usually store the offset through which the actual address is calculated.

2 Define Addressing mode and explain about different types of Addressing modes of 8086 microprocessor.

Addressing modes in 8086 microprocessor

- The way of specifying data to be operated by an instruction is known as addressing modes.
- This specifies that the given data is an immediate data or an address.
- It also specifies whether the given operand is register or register pair.

eg. MOV AL, B2    eg. MOV AX, [SI]  
 eg. MOV DX, (BX + SI)

eg. MOV DX 1000H

Four concepts



## Types of Addressing Modes

1. Register mode - In this type of addressing mode both the operands are registers.

Example : MOV AX, BX

XOR AX, DX

ADD AL, BL

2. Immediate mode - In this type of addressing mode the source operand is a 8 bit or 16 bit data. Destination operand can never be immediate data.

Ex: MOV AX, 2000

MOV CL, 0A

ADD AL, 45

AND AX, 0000

Note that to initialize the value of segment register an register is required.

MOV AX, 2000 MOV CS, AX

3. Displacement or direct mode - In this type of addressing mode the effective address is directly given in the instruction as displacement.

Ex: MOV AX, [DISP]

MOV AX, [0500]

4. Register indirect mode - In this addressing mode the effective address is in SI, DI or BX.

Ex: MOV AX, [DI]

ADD AL, [BX]

MOV AX, [SI]

5. Based indexed mode:- In this the effective address is sum of base register and index register.

- Base register : BX, BP Index register : SI, DI The physical memory address is calculated according to the base register.

Example:

MOV AL, [BP+SI]

MOV AX, [BX+DI]

6. Indexed mode:- In this type of addressing mode the effective address is sum of index register and displacement.

Example: MOV AX, [SI + 2000]

MOV AL, [DI + 3000]

7. Based mode - In this the effective address is the sum of base register and displacement.

Example: MOV AL, [BP+DI00]

8. Based indexed displacement mode: In this type of addressing mode the effective address is the sum of index register, base register and displacement.

Example: MOV AL, [SI+BP+2000]

9. String mode - This addressing mode is related to string instructions. In this value of SI and DI are auto incremented and decremented depending upon the value of directional flag

Example: MOVS B  
MOVS W

10. Relative mode: In this the effective address is calculated with reference to instruction pointer.

Example: JNZ 8 bit address

$$IP = IP + 8 \text{ bit address}$$

3 Explain the memory segmentation in 8086 microprocessor and memory organization of 8051 microcontroller.

Ans Memory Segmentation in 8086 microprocessors

- ⇒ 8086 has a 20-bit address bus
- ⇒ So it can address a maximum of 1MB of memory
- ⇒ 8086 can work with only four 64KB Segments at a time within this 1MB range
- ⇒ These four memory segments are called
  - Code Segment
  - Stack Segment
  - Data Segment
  - Extra Segment

Code segment register (CS):

Used for addressing memory location

in the code segment of the memory where the executable program is stored.



## Data Segment register (DS):

Points to the data segment of the memory where the data is stored.



## Extra Segment Register (ES):

Also refers to a segment in the memory which is another data segment in the memory



## Stack Segment Register (SS):

Is used for addressing stack segment of the memory. The stack segment is that segment of memory which is used to store stack data.



## Example:

0000 0110 1110 1111 0000 Segment, 16 bits, shifted 4 bits left (or multiplied by  $0 \times 10$ )  
 + 0001 0010 0011 0100 offset, 16 bits  
 \_\_\_\_\_  
 0000 1000 0001 0010 0100 Address, 20 bits



## 8051 memory Organization:

The 8051 has two memory spaces.

- program memory
- Data memory

- The program memory is read only memory
- The data memory is read - write memory.

### 8051 MC program memory.

- 8051 has 64KB of program memory
- In ROM / EPROM versions of 8051 lower 4K ( $0000H - 0FFFH$ ) provided internally , 60K ( $1000H - FFFFH$ ) provided externally
- After reset of the CPU begin the execution from address  $0000H$  of the program memory.
- In ROM / EPROM versions EA pin is used, when it is connected to VCC it access the internal address  $0000$  to  $0FFF$  (internal ROM)

### 8051 MC internal Data memory.

- The internal data memory address are one byte wide
- The which includes 128 bytes on chip RAM + SFRs.
- The 128 bytes of RAM can accessed by direct or indirect addressing mode
- The lower 32 bytes of on chip RAM is grouped into 4 Banks. Each bank contain 8 registers (each one 8-bit wide)
- By using PSW we can select which register is in use

## 8051 MC External Data memory

- There can be up to 64kB of data memory external to the chip
- Depending upon the addressing mode the address of memory 1 or 2 bytes wide
- MOVx instruction can be used to access the external data memory.
- External data memory and program memory may be combined by enabling both RD' and PSEN' signals

## 8051 memory Organization.

Program Memory (Read only)



Data Memory (Read/write)



4. Describe the Architecture of 8051 Microcontroller with neat diagram.

### Components of 8051

#### 1. Bus Control

- Data Bus: 8 bit data bus for carrying data
- Address Bus: 16 bit address bus used to carry address

#### 2. Four (8 bit each) general purpose parallel I/O ports:

- Port 0: When no external memory is connected it acts as general-purpose I/O port
- If external memory applied then it acts as multiplexed address and data bus.
- Can operate in dual mode
- Port 1: Normal I/O port
- Port 2: Same as Port 0
- Port 3: Dedicated I/O port

3. Timers and Counters: Used for synchronization of clock circuits in the internal operation by XTAL1 and XTAL2

4 additional pins are:

- EA (External Enable)
- PSEN (Program store enable)
- ALE (Address latch enable)
- RST (Reset)

#### 4. Memory:

- ROM - A program of 4Kb memory can be stored
- RAM - 128 bytes Internal RAM divided into 32 working registers.  
Each register has 4 register bank of 8 registers each

## 5. Serial port - for communication.

- SBUF: Serial port data buffer holds the data
- SCON: Serial control for managing communication.
- PCON: parallel control manages data transfer rates.
  - RXD and TXD
  - 4 programmable modes
    - Serial data mode 0 (shift register mode)
    - Serial data mode 1 (Standard UART)
    - Serial data mode 3

## 6 Interrupt control (software or hardware)

- 5 sources are present
- 2 external interrupt sources connected through INT0 and INT1
- 3 external interrupt sources through serial port interrupt, timer 0 flag, and timer flag
- CPU: 8031 system bus connects all the support devices to CPU.

Port 2  
0000 0000

Port 0  
1111 1111  
Tristate

## ⑤ Distinguish between Microprocessor and microcontroller.

| Micro controller                                                | Micro processors.                                                |
|-----------------------------------------------------------------|------------------------------------------------------------------|
| 1. CPU is stand-alone, RAM, ROM I/O, timer are separate         | 1. CPU, RAM, ROM, I/O and timer are all on a single chip.        |
| 2. Designer can decide on the amount of ROM, RAM and I/O ports  | 2. Fixed amount of on-chip ROM, RAM, I/O ports                   |
| 3. Microprocessor based system requires more hardware           | 3. Micro controller system requires less hardware                |
| 4. General-purpose Device                                       | 4. Single Special purpose Device                                 |
| 5. Microprocessor based system is more flexible                 | 5. Micro controller based system is not flexible                 |
| 6. Access time for memory and I/O is more                       | 6. Access time for memory and I/O is less                        |
| 7. It has many instructions to move data between memory and CPU | 7. It has less instructions to move data between memory and CPU. |