

1) The flag register of 8086 is as follows:-

|    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|
| OF | DF | IF | TF | SF | ZF | AF | PF | CF |
| 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |

2) Carry flag (CF):- 10 9 8 7 6 5 4 3 2 1 0

An addition causes this flag to be set when there is a carry out of MSB & subtraction causes it to set if a borrow is needed.

3) Parity flag (PF):-

If it is set to 1 if the lower nibble of the 8-bit of the result contains an even number of 1's otherwise it is cleared.

4) Zero flag (ZF):-

If it is set to 1 if the result is zero otherwise it is cleared.

5) Sign flag (SF):- If sign flag holds the arithmetic sign of the result after arithmetic or logical operation. If the number is 1 that is considered as negative number and if the number is 0 then it is considered as positive number.

6) Trap flag (TF):-

If the trap flag is set it initializes the program execution in single stepping mode.

7) Interrupt flag (IF):-

The interrupt flag controls the operation of INTR (P pin). If IF=0 the interrupt pin is disabled, if IF=1 the interrupt pin is enabled.

8) Direction flag:-

Direction flag selects either forward mode for the SI/PDI register during string instructions, if DF=0 the SI/PDI register are incremented & if DF=1 the register are automatically decremented.

9) Overflow flag (OF):-

The overflow flag indicates that the result has exceeded the capacity of the machine.

## Memory Segmentation of 8086.

- i) There are two types of organization which are commonly used. They are Linear addressing and Segmented addressing.
- ii) In linear addressing entire memory space is available to the processor in one linear way.
- iii) In Segmented addressing, on the other hand the available memory is divided into "chunks" called segments.
- iv) In 8086 system, the available space is 1 MB bytes.
- v) Memory is divided into number of logical segments.
- vi) Each segment is 64K bytes in size.



| ① | Segment | offset                   | Special Purpose<br>Instruction -<br>address |
|---|---------|--------------------------|---------------------------------------------|
|   | CS      | IP                       |                                             |
|   | SS      | SP or BP                 | Stack address                               |
|   | DS      | BX, SI, DI<br>8bit/16bit | Data address                                |
|   | ES      | DI for string<br>instr   | String destination<br>address               |

- Features of 8086.
- i) Provides 20 bit address line
  - ii) Multiplex 16 bit address & data bus to minimise no of pins in IC.
  - iii) Provides 16-bit data bus.
  - iv) Has 14 fourteen 16-bit registers.
  - v) Operates has two modes minimum and maximum mode
  - vi) Supports multiprogramming.
  - vii) It is 16-bit microprocessor.

(ii) Rotate register BL ~~left~~ for four times.  
→ MOV CL, 04H  
ROL BL, CL

iii) Multiply AL by 08H.  
→ MOV AL, 08H  
MUL AL.

iv) MOV AL, 00H Signed division of BL by AL.  
IDIV BL

v) Move 4000H in BX register.  
→ MOV AX, 4000H  
MOV BX, AX MOV BX, 4000H.

vi) Load offset 1000H in register BX  
→

vii) Rotate BX to left 4 time through carry

② Maximum Mode.

ALE, INIT : M/IO M/IO, RD, WR,  
HLD, HOLD, CS, T, DEN, WE  
Signal is used for  
i) GND :- transmitting & receiving  
or data  
GND :- Ground.

ii) S0, S1, S2 - These pins are called  
status I/O pins.

iii) ALE (Address Latch Enable) :-  
This signal is used to demultiplex  
the Address AD10 pin by A0-A15 and  
D0-D15.

iv) INTA (Interrupt Acknowledge) :-  
This indicates recognition of an  
interrupt pin.

v) M/IO - This pin is used to distinguish  
memory transfer & data transfer

vi) HLT / : This signal is used to control  
the data flow direction. High on  
this is used for transmitting the  
data and low is for receiving  
the data.

| Minimum Mode                                        | Maximum Mode                                                                   |
|-----------------------------------------------------|--------------------------------------------------------------------------------|
| i) MN/MX is connected to Vcc (+5V)                  | i) MN/MX is connected to GND (-5V).                                            |
| ii) It is single processor system configuration     | ii) It is a multi processor system configuration                               |
| iii) In 8086, core itself generates system control. | iii) If external device is been used.                                          |
| iv) Minimum signals are from 20 to 30.              | iv) Maximum mode<br>Q31, Q30, S0, S1, S2,<br>C0, R0/C7, R0/C6<br>respectively. |

