DEAM ASSIGNMENT 3 Microprocessor
DEAM ASSIGNMENT 3 Microprocessor
The 8086 microprocessor, designed by Intel in the late 1970s, is the first member of the x86
family. It's a 16-bit processor with a 20-bit address bus, capable of addressing up to 1 MB of
memory. The 8086 uses a CISC architecture, supporting a wide range of instructions.
The 8086 includes various registers: general-purpose registers for data storage and operations,
segment registers for memory addressing, and special registers like the flags register and the
instruction pointer (IP).
INSTRUCTION SETS:
These instructions are used to transfer the data from the source operand to the destination operand.
Following are the list of instructions under this group −
MOV − Used to copy the byte or word from the provided source to the provided destination.
PPUSH − Used to put a word at the top of the stack.
POP − Used to get a word from the top of the stack to the provided
two locations.
IN − Used to read a byte or word from the provided port to the accumulator.
OUT − Used to send out a byte or word from the accumulator to the provided port.
Instructions to transfer the address:
LEA − Used to load the address of operand into the provided register.
LDS − Used to load DS register and other provided register from the
POPF − Used to copy a word at the top of the stack to the flag register.
2) Arithmetic Instructions
ADD − Used to add the provided byte to byte/word to word. ADC − Used to add with carry.
INC − Used to increment the provided byte/word by 1. AAA − Used to adjust ASCII after
addition.
DAA − Used to adjust the decimal after the addition/subtraction operation.
NPG − Used to negate each bit of the provided byte/word and add 1/2’s complement. CMP − Usedto
compare 2 provided byte/word.
AAS − Used to adjust ASCII codes after subtraction. DAS − Used to adjust decimal after subtraction.
MUL − Used to multiply unsigned byte by byte/word by word. IMUL − Used to multiply signed
byte by byte/word by word. AAM − Used to adjust ASCII codes after multiplication.
DIV − Used to divide the unsigned word by byte or unsigned double word by word. IDIV − Used
to divide the signed word by byte or signed double word by word.
AAD − Used to adjust ASCII codes after division.
CBW − Used to fill the upper byte of the word with the copies of sign bit of the lower
byte.CWD − Used to fill the upper word of the double word with the sign bit of the
lower word.
These instructions are used to perform operations where data bits are involved, i.e. operations
likelogical, shift, etc.
AND − Used for adding each bit in a byte/word with the corresponding bit in another byte/word.
OR − Used to multiply each bit in a byte/word with the corresponding bit in another byte/word.
XOR − Used to perform Exclusive-OR operation over each bit in a byte/word with
thecorresponding bit in another byte/word.
SHL/SAL − Used to shift bits of a byte/word towards left and put zero(S) in
LSBs. SHR − Used to shift bits of a byte/word towards the right and put zero(S)
in MSBs.
SAR − Used to shift bits of a byte/word towards the right and copy the old MSB into the new
MSB.
ROL − Used to rotate bits of byte/word towards the left, i.e. MSB to LSB and to Carry Flag
[CF]. ROR − Used to rotate bits of byte/word towards the right, i.e. LSB to MSB and to Carry
Flag [CF].RCR − Used to rotate bits of byte/word towards the right, i.e. LSB to CF and CF to
MSB.
RCL − Used to rotate bits of byte/word towards the left, i.e. MSB to CF and CF to LSB.
4) String Instructions
INS/INSB/INSW − Used as an input string/byte/word from the I/O port to the provided
memorylocation.
These instructions are used to transfer/branch the instructions during an execution. It includes the
following instructions −
−CALL − Used to call a procedure and save their return address to the stack.
JMP − Used to jump to the provided address to proceed to the next instruction.
JBE/JNA − Used to jump if below/equal/ not above instruction satisfies. JC − Used to jump ifcarry
flag CF = 1
JE/JZ − Used to jump if equal/zero flag ZF = 1
JG/JNLE − Used to jump if greater/not less than/equal instruction satisfies. JGE/JNL − Used to
jump if greater than/equal/not less than instruction satisfies. JL/JNGE − Used to jump if less
than/not greater than/equal instruction satisfies. JLE/JNG − Used to jump if less than/equal/if not
greater than instruction satisfies. JNC − Used to jump if no carry flag (CF = 0)
JNE/JNZ − Used to jump if not equal/zero flag ZF = 0 JNO − Used to jump if no overflow flag OF
=0
JNP/JPO − Used to jump if not parity/parity odd PF = 0 JNS − Used to jump if not sign SF = 0
JO − Used to jump if overflow flag OF = 1
These instructions are used to control the processor action by setting/resetting the flag
STI − Used to set the interrupt enable flag to 1, i.e., enable INTR input.
CLI − Used to clear the interrupt enable flag to 0, i.e., disable INTR input.
MEMORY MODEL
Segmentation in the 8086 microprocessor divides the main memory into logical segments, each
with its own base address. This enhances execution speed by allowing the processor to efficiently
fetch and execute data.
The Bus Interface Unit (BIU) includes four 16-bit segment registers:
- Code Segment (CS):* Addresses the memory location where the executable program is stored.
- Data Segment (DS):* Points to the memory segment where data is stored.
- Stack Segment (SS):* Addresses the memory segment used for stack data.
Types Of Segmentation –
Overlapping Segment – A segment starts at a particular address and its maximum size can go up to
64kilobytes. But if another segment starts along with this 64kilobytes location of the first segment,
then the two are said to be Overlapping Segment.
Non-Overlapped Segment – A segment starts at a particular address and its maximum size can go
up to 64kilobytes. But if another segment starts before this 64kilobytes location of the first
segment, then the two segments are said to be Non-Overlapped Segment.
The starting address of a segment should be such that it can be evenly divided by 16. Minimum
size of a segment can be 16 bytes and the maximum can be 64 kB.
B] Write ALP to display HELLO using 09h function of INT 21 interrupt
.data
msg db"HELLO$"
.code
mov ah,09h
add al,bl
end