SlideShare a Scribd company logo
1 of 52
1 
x86’s instruction sets
2 
Instruction Set Classification 
 Transfer 
 Move 
 Arithmetic 
 Add / Subtract 
 Mul / Div, etc. 
 Control 
 Jump 
 Call / Return, etc.
3 
Data transfer : Move 
 MOV Dest, Src 
 MOV reg, reg reg <- reg 
 MOV reg, mem reg <- mem 
 MOV mem, reg mem <- reg 
 MOV reg, imm reg <- imm 
 MOV mem, imm mem <- imm 
 There is no move mem<-mem instruction.
Move limitation 
 Both operand must be in the same size. 
 There is no instruction to put immediate value 
directly to segment register. Have to use 
accumulator (AX) to accomplish this. 
 To put immediate value directly to memory, 
we have to specify its size. (Byte/Word PTR) 
4
5 
Move (MOV) Example 
 MOV AX,100h 
 MOV BX,AX 
 MOV DX,BX 
 MOV AX,1234h 
 MOV DX,5678h 
 MOV AL,DL 
 MOV BH,DH
6 
MOV Example 
 MOV AX,1000h 
 MOV [100h],AX 
 MOV BX,[100h] 
 MOV BYTE PTR [200h],10h 
 MOV WORD PTR [300h],10h 
 MOV AX,2300h 
 MOV DS,AX
7 
MOV : 16 / 8 Bit register 
 To move value 
between registers, 
their size must be 
the same.
8 
MOV : Memory 
 Given only offset where to put value, it will be 
automatically select DS as the segment register.
9 
Byte ordering : Little endian 
 Since, x86’s byte 
ordering is little 
endian. 
 Therefore, the LSB 
will be placed at 
lowest address and 
MSB will be placed at 
highest address.
10 
Displacement 
 We can use BX (Base) 
register to point a place 
of memory. 
 Both register direct or 
displacement. 
 AX = ?
11 
What is the result of … 
 MOV [100h] , 10h 
 Address 100 = 10h 
 What about address 101? 
 Word or Byte? 
 MOV WORD PTR [100h], 10h 
 MOV BYTE PTR [100h], 10h 
 What about MOV [100h], AX ?
12 
Status Register (Flag)
13 
Flag 
 8086 has 16 bit flag to indicate the status of final 
arithmetic result.
14 
Zero Flag 
 The zero flag will be set (1) whenever the result is 
zero.
15 
Parity flag 
 The parity flag will be set whenever the number of 
bit “1” are even.
16 
Carry flag 
 Carry flag will be set whenever there is a carry or 
borrow (only with unsigned operation).
17 
Overflow flag 
 Overflow flag will be set whenever the result is 
overflow (with signed operation).
18 
Sign flag 
 Sign flag will be set whenever the result is negative 
with signed operation.
19 
More flag 
 Auxiliary flag will be set when the result of BCD 
operation need to be adjusted. 
 Direction flag is used to specify direction 
(increment/decrement index register) in string 
operation. 
 Trap flag is used to interrupt CPU after each 
operation. 
 Interrupt flag is used to enable/disable hardware 
interrupt.
20 
Flag set/reset instructions 
 Carry flag STC / CLC 
 Direction flag STD / CLD 
 Interrupt flag STI / CLI
21 
Arithmetic instructions
22 
Increment - Decrement 
 INC / DEC 
 INC register DEC register 
 INC memory DEC memory 
 EX. 
 INC AX 
 DEC BL 
 How can we increment a byte of memory? 
 INC ??? [100]
23 
Add 
 ADD reg, imm ADC reg, imm 
 ADD reg, mem ADC reg, mem 
 ADD reg, reg ADC reg, reg 
 ADD mem, imm ADC mem, imm 
 ADD mem, reg ADC mem, reg
24 
EX. ADD 
 MOV AL, 10h 
 ADD AL, 20h ;AL = 30h 
 MOV BX, 200h ;BX = 0200h 
 MOV WORD PTR [BX], 10h 
 ADD WORD PTR [BX], 70h 
 MOV AH, 89h ;AX = 8930h 
 ADD AX, 9876h ;AX = 21A6h 
 ADC BX, 01h ;BX = 0202h ?
25 
Subtract 
 SUB reg, imm SBB reg, imm 
 SUB reg, mem SBB reg, mem 
 SUB reg, reg SBB reg, reg 
 SUB mem, imm SBB mem, imm 
 SUB mem, reg SBB mem, reg
26 
Ex. SUB 
 MOV AL, 10h 
 ADD AL, 20h ;AL = 30h 
 MOV BX, 200h ;BX = 0200h 
 MOV WORD PTR [BX], 10h 
 SUB WORD PTR [BX], 70h 
 MOV AH, 89h ;AX = 8930h 
 SBB AX, 0001h ;AX = 892Eh ? 
 SBB AX, 0001h ;AX = 892Dh
