KEMBAR78
8086 Programming: Unit 3 & 4 | PDF | Assembly Language | Binary Coded Decimal
0% found this document useful (0 votes)
10K views25 pages

8086 Programming: Unit 3 & 4

The notes have been made cautiously taking into consideration the syllabus and will form the basis of Microprocessor 8086 programming.

Uploaded by

Abhinandan Dubey
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
10K views25 pages

8086 Programming: Unit 3 & 4

The notes have been made cautiously taking into consideration the syllabus and will form the basis of Microprocessor 8086 programming.

Uploaded by

Abhinandan Dubey
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 25

8086 PROGRAMMING

Unit 3 & 4


Syllabus

Unit III (8L)
8086 programming Assembly language program development tools (editor, linker, loader,
Assembler, emulator and Debugger), Addressing modes, Instruction set descriptions.
Unit IV (8L)
Assembler directives and operators, Procedures and Macros. (Writing programs for use with an
assembler MASM).

1. Introduction to Assembly Language Programming Tools

EDITOR:
It is used to edit and write programs
LINKER:
Linking is the final stage of compilation. It takes one or more object files or libraries as input and
combines them to produce a single (usually executable) file. In doing so, it resolves references to
external symbols, assigns final addresses to procedures/functions and variables, and revises
code and data to reflect new addresses (a process called relocation). After the source code has
been assembled, it will produce an Object files (e.g. .o, .obj) and then linked, producing an
executable files.

The linker actually enables separate compilation. As shown in figure, an executable can be made
up of a number of source files which can be compiled and assembled into their object files
respectively, independently.
LOADER:
Part of the OS that brings an executable file residing on disk into memory and starts it running
Steps
Read executable files header to determine the size of text and data segments
Create a new address space for the program
Copies instructions and data into address space
Copies arguments passed to the program on the stack
Initializes the machine registers including the stack ptr
Jumps to a startup routine that copies the programs arguments from the stack to
registers and calls the programs main routine
ASSEMBLER:


Assembly is the stage of compilation. It takes the assembly source code and produces an
assembly listing with offsets. The assembler output is stored in an object file.
Assemblers need to
translate assembly instructions and pseudo-instructions into machine instructions
Convert decimal numbers, etc. specified by programmer into binary
Typically, assemblers make two passes over the assembly file
First pass: reads each line and records labels in a symbol table
Second pass: use info in symbol table to produce actual machine code for each line.
Addressing Modes

Various addressing modes of 8086/8088
1) Register Addressing mode
2) Immediate Addressing mode
3) Register Indirect Addressing mode
4) Register Relative
5) Direct Addressing mode
6) Indexed Addressing mode
7) Base Relative Addressing mode
8) Base Indexed Addressing mode

Register Addressing Mode
Data transfer using registers is called register addressing mode. Here operand value is present in
register. For example
MOV AL,BL;
MOV AX,BX;
Immediate Addressing mode
When data is stored in code segment instead of data segment immediate addressing mode is used.
Here operand value is present in the instruction. For example
MOV AX, 12345;
Direct Addressing mode
When direct memory address is supplied as part of the instruction is called direct addressing mode.
Operand offset value with respect to data segment is given in instruction. For example
MOV AX, [1234];
ADD AX, [1234];
Register Indirect Addressing mode
Here operand offset is given in a cpu register. Register used are BX, SI(source index), DI(destination
index), or BP(base pointer). BP holds offset w.r.t Stack segment, but SI,DI and BX refer to data
segment. For example
MOV [BX],AX;
ADD AX, [SI];
Register Relative
In this addressing mode, the data is available at an effective address formed by adding an 8-bit or
16-bit displacement with the content of any one of the registers BX, BP, SI and DI in the default
(either DS or ES) segment. The example given before explains this mode.
Example: MOV AX, 50H [BX]
Here, effective address is given as 10H*DS+50H+ [BX].

Indexed Addressing mode
Here operand offset is given by a sum of a value held in either SI, or DI register and a constant
displacement is specified as an operand. For example,
My_array DB 1, 2, 3,4,5;
MOV SI, 3;
MOV AL, My_array[3];
So AL holds value 4.
Base Relative Addressing mode
Operand offset given by a sum of a value held either in BP, or BX and a constant offset specified as
an operand. For example
MOV AX,[BP+1];
JMP [BX+1];
Base Indexed
Here operand offset is given by sum of either BX or BP with either SI or DI. For example
MOV AX, [BX+SI]
JMP [BP+DI]

For the control transfer instructions, the addressing modes depend upon whether the destination
location is within the same segment or a different one. It also depends upon the method of
passing the destination address to the processor. Basically, there are two addressing modes for
the control transfer instructions, viz. inter-segment and intra-segment addressing modes.

If the location to which the control is to be transferred lies in a different segment other than the
current one, the mode is called inter-segment mode. If the destination location lies in the same
segment, the mode is called intra-segment.




Instruction Set Description


DATA TRANSFER INSTRUCTIONS

MOV MOV Destination, Source
The MOV instruction copies a word or byte of data from a specified source to a specified destination.
The destination can be a register or a memory location.
MOV instruction does not affect any flag.
MOV CX, 037AH Put immediate number 037AH to CX
MOV BL, [437AH] Copy byte in DS at offset 437AH to BL
MOV AX, BX Copy content of register BX to AX
MOV DL, [BX] Copy byte from memory at [BX] to DL
MOV DS, BX Copy word from BX to DS register

XCHG XCHG Destination, Source

The XCHG instruction exchanges the content of a register with the content of another register or
with the content of memory location(s). It cannot directly exchange the content of two memory
locations. The source and destination must both be of the same type (bytes or words). The segment
registers cannot be used in this instruction. This instruction does not affect any flag.