| (A) Inter segment                                                                 | Intra segment                                                   |
|-----------------------------------------------------------------------------------|-----------------------------------------------------------------|
| i) It is far jump.                                                                | i) It is near jump.                                             |
| ii) More memory is required.                                                      | ii) Less memory is required.                                    |
| iii) It segment jump from one segment to another segment outside present segment. | iii) This segment jumps with the segment on in present segment. |
| iv) It is declared in different segments.                                         | iv) It is declared in same segment.                             |
| (B) MUL                                                                           | IMUL                                                            |
| i) This instn is used for unsigned multiplication.                                | i) This instruction is used for signed multiplication.          |
| ii) Shows unsigned result.                                                        | ii) Shows signed result.                                        |
| iii) It does not represent the signed magnitude in any register.                  | iii) It represents.                                             |
| iv) It is not rejected.                                                           | iv) It is rejected.                                             |

Pin diagram

|       |    |               |
|-------|----|---------------|
| GND   | 1  | Vcc           |
| AD0   | 2  | BA 22 AD15    |
| AD1   | 3  | 36 23 AD16/33 |
| AD2   | 4  | 37 24 AD17/34 |
| AD3   | 5  | 38 25 AD18/35 |
| AD4   | 6  | 39 26 AD19/36 |
| AD5   | 7  | 34 7P BHE/57  |
| AD6   | 8  | 33 29 MN/Mx   |
| AD7   | 9  | 32 20 RB      |
| AD8   | 10 | 31 30 RO/CTB  |
| AD9   | 11 | 30 3 RO/CTB   |
| 16    | 12 | 29 LOCK       |
| 11    | 13 | 28 S2         |
| 12    | 14 | 27 S1         |
| 13    | 15 | 26 SO         |
| 14    | 16 | 25 QSO        |
| EMI   | 17 | 24 QSI        |
| INITR | 18 | R8 test       |
| C1K   | 19 | 22 Ready      |
| GND   | 20 | 21 Reset      |

### ① Addressing modes

- i) Immediate addressing mode:- Here the data come can be of 8 bit or 16 bit in the form of successive byte or word.
- e.g. MOV AL, 16H

### ii) Direct:-

In Direct addressing mode the 16 bit data is directly specified in the instruction for a part of it.

e.g. MOV AX, [1000H]

### iii) Register:-

In Register addressing mode, the data stored in the register and it is referred using the particular register.

e.g. mov BX, BX  
MOV AL, BL

### iv) Indexed:-

In Indexed addressing mode offset of the operand is stored in one of the indexed register.

e.g. MOV AX, CS[i]

### v) Implicit addressing mode:-

No address is required because the address of the operand is implied in the instruction itself.

e.g. STB, STC, NOA

i) Register Indirect:-

Operand is determined in an indirect way of using offset address.

e.g. - MOV Ax[BX]

→ i) Text editor:-

The first step in the development process is to write an assembly language program. The assembly language program can be written with an ordinary word such as staredit and so on.  
c:\fasm\bin> edit prg.asm.

ii) Assembler:-

- Assemblers translates the source file that was created using the editor into machine language such as binary or machine code.
- The assembler then reads the source file of our program from the disk where we have saved the editing.
- The assembler generates two files on floppy or hard disk during these two passes.
- The first file is called object file.
- The second file is called assembly link file.

the command on command prompt performing this operation is given below:-

c:\fasm\bin> fasm prg

iii) Linker:-

The linker is generally used to join together a several programs into one large program. When writing a large program, it is usually much more efficient to divide them into small modules. Such module can be individually tested, written and debugged and then these small modules then can be joined together and will get ~~into~~ come into a large functioning program.

The linker also provides a link map which contains the address information about the ~~file~~ link files.

command prompt

c:\fasm\bin> link prg.obj

### iv) Debugger:-

The debugger is a program which allows us to load the object program into the system memory, execute the program and debug it.

command prompt:-

C:\[farm]\bin>ld prg.exe,

- ④ Draw the flowchart for multiplication of two 16-bit numbers.



- ⑤ Procedures:- A procedure is a group of instructions that usually performs one task, it is a reusable section of the software in memory once, but used as often as necessary.

Syntax:-

Procedure-Name PROC

Procedure statements

Procedure-name ENDP