27 
Compare 
 CMP reg, imm 
 CMP reg, mem 
 CMP reg, reg 
 CMP mem, reg 
 There is no “CMP mem, imm”
28 
Ex. CMP 
 MOV CX, 10h 
 CMP CX, 20h ;Z=0,S=1,C=1,O=0 
 MOV BX, 40h 
 CMP BX, 40h ;Z=1,S=0,C=0,O=0 
 MOV AX, 30h 
 CMP AX, 20h ;Z=0,S=0,C=0,O=0
29 
Negation 
 Compute 2’complement. 
 Carry flag always set. 
 Usage 
 NEG reg 
 NEG mem
30 
Ex. NEG 
 MOV CX, 10h 
 NEG CX ; CX = 0FFF0h 
 MOV AX,0FFFFH 
 NEG AX ; AX = 1 
 MOV BX,1H 
 NEG BX ; BX = 0FFFFh
31 
Multiplication 
 IMUL (Integer multiplication) unsigned 
multiplication 
 MUL (Multiplication) signed multiplication. 
 MUL reg IMUL reg 
 MUL mem IMUL mem 
 Always perform with accumulator. 
 Effected flag are only over and carry flag.
32 
8 bit multiplication 
 AL is multiplicand 
 AX keep the result 
 MOV AL,10h ; AL = 10h 
 MOV CL,13h ; CL = 13h 
 IMUL CL ; AX = 0130h
33 
16 bit multiplication 
 AX is multiplicand 
 DX:AX keep the result 
 MOV AX,0100h ; AX = 0100h 
 MOV BX,1234h ; BX = 1234h 
 IMUL BX ; DX = 0012h 
; AX = 3400h
34 
Division 
 IDIV (Integer division) unsigned division. 
 DIV (Division) signed division. 
 DIV reg IDIV reg 
 DIV mem IDIV mem 
 Always perform with accumulator. 
 Effected flag are only over and carry flag.
35 
8 bit division 
 AL is dividend 
 AL keep the result 
 AH keep the remainder 
 MOV AX, 0017h 
 MOV BX, 0010h 
 DIV BL ; AX = 0701
36 
16 bit multiplication 
 DX:AX dividend. 
 AX keep the result, DX keep the remainder. 
 MOV AX,4022h ; 
 MOV DX,0000h ; 
 MOV CX,1000h ; 
 DIV CX ;AX = 0004 
;DX = 0022
37 
Conversion 
 Byte to Word : CBW 
 Signed convert AL -> AX 
 Word to Double word : CWD 
 Signed convert AX -> DX:AX
38 
Ex. Conversion 
 MOV AL,22h 
 CBW ; AX=0022h 
 MOV AL,F0h 
 CBW ; AX=FFF0h 
 MOV AX, 3422h 
 CWD ; DX=0000h 
; AX=3422h
39
Example about flag with arithmetic 
40 
 เอกสารอ้างอิง 
 เอกสารประกอบการสอนวิชา 204221 องค์ประกอบคอมพิวเตอร์และ 
ภาษาแอสเซมบลี้ มหาวิทยาลัยเกษตรศาสตร์, 1994
Example about flag with arithmetic 
41 
NEG -> Carry flag always 1, INC/DEC does not effect any flag
42 
Jump and Loops 
 Control structures 
 Selection 
 Repetition / Loop 
 Jxx Label
43
44
45
46 
If ah=10, if ah>=10
47 
Get ‘Q’ and Print ASCII code.
48 
Loop 
 Base on CX (Counter register) to count the 
loop. 
 Instructions : 
 LOOP ; Dec CX … 0 
 LOOPZ ;CX<>0 and Z=1 
 LOOPNZ ;CX<>0 and Z=0 
 JCXZ ; Jump if CX=0, used with 
LOOP to determine the CX before loop.
49 
LOOP
50 
JCXZ
51 
Example finding first character
52 
That’s all.

More Related Content

What's hot

Ascii adjust & decimal adjust
Ascii adjust & decimal adjustAscii adjust & decimal adjust
Ascii adjust & decimal adjustTech_MX
 
Instruction sets of 8086
Instruction sets of 8086Instruction sets of 8086
Instruction sets of 8086Mahalakshmiv11
 
8086 instruction set (with simulator)
8086 instruction set (with simulator)8086 instruction set (with simulator)
8086 instruction set (with simulator)Aswini Dharmaraj
 
8086 microprocessor
8086 microprocessor8086 microprocessor
8086 microprocessorVikas Gupta
 
