SlideShare ist ein Scribd-Unternehmen logo
1 von 35
Chapter 2
Assemblers
Assembly Language Programming
• Writing a program in assembly lang is more
convenient than in machine lang.
• Assembly program is more readable.
• Assembly lang is machine dependent.
• Assembly program is written using
symbols(Mnemonics).
• Assembly program is translated into machine
code before execution.
Assembler
Assembly
Language
Program
Machine
Language
Figure: Assembler
Example:
MOV AX, X
--MOV is a mnemonic opcode.
--AX is a register operand in symbolic form.
--X is a memory operand in symbolic form.
Elements of Assembly Language
1. Mnemonic Operation Code:-
Eliminates the need to memorize numeric
operation code.
2. Symbolic Operands:-
Symbolic names can be used.
3. Data Declarations:-
Data can be declared in any form
Eg: -5, 10.5 etc.
Statement Format
[Label] <Opcode> <operand Spec> [<operand spec>….]
1. Label:- Is optional.
2. Opcode:- Symbolic opcode
3. Operand:- Symbolic name (Register or Memory
variable)
Instruction
Opcode
Assembly
Mnemonic
Remarks
00 STOP Stop Execution
01 ADD Op1  Op1+ Op2
02 SUB Op1  Op1 – Op2
03 MULT Op1  Op1* Op2
04 MOVER CPU Reg  Memory operand
05 MOVEM Memory  CPU Reg
06 COMP Sets Condition Code
07 BC Branch on Condition
08 DIV Op1  Op1/ Op2
09 READ Operand 2  input Value
10 PRINT Output  Operand2
Fig: Mnemonic Operation Codes
Instruction Format
sign opcode reg
operand
memory
operand
Fig: Instruction Format
Assembly Lang to M/C lang Program
1. Find address of variables and labels.
2. Replace Symbolic addr by numeric addr.
3. Replace Symbolic opcodes by machine
opcode.
4. Reserve storage for data.
START 101
READ X
READ Y
MOVER AREG, X
ADD AREG, Y
MOVEM AREG, RESULT
PRINT RESULT
STOP
X DS 1
Y DS 1
RESULT DS 1
END
Fig: Sample program to find X+Y
START 101
READ X
READ Y
MOVER AREG, X
ADD AREG, Y
MOVEM AREG, RESULT
PRINT RESULT
STOP
X DS 1
Y DS 1
RESULT DS 1
END
LC
101
102
103
104
105
106
107
108
109
110
+ 09 0 108
+ 09 0 109
+ 04 1 108
+ 01 1 109
+ 05 0 110
+ 10 0 110
+ 00 0 000
Opcode Register Memory
operand
Variable Address
X 108
Y 109
RESULT 110
Figure: After LC Processing
Required M/C Code
LC Opcode Register Address
101 09 0 108
102 09 0 109
103 04 1 108
104 01 1 109
105 05 0 110
106 10 0 110
107 00 0 000
108
109
110
111
Assembly Language Statement
1. Imperative Statement.
2. Declaration Statement.
3. Assembler Directives.
• Imperative Statements:-
– Indicates an action to be taken during execution of a
program.
– Eg: MOV, ADD, MULT, etc.
• Declaration Statement:-
– To reserve memory for variable.
[Label] DS <constant> eg: X DS 5
[Label] DC ‘<value>’ eg: X DC 3
• Assembler Directives:-
– Instructs the assembler to perform ceratin action during
assembly of a program.
START <constant>
END
Literals & Constants
int z=5;
x = x + 5;
1. Literal cannot be changed during program
execution
2. Literal is more safe and protected than a
constant.
3. Literals appear as a part of the instruction.
Advanced Assembler Directives
• ORIGIN
– ORIGIN <address specification>
• EQU
– <symbol> EQU <address specification>
• LTORG
– Allocates address for literals.
Pass structure of assembler
Pass I Pass II
Intermediate Code
Source
Program
Target
Program
Figure: Overview of Two Pass Assembler
Data Structures
Two Pass Translation
• Handles forward references easily.
• Requires 2 scans of the source program.
• LC processing is performed in the 1st pass and
symbols are stored in the symbol table.
• Second pass synthesis Target Program.
Single Pass Translation
• The problem of forward reference can be
handled using a technique called as back
patching.
START 100
MOVER AREG, X
L1 ADD BREG, ONE
ADD CREG, TEN
STOP
X DC ‘5’
ONE DC ‘1’
TEN DC ‘10’
END
START 100
MOVER AREG, X
L1 ADD BREG, ONE
ADD CREG, TEN
STOP
X DC ‘5’
ONE DC ‘1’
TEN DC ‘10’
END
100 04 1 _ _ _
101 01 2 _ _ _
102 06 3 _ _ _
103 00 0 000
104
105
106
Instruction Address Symbol Making a forward reference
100 X
101 ONE
102 TEN
Figure : TII
Machine Instruction After Backpatching
04 1 104
01 2 105
06 2 106
00 0 000
Design of a Two Pass Assembler
• Pass I:-
1. Separate the symbol, mnemonic, opcode and
operand.
2. Build Symbol Table.
3. Perform LC Processing.
4. Construct Intermediate Representation.
• Pass II:-
1.Process IR to synthesize the target program.
Pass I
• Pass I uses the following data structures
1. Machine Opcode table (OPTAB)
2. Symbol Table (ST)
3. Literal Table (LT)
4. Pool Table (PT)
1. OPTAB contains opcode, class and opcode
length.
2. SYMTAB contains symbol and address.
3. LITTAB contains literal and address.
4. POOLTAB contains starting literal number of
each pool.
START 200
MOVER AREG, =‘5’
MOVEM AREG, X
L1 MOVER BREG, =‘2’
ORIGIN L1+3
LTORG
NEXT ADD AREG,=‘1’
SUB BREG,=‘2’
BC LT, BACK
LTORG
BACK EQU L1
ORIGIN NEXT+5
MULT CREG,=‘4’
STOP
X DS 1
END
LC
200
201
202
205
206
207
208
209
210
211
212
212
213
214
Symbol Address Literal Address Pool Table
0
START 200
MOVER AREG,=‘5’ 200
Symbol Address Literal Address
=‘5’ ---
Pool Table
0
MOVEM AREG,X 201
Symbol Address
X ----
Literal Address
=‘5’ ---
Pool Table
0
L1 MOVER BREG,=‘2’ 202
Symbol Address
X ----
L1 202
Literal Address
=‘5’ ---
=‘2’ ---
Pool Table
0
ORIGIN L1+3 203
Symbol Address
X ----
L1 202
Literal Address
=‘5’ ---
=‘2’ ---
Pool Table
0
LTORG 205
206
Symbol Address
X ----
L1 202
Literal Address
=‘5’ 205
=‘2’ 206
Pool Table
0
2
NEXT ADD AREG, =‘1’ 207
Symbol Address
X ----
L1 202
NEXT 207
Literal Address
=‘5’ 205
=‘2’ 206
=‘1’ ----
Pool Table
0
2
SUB BREG,=‘2’ 208
Symbol Address
X ----
L1 202
NEXT 207
Literal Address
=‘5’ 205
=‘2’ 206
=‘1’ ----
=‘2’ -----
Pool Table
0
2
BC LT, BACK 209
Symbol Address
X ----
L1 202
NEXT 207
BACK ----
Literal Address
=‘5’ 205
=‘2’ 206
=‘1’ ----
=‘2’ ----
Pool Table
0
2
LTORG 210
211
Symbol Address
X ----
L1 202
NEXT 207
Literal Address
=‘5’ 205
=‘2’ 206
=‘1’ 210
=‘2’ 211
Pool Table
0
2
4
BACK EQU L1 212
Symbol Address
X ----
L1 202
NEXT 207
BACK 202
Literal Address
=‘5’ 205
=‘2’ 206
=‘1’ 210
=‘2’ 211
Pool Table
0
2
4
ORIGIN NEXT+5 213
Symbol Address
X ----
L1 202
NEXT 207
BACK 202
Literal Address
=‘5’ 205
=‘2’ 206
=‘1’ 210
=‘2’ 211
Pool Table
0
2
4
MULT CREG,=‘4’ 212
Symbol Address
X ----
L1 202
NEXT 207
BACK 202
Literal Address
=‘5’ 205
=‘2’ 206
=‘1’ 210
=‘2’ 211
=‘4’ ----
Pool Table
0
2
4
STOP 213
Symbol Address
X ----
L1 202
NEXT 207
BACK 202
Pool Table
0
2
4
Literal Address
=‘5’ 205
=‘2’ 206
=‘1’ 210
=‘2’ 211
=‘4’ ----
X DS 1 214
Symbol Address
X 214
L1 202
NEXT 207
BACK 202
Pool Table
0
2
4
END
Symbol Address
X 214
L1 202
NEXT 207
BACK 202
Pool Table
0
2
4
5
Literal Address
=‘5’ 205
=‘2’ 206
=‘1’ 210
=‘2’ 211
=‘4’ ----
Literal Address
=‘5’ 205
=‘2’ 206
=‘1’ 210
=‘2’ 211
=‘4’ 215