- ⑥ what is the role TEST instruction in Assembly language Programming  
→ The TEST instruction performs the AND operation. The difference is that the AND instruction changes the destination operand, while the TEST does not change. The TEST instruction only affects the F flag register, which indicates the result of the test.  
eg:- TEST AL, BL  
TEST AX1, BX

- (A) List the major steps in developing an Assembly language program
- Major steps in developing an Assembly language program are:-
- Specifying the problem.
  - Designing the problem solution.
  - Coding.
  - Debugging.

- (B) What is stack? State its significance.
- ~~The~~ The Stack is a section of memory you set aside for storing return addresses. The stack is also used to save the contents of registers for the calling program while a procedure executes.

Significance is as:-

- Push instruction.
- Pop instruction.

- (C) What is the use of REP in string related instruction?
- REP is a prefix which is written before one of the string instructions. This instruction repeats until the specified condition exists.

- (D) What is pipelining? How it improves the processing speed?
- i) To speed up program execution, the Bus fetches six instruction bytes ahead of time from the memory.
  - ii) These prefetched instruction bytes are held for the execution unit in groups of registers called queue.
  - iii) The Bus continues the process as much long as the process doesn't get fulfilled.
  - iv) In case of JUMP and CALL instructions, instruction already fetched in queue for no use.
  - v) Features of fetching the next instruction while the current instruction is executing. It is called as posting Pipelining.
  - vi) The queue operates the principle of First in first Out (FIFO).

Diagram.



- ① State the function of p following pins of 8086 microprocessor.
- i) INT R :- It is a level triggered, and non-vectorized interrupt. When INT R occurs the microprocessor generates interrupt acknowledgement signal INT A.
- ii) INT A :- It is an active low acknowledgement signal for INT R.
- ② List any four features of 8086.
- i) It is a 16 bit microprocessor.
  - ii) It has 16 bit data bus.
  - iii) It has 20 bit address bus.
  - iv) It mainly has 40 pins.
  - v) It has multiplexed pin AD0-AD15 and AD16-AD9.
  - vi) It has two modes known as minimum & maximum.
  - vii) It provides 16 bit register.

- ③ Define immediate and direct addressing mode. Also give one example of each.
- Immediate addressing mode:- In this addressing mode, immediate data is a part of instruction and appears in the form of successive bytes or bytes.
- eg:-  
MOV AX, 1004H

- ii) Direct addressing mode:- In direct addressing mode, 16 bit (offset) address is directly specified as a part of it.  
eg:- MOV CL, [1004H].
- ④ List the program development steps for assembly language programming.
- i) Defining the problem.
  - ii) Algorithm
  - iii) Flowchart.
  - iv) Initializing checklist.
  - v) choosing instructions.
  - vi) Converting algorithms to assembly language program.



Q) Draw the format of 8086 flag register

→

|         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|---------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| T       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |
| C       |    |    |    | F  |    |   |   | O |   |   |   | D |   |   |   | I | T | S | Z | X | A | M | P | R | C |
| control |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

- Q) Give the steps in physical address generation in 8086 microprocessor.
- i) Segment register carry 16 bit data, which is also known as base address.
- ii) Then append CBW (Interface unit) four 0000 bits to LSB of the base address. This address becomes 20-bit address.
- iii) Any base / pointer or index register carries ~~offset~~ 10 bit offset.

Q) Give the syntax for defining a procedure.

→ Procedure-name PROC

Procedure Statement  
Procedure-name ENDP.

Q) i) copy 1000H to register BX  
→ MOV BX, 1000H

ii) Rotate register BL left four times  
→ MOV CL, 04H  
ROL EBL, CL.

- Q) State the function of Assembler and Debugger.
- i) Assembler -
- Assembler is a program which translates assembly language program to the correct binary code.
  - It also generates the object file with extension .obj.
  - It also displays syntactical errors in program if any.
  - It can also generate .list and .err files.

- ii) Debugger -
- Debugger is a program that allows the execution of program in single step mode under the control of user.
  - The error in program can be located and corrected using a debugger.
  - Debugger generates .err file.

- Q) i) DB - This is used to define byte type variable.  
ii) This can be used to define single byte or multiple bytes.

• **DW (Define word) :**

- This is used to define 16-bit word type variable.
- This can be used to define single word or multiple word.

• **DD (Defining Double).**

- This is used to define double word (32-bit) type variable.
- This can be used to define double word or multiple double word.

• **DQ (Define Quad word).**

- To define (64-bit) type variable.

**(\*) Re-entrant procedure**

