SlideShare a Scribd company logo
1 of 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

More Related Content

What's hot (20)

Loaders
LoadersLoaders
Loaders
 
System software - macro expansion,nested macro calls
System software - macro expansion,nested macro callsSystem software - macro expansion,nested macro calls
System software - macro expansion,nested macro calls
 
Unit 3
Unit 3Unit 3
Unit 3
 
Loaders ( system programming )
Loaders ( system programming ) Loaders ( system programming )
Loaders ( system programming )
 
loaders and linkers
 loaders and linkers loaders and linkers
loaders and linkers
 
Assemblers: Ch03
Assemblers: Ch03Assemblers: Ch03
Assemblers: Ch03
 
First pass of assembler
First pass of assemblerFirst pass of assembler
First pass of assembler
 
Assembler
AssemblerAssembler
Assembler
 
Macro Processor
Macro ProcessorMacro Processor
Macro Processor
 
Language processing activity
Language processing activityLanguage processing activity
Language processing activity
 
System Programing Unit 1
System Programing Unit 1System Programing Unit 1
System Programing Unit 1
 
Pass Structure of Assembler
Pass Structure of AssemblerPass Structure of Assembler
Pass Structure of Assembler
 
Direct linking loaders
Direct linking loadersDirect linking loaders
Direct linking loaders
 
Syntax Analysis in Compiler Design
Syntax Analysis in Compiler Design Syntax Analysis in Compiler Design
Syntax Analysis in Compiler Design
 
Input-Buffering
Input-BufferingInput-Buffering
Input-Buffering
 
Two pass Assembler
Two pass AssemblerTwo pass Assembler
Two pass Assembler
 
Compiler Design
Compiler DesignCompiler Design
Compiler Design
 
Lexical analysis - Compiler Design
Lexical analysis - Compiler DesignLexical analysis - Compiler Design
Lexical analysis - Compiler Design
 
Specification-of-tokens
Specification-of-tokensSpecification-of-tokens
Specification-of-tokens
 
Assembler
AssemblerAssembler
Assembler
 

Similar to ASM-Assembly Language

assembler_full_slides.ppt
assembler_full_slides.pptassembler_full_slides.ppt
assembler_full_slides.pptAshwini864432
 
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
 
Assembler - System Programming
Assembler - System ProgrammingAssembler - System Programming
Assembler - System ProgrammingRadhika Talaviya
 
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
 

Similar to 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
 
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
 
Assembler - System Programming
Assembler - System ProgrammingAssembler - System Programming
Assembler - System Programming
 
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
 

Recently uploaded