Weitere ähnliche Inhalte

Was ist angesagt?

Assemblers: Ch03
Assemblers: Ch03Assemblers: Ch03
Assemblers: Ch03desta_gebre
 
Loaders ( system programming )
Loaders ( system programming ) Loaders ( system programming )
Loaders ( system programming ) Adarsh Patel
 
Language processing activity
Language processing activityLanguage processing activity
Language processing activityDhruv Sabalpara
 
Introduction to loaders
Introduction to loadersIntroduction to loaders
Introduction to loadersTech_MX
 
Single pass assembler
Single pass assemblerSingle pass assembler
Single pass assemblerBansari Shah
 
Register Reference Instructions | Computer Science
Register Reference Instructions | Computer ScienceRegister Reference Instructions | Computer Science
Register Reference Instructions | Computer ScienceTransweb Global Inc
 
Fundamentals of Language Processing
Fundamentals of Language ProcessingFundamentals of Language Processing
Fundamentals of Language ProcessingHemant Sharma
 
Assembler - System Programming
Assembler - System ProgrammingAssembler - System Programming
Assembler - System ProgrammingRadhika Talaviya
 

Was ist angesagt? (20)

Assemblers: Ch03
Assemblers: Ch03Assemblers: Ch03
Assemblers: Ch03
 