- A procedure is said to be re-entrant if it can be interrupted, re-entered, used without losing or corrupting over anything.

**Recursive Procedure**

- Recursive procedure is a procedure which calls itself.

①  
→

Draw the architecture of 8086.



- (\*) i) MN/M<sub>x</sub>:- The MN/M<sub>x</sub> pin is used to select minimum mode or maximum mode operation of 8086. This pin is achieved by connecting either +5V directly or to the ground.
- ii) Ready :- This pin is used to insert the wait state into the timing cycle of 8086. If the logic ready pin is at logic 1 then there is no effect in the microprocessor. And if the ready pin is at logic 0 then it enters to the wait state and remains the idle.
- iii) ALE (Address Latches Enable):- This pin is used to enable demultiplex A0-A15 and D0-D15 i.e. A0-A15 and D0-D15.
- iv) DT/R:- This signal is used to control the flow of direction, high on transmitting the and receiving the data..

- i) Explain the concept of pipeline in 8086 microprocessor with diagram.
- ii) To speed up program execution, the BCU fetches six instructions bytes, ahead of time from the memory.
- iii) These prefetched instruction bytes are held for the execution unit of group called as queue.
- iv) Pipelining follows the principle of first in and first out i.e. FIFO.
- v) The BCU continues the process as long as the queue is not full.
- vi) In case of JUMP and CALL instructions, instructions get fetched already for no use.



- i) Calculate the physical address for given:

$$DS = 73A2H$$

$$SE = 3216H$$

$$\begin{array}{r} 73 \ A \ 2 \ 0 \\ 32 \ 1 \ 6 \\ \hline 7 \ A \ C \ 3 \ 6 \\ 26 \end{array}$$

$$\begin{array}{r} 73 \ A \ 2 \ 0 \\ 32 \ 1 \ 6 \\ \hline 7 \ A \ C \ 3 \ 6H \end{array}$$

ii)  $CS = 7370H$

$IP = 561EH$

$$\begin{array}{r} 7370 \ 0 \ 0 \\ 561 \ E \\ \hline 78D1 \ EH \end{array}$$

CC  
CD  
AC  
SD

- Q) State the function of the following register of 8086 micro processor.

| General Purpose Registers of 8086 | Segment Register |
|-----------------------------------|------------------|
| AX                                | CS               |
| BX                                | DS               |
| CX                                | ES               |
| DX                                | SS               |
| SI                                |                  |
| DI                                |                  |
| BP                                |                  |
| IP                                |                  |

- Q) List and explain ~~many~~ four process control instruction with their function.

- i) CLC → clear carry flag  
 CLD → clear direction flag  
 STC → set carry flag  
 STD → set direction flag.  
~~WTD WAIT~~ →

CLC → This instruction clear carry flag.  
 CLD → This instruction clear direction flag.  $DF \leftarrow 0$

STC → This instruction set carry flag  $CF \leftarrow 1$

STD → This instruction set direction flag.  $DF \leftarrow 1$ .

Q) Identify the addressing mode for following instructions.

- i) MOV AX, 2034H  
→ Immediate addressing mode
- ii) MOV AL, [6000H]  
→ Direct Addressing mode.
- iii) ADD AL, CL  
→ Register addressing mode.
- iv) MOV AX, 50H [BX] [SI]  
→ Relative Base addressing mode.

Q) XLAT

- i) XLAT replaces a byte in AL register with a byte from 8256 byte ~~following~~ lookup table beginning with BX
- ii) AL is used as offset in this table.
- iii) Flags are not affected
- iv) Operation - AL  $\leftarrow$  [BX+AL]

Q) RCRK

This instruction exchanges the register from the another register or memory location.

Q) Define MACRO with its syntax. Also give two advantages of it.

→ MACRO is a group of instructions. The macro assembler generates the code in program where each time macro is "called". Macro can be defined by MACRO and EQU M assembler directives.

Advantages of MACRO

- i) To speed up the execution of the program.
- ii) It reduces the length of the program.

+ Near Procedure

- i) It is also called as Intra-Segment
- ii) less stack segment is required
- iii) The near procedure can replace old IP to New IP
- iv) If has the same code segment

Far Procedure

- i) It is also called as Intra Segment.
- ii) More stack segment is required.
- iii) The far procedure can replace the old DS:IP pairs with new DS, IP.
- iv) It has the different code segment