Instruction set of 8086
Instruction set of 8086Instruction set of 8086
Instruction set of 80869840596838
 
Assembly Language Basics
Assembly Language BasicsAssembly Language Basics
Assembly Language BasicsEducation Front
 
Logical, Shift, and Rotate Instruction
Logical, Shift, and Rotate InstructionLogical, Shift, and Rotate Instruction
Logical, Shift, and Rotate InstructionBadrul Alam
 
Flag Registers (Assembly Language)
Flag Registers (Assembly Language)Flag Registers (Assembly Language)
Flag Registers (Assembly Language)Anwar Hasan Shuvo
 
assembly language programming and organization of IBM PC" by YTHA YU
assembly language programming and organization of IBM PC" by YTHA YUassembly language programming and organization of IBM PC" by YTHA YU
assembly language programming and organization of IBM PC" by YTHA YUEducation
 
Instruction set of 8086
Instruction set of 8086Instruction set of 8086
Instruction set of 8086Vijay Kumar
 
Assembly language programming(unit 4)
Assembly language programming(unit 4)Assembly language programming(unit 4)
Assembly language programming(unit 4)Ashim Saha
 
Chapter 2 The 8088 Microprocessor
Chapter 2   The 8088 MicroprocessorChapter 2   The 8088 Microprocessor
Chapter 2 The 8088 MicroprocessorDwight Sabio
 
Assembly language
Assembly languageAssembly language
Assembly languagegaurav jain
 
Assembly language (coal)
Assembly language (coal)Assembly language (coal)
Assembly language (coal)Hareem Aslam
 
Instruction Set of 8086 Microprocessor
Instruction Set of 8086 MicroprocessorInstruction Set of 8086 Microprocessor
Instruction Set of 8086 MicroprocessorAshita Agrawal
 
INTEL 8086 MICROPROCESSOR
INTEL 8086 MICROPROCESSORINTEL 8086 MICROPROCESSOR
INTEL 8086 MICROPROCESSORSagar Kuntumal
 
instruction set of 8086
instruction set of 8086instruction set of 8086
instruction set of 8086muneer.k
 

What's hot (20)

Ascii adjust & decimal adjust
Ascii adjust & decimal adjustAscii adjust & decimal adjust
Ascii adjust & decimal adjust
 
Instruction sets of 8086
Instruction sets of 8086Instruction sets of 8086
Instruction sets of 8086
 
Stack
StackStack
Stack
 
8086 instruction set (with simulator)
8086 instruction set (with simulator)8086 instruction set (with simulator)
8086 instruction set (with simulator)
 
8086 microprocessor
8086 microprocessor8086 microprocessor
8086 microprocessor
 
Assignment on alp
Assignment on alpAssignment on alp
Assignment on alp
 
Instruction set of 8086
Instruction set of 8086Instruction set of 8086
Instruction set of 8086
 
Assembly Language Basics
Assembly Language BasicsAssembly Language Basics
Assembly Language Basics
 
Logical, Shift, and Rotate Instruction
Logical, Shift, and Rotate InstructionLogical, Shift, and Rotate Instruction
Logical, Shift, and Rotate Instruction
 
Flag Registers (Assembly Language)
Flag Registers (Assembly Language)Flag Registers (Assembly Language)
Flag Registers (Assembly Language)
 
assembly language programming and organization of IBM PC" by YTHA YU
assembly language programming and organization of IBM PC" by YTHA YUassembly language programming and organization of IBM PC" by YTHA YU
assembly language programming and organization of IBM PC" by YTHA YU
 
Assembly 8086
Assembly 8086Assembly 8086
Assembly 8086
 
Instruction set of 8086
Instruction set of 8086Instruction set of 8086
Instruction set of 8086
 
Assembly language programming(unit 4)
Assembly language programming(unit 4)Assembly language programming(unit 4)
Assembly language programming(unit 4)
 
Chapter 2 The 8088 Microprocessor
Chapter 2   The 8088 MicroprocessorChapter 2   The 8088 Microprocessor
Chapter 2 The 8088 Microprocessor
 
Assembly language
Assembly languageAssembly language
Assembly language
 
Assembly language (coal)
Assembly language (coal)Assembly language (coal)
Assembly language (coal)
 
Instruction Set of 8086 Microprocessor
Instruction Set of 8086 MicroprocessorInstruction Set of 8086 Microprocessor
Instruction Set of 8086 Microprocessor
 
INTEL 8086 MICROPROCESSOR
INTEL 8086 MICROPROCESSORINTEL 8086 MICROPROCESSOR
INTEL 8086 MICROPROCESSOR
 
instruction set of 8086
instruction set of 8086instruction set of 8086
instruction set of 8086
 

Similar to 8086 instruction set (20)