Ch 4 linker loader
Ch 4 linker loaderCh 4 linker loader
Ch 4 linker loader
 
Macro Processor
Macro ProcessorMacro Processor
Macro Processor
 
Loaders ( system programming )
Loaders ( system programming ) Loaders ( system programming )
Loaders ( system programming )
 
Design of a two pass assembler
Design of a two pass assemblerDesign of a two pass assembler
Design of a two pass assembler
 
Pass 1 flowchart
Pass 1 flowchartPass 1 flowchart
Pass 1 flowchart
 
Language processing activity
Language processing activityLanguage processing activity
Language processing activity
 
MACRO PROCESSOR
MACRO PROCESSORMACRO PROCESSOR
MACRO PROCESSOR
 
Introduction to loaders
Introduction to loadersIntroduction to loaders
Introduction to loaders
 
Compilers
CompilersCompilers
Compilers
 
Linker and Loader
Linker and Loader Linker and Loader
Linker and Loader
 
Single pass assembler
Single pass assemblerSingle pass assembler
Single pass assembler
 
Register Reference Instructions | Computer Science
Register Reference Instructions | Computer ScienceRegister Reference Instructions | Computer Science
Register Reference Instructions | Computer Science
 
Assembler
AssemblerAssembler
Assembler
 
Instruction format
Instruction formatInstruction format
Instruction format
 
Code Generation
Code GenerationCode Generation
Code Generation
 
Loaders
LoadersLoaders
Loaders
 
Fundamentals of Language Processing
Fundamentals of Language ProcessingFundamentals of Language Processing
Fundamentals of Language Processing
 
Assembler - System Programming
Assembler - System ProgrammingAssembler - System Programming
Assembler - System Programming
 
loaders and linkers
 loaders and linkers loaders and linkers
loaders and linkers
 

Ähnlich wie ASM-Assembly Language

assembler_full_slides.ppt
assembler_full_slides.pptassembler_full_slides.ppt
assembler_full_slides.pptAshwini864432
 
Ch 3 Assembler in System programming
Ch 3 Assembler in System programming Ch 3 Assembler in System programming
Ch 3 Assembler in System programming Bhatt Balkrishna
 
Instruction Set Architecture
Instruction Set ArchitectureInstruction Set Architecture
Instruction Set ArchitectureDilum Bandara
 
basic computer programming and micro programmed control
basic computer programming and micro programmed controlbasic computer programming and micro programmed control
basic computer programming and micro programmed controlRai University
 
Windows debugging sisimon
Windows debugging   sisimonWindows debugging   sisimon
Windows debugging sisimonSisimon Soman
 
8086-instruction-set-ppt
 8086-instruction-set-ppt 8086-instruction-set-ppt
8086-instruction-set-pptjemimajerome
 
B.sc cs-ii-u-3.1-basic computer programming and micro programmed control
B.sc cs-ii-u-3.1-basic computer programming and micro programmed controlB.sc cs-ii-u-3.1-basic computer programming and micro programmed control
B.sc cs-ii-u-3.1-basic computer programming and micro programmed controlRai University
 
Ccna cheat sheet
Ccna cheat sheetCcna cheat sheet
Ccna cheat sheetaromal4frnz
 
Bca 2nd sem-u-3.1-basic computer programming and micro programmed control
Bca 2nd sem-u-3.1-basic computer programming and micro programmed controlBca 2nd sem-u-3.1-basic computer programming and micro programmed control
Bca 2nd sem-u-3.1-basic computer programming and micro programmed controlRai University
 
basic computer programming and micro programmed control
basic computer programming and micro programmed controlbasic computer programming and micro programmed control
basic computer programming and micro programmed controlRai University
 

Ähnlich wie ASM-Assembly Language (20)