XCHG AX, DX Exchange word in AX with word in DX
XCHG BL, CH Exchange byte in BL with byte in CH

LEA LEA Register, Source (Load Affective Address)

This instruction determines the offset of the variable or memory location named as the source and
puts this offset in the indicated 16-bit register. LEA does not affect any flag.

LEA BX, PRICES Load BX with offset of PRICE in DS
LEA BP, SS: STACK_TOP Load BP with offset of STACK_TOP in SS
LEA CX, [BX][DI] Load CX with EA = [BX] + [DI]

ARITHMETIC INSTRUCTIONS


ADD ADD Destination, Source
ADC ADC Destination, Source

These instructions add a number from some source to a number in some destination and put the
result in the specified destination. The ADC also adds the status of the carry flag to the result. The
source may be an immediate number, a register, or a memory location. The destination may be a
register or a memory location. The source and the destination in an instruction cannot both be
memory locations. The source and the destination must be of the same type (bytes or words). If you
want to add a byte to a word, you must copy the byte to a word location and fill the upper byte of
the word with 0s before adding. Flags affected: AF, CF, OF, SF, ZF.

ADD AL, 74H Add immediate number 74H to content of AL. Result in AL
ADC CL, BL Add content of BL plus carry status to content of CL
ADD DX, BX Add content of BX to content of DX
ADD DX, [SI] Add word from memory at offset [SI] in DS to content of DX
ADC AL, PRICES [BX] Add byte from eff. addr. PRICES [BX] plus carry status
to content of AL
ADD AL, PRICES [BX] Add content of memory at effective address PRICES [BX]
to AL


SUB SUB Destination, Source
SBB SBB Destination, Source

These instructions subtract the number in some source from the number in some destination and
put the result in the destination. The SBB instruction also subtracts the content of carry flag from the
destination. The source may be an immediate number, a register or memory location. The
destination can also be a register or a memory location. However, the source and the destination
cannot both be memory location. The source and the destination must both be of the same type
(bytes or words). If you want to subtract a byte from a word, you must first move the byte to a word
location such as a 16-bit register and fill the upper byte of the word with 0s. Flags affected: AF, CF,
OF, PF, SF, ZF.

SUB CX, BX CX BX; Result in CX
SBB CH, AL Subtract content of AL and content of CF from content of CH.
Result in CH
SUB AX, 3427H Subtract immediate number 3427H from AX
SBB BX, [3427H] Subtract word at displacement 3427H in DS and content of CF
from BX
SUB PRICES [BX], 04H Subtract 04 from byte at effective address PRICES [BX], if PRICES
is declared with DB; Subtract 04 from word at effective address
PRICES [BX], if it is declared with DW.
SBB CX, TABLE [BX] Subtract word from effective address TABLE [BX] and
status of CF from CX.
SBB TABLE [BX], CX Subtract CX and status of CF from word in memory at
effective address TABLE[BX].


MUL MUL Source

This instruction multiplies an unsigned byte in some source with an unsigned byte in AL register or an
unsigned word in some source with an unsigned word in AX register. The source can be a register or
a memory location. When a byte is multiplied by the content of AL, the result (product) is put in AX.
When a word is multiplied by the content of AX, the result is put in DX and AX registers. If the most
significant byte of a 16-bit result or the most significant word of a 32-bit result is 0, CF and OF will
both be 0s. AF, PF, SF and ZF are undefined after a MUL instruction.

If you want to multiply a byte with a word, you must first move the byte to a word location such as
an extended register and fill the upper byte of the word with all 0s. You cannot use the CBW
instruction for this, because the CBW instruction fills the upper byte with copies of the most
significant bit of the lower byte.

MUL BH Multiply AL with BH; result in AX
MUL CX Multiply AX with CX; result high word in DX, low word in AX
MUL BYTE PTR [BX] Multiply AL with byte in DS pointed to by [BX]
MUL FACTOR [BX] Multiply AL with byte at effective address FACTOR [BX], if it is
declared as type byte with DB. Multiply AX with word at effective address FACTOR [BX], if it is
declared as type word with DW.
MOV AX, MCAND_16 Load 16-bit multiplicand into AX
MOV CL, MPLIER_8 Load 8-bit multiplier into CL MOV CH,
00H Set upper byte of CX to all 0s
MUL CX AX times CX; 32-bit result in DX and AX
IMUL IMUL Source

This instruction multiplies a signed byte from source with a signed byte in AL or a signed word from
some source with a signed word in AX.
IMUL BH Multiply signed byte in AL with signed byte in BH;
result in AX.
IMUL AX Multiply AX times AX; result in DX and AX
MOV CX, MULTIPLIER Load signed word in CX
MOV AL, MULTIPLICAND Load signed byte in AL
CBW Extend sign of AL into AH
IMUL CX Multiply CX with AX; Result in DX and AX

DIV DIV Source

This instruction is used to divide an unsigned word by a byte or to divide an unsigned double word
(32 bits) by a word. When a word is divided by a byte, the word must be in the AX register. The
divisor can be in a register or a memory location. After the division, AL will contain the 8-bit
quotient, and AH will contain the 8-bit remainder. When a double word is divided by a word, the
most significant word of the double word must be in DX, and the least significant word of the double
word must be in AX. After the division, AX will contain the 16-bit quotient and DX will contain the 16-
bit remainder. If an attempt is made to divide by 0 or if the quotient is too large to fit in the
destination (greater than FFH / FFFFH), the 8086 will generate a type 0 interrupt. All flags are
undefined after a DIV instruction.