Instruction 4.pptx
Instruction 4.pptxInstruction 4.pptx
Instruction 4.pptx
 
[ASM]Lab7
[ASM]Lab7[ASM]Lab7
[ASM]Lab7
 
Assembly Complete 8086 Instruction Set
Assembly Complete 8086 Instruction SetAssembly Complete 8086 Instruction Set
Assembly Complete 8086 Instruction Set
 
[ASM]Lab4
[ASM]Lab4[ASM]Lab4
[ASM]Lab4
 
Mod-2.pptx
Mod-2.pptxMod-2.pptx
Mod-2.pptx
 
Arithmetic instrctions
Arithmetic instrctionsArithmetic instrctions
Arithmetic instrctions
 
Module 2 (1).pptx
Module 2 (1).pptxModule 2 (1).pptx
Module 2 (1).pptx
 
1344 Alp Of 8086
1344 Alp Of 80861344 Alp Of 8086
1344 Alp Of 8086
 
Lec06
Lec06Lec06
Lec06
 
Instructionsetof8086 180224060745(3)
Instructionsetof8086 180224060745(3)Instructionsetof8086 180224060745(3)
Instructionsetof8086 180224060745(3)
 
Assembly class
Assembly classAssembly class
Assembly class
 
Al2ed chapter7
Al2ed chapter7Al2ed chapter7
Al2ed chapter7
 
8086-instruction-set-ppt
 8086-instruction-set-ppt 8086-instruction-set-ppt
8086-instruction-set-ppt
 
Intel codetable
Intel codetableIntel codetable
Intel codetable
 
Instruction set of 8086
Instruction set of 8086Instruction set of 8086
Instruction set of 8086
 
Chap 3_2.ppt
Chap 3_2.pptChap 3_2.ppt
Chap 3_2.ppt
 
8086 alp
8086 alp8086 alp
8086 alp
 
Lecture5
Lecture5Lecture5
Lecture5
 
Lecture5(1)
Lecture5(1)Lecture5(1)
Lecture5(1)
 
Micro unit 3
Micro unit 3Micro unit 3
Micro unit 3
 

Recently uploaded

(ANIKA) Wanwadi Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Esc...
(ANIKA) Wanwadi Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Esc...(ANIKA) Wanwadi Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Esc...
(ANIKA) Wanwadi Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Esc...ranjana rawat
 
定制加拿大滑铁卢大学毕业证(Waterloo毕业证书)成绩单(文凭)原版一比一
定制加拿大滑铁卢大学毕业证(Waterloo毕业证书)成绩单(文凭)原版一比一定制加拿大滑铁卢大学毕业证(Waterloo毕业证书)成绩单(文凭)原版一比一
定制加拿大滑铁卢大学毕业证(Waterloo毕业证书)成绩单(文凭)原版一比一zul5vf0pq
 
Hifi Defence Colony Call Girls Service WhatsApp -> 9999965857 Available 24x7 ...
Hifi Defence Colony Call Girls Service WhatsApp -> 9999965857 Available 24x7 ...Hifi Defence Colony Call Girls Service WhatsApp -> 9999965857 Available 24x7 ...
Hifi Defence Colony Call Girls Service WhatsApp -> 9999965857 Available 24x7 ...srsj9000
 
Papular No 1 Online Istikhara Amil Baba Pakistan Amil Baba In Karachi Amil B...
Papular No 1 Online Istikhara Amil Baba Pakistan  Amil Baba In Karachi Amil B...Papular No 1 Online Istikhara Amil Baba Pakistan  Amil Baba In Karachi Amil B...
Papular No 1 Online Istikhara Amil Baba Pakistan Amil Baba In Karachi Amil B...Authentic No 1 Amil Baba In Pakistan
 
Call Girls Delhi {Rs-10000 Laxmi Nagar] 9711199012 Whats Up Number
Call Girls Delhi {Rs-10000 Laxmi Nagar] 9711199012 Whats Up NumberCall Girls Delhi {Rs-10000 Laxmi Nagar] 9711199012 Whats Up Number
Call Girls Delhi {Rs-10000 Laxmi Nagar] 9711199012 Whats Up NumberMs Riya
 
NO1 Qualified Best Black Magic Specialist Near Me Spiritual Healer Powerful L...
NO1 Qualified Best Black Magic Specialist Near Me Spiritual Healer Powerful L...NO1 Qualified Best Black Magic Specialist Near Me Spiritual Healer Powerful L...
NO1 Qualified Best Black Magic Specialist Near Me Spiritual Healer Powerful L...Amil baba
 