assembler_full_slides.ppt
assembler_full_slides.pptassembler_full_slides.ppt
assembler_full_slides.ppt
 
Spr ch-02
Spr ch-02Spr ch-02
Spr ch-02
 
Ch 3 Assembler in System programming
Ch 3 Assembler in System programming Ch 3 Assembler in System programming
Ch 3 Assembler in System programming
 
Instruction Set Architecture
Instruction Set ArchitectureInstruction Set Architecture
Instruction Set Architecture
 
Chap 01[1]
Chap 01[1]Chap 01[1]
Chap 01[1]
 
basic computer programming and micro programmed control
basic computer programming and micro programmed controlbasic computer programming and micro programmed control
basic computer programming and micro programmed control
 
Sp chap2
Sp chap2Sp chap2
Sp chap2
 
Windows debugging sisimon
Windows debugging   sisimonWindows debugging   sisimon
Windows debugging sisimon
 
12 mt06ped008
12 mt06ped008 12 mt06ped008
12 mt06ped008
 
Cisco CCENT Cram Notes
Cisco CCENT Cram NotesCisco CCENT Cram Notes
Cisco CCENT Cram Notes
 
8086-instruction-set-ppt
 8086-instruction-set-ppt 8086-instruction-set-ppt
8086-instruction-set-ppt
 
B.sc cs-ii-u-3.1-basic computer programming and micro programmed control
B.sc cs-ii-u-3.1-basic computer programming and micro programmed controlB.sc cs-ii-u-3.1-basic computer programming and micro programmed control
B.sc cs-ii-u-3.1-basic computer programming and micro programmed control
 
Ccna cheat sheet
Ccna cheat sheetCcna cheat sheet
Ccna cheat sheet
 
Instruction set of 8086
Instruction set of 8086Instruction set of 8086
Instruction set of 8086
 
ISA.pptx
ISA.pptxISA.pptx
ISA.pptx
 
Bca 2nd sem-u-3.1-basic computer programming and micro programmed control
Bca 2nd sem-u-3.1-basic computer programming and micro programmed controlBca 2nd sem-u-3.1-basic computer programming and micro programmed control
Bca 2nd sem-u-3.1-basic computer programming and micro programmed control
 
Instruction types
Instruction typesInstruction types
Instruction types
 
[ASM] Lab1
[ASM] Lab1[ASM] Lab1
[ASM] Lab1
 
Assembler
AssemblerAssembler
Assembler
 
basic computer programming and micro programmed control
basic computer programming and micro programmed controlbasic computer programming and micro programmed control
basic computer programming and micro programmed control
 

Mehr von Dattatray Gandhmal

Mehr von Dattatray Gandhmal (7)

Lexical analysis-using-lex
Lexical analysis-using-lexLexical analysis-using-lex
Lexical analysis-using-lex
 
Finite automata-for-lexical-analysis
Finite automata-for-lexical-analysisFinite automata-for-lexical-analysis
Finite automata-for-lexical-analysis
 
Recognition-of-tokens
Recognition-of-tokensRecognition-of-tokens
Recognition-of-tokens
 
Specification-of-tokens
Specification-of-tokensSpecification-of-tokens
Specification-of-tokens
 
Input-Buffering
Input-BufferingInput-Buffering
Input-Buffering
 
Role-of-lexical-analysis
Role-of-lexical-analysisRole-of-lexical-analysis
Role-of-lexical-analysis
 
System Programming Overview
System Programming OverviewSystem Programming Overview
System Programming Overview
 

Kürzlich hochgeladen

Call Girls Service Nashik Vaishnavi 7001305949 Independent Escort Service Nashik
Call Girls Service Nashik Vaishnavi 7001305949 Independent Escort Service NashikCall Girls Service Nashik Vaishnavi 7001305949 Independent Escort Service Nashik
Call Girls Service Nashik Vaishnavi 7001305949 Independent Escort Service NashikCall Girls in Nagpur High Profile
 
The Most Attractive Pune Call Girls Manchar 8250192130 Will You Miss This Cha...
The Most Attractive Pune Call Girls Manchar 8250192130 Will You Miss This Cha...The Most Attractive Pune Call Girls Manchar 8250192130 Will You Miss This Cha...
The Most Attractive Pune Call Girls Manchar 8250192130 Will You Miss This Cha...ranjana rawat
 
Microscopic Analysis of Ceramic Materials.pptx
Microscopic Analysis of Ceramic Materials.pptxMicroscopic Analysis of Ceramic Materials.pptx
Microscopic Analysis of Ceramic Materials.pptxpurnimasatapathy1234
 
Porous Ceramics seminar and technical writing
Porous Ceramics seminar and technical writingPorous Ceramics seminar and technical writing
Porous Ceramics seminar and technical writingrakeshbaidya232001
 