If you want to divide a byte by a byte, you must first put the dividend byte in AL and fill AH with all
0s. Likewise, if you want to divide a word by another word, then put the dividend word in AX and fill
DX with all 0s.

DIV BL Divide word in AX by byte in BL; Quotient in AL, remainder in AH
DIV CX Divide down word in DX and AX by word in CX;
Quotient in AX, and remainder in DX.
DIV SCALE [BX] AX / (byte at effective address SCALE [BX]) if SCALE [BX] is of type
byte; or (DX and AX) / (word at effective address SCALE[BX]
if SCALE[BX] is of type word
INC INC Destination

The INC instruction adds 1 to a specified register or to a memory location. AF, OF, PF, SF, and ZF are
updated, but CF is not affected. This means that if an 8-bit destination containing FFH or a 16-bit
destination containing FFFFH is incremented, the result will be all 0s with no carry.

INC BL Add 1 to contains of BL register
INC CX Add 1 to contains of CX register
INC BYTE PTR [BX] Increment byte in data segment at offset contained in BX. INC
WORD PTR [BX] Increment the word at offset of [BX] and [BX + 1]
in the data segment.
INC TEMP Increment byte or word named TEMP in the data segment.
Increment byte if MAX_TEMP declared with DB.
Increment word if MAX_TEMP is declared with DW.
INC PRICES [BX] Increment element pointed to by [BX] in array PRICES.
Increment a word if PRICES is declared as an array of words;
Increment a byte if PRICES is declared as an array of bytes.


DEC DEC Destination

This instruction subtracts 1 from the destination word or byte. The destination can be a register or a
memory location. AF, OF, SF, PF, and ZF are updated, but CF is not affected. This means that if an 8-
bit destination containing 00H or a 16-bit destination containing 0000H is decremented, the result
will be FFH or FFFFH with no carry (borrow).

DEC CL Subtract 1 from content of CL register DEC BP
Subtract 1 from content of BP register DEC BYTE PTR [BX]
Subtract 1 from byte at offset [BX] in DS.
DEC WORD PTR [BP] Subtract 1 from a word at offset [BP] in SS.
DEC COUNT Subtract 1 from byte or word named COUNT in DS.
Decrement a byte if COUNT is declared with a DB;
Decrement a word if COUNT is declared with a DW.


DAA (DECIMAL ADJUST AFTER BCD ADDITION)

This instruction is used to make sure the result of adding two packed BCD numbers is adjusted to be
a legal BCD number. The result of the addition must be in AL for DAA to work correctly. If the lower
nibble in AL after an addition is greater than 9 or AF was set by the addition, then the DAA
instruction will add 6 to the lower nibble in AL. If the result in the upper nibble of AL in now greater
than 9 or if the carry flag was set by the addition or correction, then the DAA instruction will add 60H
to AL.

Let AL = 59 BCD, and BL = 35 BCD
ADD AL, BL AL = 8EH; lower nibble > 9, add 06H to AL
DAA AL = 94 BCD, CF = 0
Let AL = 88 BCD, and BL = 49 BCD
ADD AL, BL AL = D1H; AF = 1, add 06H to AL
DAA AL = D7H; upper nibble > 9, add 60H to AL
AL = 37 BCD, CF = 1

The DAA instruction updates AF, CF, SF, PF, and ZF; but OF is undefined.


DAS (DECIMAL ADJUST AFTER BCD SUBTRACTION)

This instruction is used after subtracting one packed BCD number from another packed BCD number,
to make sure the result is correct packed BCD. The result of the subtraction must be in AL for DAS to
work correctly. If the lower nibble in AL after a subtraction is greater than 9 or the AF was set by the
subtraction, then the DAS instruction will subtract 6 from the lower nibble AL. If the result in the
upper nibble is now greater than 9 or if the carry flag was set, the DAS instruction will subtract 60
from AL.
Let AL = 86 BCD, and BH = 57 BCD
SUB AL, BH AL = 2FH; lower nibble > 9, subtract 06H from AL
AL = 29 BCD, CF = 0
Let AL = 49 BCD, and BH = 72 BCD
SUB AL, BH AL = D7H; upper nibble > 9, subtract 60H from AL
DAS AL = 77 BCD, CF = 1 (borrow is needed)

The DAS instruction updates AF, CF, SF, PF, and ZF; but OF is undefined.
AAA (ASCII ADJUST FOR ADDITION)

Numerical data coming into a computer from a terminal is usually in ASCII code. In this code, the
numbers 0 to 9 are represented by the ASCII codes 30H to 39H. The 8086 allows you to add the ASCII
codes for two decimal digits without masking off the 3 in the upper nibble of each. After the
addition, the AAA instruction is used to make sure the result is the correct unpacked BCD.

Let AL = 0011 0101 (ASCII 5), and BL = 0011 1001 (ASCII 9)
ADD AL, BL AL = 0110 1110 (6EH, which is incorrect BCD)
AAA AL = 0000 0100 (unpacked BCD 4)
CF = 1 indicates answer is 14 decimal.

The AAA instruction works only on the AL register. The AAA instruction updates AF and CF; but OF,
PF, SF and ZF are left undefined.


AAS (ASCII ADJUST FOR SUBTRACTION)

Numerical data coming into a computer from a terminal is usually in an ASCII code. In this code the
numbers 0 to 9 are represented by the ASCII codes 30H to 39H. The 8086 allows you to subtract the
ASCII codes for two decimal digits without masking the 3 in the upper nibble of each. The AAS
instruction is then used to make sure the result is the correct unpacked BCD.

Let AL = 00111001 (39H or ASCII 9), and BL = 00110101 (35H or ASCII 5)
SUB AL, BL AL = 00000100 (BCD 04), and CF = 0
AAS AL = 00000100 (BCD 04), and CF = 0 (no borrow required)
Let AL = 00110101 (35H or ASCII 5), and BL = 00111001 (39H or ASCII 9)
SUB AL, BL AL = 11111100 ( 4 in 2s complement form), and CF = 1 AAS
AL = 00000100 (BCD 06), and CF = 1 (borrow required)

The AAS instruction works only on the AL register. It updates ZF and CF; but OF, PF, SF, AF are left
undefined.
AAD (BCD-TO-BINARY CONVERT BEFORE DIVISION)

AAD converts two unpacked BCD digits in AH and AL to the equivalent binary number in AL. This
adjustment must be made before dividing the two unpacked BCD digits in AX by an unpacked BCD
byte. After the BCD division, AL will contain the unpacked BCD quotient and AH will contain the
unpacked BCD remainder. AAD updates PF, SF and ZF; AF, CF and OF are left undefined.

Let AX = 0607 (unpacked BCD for 67 decimal), and CH = 09H
AAD AX = 0043 (43H = 67 decimal)
DIV CH AL = 07; AH = 04; Flags undefined after DIV

If an attempt is made to divide by 0, the 8086 will generate a type 0 interrupt.

LOGICAL INSTRUCTIONS


AND AND Destination, Source

The destination can be a register or a memory location. The source and the destination cannot both
be memory locations. CF and OF are both 0 after AND. PF, SF, and ZF are updated by the AND
instruction. AF is undefined. PF has meaning only for an 8-bit operand.


AND CX, [SI] AND word in DS at offset [SI] with word in CX register;
Result in CX register
AND BH, CL AND byte in CL with byte in BH; Result in BH
AND BX, 00FFH 00FFH Masks upper byte, leaves lower byte unchanged.

OR OR Destination, Source

The source can be an immediate number, the content of a register, or the content of a memory
location. The destination can be a register or a memory location. The source and destination cannot
both be memory locations. CF and OF are both 0 after OR. PF, SF, and ZF are updated by the OR
instruction. AF is undefined. PF has meaning only for an 8-bit operand.

OR AH, CL CL ORed with AH, result in AH, CL not changed
OR BP, SI SI ORed with BP, result in BP, SI not changed

XOR XOR Destination, Source
The source and destination cannot both be memory locations. CF and OF are both 0 after XOR. PF,
SF, and ZF are updated. PF has meaning only for an 8-bit operand. AF is undefined.

XOR CL, BH Byte in BH exclusive-ORed with byte in CL. Result in
CL. BH not changed.
XOR BP, DI Word in DI exclusive-ORed with word in BP. Result
in BP. DI not changed.
XOR WORD PTR [BX], 00FFH Exclusive-OR immediate number 00FFH with word at
offset [BX] in the data segment.
Result in memory location [BX]

NOT NOT Destination
The NOT instruction inverts each bit (forms the 1s complement) of a byte or word in the specified
destination. The destination can be a register or a memory location. This instruction does not affect
any flag.

NOT BX Complement content or BX register
NOT BYTE PTR [BX] Complement memory byte at offset [BX] in data segment.

CMP CMP Destination, Source

This instruction compares a byte / word in the specified source with a byte / word in the specified
destination. The source can be an immediate number, a register, or a memory location. The
destination can be a register or a memory location. However, the source and the destination cannot
both be memory locations. The comparison is actually done by subtracting the source byte or word
from the destination byte or word. The source and the destination are not changed, but the flags are
set to indicate the results of the comparison. AF, OF, SF, ZF, PF, and CF are updated by the CMP
instruction. For the instruction CMP CX, BX, the values of CF, ZF, and SF will be as follows:
CF ZF SF
CX = BX 0 1 0 Result of subtraction is 0
CX > BX 0 0 0 No borrow required, so CF = 0
CX < BX 1

0 1 Subtraction requires borrow, so CF = 1
CMP AL, 01H Compare immediate number 01H with byte in AL
CMP BH, CL Compare byte in CL with byte in BH

TRANSFER-OF-CONTROL INSTRUCTIONS

JMP (UNCONDITIONAL JUMP TO SPECIFIED DESTINATION)

This instruction will fetch the next instruction from the location specified in the instruction rather
than from the next location after the JMP instruction. If the destination is in the same code segment
as the JMP instruction, then only the instruction pointer will be changed to get the destination
location. This is referred to as a near jump. If the destination for the jump instruction is in a segment
with a name different from that of the segment containing the JMP instruction, then both the
instruction pointer and the code segment register content will be changed to get the destination
location. This referred to as a far jump. The JMP instruction does not affect any flag.

JMP CONTINUE
This instruction fetches the next instruction from address at label CONTINUE. If the label is in the
same segment, an offset coded as part of the instruction will be added to the instruction pointer to
produce the new fetch address. If the label is another segment, then IP and CS will be replaced with
value coded in part of the instruction. This type of jump is referred to as direct because the
displacement of the destination or the destination itself is specified directly in the instruction.

JMP BX
This instruction replaces the content of IP with the content of BX. BX must first be loaded with the
offset of the destination instruction in CS. This is a near jump. It is also referred to as an indirect
jump because the new value of IP comes from a register rather than from the instruction itself, as in
a direct jump.

JMP WORD PTR [BX]
This instruction replaces IP with word from a memory location pointed to by BX in DX. This is an
indirect near jump.


JMP DWORD PTR [SI]
This instruction replaces IP with word pointed to by SI in DS. It replaces CS with a word pointed by SI
+ 2 in DS. This is an indirect far jump.


JA / JNBE (JUMP IF ABOVE / JUMP IF NOT BELOW OR EQUAL)

If, after a compare or some other instructions which affect flags, the zero flag and the carry flag both
are 0, this instruction will cause execution to jump to a label given in the instruction. If CF and ZF are
not both 0, the instruction will have no effect on program execution.

CMP AX, 4371H Compare by subtracting 4371H from AX
JA NEXT Jump to label NEXT if AX above 4371H
CMP AX, 4371H Compare (AX 4371H)
JNBE NEXT Jump to label NEXT if AX not below or equal to 4371H


JAE / JNB / JNC
(JUMP IF ABOVE OR EQUAL / JUMP IF NOT BELOW / JUMP IF NO CARRY)

If, after a compare or some other instructions which affect flags, the carry flag is 0, this instruction
will cause execution to jump to a label given in the instruction. If CF is 1, the instruction will have no
effect on program execution.

CMP AX, 4371H Compare (AX 4371H)
JAE NEXT Jump to label NEXT if AX above 4371H
CMP AX, 4371H Compare (AX 4371H)
JNB NEXT Jump to label NEXT if AX not below 4371H
ADD AL, BL Add two bytes
JNC NEXT If the result with in acceptable range,
continue


JB / JC / JNAE (JUMP IF BELOW / JUMP IF CARRY / JUMP IF NOT ABOVE OR EQUAL)

If, after a compare or some other instructions which affect flags, the carry flag is a 1, this instruction
will cause execution to jump to a label given in the instruction. If CF is 0, the instruction will have no
effect on program execution.

CMP AX, 4371H Compare (AX 4371H)
JB NEXT Jump to label NEXT if AX below 4371H
ADD BX, CX Add two words
JC NEXT Jump to label NEXT if CF = 1
CMP AX, 4371H Compare (AX 4371H)
given in the instruction. If CF is 1, the instruction will have no effect on program execution.

CMP AX, 4371H Compare (AX 4371H)
JAE NEXT Jump to label NEXT if AX above 4371H
CMP AX, 4371H Compare (AX 4371H)
JNB NEXT Jump to label NEXT if AX not below 4371H
ADD AL, BL Add two bytes
JNC NEXT If the result with in acceptable range,
continue


JB / JC / JNAE (JUMP IF BELOW / JUMP IF CARRY / JUMP IF NOT ABOVE OR EQUAL)

If, after a compare or some other instructions which affect flags, the carry flag is a 1, this instruction
will cause execution to jump to a label given in the instruction. If CF is 0, the instruction will have no
effect on program execution.

CMP AX, 4371H Compare (AX 4371H)
JB NEXT Jump to label NEXT if AX below 4371H
ADD BX, CX Add two words
JC NEXT Jump to label NEXT if CF = 1
CMP AX, 4371H Compare (AX 4371H)
JNAE NEXT Jump to label NEXT if AX not above or equal to 4371H


JBE / JNA (JUMP IF BELOW OR EQUAL / JUMP IF NOT ABOVE)

If, after a compare or some other instructions which affect flags, either the zero flag or the carry flag
is 1, this instruction will cause execution to jump to a label given in the instruction. If CF and ZF are
both 0, the instruction will have no effect on program execution.

CMP AX, 4371H Compare (AX 4371H)
JBE NEXT Jump to label NEXT if AX is below or equal to 4371H
CMP AX, 4371H Compare (AX 4371H)
JNA NEXT Jump to label NEXT if AX not above 4371H


JG / JNLE (JUMP IF GREATER / JUMP IF NOT LESS THAN OR EQUAL)

This instruction is usually used after a Compare instruction. The instruction will cause a jump to the
label given in the instruction, if the zero flag is 0 and the carry flag is the same as the overflow flag.

CMP BL, 39H Compare by subtracting 39H from BL
JG NEXT Jump to label NEXT if BL more positive than 39H
CMP BL, 39H Compare by subtracting 39H from BL
JNLE NEXT Jump to label NEXT if BL is not less than or equal to 39H


JGE / JNL (JUMP IF GREATER THAN OR EQUAL / JUMP IF NOT LESS THAN)

This instruction is usually used after a Compare instruction. The instruction will cause a jump to the
label given in the instruction, if the sign flag is equal to the overflow flag.

CMP BL, 39H Compare by subtracting 39H from BL
JGE NEXT Jump to label NEXT if BL more positive than or equal to 39H
CMP BL, 39H Compare by subtracting 39H from BL
JNL NEXT Jump to label NEXT if BL not less than 39H


JL / JNGE (JUMP IF LESS THAN / JUMP IF NOT GREATER THAN OR EQUAL)

This instruction is usually used after a Compare instruction. The instruction will cause a jump to the
label given in the instruction if the sign flag is not equal to the overflow flag.

CMP BL, 39H Compare by subtracting 39H from BL
JL AGAIN Jump to label AGAIN if BL more negative than 39H
CMP BL, 39H Compare by subtracting 39H from BL
JNGE AGAIN Jump to label AGAIN if BL not more positive than or equal to
39H


JLE / JNG (JUMP IF LESS THAN OR EQUAL / JUMP IF NOT GREATER)

This instruction is usually used after a Compare instruction. The instruction will cause a jump to the
label given in the instruction if the zero flag is set, or if the sign flag not equal to the overflow flag.

CMP BL, 39H Compare by subtracting 39H from BL
JLE NEXT Jump to label NEXT if BL more negative than or equal to 39H
CMP BL, 39H Compare by subtracting 39H from BL
JNG NEXT Jump to label NEXT if BL not more positive than 39H


JE / JZ (JUMP IF EQUAL / JUMP IF ZERO)

This instruction is usually used after a Compare instruction. If the zero flag is set, then this
instruction will cause a jump to the label given in the instruction.

CMP BX, DX Compare (BX-DX)
JE DONE Jump to DONE if BX = DX
IN AL, 30H Read data from port 8FH
SUB AL, 30H Subtract the minimum value.
JZ START Jump to label START if the result of subtraction is 0
JNE / JNZ (JUMP NOT EQUAL / JUMP IF NOT ZERO)

This instruction is usually used after a Compare instruction. If the zero flag is 0, then this instruction
will cause a jump to the label given in the instruction.

IN AL, 0F8H Read data value from port
CMP AL, 72 Compare (AL 72)
JNE NEXT
Jump to label NEXT if AL 72
ADD AX, 0002H Add count factor 0002H to AX
DEC BX Decrement BX
JNZ NEXT
Jump to label NEXT if BX 0


JS (JUMP IF SIGNED / JUMP IF NEGATIVE)

This instruction will cause a jump to the specified destination address if the sign flag is set. Since a 1
in the sign flag indicates a negative signed number, you can think of this instruction as saying jump
if negative.

ADD BL, DH Add signed byte in DH to signed byte in DL
JS NEXT Jump to label NEXT if result of addition is negative
number


JNS (JUMP IF NOT SIGNED / JUMP IF POSITIVE)

This instruction will cause a jump to the specified destination address if the sign flag is 0. Since a 0 in
the sign flag indicate a positive signed number, you can think to this instruction as saying jump if
positive.

DEC AL Decrement AL
JNS NEXT Jump to label NEXT if AL has not decremented to FFH


JP / JPE (JUMP IF PARITY / JUMP IF PARITY EVEN)

If the number of 1s left in the lower 8 bits of a data word after an instruction which affects the
parity flag is even, then the parity flag will be set. If the parity flag is set, the JP / JPE instruction will
cause a jump to the specified destination address.

IN AL, 0F8H Read ASCII character from Port F8H
OR AL, AL Set flags
LOOP (JUMP TO SPECIFIED LABEL IF CX 0 AFTER AUTO DECREMENT)

This instruction is used to repeat a series of instructions some number of times. The number of times
the instruction sequence is to be repeated is loaded into CX. Each time the LOOP instruction
executes, CX is automatically decremented by 1. If CX is not 0, execution will jump to a destination
specified by a label in the instruction. If CX = 0 after the auto decrement, execution will simply go on
to the next instruction after LOOP. The destination address for the jump must be in the range of
128 bytes to +127 bytes from the address of the instruction after the LOOP instruction. This
instruction does not affect any flag.

MOV BX, OFFSET PRICES Point BX at first element in array
MOV CX, 40 Load CX with number of elements in array
NEXT: MOV AL, [BX] Get element from array
INC AL Increment the content of AL
MOV [BX], AL Put result back in array
INC BX Increment BX to point to next location
LOOP NEXT Repeat until all elements adjusted


LOOPE / LOOPZ (LOOP WHILE CX 0 AND ZF = 1)

This instruction is used to repeat a group of instructions some number of times, or until the zero flag
becomes 0. The number of times the instruction sequence is to be repeated is loaded into CX. Each
time the LOOP instruction executes, CX is automatically decremented by 1. If CX 0 and ZF = 1,
execution will jump to a destination specified by a label in the instruction. If CX = 0, execution simply
go on the next instruction after LOOPE / LOOPZ. In other words, the two ways to exit the loop are CX
= 0 or ZF = 0. The destination address for the jump must be in the range of 128 bytes to +127 bytes
from the address of the instruction after the LOOPE / LOOPZ instruction. This instruction does not
affect any flag.

MOV BX, OFFSET ARRAY Point BX to address of ARRAY before start of array
DEC BX Decrement BX
MOV CX, 100 Put number of array elements in CX
NEXT: INC BX Point to next element in array
CMP [BX], OFFH Compare array element with FFH
LOOPE NEXT


LOOPNE / LOOPNZ (LOOP WHILE CX 0 AND ZF = 0)

This instruction is used to repeat a group of instructions some number of times, or until the zero flag
becomes a 1. The number of times the instruction sequence is to be repeated is loaded into the
count register CX. Each time the LOOPNE / LOOPNZ instruction executes, CX is automatically
decremented by 1. If CX 0 and ZF = 0, execution will jump to a destination specified by a label in
the instruction. If CX = 0, after the auto decrement or if ZF = 1, execution simply go on the next
instruction after LOOPNE / LOOPNZ. In other words, the two ways to exit the loop are CX = 0 or ZF =
1. The destination address for the jump must be in the range of 128 bytes to +127 bytes from the
address of the instruction after the LOOPNE / LOOPZ instruction. This instruction does not affect any
flags.

MOV BX, OFFSET ARRAY Point BX to adjust before start of array
DEC BX Decrement BX
MOV CX, 100 Put number of array in CX
NEXT: INC BX Point to next element in array
CMP [BX], ODH Compare array element with 0DH
LOOPNZ NEXT


CALL (CALL A PROCEDURE)

The CALL instruction is used to transfer execution to a subprogram or a procedure. There two basic
type of calls near and far.
1. A near call is a call to a procedure, which is in the same code segment as the CALL instruction.
When the 8086 executes a near CALL instruction, it decrements the stack pointer by 2 and copies
the offset of the next instruction after the CALL into the stack. This offset saved in the stack is
referred to as the return address, because this is the address that execution will return to after
the procedure is executed. A near CALL instruction will also load the instruction pointer with the
offset of the first instruction in the procedure. A RET instruction at the end of the procedure will
return execution to the offset saved on the stack which is copied back to IP.
2. A far call is a call to a procedure, which is in a different segment from the one that contains the
CALL instruction. When the 8086 executes a far call, it decrements the stack pointer by 2 and
copies the content of the CS register to the stack. It then decrements the stack pointer by 2 again
and copies the offset of the instruction after the CALL instruction to the stack. Finally, it loads CS
with the segment base of the segment that contains the procedure, and loads IP with the offset
of the first instruction of the procedure in that segment. A RET instruction at the end of the
procedure will return execution to the next instruction after the CALL by restoring the saved
values of CS and IP from the stack.

RET (RETURN EXECUTION FROM PROCEDURE TO CALLING PROGRAM)

The RET instruction will return execution from a procedure to the next instruction after the CALL
instruction which was used to call the procedure. If the procedure is near procedure (in the same
code segment as the CALL instruction), then the return will be done by replacing the IP with a word
from the top of the stack. The word from the top of the stack is the offset of the next instruction
after the CALL. This offset was pushed into the stack as part of the operation of the CALL instruction.
The stack pointer will be incremented by 2 after the return address is popped off the stack.

If the procedure is a far procedure (in a code segment other than the one from which it is called),
then the instruction pointer will be replaced by the word at the top of the stack. This word is the
offset part of the return address put there by the CALL instruction. The stack pointer will then be
incremented by 2. The CS register is then replaced with a word from the new top of the stack. This
word is the segment base part of the return address that was pushed onto the stack by a far call
operation. After this, the stack pointer is again incremented by 2.

A RET instruction can be followed by a number, for example, RET 6. In this case, the stack pointer will
be incremented by an additional six addresses after the IP when the IP and CS are popped off the
stack. This form is used to increment the stack pointer over parameters passed to the procedure on
the stack.

The RET instruction does not affect any flag.
FLAG MANIPULATION INSTRUCTIONS


STC (SET CARRY FLAG)

This instruction sets the carry flag to 1. It does not affect any other flag.


CLC (CLEAR CARRY FLAG)

This instruction resets the carry flag to 0. It does not affect any other flag.

CMC (COMPLEMENT CARRY FLAG)

This instruction complements the carry flag. It does not affect any other flag.


STD (SET DIRECTION FLAG)

This instruction sets the direction flag to 1. It does not affect any other flag.


CLD (CLEAR DIRECTION FLAG)

This instruction resets the direction flag to 0. It does not affect any other flag.


STI (SET INTERRUPT FLAG)

Setting the interrupt flag to a 1 enables the INTR interrupt input of the 8086. The instruction will not
take affect until the next instruction after STI. When the INTR input is enabled, an interrupt signal on
this input will then cause the 8086 to interrupt program execution, push the return address and flags
on the stack, and execute an interrupt service procedure. An IRET instruction at the end of the
interrupt service procedure will restore the return address and flags that were pushed onto the
stack and return execution to the interrupted program. STI does not affect any other flag.


CLI (CLEAR INTERRUPT FLAG)

This instruction resets the interrupt flag to 0. If the interrupt flag is reset, the 8086 will not respond
to an interrupt signal on its INTR input. The CLI instructions, however, has no effect on the non-
maskable interrupt input, NMI. It does not affect any other flag.

STACK RELATED INSTRUCTIONS


PUSH PUSH Source

The PUSH instruction decrements the stack pointer by 2 and copies a word from a specified source
to the location in the stack segment to which the stack pointer points. The source of the word can be
generalpurpose register, segment register, or memory. The stack segment register and the stack
pointer must be initialized before this instruction can be used. PUSH can be used to save data on the
stack so that it will not destroyed by a procedure. This instruction does not affect any flag.

PUSH BX Decrement SP by 2, copy BX to stack.
PUSH DS Decrement SP by 2, copy DS to stack.
PUSH BL Illegal; must push a word
PUSH TABLE [BX] Decrement SP by 2, and copy word from memory in DS at
EA = TABLE + [BX] to stack


POP POP Destination

The POP instruction copies a word from the stack location pointed to by the stack pointer to a
destination specified in the instruction. The destination can be a general-purpose register, a segment
register or a memory location. The data in the stack is not changed. After the word is copied to the
specified destination, the stack pointer is automatically incremented by 2 to point to the next word
on the stack. The POP instruction does not affect any flag.

POP DX Copy a word from top of stack to DX; increment SP by 2
POP DS Copy a word from top of stack to DS; increment SP by 2
POP TABLE [DX] Copy a word from top of stack to memory in DS with EA = TABLE + [BX];
increment SP by 2.


PUSHF (PUSH FLAG REGISTER TO STACK)

The PUSHF instruction decrements the stack pointer by 2 and copies a word in the flag register to
two memory locations in stack pointed to by the stack pointer. The stack segment register is not
affected. This instruction does to affect any flag.


POPF (POP WORD FROM TOP OF STACK TO FLAG REGISTER)

The POPF instruction copies a word from two memory locations at the top of the stack to the flag
register and increments the stack pointer by 2. The stack segment register and word on the stack are
not affected. This instruction does to affect any flag.


INPUT-OUTPUT INSTRUCTIONS


IN IN Accumulator, Port

The IN instruction copies data from a port to the AL or AX register. If an 8-bit port is read, the data
will go to AL. If a 16-bit port is read, the data will go to AX.

The IN instruction has two possible formats, fixed port and variable port. For fixed port type, the 8-
bit address of a port is specified directly in the instruction. With this form, any one of 256 possible
ports can be addressed.

IN AL, OC8H Input a byte from port OC8H to AL
IN AX, 34H Input a word from port 34H to AX

For the variable-port form of the IN instruction, the port address is loaded into the DX register
before the IN instruction. Since DX is a 16-bit register, the port address can be any number between
0000H and FFFFH. Therefore, up to 65,536 ports are addressable in this mode.

MOV DX, 0FF78H Initialize DX to point to port
IN AL, DX Input a byte from 8-bit port 0FF78H to AL
IN AX, DX Input a word from 16-bit port 0FF78H to AX

The variable-port IN instruction has advantage that the port address can be computed or
dynamically determined in the program. Suppose, for example, that an 8086-based computer needs
to input data from 10 terminals, each having its own port address. Instead of having a separate
procedure to input data from each port, you can write one generalized input procedure and simply
pass the address of the desired port to the procedure in DX.

The IN instruction does not change any flag.


OUT OUT Port, Accumulator

The OUT instruction copies a byte from AL or a word from AX to the specified port. The OUT
instruction has two possible forms, fixed port and variable port.
For the fixed port form, the 8-bit port address is specified directly in the instruction. With this form,
any one of 256 possible ports can be addressed.

OUT 3BH, AL Copy the content of AL to port 3BH
OUT 2CH, AX Copy the content of AX to port 2CH

For variable port form of the OUT instruction, the content of AL or AX will be copied to the port at an
address contained in DX. Therefore, the DX register must be loaded with the desired port address
before this form of the OUT instruction is used.

MOV DX, 0FFF8H Load desired port address in DX
OUT DX, AL Copy content of AL to port FFF8H
OUT DX, AX Copy content of AX to port FFF8H

The OUT instruction does not affect any flag.
8086 ASSEMBLER DIRECTIVES


SEGMENT

The SEGMENT directive is used to indicate the start of a logical segment. Preceding the SEGMENT
directive is the name you want to give the segment. For example, the statement CODE SEGMENT
indicates to the assembler the start of a logical segment called CODE. The SEGMENT and ENDS
directive are used to bracket a logical segment containing code of data.
ENDS (END SEGMENT)
END (END PROCEDURE)
ASSUME

The ASSUME directive is used tell the assembler the name of the logical segment it should use for a
specified segment. The statement ASSUME CS: CODE, for example, tells the assembler that the
instructions for a program are in a logical segment named CODE.

DB (DEFINE BYTE)

The DB directive is used to declare a byte type variable, or a set aside one or more storage locations
of type byte in memory.

PRICES DB 49H, 98H, 29H Declare array of 3 bytes named PRICE and initialize them with
specified values.
NAMES DB THOMAS Declare array of 6 bytes and initialize with ASCII codes for
the letters in THOMAS.

DD (DEFINE DOUBLE WORD)
DQ (DEFINE QUADWORD)
DT (DEFINE TEN BYTES)
DW (DEFINE WORD)

The DW directive is used to tell the assembler to define a variable of type word or to reserve storage
locations of type word in memory. The statement MULTIPLIER DW 437AH, for example, declares a
variable of type word named MULTIPLIER, and initialized with the value 437AH when the program is
loaded into memory to be run.

WORDS DW 1234H, 3456H Declare an array of 2 words and initialize them
with the specified values.
EQU (EQUATE)

EQU is used to give a name to some value or symbol. Each time the assembler finds the given name
in the program, it replaces the name with the value or symbol you equated with that name.
Suppose, for example, you write the statement FACTOR EQU 03H at the start of your program, and
later in the program you write the instruction statement ADD AL, FACTOR.

PTR (POINTER)

The PTR operator is used to assign a specific type to a variable or a label. It is necessary to do this in
any instruction where the type of the operand is not clear. When the assembler reads the
instruction INC [BX], for example, it will not know whether to increment the byte pointed to by BX.
We use the PTR operator to clarify how we want the assembler to code the instruction. The
statement INC BYTE PTR [BX] tells the assembler that we want to increment the byte pointed to by
BX.
EVEN (ALIGN ON EVEN MEMORY ADDRESS)

As an assembler assembles a section of data declaration or instruction statements, it uses a location
counter to keep track of how many bytes it is from the start of a segment at any time. The EVEN
directive tells the assembler to increment the location counter to the next even address, if it is not
already at an even address.
PROC (PROCEDURE)

The PROC directive is used to identify the start of a procedure.
ENDP (END PROCEDURE)

The directive is used along with the name of the procedure to indicate the end of a procedure to the
assembler.
ORG (ORIGIN)

As an assembler assembles a section of a data declarations or instruction statements, it uses a
location counter to keep track of how many bytes it is from the start of a segment at any time. The
location counter is automatically set to 0000 when assembler starts reading a segment. The ORG
directive allows you to set the location counter to a desired value at any point in the program. The
statement ORG 2000H tells the assembler to set the location counter to 2000H, for example.

NAME

The NAME directive is used to give a specific name to each assembly module when programs
consisting of several modules are written.


LABEL

As an assembler assembles a section of a data declarations or instruction statements, it uses a
location counter to be keep track of how many bytes it is from the start of a segment at any time.
The LABEL directive is used to give a name to the current value in the location counter.
EXTRN

The EXTRN directive is used to tell the assembler that the name or labels following the directive are
in some other assembly module. For example, if you want to call a procedure, which in a program
module assembled at a different time from that which contains the CALL instruction, you must tell
the assembler that the procedure is external. The assembler will then put this information in the
object code file so that the linker can connect the two modules together. For a reference to
externally named variable, you must specify the type of the variable, as in the statement EXTRN
DIVISOR: WORD.

You might also like