Vip Noida Escorts 9873940964 Greater Noida Escorts Service
Vip Noida Escorts 9873940964 Greater Noida Escorts ServiceVip Noida Escorts 9873940964 Greater Noida Escorts Service
Vip Noida Escorts 9873940964 Greater Noida Escorts Serviceankitnayak356677
 
Hifi Babe North Delhi Call Girl Service Fun Tonight
Hifi Babe North Delhi Call Girl Service Fun TonightHifi Babe North Delhi Call Girl Service Fun Tonight
Hifi Babe North Delhi Call Girl Service Fun TonightKomal Khan
 
Alambagh Call Girl 9548273370 , Call Girls Service Lucknow
Alambagh Call Girl 9548273370 , Call Girls Service LucknowAlambagh Call Girl 9548273370 , Call Girls Service Lucknow
Alambagh Call Girl 9548273370 , Call Girls Service Lucknowmakika9823
 
(SANA) Call Girls Landewadi ( 7001035870 ) HI-Fi Pune Escorts Service
(SANA) Call Girls Landewadi ( 7001035870 ) HI-Fi Pune Escorts Service(SANA) Call Girls Landewadi ( 7001035870 ) HI-Fi Pune Escorts Service
(SANA) Call Girls Landewadi ( 7001035870 ) HI-Fi Pune Escorts Serviceranjana rawat
 
Call Girls in Nagpur Bhavna Call 7001035870 Meet With Nagpur Escorts
Call Girls in Nagpur Bhavna Call 7001035870 Meet With Nagpur EscortsCall Girls in Nagpur Bhavna Call 7001035870 Meet With Nagpur Escorts
Call Girls in Nagpur Bhavna Call 7001035870 Meet With Nagpur Escortsranjana rawat
 
定制宾州州立大学毕业证(PSU毕业证) 成绩单留信学历认证原版一比一
定制宾州州立大学毕业证(PSU毕业证) 成绩单留信学历认证原版一比一定制宾州州立大学毕业证(PSU毕业证) 成绩单留信学历认证原版一比一
定制宾州州立大学毕业证(PSU毕业证) 成绩单留信学历认证原版一比一ga6c6bdl
 
原版1:1复刻斯坦福大学毕业证Stanford毕业证留信学历认证
原版1:1复刻斯坦福大学毕业证Stanford毕业证留信学历认证原版1:1复刻斯坦福大学毕业证Stanford毕业证留信学历认证
原版1:1复刻斯坦福大学毕业证Stanford毕业证留信学历认证gwhohjj
 
Gaya Call Girls #9907093804 Contact Number Escorts Service Gaya
Gaya Call Girls #9907093804 Contact Number Escorts Service GayaGaya Call Girls #9907093804 Contact Number Escorts Service Gaya
Gaya Call Girls #9907093804 Contact Number Escorts Service Gayasrsj9000
 
WhatsApp 9892124323 ✓Call Girls In Khar ( Mumbai ) secure service - Bandra F...
WhatsApp 9892124323 ✓Call Girls In Khar ( Mumbai ) secure service -  Bandra F...WhatsApp 9892124323 ✓Call Girls In Khar ( Mumbai ) secure service -  Bandra F...
WhatsApp 9892124323 ✓Call Girls In Khar ( Mumbai ) secure service - Bandra F...Pooja Nehwal
 
萨斯喀彻温大学毕业证学位证成绩单-购买流程
萨斯喀彻温大学毕业证学位证成绩单-购买流程萨斯喀彻温大学毕业证学位证成绩单-购买流程
萨斯喀彻温大学毕业证学位证成绩单-购买流程1k98h0e1
 
定制(Salford学位证)索尔福德大学毕业证成绩单原版一比一
定制(Salford学位证)索尔福德大学毕业证成绩单原版一比一定制(Salford学位证)索尔福德大学毕业证成绩单原版一比一
定制(Salford学位证)索尔福德大学毕业证成绩单原版一比一ss ss
 

Recently uploaded (20)

(ANIKA) Wanwadi Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Esc...
(ANIKA) Wanwadi Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Esc...(ANIKA) Wanwadi Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Esc...
(ANIKA) Wanwadi Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Esc...
 
定制加拿大滑铁卢大学毕业证(Waterloo毕业证书)成绩单(文凭)原版一比一
定制加拿大滑铁卢大学毕业证(Waterloo毕业证书)成绩单(文凭)原版一比一定制加拿大滑铁卢大学毕业证(Waterloo毕业证书)成绩单(文凭)原版一比一
定制加拿大滑铁卢大学毕业证(Waterloo毕业证书)成绩单(文凭)原版一比一
 
Hifi Defence Colony Call Girls Service WhatsApp -> 9999965857 Available 24x7 ...
Hifi Defence Colony Call Girls Service WhatsApp -> 9999965857 Available 24x7 ...Hifi Defence Colony Call Girls Service WhatsApp -> 9999965857 Available 24x7 ...
Hifi Defence Colony Call Girls Service WhatsApp -> 9999965857 Available 24x7 ...
 