Structural Analysis and Design of Foundations: A Comprehensive Handbook for S...
Structural Analysis and Design of Foundations: A Comprehensive Handbook for S...Structural Analysis and Design of Foundations: A Comprehensive Handbook for S...
Structural Analysis and Design of Foundations: A Comprehensive Handbook for S...Dr.Costas Sachpazis
 
(ANJALI) Dange Chowk Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...
(ANJALI) Dange Chowk Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...(ANJALI) Dange Chowk Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...
(ANJALI) Dange Chowk Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...ranjana rawat
 
247267395-1-Symmetric-and-distributed-shared-memory-architectures-ppt (1).ppt
247267395-1-Symmetric-and-distributed-shared-memory-architectures-ppt (1).ppt247267395-1-Symmetric-and-distributed-shared-memory-architectures-ppt (1).ppt
247267395-1-Symmetric-and-distributed-shared-memory-architectures-ppt (1).pptssuser5c9d4b1
 
Call Girls in Nagpur Suman Call 7001035870 Meet With Nagpur Escorts
Call Girls in Nagpur Suman Call 7001035870 Meet With Nagpur EscortsCall Girls in Nagpur Suman Call 7001035870 Meet With Nagpur Escorts
Call Girls in Nagpur Suman Call 7001035870 Meet With Nagpur EscortsCall Girls in Nagpur High Profile
 
KubeKraft presentation @CloudNativeHooghly
KubeKraft presentation @CloudNativeHooghlyKubeKraft presentation @CloudNativeHooghly
KubeKraft presentation @CloudNativeHooghlysanyuktamishra911
 
CCS335 _ Neural Networks and Deep Learning Laboratory_Lab Complete Record
CCS335 _ Neural Networks and Deep Learning Laboratory_Lab Complete RecordCCS335 _ Neural Networks and Deep Learning Laboratory_Lab Complete Record
CCS335 _ Neural Networks and Deep Learning Laboratory_Lab Complete RecordAsst.prof M.Gokilavani
 
Introduction to IEEE STANDARDS and its different types.pptx
Introduction to IEEE STANDARDS and its different types.pptxIntroduction to IEEE STANDARDS and its different types.pptx
Introduction to IEEE STANDARDS and its different types.pptxupamatechverse
 
OSVC_Meta-Data based Simulation Automation to overcome Verification Challenge...
OSVC_Meta-Data based Simulation Automation to overcome Verification Challenge...OSVC_Meta-Data based Simulation Automation to overcome Verification Challenge...
OSVC_Meta-Data based Simulation Automation to overcome Verification Challenge...Soham Mondal
 
Call Girls Pimpri Chinchwad Call Me 7737669865 Budget Friendly No Advance Boo...
Call Girls Pimpri Chinchwad Call Me 7737669865 Budget Friendly No Advance Boo...Call Girls Pimpri Chinchwad Call Me 7737669865 Budget Friendly No Advance Boo...
Call Girls Pimpri Chinchwad Call Me 7737669865 Budget Friendly No Advance Boo...roncy bisnoi
 
Introduction to Multiple Access Protocol.pptx
Introduction to Multiple Access Protocol.pptxIntroduction to Multiple Access Protocol.pptx
Introduction to Multiple Access Protocol.pptxupamatechverse
 
UNIT-III FMM. DIMENSIONAL ANALYSIS
UNIT-III FMM.        DIMENSIONAL ANALYSISUNIT-III FMM.        DIMENSIONAL ANALYSIS
UNIT-III FMM. DIMENSIONAL ANALYSISrknatarajan
 
HARDNESS, FRACTURE TOUGHNESS AND STRENGTH OF CERAMICS
HARDNESS, FRACTURE TOUGHNESS AND STRENGTH OF CERAMICSHARDNESS, FRACTURE TOUGHNESS AND STRENGTH OF CERAMICS
HARDNESS, FRACTURE TOUGHNESS AND STRENGTH OF CERAMICSRajkumarAkumalla
 
Introduction and different types of Ethernet.pptx
Introduction and different types of Ethernet.pptxIntroduction and different types of Ethernet.pptx
Introduction and different types of Ethernet.pptxupamatechverse
 
result management system report for college project
result management system report for college projectresult management system report for college project
result management system report for college projectTonystark477637
 

Kürzlich hochgeladen (20)

DJARUM4D - SLOT GACOR ONLINE | SLOT DEMO ONLINE
DJARUM4D - SLOT GACOR ONLINE | SLOT DEMO ONLINEDJARUM4D - SLOT GACOR ONLINE | SLOT DEMO ONLINE
DJARUM4D - SLOT GACOR ONLINE | SLOT DEMO ONLINE
 