(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
 
Coefficient of Thermal Expansion and their Importance.pptx
Coefficient of Thermal Expansion and their Importance.pptxCoefficient of Thermal Expansion and their Importance.pptx
Coefficient of Thermal Expansion and their Importance.pptxAsutosh Ranjan
 
(PRIYA) Rajgurunagar Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...
(PRIYA) Rajgurunagar Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...(PRIYA) Rajgurunagar Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...
(PRIYA) Rajgurunagar Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...ranjana rawat
 
Extrusion Processes and Their Limitations
Extrusion Processes and Their LimitationsExtrusion Processes and Their Limitations
Extrusion Processes and Their Limitations120cr0395
 
the ladakh protest in leh ladakh 2024 sonam wangchuk.pptx
the ladakh protest in leh ladakh 2024 sonam wangchuk.pptxthe ladakh protest in leh ladakh 2024 sonam wangchuk.pptx
the ladakh protest in leh ladakh 2024 sonam wangchuk.pptxhumanexperienceaaa
 
SPICE PARK APR2024 ( 6,793 SPICE Models )
SPICE PARK APR2024 ( 6,793 SPICE Models )SPICE PARK APR2024 ( 6,793 SPICE Models )
SPICE PARK APR2024 ( 6,793 SPICE Models )Tsuyoshi Horigome
 
Call for Papers - African Journal of Biological Sciences, E-ISSN: 2663-2187, ...
Call for Papers - African Journal of Biological Sciences, E-ISSN: 2663-2187, ...Call for Papers - African Journal of Biological Sciences, E-ISSN: 2663-2187, ...
Call for Papers - African Journal of Biological Sciences, E-ISSN: 2663-2187, ...Christo Ananth
 
Microscopic Analysis of Ceramic Materials.pptx
Microscopic Analysis of Ceramic Materials.pptxMicroscopic Analysis of Ceramic Materials.pptx
Microscopic Analysis of Ceramic Materials.pptxpurnimasatapathy1234
 
Call Girls Service Nagpur Tanvi Call 7001035870 Meet With Nagpur Escorts
Call Girls Service Nagpur Tanvi Call 7001035870 Meet With Nagpur EscortsCall Girls Service Nagpur Tanvi Call 7001035870 Meet With Nagpur Escorts
Call Girls Service Nagpur Tanvi Call 7001035870 Meet With Nagpur EscortsCall Girls in Nagpur High Profile
 
APPLICATIONS-AC/DC DRIVES-OPERATING CHARACTERISTICS
APPLICATIONS-AC/DC DRIVES-OPERATING CHARACTERISTICSAPPLICATIONS-AC/DC DRIVES-OPERATING CHARACTERISTICS
APPLICATIONS-AC/DC DRIVES-OPERATING CHARACTERISTICSKurinjimalarL3
 
(MEERA) Dapodi Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Escorts
(MEERA) Dapodi Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Escorts(MEERA) Dapodi Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Escorts
(MEERA) Dapodi Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Escortsranjana rawat
 
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
 
Sheet Pile Wall Design and Construction: A Practical Guide for Civil Engineer...
Sheet Pile Wall Design and Construction: A Practical Guide for Civil Engineer...Sheet Pile Wall Design and Construction: A Practical Guide for Civil Engineer...
Sheet Pile Wall Design and Construction: A Practical Guide for Civil Engineer...Dr.Costas Sachpazis
 
Introduction to Multiple Access Protocol.pptx
Introduction to Multiple Access Protocol.pptxIntroduction to Multiple Access Protocol.pptx
Introduction to Multiple Access Protocol.pptxupamatechverse
 
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
 
(SHREYA) Chakan Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Esc...
(SHREYA) Chakan Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Esc...(SHREYA) Chakan Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Esc...
(SHREYA) Chakan Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Esc...ranjana rawat
 

Recently uploaded (20)

(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
 
Coefficient of Thermal Expansion and their Importance.pptx
Coefficient of Thermal Expansion and their Importance.pptxCoefficient of Thermal Expansion and their Importance.pptx
Coefficient of Thermal Expansion and their Importance.pptx
 
(PRIYA) Rajgurunagar Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...
(PRIYA) Rajgurunagar Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...(PRIYA) Rajgurunagar Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...
(PRIYA) Rajgurunagar Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...
 
Extrusion Processes and Their Limitations
Extrusion Processes and Their LimitationsExtrusion Processes and Their Limitations
Extrusion Processes and Their Limitations
 
the ladakh protest in leh ladakh 2024 sonam wangchuk.pptx
the ladakh protest in leh ladakh 2024 sonam wangchuk.pptxthe ladakh protest in leh ladakh 2024 sonam wangchuk.pptx
the ladakh protest in leh ladakh 2024 sonam wangchuk.pptx
 
SPICE PARK APR2024 ( 6,793 SPICE Models )
SPICE PARK APR2024 ( 6,793 SPICE Models )SPICE PARK APR2024 ( 6,793 SPICE Models )
SPICE PARK APR2024 ( 6,793 SPICE Models )
 
Call for Papers - African Journal of Biological Sciences, E-ISSN: 2663-2187, ...
Call for Papers - African Journal of Biological Sciences, E-ISSN: 2663-2187, ...Call for Papers - African Journal of Biological Sciences, E-ISSN: 2663-2187, ...
Call for Papers - African Journal of Biological Sciences, E-ISSN: 2663-2187, ...
 
Microscopic Analysis of Ceramic Materials.pptx
Microscopic Analysis of Ceramic Materials.pptxMicroscopic Analysis of Ceramic Materials.pptx
Microscopic Analysis of Ceramic Materials.pptx
 
Call Girls Service Nagpur Tanvi Call 7001035870 Meet With Nagpur Escorts
Call Girls Service Nagpur Tanvi Call 7001035870 Meet With Nagpur EscortsCall Girls Service Nagpur Tanvi Call 7001035870 Meet With Nagpur Escorts
Call Girls Service Nagpur Tanvi Call 7001035870 Meet With Nagpur Escorts
 
APPLICATIONS-AC/DC DRIVES-OPERATING CHARACTERISTICS
APPLICATIONS-AC/DC DRIVES-OPERATING CHARACTERISTICSAPPLICATIONS-AC/DC DRIVES-OPERATING CHARACTERISTICS
APPLICATIONS-AC/DC DRIVES-OPERATING CHARACTERISTICS
 
(MEERA) Dapodi Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Escorts
(MEERA) Dapodi Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Escorts(MEERA) Dapodi Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Escorts
(MEERA) Dapodi Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Escorts
 
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
 
9953056974 Call Girls In South Ex, Escorts (Delhi) NCR.pdf
9953056974 Call Girls In South Ex, Escorts (Delhi) NCR.pdf9953056974 Call Girls In South Ex, Escorts (Delhi) NCR.pdf
9953056974 Call Girls In South Ex, Escorts (Delhi) NCR.pdf
 
Sheet Pile Wall Design and Construction: A Practical Guide for Civil Engineer...
Sheet Pile Wall Design and Construction: A Practical Guide for Civil Engineer...Sheet Pile Wall Design and Construction: A Practical Guide for Civil Engineer...
Sheet Pile Wall Design and Construction: A Practical Guide for Civil Engineer...
 
Call Us -/9953056974- Call Girls In Vikaspuri-/- Delhi NCR
Call Us -/9953056974- Call Girls In Vikaspuri-/- Delhi NCRCall Us -/9953056974- Call Girls In Vikaspuri-/- Delhi NCR
Call Us -/9953056974- Call Girls In Vikaspuri-/- Delhi NCR
 
Introduction to Multiple Access Protocol.pptx
Introduction to Multiple Access Protocol.pptxIntroduction to Multiple Access Protocol.pptx
Introduction to Multiple Access Protocol.pptx
 
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
 
(SHREYA) Chakan Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Esc...
(SHREYA) Chakan Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Esc...(SHREYA) Chakan Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Esc...
(SHREYA) Chakan Call Girls Just Call 7001035870 [ Cash on Delivery ] Pune Esc...
 
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
 

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