Papular No 1 Online Istikhara Amil Baba Pakistan Amil Baba In Karachi Amil B...
Papular No 1 Online Istikhara Amil Baba Pakistan  Amil Baba In Karachi Amil B...Papular No 1 Online Istikhara Amil Baba Pakistan  Amil Baba In Karachi Amil B...
Papular No 1 Online Istikhara Amil Baba Pakistan Amil Baba In Karachi Amil B...
 
young call girls in Khanpur,🔝 9953056974 🔝 escort Service
young call girls in  Khanpur,🔝 9953056974 🔝 escort Serviceyoung call girls in  Khanpur,🔝 9953056974 🔝 escort Service
young call girls in Khanpur,🔝 9953056974 🔝 escort Service
 
Call Girls Delhi {Rs-10000 Laxmi Nagar] 9711199012 Whats Up Number
Call Girls Delhi {Rs-10000 Laxmi Nagar] 9711199012 Whats Up NumberCall Girls Delhi {Rs-10000 Laxmi Nagar] 9711199012 Whats Up Number
Call Girls Delhi {Rs-10000 Laxmi Nagar] 9711199012 Whats Up Number
 
NO1 Qualified Best Black Magic Specialist Near Me Spiritual Healer Powerful L...
NO1 Qualified Best Black Magic Specialist Near Me Spiritual Healer Powerful L...NO1 Qualified Best Black Magic Specialist Near Me Spiritual Healer Powerful L...
NO1 Qualified Best Black Magic Specialist Near Me Spiritual Healer Powerful L...
 
Vip Noida Escorts 9873940964 Greater Noida Escorts Service
Vip Noida Escorts 9873940964 Greater Noida Escorts ServiceVip Noida Escorts 9873940964 Greater Noida Escorts Service
Vip Noida Escorts 9873940964 Greater Noida Escorts Service
 
Hifi Babe North Delhi Call Girl Service Fun Tonight
Hifi Babe North Delhi Call Girl Service Fun TonightHifi Babe North Delhi Call Girl Service Fun Tonight
Hifi Babe North Delhi Call Girl Service Fun Tonight
 
Alambagh Call Girl 9548273370 , Call Girls Service Lucknow
Alambagh Call Girl 9548273370 , Call Girls Service LucknowAlambagh Call Girl 9548273370 , Call Girls Service Lucknow
Alambagh Call Girl 9548273370 , Call Girls Service Lucknow
 
(SANA) Call Girls Landewadi ( 7001035870 ) HI-Fi Pune Escorts Service
(SANA) Call Girls Landewadi ( 7001035870 ) HI-Fi Pune Escorts Service(SANA) Call Girls Landewadi ( 7001035870 ) HI-Fi Pune Escorts Service
(SANA) Call Girls Landewadi ( 7001035870 ) HI-Fi Pune Escorts Service
 
Call Girls in Nagpur Bhavna Call 7001035870 Meet With Nagpur Escorts
Call Girls in Nagpur Bhavna Call 7001035870 Meet With Nagpur EscortsCall Girls in Nagpur Bhavna Call 7001035870 Meet With Nagpur Escorts
Call Girls in Nagpur Bhavna Call 7001035870 Meet With Nagpur Escorts
 
定制宾州州立大学毕业证(PSU毕业证) 成绩单留信学历认证原版一比一
定制宾州州立大学毕业证(PSU毕业证) 成绩单留信学历认证原版一比一定制宾州州立大学毕业证(PSU毕业证) 成绩单留信学历认证原版一比一
定制宾州州立大学毕业证(PSU毕业证) 成绩单留信学历认证原版一比一
 
原版1:1复刻斯坦福大学毕业证Stanford毕业证留信学历认证
原版1:1复刻斯坦福大学毕业证Stanford毕业证留信学历认证原版1:1复刻斯坦福大学毕业证Stanford毕业证留信学历认证
原版1:1复刻斯坦福大学毕业证Stanford毕业证留信学历认证
 
Gaya Call Girls #9907093804 Contact Number Escorts Service Gaya
Gaya Call Girls #9907093804 Contact Number Escorts Service GayaGaya Call Girls #9907093804 Contact Number Escorts Service Gaya
Gaya Call Girls #9907093804 Contact Number Escorts Service Gaya
 
WhatsApp 9892124323 ✓Call Girls In Khar ( Mumbai ) secure service - Bandra F...
WhatsApp 9892124323 ✓Call Girls In Khar ( Mumbai ) secure service -  Bandra F...WhatsApp 9892124323 ✓Call Girls In Khar ( Mumbai ) secure service -  Bandra F...
WhatsApp 9892124323 ✓Call Girls In Khar ( Mumbai ) secure service - Bandra F...
 