Call Girls Service Nashik Vaishnavi 7001305949 Independent Escort Service Nashik
Call Girls Service Nashik Vaishnavi 7001305949 Independent Escort Service NashikCall Girls Service Nashik Vaishnavi 7001305949 Independent Escort Service Nashik
Call Girls Service Nashik Vaishnavi 7001305949 Independent Escort Service Nashik
 
The Most Attractive Pune Call Girls Manchar 8250192130 Will You Miss This Cha...
The Most Attractive Pune Call Girls Manchar 8250192130 Will You Miss This Cha...The Most Attractive Pune Call Girls Manchar 8250192130 Will You Miss This Cha...
The Most Attractive Pune Call Girls Manchar 8250192130 Will You Miss This Cha...
 
Microscopic Analysis of Ceramic Materials.pptx
Microscopic Analysis of Ceramic Materials.pptxMicroscopic Analysis of Ceramic Materials.pptx
Microscopic Analysis of Ceramic Materials.pptx
 
Porous Ceramics seminar and technical writing
Porous Ceramics seminar and technical writingPorous Ceramics seminar and technical writing
Porous Ceramics seminar and technical writing
 
Structural Analysis and Design of Foundations: A Comprehensive Handbook for S...
Structural Analysis and Design of Foundations: A Comprehensive Handbook for S...Structural Analysis and Design of Foundations: A Comprehensive Handbook for S...
Structural Analysis and Design of Foundations: A Comprehensive Handbook for S...
 
(ANJALI) Dange Chowk Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...
(ANJALI) Dange Chowk Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...(ANJALI) Dange Chowk Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...
(ANJALI) Dange Chowk Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...
 
247267395-1-Symmetric-and-distributed-shared-memory-architectures-ppt (1).ppt
247267395-1-Symmetric-and-distributed-shared-memory-architectures-ppt (1).ppt247267395-1-Symmetric-and-distributed-shared-memory-architectures-ppt (1).ppt
247267395-1-Symmetric-and-distributed-shared-memory-architectures-ppt (1).ppt
 
Call Girls in Nagpur Suman Call 7001035870 Meet With Nagpur Escorts
Call Girls in Nagpur Suman Call 7001035870 Meet With Nagpur EscortsCall Girls in Nagpur Suman Call 7001035870 Meet With Nagpur Escorts
Call Girls in Nagpur Suman Call 7001035870 Meet With Nagpur Escorts
 
KubeKraft presentation @CloudNativeHooghly
KubeKraft presentation @CloudNativeHooghlyKubeKraft presentation @CloudNativeHooghly
KubeKraft presentation @CloudNativeHooghly
 
CCS335 _ Neural Networks and Deep Learning Laboratory_Lab Complete Record
CCS335 _ Neural Networks and Deep Learning Laboratory_Lab Complete RecordCCS335 _ Neural Networks and Deep Learning Laboratory_Lab Complete Record
CCS335 _ Neural Networks and Deep Learning Laboratory_Lab Complete Record
 
Introduction to IEEE STANDARDS and its different types.pptx
Introduction to IEEE STANDARDS and its different types.pptxIntroduction to IEEE STANDARDS and its different types.pptx
Introduction to IEEE STANDARDS and its different types.pptx
 
Water Industry Process Automation & Control Monthly - April 2024
Water Industry Process Automation & Control Monthly - April 2024Water Industry Process Automation & Control Monthly - April 2024
Water Industry Process Automation & Control Monthly - April 2024
 
OSVC_Meta-Data based Simulation Automation to overcome Verification Challenge...
OSVC_Meta-Data based Simulation Automation to overcome Verification Challenge...OSVC_Meta-Data based Simulation Automation to overcome Verification Challenge...
OSVC_Meta-Data based Simulation Automation to overcome Verification Challenge...
 
Call Girls Pimpri Chinchwad Call Me 7737669865 Budget Friendly No Advance Boo...
Call Girls Pimpri Chinchwad Call Me 7737669865 Budget Friendly No Advance Boo...Call Girls Pimpri Chinchwad Call Me 7737669865 Budget Friendly No Advance Boo...
Call Girls Pimpri Chinchwad Call Me 7737669865 Budget Friendly No Advance Boo...
 
Introduction to Multiple Access Protocol.pptx
Introduction to Multiple Access Protocol.pptxIntroduction to Multiple Access Protocol.pptx
Introduction to Multiple Access Protocol.pptx
 
UNIT-III FMM. DIMENSIONAL ANALYSIS
UNIT-III FMM.        DIMENSIONAL ANALYSISUNIT-III FMM.        DIMENSIONAL ANALYSIS
UNIT-III FMM. DIMENSIONAL ANALYSIS
 
HARDNESS, FRACTURE TOUGHNESS AND STRENGTH OF CERAMICS
HARDNESS, FRACTURE TOUGHNESS AND STRENGTH OF CERAMICSHARDNESS, FRACTURE TOUGHNESS AND STRENGTH OF CERAMICS
HARDNESS, FRACTURE TOUGHNESS AND STRENGTH OF CERAMICS
 