|      |                                                                        |
|------|------------------------------------------------------------------------|
| ①    | Syntax :-                                                              |
|      | macro-name MACRO [arg1, arg2 ~ argN]                                   |
| ②    | Near                                                                   |
|      | Procedure                                                              |
| i)   | i) It is also called Intra segment                                     |
| ii)  | Less stack location is required                                        |
| iii) | The near procedure replace the old IP with the new IP                  |
| iv)  | It has same code segment                                               |
| ③    | Far                                                                    |
|      | Procedure                                                              |
| i)   | i) It is also called as Inter segment                                  |
| ii)  | More stack location is required                                        |
| iii) | ii) The far procedure replaces the old DS:IP pairs with the new DS:IP. |
| iv)  | iv) It has different code segment                                      |

## ④ INC

- i) This instruction is used to increment the operand specified.

Syntax

INC operand.

- Operand can be either register or memory locations.
- Operand = operand + 1
- Immediate cannot be an operand.

## ⑤ LOOP

This instruction is used to specify a series of instruction in many times. The number of times the instruction sequence is to be repeated is loaded in CX. Each time loop is executed, the CX is decremented by 1.

Syntax :-

LOOP label name

## ⑥ Re-entrant procedure :-

In some situations it may happen that Procedure 1 is called in main program. Procedure 2 is called in procedure 1 and Procedure 1 is called again in Procedure 2. If this should not occur than we have a procedure name as ~~re-defined~~. re-entrant procedure.

In this procedure if it is entered, it can be interrupted. Used and re-entered with losing or writing anything.

## ⑦ Two manipulation instructions.

- i) AND, OR, XOR, NOT

1 MB = 00000 H — EFFFF H

Ad - A<sub>16</sub>

- ① State the control signal generated by S<sub>0</sub>, S<sub>1</sub>, S<sub>2</sub> with their function of 8086.

→

|   | S <sub>2</sub> | S <sub>1</sub> | S <sub>0</sub> | Function              |
|---|----------------|----------------|----------------|-----------------------|
| 0 | 0              | 0              | 0              | Interrupt acknowledge |
| 1 | 0              | 0              | 1              | Read I/O              |
| 2 | 0              | 1              | 0              | Write I/O             |
| 3 | 0              | 1              | 1              | Halt                  |
| 4 | 1              | 0              | 0              | Code address          |
| 5 | 1              | 0              | 1              | Read memory           |
| 6 | 1              | 1              | 0              | Write memory          |
| 7 | 1              | 1              | 1              | Inactive              |

F0000

64 Kbytes

16 Segments

Segment

Code Segment  
Stack  
Data  
Extra

1 MB

= 1 MB

64 Kbytes



Main program



20 bit



segment registers.

$$\begin{aligned}
 CS &\Rightarrow I.P \\
 DS &\Rightarrow B.P \\
 ES &\Rightarrow D.I \\
 SS &\Rightarrow S.I
 \end{aligned}$$

CS - 2000H  
IP - 3000H

$$\begin{array}{r}
 00000 \\
 + 2000 \\
 \hline
 02000H
 \end{array}
 \quad
 \begin{array}{r}
 30000 \\
 + 2000 \\
 \hline
 32000H
 \end{array}$$

CS : Hatchala  
CS : XYZ

Assume CS : code, DS : Data

XYZ  
Code Segment

Mnemonics  
opcodes.

```

MOV AX, Data
MOV DS, AX.
MOV AX, num1
MOV BX, num2
ADD AX, BX.
MOV Result, AX.

```

Code ENDS

Data Segment

num1 DW 1111H

num2 DW 2222H

Result DW ?

Data ENDS

0011 0011 0011 0011

num db 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,

$$\begin{array}{r} 0.5 \\ - 0.4 \\ \hline 0.1 \end{array}$$
$$\begin{array}{r} 4 \\ - 5 \\ \hline -1 \end{array}$$

Addition Subtraction.

Main program.

```
data segment
num1 dw 4444H
num2 dw 2222H
sum dw ?
difference dw ?
data ENDS
```

Main segment

```
mov ax, data
mov ds, ax
jmp proc call Addition
```

addition

ENDP

Addition segment proc Macro num1, num2

```
mov ax, num1
mov bx, num2
Add AX, BX
```

Endp

Subtraction proc

```
MOV AX, num1
MOV BX, num2
SUB AX, BX
Endp
```

Main segment

```
Mov ax, data
Mov DS, ax
addition { 10, 20
Mov AX, BX
addition 40, 30
```