萨斯喀彻温大学毕业证学位证成绩单-购买流程
萨斯喀彻温大学毕业证学位证成绩单-购买流程萨斯喀彻温大学毕业证学位证成绩单-购买流程
萨斯喀彻温大学毕业证学位证成绩单-购买流程
 
定制(Salford学位证)索尔福德大学毕业证成绩单原版一比一
定制(Salford学位证)索尔福德大学毕业证成绩单原版一比一定制(Salford学位证)索尔福德大学毕业证成绩单原版一比一
定制(Salford学位证)索尔福德大学毕业证成绩单原版一比一
 
9953330565 Low Rate Call Girls In Jahangirpuri Delhi NCR
9953330565 Low Rate Call Girls In Jahangirpuri  Delhi NCR9953330565 Low Rate Call Girls In Jahangirpuri  Delhi NCR
9953330565 Low Rate Call Girls In Jahangirpuri Delhi NCR
 
CIVIL ENGINEERING
CIVIL ENGINEERINGCIVIL ENGINEERING
CIVIL ENGINEERING
 

8086 instruction set

  • 2. 2 Instruction Set Classification  Transfer  Move  Arithmetic  Add / Subtract  Mul / Div, etc.  Control  Jump  Call / Return, etc.
  • 3. 3 Data transfer : Move  MOV Dest, Src  MOV reg, reg reg <- reg  MOV reg, mem reg <- mem  MOV mem, reg mem <- reg  MOV reg, imm reg <- imm  MOV mem, imm mem <- imm  There is no move mem<-mem instruction.
  • 4. Move limitation  Both operand must be in the same size.  There is no instruction to put immediate value directly to segment register. Have to use accumulator (AX) to accomplish this.  To put immediate value directly to memory, we have to specify its size. (Byte/Word PTR) 4
  • 5. 5 Move (MOV) Example  MOV AX,100h  MOV BX,AX  MOV DX,BX  MOV AX,1234h  MOV DX,5678h  MOV AL,DL  MOV BH,DH
  • 6. 6 MOV Example  MOV AX,1000h  MOV [100h],AX  MOV BX,[100h]  MOV BYTE PTR [200h],10h  MOV WORD PTR [300h],10h  MOV AX,2300h  MOV DS,AX
  • 7. 7 MOV : 16 / 8 Bit register  To move value between registers, their size must be the same.
  • 8. 8 MOV : Memory  Given only offset where to put value, it will be automatically select DS as the segment register.
  • 9. 9 Byte ordering : Little endian  Since, x86’s byte ordering is little endian.  Therefore, the LSB will be placed at lowest address and MSB will be placed at highest address.
  • 10. 10 Displacement  We can use BX (Base) register to point a place of memory.  Both register direct or displacement.  AX = ?
  • 11. 11 What is the result of …  MOV [100h] , 10h  Address 100 = 10h  What about address 101?  Word or Byte?  MOV WORD PTR [100h], 10h  MOV BYTE PTR [100h], 10h  What about MOV [100h], AX ?
  • 13. 13 Flag  8086 has 16 bit flag to indicate the status of final arithmetic result.
  • 14. 14 Zero Flag  The zero flag will be set (1) whenever the result is zero.
  • 15. 15 Parity flag  The parity flag will be set whenever the number of bit “1” are even.
  • 16. 16 Carry flag  Carry flag will be set whenever there is a carry or borrow (only with unsigned operation).
  • 17. 17 Overflow flag  Overflow flag will be set whenever the result is overflow (with signed operation).
  • 18. 18 Sign flag  Sign flag will be set whenever the result is negative with signed operation.
  • 19. 19 More flag  Auxiliary flag will be set when the result of BCD operation need to be adjusted.  Direction flag is used to specify direction (increment/decrement index register) in string operation.  Trap flag is used to interrupt CPU after each operation.  Interrupt flag is used to enable/disable hardware interrupt.
  • 20. 20 Flag set/reset instructions  Carry flag STC / CLC  Direction flag STD / CLD  Interrupt flag STI / CLI
  • 22. 22 Increment - Decrement  INC / DEC  INC register DEC register  INC memory DEC memory  EX.  INC AX  DEC BL  How can we increment a byte of memory?  INC ??? [100]
  • 23. 23 Add  ADD reg, imm ADC reg, imm  ADD reg, mem ADC reg, mem  ADD reg, reg ADC reg, reg  ADD mem, imm ADC mem, imm  ADD mem, reg ADC mem, reg
  • 24. 24 EX. ADD  MOV AL, 10h  ADD AL, 20h ;AL = 30h  MOV BX, 200h ;BX = 0200h  MOV WORD PTR [BX], 10h  ADD WORD PTR [BX], 70h  MOV AH, 89h ;AX = 8930h  ADD AX, 9876h ;AX = 21A6h  ADC BX, 01h ;BX = 0202h ?
  • 25. 25 Subtract  SUB reg, imm SBB reg, imm  SUB reg, mem SBB reg, mem  SUB reg, reg SBB reg, reg  SUB mem, imm SBB mem, imm  SUB mem, reg SBB mem, reg
  • 26. 26 Ex. SUB  MOV AL, 10h  ADD AL, 20h ;AL = 30h  MOV BX, 200h ;BX = 0200h  MOV WORD PTR [BX], 10h  SUB WORD PTR [BX], 70h  MOV AH, 89h ;AX = 8930h  SBB AX, 0001h ;AX = 892Eh ?  SBB AX, 0001h ;AX = 892Dh
  • 27. 27 Compare  CMP reg, imm  CMP reg, mem  CMP reg, reg  CMP mem, reg  There is no “CMP mem, imm”
  • 28. 28 Ex. CMP  MOV CX, 10h  CMP CX, 20h ;Z=0,S=1,C=1,O=0  MOV BX, 40h  CMP BX, 40h ;Z=1,S=0,C=0,O=0  MOV AX, 30h  CMP AX, 20h ;Z=0,S=0,C=0,O=0
  • 29. 29 Negation  Compute 2’complement.  Carry flag always set.  Usage  NEG reg  NEG mem
  • 30. 30 Ex. NEG  MOV CX, 10h  NEG CX ; CX = 0FFF0h  MOV AX,0FFFFH  NEG AX ; AX = 1  MOV BX,1H  NEG BX ; BX = 0FFFFh
  • 31. 31 Multiplication  IMUL (Integer multiplication) unsigned multiplication  MUL (Multiplication) signed multiplication.  MUL reg IMUL reg  MUL mem IMUL mem  Always perform with accumulator.  Effected flag are only over and carry flag.
  • 32. 32 8 bit multiplication  AL is multiplicand  AX keep the result  MOV AL,10h ; AL = 10h  MOV CL,13h ; CL = 13h  IMUL CL ; AX = 0130h
  • 33. 33 16 bit multiplication  AX is multiplicand  DX:AX keep the result  MOV AX,0100h ; AX = 0100h  MOV BX,1234h ; BX = 1234h  IMUL BX ; DX = 0012h ; AX = 3400h
  • 34. 34 Division  IDIV (Integer division) unsigned division.  DIV (Division) signed division.  DIV reg IDIV reg  DIV mem IDIV mem  Always perform with accumulator.  Effected flag are only over and carry flag.
  • 35. 35 8 bit division  AL is dividend  AL keep the result  AH keep the remainder  MOV AX, 0017h  MOV BX, 0010h  DIV BL ; AX = 0701
  • 36. 36 16 bit multiplication  DX:AX dividend.  AX keep the result, DX keep the remainder.  MOV AX,4022h ;  MOV DX,0000h ;  MOV CX,1000h ;  DIV CX ;AX = 0004 ;DX = 0022
  • 37. 37 Conversion  Byte to Word : CBW  Signed convert AL -> AX  Word to Double word : CWD  Signed convert AX -> DX:AX
  • 38. 38 Ex. Conversion  MOV AL,22h  CBW ; AX=0022h  MOV AL,F0h  CBW ; AX=FFF0h  MOV AX, 3422h  CWD ; DX=0000h ; AX=3422h
  • 39. 39
  • 40. Example about flag with arithmetic 40  เอกสารอ้างอิง  เอกสารประกอบการสอนวิชา 204221 องค์ประกอบคอมพิวเตอร์และ ภาษาแอสเซมบลี้ มหาวิทยาลัยเกษตรศาสตร์, 1994
  • 41. Example about flag with arithmetic 41 NEG -> Carry flag always 1, INC/DEC does not effect any flag
  • 42. 42 Jump and Loops  Control structures  Selection  Repetition / Loop  Jxx Label
  • 43. 43
  • 44. 44
  • 45. 45
  • 46. 46 If ah=10, if ah>=10
  • 47. 47 Get ‘Q’ and Print ASCII code.
  • 48. 48 Loop  Base on CX (Counter register) to count the loop.  Instructions :  LOOP ; Dec CX … 0  LOOPZ ;CX<>0 and Z=1  LOOPNZ ;CX<>0 and Z=0  JCXZ ; Jump if CX=0, used with LOOP to determine the CX before loop.
  • 51. 51 Example finding first character