Introduction and different types of Ethernet.pptx
Introduction and different types of Ethernet.pptxIntroduction and different types of Ethernet.pptx
Introduction and different types of Ethernet.pptx
 
result management system report for college project
result management system report for college projectresult management system report for college project
result management system report for college project
 

ASM-Assembly Language

  • 2. Assembly Language Programming • Writing a program in assembly lang is more convenient than in machine lang. • Assembly program is more readable. • Assembly lang is machine dependent. • Assembly program is written using symbols(Mnemonics). • Assembly program is translated into machine code before execution.
  • 4. Example: MOV AX, X --MOV is a mnemonic opcode. --AX is a register operand in symbolic form. --X is a memory operand in symbolic form.
  • 5. Elements of Assembly Language 1. Mnemonic Operation Code:- Eliminates the need to memorize numeric operation code. 2. Symbolic Operands:- Symbolic names can be used. 3. Data Declarations:- Data can be declared in any form Eg: -5, 10.5 etc.
  • 6. Statement Format [Label] <Opcode> <operand Spec> [<operand spec>….] 1. Label:- Is optional. 2. Opcode:- Symbolic opcode 3. Operand:- Symbolic name (Register or Memory variable)
  • 7. Instruction Opcode Assembly Mnemonic Remarks 00 STOP Stop Execution 01 ADD Op1  Op1+ Op2 02 SUB Op1  Op1 – Op2 03 MULT Op1  Op1* Op2 04 MOVER CPU Reg  Memory operand 05 MOVEM Memory  CPU Reg 06 COMP Sets Condition Code 07 BC Branch on Condition 08 DIV Op1  Op1/ Op2 09 READ Operand 2  input Value 10 PRINT Output  Operand2 Fig: Mnemonic Operation Codes
  • 8. Instruction Format sign opcode reg operand memory operand Fig: Instruction Format
  • 9. Assembly Lang to M/C lang Program 1. Find address of variables and labels. 2. Replace Symbolic addr by numeric addr. 3. Replace Symbolic opcodes by machine opcode. 4. Reserve storage for data.
  • 10. START 101 READ X READ Y MOVER AREG, X ADD AREG, Y MOVEM AREG, RESULT PRINT RESULT STOP X DS 1 Y DS 1 RESULT DS 1 END Fig: Sample program to find X+Y
  • 11. START 101 READ X READ Y MOVER AREG, X ADD AREG, Y MOVEM AREG, RESULT PRINT RESULT STOP X DS 1 Y DS 1 RESULT DS 1 END LC 101 102 103 104 105 106 107 108 109 110 + 09 0 108 + 09 0 109 + 04 1 108 + 01 1 109 + 05 0 110 + 10 0 110 + 00 0 000 Opcode Register Memory operand
  • 12. Variable Address X 108 Y 109 RESULT 110 Figure: After LC Processing
  • 13. Required M/C Code LC Opcode Register Address 101 09 0 108 102 09 0 109 103 04 1 108 104 01 1 109 105 05 0 110 106 10 0 110 107 00 0 000 108 109 110 111
  • 14. Assembly Language Statement 1. Imperative Statement. 2. Declaration Statement. 3. Assembler Directives.
  • 15. • Imperative Statements:- – Indicates an action to be taken during execution of a program. – Eg: MOV, ADD, MULT, etc. • Declaration Statement:- – To reserve memory for variable. [Label] DS <constant> eg: X DS 5 [Label] DC ‘<value>’ eg: X DC 3 • Assembler Directives:- – Instructs the assembler to perform ceratin action during assembly of a program. START <constant> END
  • 16. Literals & Constants int z=5; x = x + 5; 1. Literal cannot be changed during program execution 2. Literal is more safe and protected than a constant. 3. Literals appear as a part of the instruction.
  • 17. Advanced Assembler Directives • ORIGIN – ORIGIN <address specification> • EQU – <symbol> EQU <address specification> • LTORG – Allocates address for literals.
  • 18. Pass structure of assembler Pass I Pass II Intermediate Code Source Program Target Program Figure: Overview of Two Pass Assembler Data Structures
  • 19. Two Pass Translation • Handles forward references easily. • Requires 2 scans of the source program. • LC processing is performed in the 1st pass and symbols are stored in the symbol table. • Second pass synthesis Target Program.
  • 20. Single Pass Translation • The problem of forward reference can be handled using a technique called as back patching.
  • 21. START 100 MOVER AREG, X L1 ADD BREG, ONE ADD CREG, TEN STOP X DC ‘5’ ONE DC ‘1’ TEN DC ‘10’ END
  • 22. START 100 MOVER AREG, X L1 ADD BREG, ONE ADD CREG, TEN STOP X DC ‘5’ ONE DC ‘1’ TEN DC ‘10’ END 100 04 1 _ _ _ 101 01 2 _ _ _ 102 06 3 _ _ _ 103 00 0 000 104 105 106 Instruction Address Symbol Making a forward reference 100 X 101 ONE 102 TEN Figure : TII
  • 23. Machine Instruction After Backpatching 04 1 104 01 2 105 06 2 106 00 0 000
  • 24. Design of a Two Pass Assembler • Pass I:- 1. Separate the symbol, mnemonic, opcode and operand. 2. Build Symbol Table. 3. Perform LC Processing. 4. Construct Intermediate Representation. • Pass II:- 1.Process IR to synthesize the target program.
  • 25. Pass I • Pass I uses the following data structures 1. Machine Opcode table (OPTAB) 2. Symbol Table (ST) 3. Literal Table (LT) 4. Pool Table (PT)
  • 26. 1. OPTAB contains opcode, class and opcode length. 2. SYMTAB contains symbol and address. 3. LITTAB contains literal and address. 4. POOLTAB contains starting literal number of each pool.
  • 27. START 200 MOVER AREG, =‘5’ MOVEM AREG, X L1 MOVER BREG, =‘2’ ORIGIN L1+3 LTORG NEXT ADD AREG,=‘1’ SUB BREG,=‘2’ BC LT, BACK LTORG BACK EQU L1 ORIGIN NEXT+5 MULT CREG,=‘4’ STOP X DS 1 END LC 200 201 202 205 206 207 208 209 210 211 212 212 213 214
  • 28. Symbol Address Literal Address Pool Table 0 START 200 MOVER AREG,=‘5’ 200 Symbol Address Literal Address =‘5’ --- Pool Table 0
  • 29. MOVEM AREG,X 201 Symbol Address X ---- Literal Address =‘5’ --- Pool Table 0 L1 MOVER BREG,=‘2’ 202 Symbol Address X ---- L1 202 Literal Address =‘5’ --- =‘2’ --- Pool Table 0
  • 30. ORIGIN L1+3 203 Symbol Address X ---- L1 202 Literal Address =‘5’ --- =‘2’ --- Pool Table 0 LTORG 205 206 Symbol Address X ---- L1 202 Literal Address =‘5’ 205 =‘2’ 206 Pool Table 0 2
  • 31. NEXT ADD AREG, =‘1’ 207 Symbol Address X ---- L1 202 NEXT 207 Literal Address =‘5’ 205 =‘2’ 206 =‘1’ ---- Pool Table 0 2 SUB BREG,=‘2’ 208 Symbol Address X ---- L1 202 NEXT 207 Literal Address =‘5’ 205 =‘2’ 206 =‘1’ ---- =‘2’ ----- Pool Table 0 2
  • 32. BC LT, BACK 209 Symbol Address X ---- L1 202 NEXT 207 BACK ---- Literal Address =‘5’ 205 =‘2’ 206 =‘1’ ---- =‘2’ ---- Pool Table 0 2 LTORG 210 211 Symbol Address X ---- L1 202 NEXT 207 Literal Address =‘5’ 205 =‘2’ 206 =‘1’ 210 =‘2’ 211 Pool Table 0 2 4
  • 33. BACK EQU L1 212 Symbol Address X ---- L1 202 NEXT 207 BACK 202 Literal Address =‘5’ 205 =‘2’ 206 =‘1’ 210 =‘2’ 211 Pool Table 0 2 4 ORIGIN NEXT+5 213 Symbol Address X ---- L1 202 NEXT 207 BACK 202 Literal Address =‘5’ 205 =‘2’ 206 =‘1’ 210 =‘2’ 211 Pool Table 0 2 4
  • 34. MULT CREG,=‘4’ 212 Symbol Address X ---- L1 202 NEXT 207 BACK 202 Literal Address =‘5’ 205 =‘2’ 206 =‘1’ 210 =‘2’ 211 =‘4’ ---- Pool Table 0 2 4 STOP 213 Symbol Address X ---- L1 202 NEXT 207 BACK 202 Pool Table 0 2 4 Literal Address =‘5’ 205 =‘2’ 206 =‘1’ 210 =‘2’ 211 =‘4’ ----
  • 35. X DS 1 214 Symbol Address X 214 L1 202 NEXT 207 BACK 202 Pool Table 0 2 4 END Symbol Address X 214 L1 202 NEXT 207 BACK 202 Pool Table 0 2 4 5 Literal Address =‘5’ 205 =‘2’ 206 =‘1’ 210 =‘2’ 211 =‘4’ ---- Literal Address =‘5’ 205 =‘2’ 206 =‘1’ 210 =‘2’ 211 =‘4’ 215