SlideShare a Scribd company logo
1 of 20
PROCEDURES & MACROS
Procedures
• While writing programs, sometimes it may be required
to use same set of instructions repeatedly.
• If these instructions are actually written again & again,
the program size increases and occupies more memory
space.
• To avoid this, these instructions can be written as a
separate program (subprogram) and whenever this set
of instructions is required, an instruction can be
written in the main program CALL this subprogram.
• This saves the memory space.
• A subprogram which is called from the main program
to execute certain set of instructions is called
subroutine or procedure.
Procedures
• Declaring PROCEDURES:
• The syntax for procedure declaration:
• name PROC [NEAR/FAR]
; Instructions of the procedures
; are written here.
RET
• name ENDP
Procedures
• Example:
Delay PROC
MOV CX,COUNT
AGAIN: NOP
LOOP AGAIN
RET
Delay ENDP
Procedures
• A procedure in 8086 can be accessed with a CALL &
RET instruction.
• CALL instruction: This performs two operations
1. Saves the return address or the address of the
instruction next to the CALL instruction on the stack.
Return address is the address where the program will
return to after the procedure completes execution.
– If the call to procedure is in the same code segment, i.e. a
near CALL, then only the contents of IP are pushed on the
stack.
– If the call to procedure is in another code segment, i.e. a
far CALL, then the contents of IP as well as CS are pushed
on the stack.
2. It loads the IP & CS register with a new starting
address of the procedure and then branches to the
procedure.
Procedures
• RET instruction:
• When 8086 executes a CALL instruction, it
stores the return address of the CALLing
routine on the stack.
• A RET instruction at the end of the procedure
copies the return address stored on the stack
back into the CS and IP registers and then
returns execution to the main program.
Procedures
• Passing Parameters to procedures:
• Procedures may require input data or constants for
their execution.
• Their data or constants may be passed to the
procedure by the main program or some procedures
may access the readily available data of constants
available in memory.
• Generally following techniques are used to pass input
data/parameter to procedures in assembly language
programs,
1. Using global declared variable
2. Using registers of CPU architecture
3. Using memory locations
4. Using stack
Example : Using registers
CODE SEGMENT
START: MOV AX, 5555H
MOV BX,7272h
:
:
CALL PROC1
:
:
PROC1 PROCEDURE
:
:
ADD AX,BX
:
:
RET
PROC1 ENDP
CODE ENDS
END START
Procedures
• Re-entrant Procedures :
• A procedure is said to be re-entrant, if it can
be interrupted, used and re-entered without
losing or writing over anything. To be a re-
entrant,
• Procedure must first push all the flags and
registers used in the procedure.
• It should also use only registers or stack to pass
parameters.
• The flow of re-entrant procedure for a multiply
procedure when interrupt procedure is executed,
as shown in the next slide
Procedures
Procedures
• Recursive Procedures:
• A recursive procedure is a procedure which
calls itself.
• Here, the program sets aside a few locations in
stack for the storage of the parameters which
are passed each time the computation is done
and the value is returned.
• Each value returned is then obtained by
popping back from the stack at every RET
instruction when executed at the end of the
procedure.
Program to find the factorial using
recursiondata segment
n db 04h
res dw ?
data ends
code segment
assume cs:code, ds:data
start: mov ax,data
mov ds,ax
mov al,n
mov ah,00h
call fact
int 3
fact proc
cmp ax,01 ;if n=1, fact=1 else fact=n*fact(n-1)
jz exit
push ax
dec ax ;n-1
call fact ;fact(n-1) , RECURSION
pop ax
mul res ;n*fact(n-1)
mov res,ax ;res=factorial
ret
exit:
mov res,01
ret
fact endp
code ends
end start
Advantages of Procedures
• Simple modular programming
• Reduced workload and development time
• Debugging of program and procedure is easier
• Reduction in the size of the main program
• Reuse of procedures in the same program
many times or in another program.
MACROS
• Small sequences of codes of the same pattern
repeated frequently at different places which
perform the same operation on the different
data of the same data type are called MACRO.
• Macro is also called as an Open subroutine.
• When Called, the code written within macro
are executed automatically.
• Macros should be used when it has few
program statements.
• This simplifies the programming process.
MACROS
Advantages
• Simplify and reduce the amount of repetitive
coding
• Reduce errors caused by repetitive coding
• Makes program more readable
• Execution time is less as compared to
procedures as no extra instructions required
Procedure Vs Macros
• Procedure does occupy minimum memory
space than macro.
• In macro machine code is generated for
instructions each time when it is called but in
procedure machine code for instruction is put
only once in the memory
• Procedure is accessed by call Instruction
whereas Macro is accessed with the name
given.
MACROS
Defining Macros
The Directive MACRO indicates the beginning of a
MACRO
Name of the Macro followed by MACRO and arguments if
any are specified.
ENDM is always associated with MACRO which ends the
macro.
General Form :
Macro_name MACRO [Arguement1, arguement2…]
:
:
ENDM
MACROS
Example:
PRINT MACRO MES
MOV AX,09H
LEA DX, MES
INT 21H
ENDM
The above macro is used to display a string
specified in the argument MES on the screen,
when evoked by the main program as given in
the next slide.
MACROS
DATA SEGEMENT
STR DB 0DH,0AH,”Hello World$”
DATA ENDS
CODE SEGMENT
ASSUME DS:DATA, CS:CODE
START: MOV AX, DATA
MOV DS, AX
PRINT STR ; Calls Macro PRINT to display STR
; STR is the parameter passed which is
;taken as MES in the Macro PRINT.
:
:
CODE ENDS
END START

More Related Content

What's hot

What's hot (19)

Pipelining powerpoint presentation
Pipelining powerpoint presentationPipelining powerpoint presentation
Pipelining powerpoint presentation
 
Pipeline hazard
Pipeline hazardPipeline hazard
Pipeline hazard
 
Compiler design
Compiler designCompiler design
Compiler design
 
Instruction pipelining
Instruction pipeliningInstruction pipelining
Instruction pipelining
 
Central processing unit and stack organization r013
Central processing unit and stack organization   r013Central processing unit and stack organization   r013
Central processing unit and stack organization r013
 
Unit 3 part2
Unit 3 part2Unit 3 part2
Unit 3 part2
 
Computer architecture pipelining
Computer architecture pipeliningComputer architecture pipelining
Computer architecture pipelining
 
Instruction Pipelining
Instruction PipeliningInstruction Pipelining
Instruction Pipelining
 
Pipelining
PipeliningPipelining
Pipelining
 
3 Pipelining
3 Pipelining3 Pipelining
3 Pipelining
 
Data Hazard and Solution for Data Hazard
Data Hazard and Solution for Data HazardData Hazard and Solution for Data Hazard
Data Hazard and Solution for Data Hazard
 
Pipeline processing - Computer Architecture
Pipeline processing - Computer Architecture Pipeline processing - Computer Architecture
Pipeline processing - Computer Architecture
 
INSTRUCTION LEVEL PARALLALISM
INSTRUCTION LEVEL PARALLALISMINSTRUCTION LEVEL PARALLALISM
INSTRUCTION LEVEL PARALLALISM
 
Unit 3 part2
Unit 3 part2Unit 3 part2
Unit 3 part2
 
Computer Organozation
Computer OrganozationComputer Organozation
Computer Organozation
 
Chapter 04 the processor
Chapter 04   the processorChapter 04   the processor
Chapter 04 the processor
 
Pipelining & All Hazards Solution
Pipelining  & All Hazards SolutionPipelining  & All Hazards Solution
Pipelining & All Hazards Solution
 
1.prallelism
1.prallelism1.prallelism
1.prallelism
 
pipelining
pipeliningpipelining
pipelining
 

Similar to PROCEDURES & MACROS GUIDE

Similar to PROCEDURES & MACROS GUIDE (20)

Chapter 5 notes
Chapter 5 notesChapter 5 notes
Chapter 5 notes
 
EC8691-MPMC-PPT.pptx
EC8691-MPMC-PPT.pptxEC8691-MPMC-PPT.pptx
EC8691-MPMC-PPT.pptx
 
unit-2.pptx
unit-2.pptxunit-2.pptx
unit-2.pptx
 
Assembly language programming_fundamentals 8086
Assembly language programming_fundamentals 8086Assembly language programming_fundamentals 8086
Assembly language programming_fundamentals 8086
 
Introduction to Microcontrollers
Introduction to MicrocontrollersIntroduction to Microcontrollers
Introduction to Microcontrollers
 
Procedure
ProcedureProcedure
Procedure
 
OpenPOWER Application Optimization
OpenPOWER Application Optimization OpenPOWER Application Optimization
OpenPOWER Application Optimization
 
Chapter Seven(1)
Chapter Seven(1)Chapter Seven(1)
Chapter Seven(1)
 
assembler Directives hnotesnnnnnnnn.pptx
assembler Directives hnotesnnnnnnnn.pptxassembler Directives hnotesnnnnnnnn.pptx
assembler Directives hnotesnnnnnnnn.pptx
 
Mod 3.pptx
Mod 3.pptxMod 3.pptx
Mod 3.pptx
 
Unit 4 assembly language programming
Unit 4   assembly language programmingUnit 4   assembly language programming
Unit 4 assembly language programming
 
13 risc
13 risc13 risc
13 risc
 
CPU Architecture
CPU ArchitectureCPU Architecture
CPU Architecture
 
Co&al lecture-07
Co&al lecture-07Co&al lecture-07
Co&al lecture-07
 
class-Stacks.pptx
class-Stacks.pptxclass-Stacks.pptx
class-Stacks.pptx
 
Unit 4 sp macro
Unit 4 sp macroUnit 4 sp macro
Unit 4 sp macro
 
Different addressing mode and risc, cisc microprocessor
Different addressing mode and risc, cisc microprocessorDifferent addressing mode and risc, cisc microprocessor
Different addressing mode and risc, cisc microprocessor
 
Reduced instruction set computers
Reduced instruction set computersReduced instruction set computers
Reduced instruction set computers
 
Assembly level language
Assembly level languageAssembly level language
Assembly level language
 
C programming session9 -
C programming  session9 -C programming  session9 -
C programming session9 -
 

More from HarshitParkar6677 (20)

Wi fi hacking
Wi fi hackingWi fi hacking
Wi fi hacking
 
D dos attack
D dos attackD dos attack
D dos attack
 
Notes chapter 6
Notes chapter  6Notes chapter  6
Notes chapter 6
 
Interface notes
Interface notesInterface notes
Interface notes
 
Chapter6 2
Chapter6 2Chapter6 2
Chapter6 2
 
Chapter6
Chapter6Chapter6
Chapter6
 
8086 cpu 1
8086 cpu 18086 cpu 1
8086 cpu 1
 
Notes arithmetic instructions
Notes arithmetic instructionsNotes arithmetic instructions
Notes arithmetic instructions
 
Notes all instructions
Notes all instructionsNotes all instructions
Notes all instructions
 
Notes aaa aa
Notes aaa aaNotes aaa aa
Notes aaa aa
 
Notes 8086 instruction format
Notes 8086 instruction formatNotes 8086 instruction format
Notes 8086 instruction format
 
Misc
MiscMisc
Misc
 
Copy of 8086inst logical
Copy of 8086inst logicalCopy of 8086inst logical
Copy of 8086inst logical
 
Copy of 8086inst logical
Copy of 8086inst logicalCopy of 8086inst logical
Copy of 8086inst logical
 
Chapter3 program flow control instructions
Chapter3 program flow control instructionsChapter3 program flow control instructions
Chapter3 program flow control instructions
 
Chapter3 8086inst stringsl
Chapter3 8086inst stringslChapter3 8086inst stringsl
Chapter3 8086inst stringsl
 
Chapter3 8086inst logical 2
Chapter3 8086inst logical 2Chapter3 8086inst logical 2
Chapter3 8086inst logical 2
 
Chapter 3 8086 ins2 math
Chapter 3 8086 ins2 mathChapter 3 8086 ins2 math
Chapter 3 8086 ins2 math
 
Chap3 program flow control instructions
Chap3 program flow control instructionsChap3 program flow control instructions
Chap3 program flow control instructions
 
Chap3 8086 logical
Chap3 8086 logicalChap3 8086 logical
Chap3 8086 logical
 

Recently uploaded

US Department of Education FAFSA Week of Action
US Department of Education FAFSA Week of ActionUS Department of Education FAFSA Week of Action
US Department of Education FAFSA Week of ActionMebane Rash
 
Ch10-Global Supply Chain - Cadena de Suministro.pdf
Ch10-Global Supply Chain - Cadena de Suministro.pdfCh10-Global Supply Chain - Cadena de Suministro.pdf
Ch10-Global Supply Chain - Cadena de Suministro.pdfChristianCDAM
 
FUNCTIONAL AND NON FUNCTIONAL REQUIREMENT
FUNCTIONAL AND NON FUNCTIONAL REQUIREMENTFUNCTIONAL AND NON FUNCTIONAL REQUIREMENT
FUNCTIONAL AND NON FUNCTIONAL REQUIREMENTSneha Padhiar
 
High Voltage Engineering- OVER VOLTAGES IN ELECTRICAL POWER SYSTEMS
High Voltage Engineering- OVER VOLTAGES IN ELECTRICAL POWER SYSTEMSHigh Voltage Engineering- OVER VOLTAGES IN ELECTRICAL POWER SYSTEMS
High Voltage Engineering- OVER VOLTAGES IN ELECTRICAL POWER SYSTEMSsandhya757531
 
Input Output Management in Operating System
Input Output Management in Operating SystemInput Output Management in Operating System
Input Output Management in Operating SystemRashmi Bhat
 
ROBOETHICS-CCS345 ETHICS AND ARTIFICIAL INTELLIGENCE.ppt
ROBOETHICS-CCS345 ETHICS AND ARTIFICIAL INTELLIGENCE.pptROBOETHICS-CCS345 ETHICS AND ARTIFICIAL INTELLIGENCE.ppt
ROBOETHICS-CCS345 ETHICS AND ARTIFICIAL INTELLIGENCE.pptJohnWilliam111370
 
Comparative study of High-rise Building Using ETABS,SAP200 and SAFE., SAFE an...
Comparative study of High-rise Building Using ETABS,SAP200 and SAFE., SAFE an...Comparative study of High-rise Building Using ETABS,SAP200 and SAFE., SAFE an...
Comparative study of High-rise Building Using ETABS,SAP200 and SAFE., SAFE an...Erbil Polytechnic University
 
OOP concepts -in-Python programming language
OOP concepts -in-Python programming languageOOP concepts -in-Python programming language
OOP concepts -in-Python programming languageSmritiSharma901052
 
Levelling - Rise and fall - Height of instrument method
Levelling - Rise and fall - Height of instrument methodLevelling - Rise and fall - Height of instrument method
Levelling - Rise and fall - Height of instrument methodManicka Mamallan Andavar
 
Cost estimation approach: FP to COCOMO scenario based question
Cost estimation approach: FP to COCOMO scenario based questionCost estimation approach: FP to COCOMO scenario based question
Cost estimation approach: FP to COCOMO scenario based questionSneha Padhiar
 
Paper Tube : Shigeru Ban projects and Case Study of Cardboard Cathedral .pdf
Paper Tube : Shigeru Ban projects and Case Study of Cardboard Cathedral .pdfPaper Tube : Shigeru Ban projects and Case Study of Cardboard Cathedral .pdf
Paper Tube : Shigeru Ban projects and Case Study of Cardboard Cathedral .pdfNainaShrivastava14
 
THE SENDAI FRAMEWORK FOR DISASTER RISK REDUCTION
THE SENDAI FRAMEWORK FOR DISASTER RISK REDUCTIONTHE SENDAI FRAMEWORK FOR DISASTER RISK REDUCTION
THE SENDAI FRAMEWORK FOR DISASTER RISK REDUCTIONjhunlian
 
Energy Awareness training ppt for manufacturing process.pptx
Energy Awareness training ppt for manufacturing process.pptxEnergy Awareness training ppt for manufacturing process.pptx
Energy Awareness training ppt for manufacturing process.pptxsiddharthjain2303
 
2022 AWS DNA Hackathon 장애 대응 솔루션 jarvis.
2022 AWS DNA Hackathon 장애 대응 솔루션 jarvis.2022 AWS DNA Hackathon 장애 대응 솔루션 jarvis.
2022 AWS DNA Hackathon 장애 대응 솔루션 jarvis.elesangwon
 
Main Memory Management in Operating System
Main Memory Management in Operating SystemMain Memory Management in Operating System
Main Memory Management in Operating SystemRashmi Bhat
 
Engineering Drawing section of solid
Engineering Drawing     section of solidEngineering Drawing     section of solid
Engineering Drawing section of solidnamansinghjarodiya
 
Turn leadership mistakes into a better future.pptx
Turn leadership mistakes into a better future.pptxTurn leadership mistakes into a better future.pptx
Turn leadership mistakes into a better future.pptxStephen Sitton
 
KCD Costa Rica 2024 - Nephio para parvulitos
KCD Costa Rica 2024 - Nephio para parvulitosKCD Costa Rica 2024 - Nephio para parvulitos
KCD Costa Rica 2024 - Nephio para parvulitosVictor Morales
 
Katarzyna Lipka-Sidor - BIM School Course
Katarzyna Lipka-Sidor - BIM School CourseKatarzyna Lipka-Sidor - BIM School Course
Katarzyna Lipka-Sidor - BIM School Coursebim.edu.pl
 

Recently uploaded (20)

US Department of Education FAFSA Week of Action
US Department of Education FAFSA Week of ActionUS Department of Education FAFSA Week of Action
US Department of Education FAFSA Week of Action
 
Ch10-Global Supply Chain - Cadena de Suministro.pdf
Ch10-Global Supply Chain - Cadena de Suministro.pdfCh10-Global Supply Chain - Cadena de Suministro.pdf
Ch10-Global Supply Chain - Cadena de Suministro.pdf
 
FUNCTIONAL AND NON FUNCTIONAL REQUIREMENT
FUNCTIONAL AND NON FUNCTIONAL REQUIREMENTFUNCTIONAL AND NON FUNCTIONAL REQUIREMENT
FUNCTIONAL AND NON FUNCTIONAL REQUIREMENT
 
High Voltage Engineering- OVER VOLTAGES IN ELECTRICAL POWER SYSTEMS
High Voltage Engineering- OVER VOLTAGES IN ELECTRICAL POWER SYSTEMSHigh Voltage Engineering- OVER VOLTAGES IN ELECTRICAL POWER SYSTEMS
High Voltage Engineering- OVER VOLTAGES IN ELECTRICAL POWER SYSTEMS
 
Input Output Management in Operating System
Input Output Management in Operating SystemInput Output Management in Operating System
Input Output Management in Operating System
 
ROBOETHICS-CCS345 ETHICS AND ARTIFICIAL INTELLIGENCE.ppt
ROBOETHICS-CCS345 ETHICS AND ARTIFICIAL INTELLIGENCE.pptROBOETHICS-CCS345 ETHICS AND ARTIFICIAL INTELLIGENCE.ppt
ROBOETHICS-CCS345 ETHICS AND ARTIFICIAL INTELLIGENCE.ppt
 
Comparative study of High-rise Building Using ETABS,SAP200 and SAFE., SAFE an...
Comparative study of High-rise Building Using ETABS,SAP200 and SAFE., SAFE an...Comparative study of High-rise Building Using ETABS,SAP200 and SAFE., SAFE an...
Comparative study of High-rise Building Using ETABS,SAP200 and SAFE., SAFE an...
 
OOP concepts -in-Python programming language
OOP concepts -in-Python programming languageOOP concepts -in-Python programming language
OOP concepts -in-Python programming language
 
Levelling - Rise and fall - Height of instrument method
Levelling - Rise and fall - Height of instrument methodLevelling - Rise and fall - Height of instrument method
Levelling - Rise and fall - Height of instrument method
 
Cost estimation approach: FP to COCOMO scenario based question
Cost estimation approach: FP to COCOMO scenario based questionCost estimation approach: FP to COCOMO scenario based question
Cost estimation approach: FP to COCOMO scenario based question
 
Paper Tube : Shigeru Ban projects and Case Study of Cardboard Cathedral .pdf
Paper Tube : Shigeru Ban projects and Case Study of Cardboard Cathedral .pdfPaper Tube : Shigeru Ban projects and Case Study of Cardboard Cathedral .pdf
Paper Tube : Shigeru Ban projects and Case Study of Cardboard Cathedral .pdf
 
THE SENDAI FRAMEWORK FOR DISASTER RISK REDUCTION
THE SENDAI FRAMEWORK FOR DISASTER RISK REDUCTIONTHE SENDAI FRAMEWORK FOR DISASTER RISK REDUCTION
THE SENDAI FRAMEWORK FOR DISASTER RISK REDUCTION
 
Energy Awareness training ppt for manufacturing process.pptx
Energy Awareness training ppt for manufacturing process.pptxEnergy Awareness training ppt for manufacturing process.pptx
Energy Awareness training ppt for manufacturing process.pptx
 
2022 AWS DNA Hackathon 장애 대응 솔루션 jarvis.
2022 AWS DNA Hackathon 장애 대응 솔루션 jarvis.2022 AWS DNA Hackathon 장애 대응 솔루션 jarvis.
2022 AWS DNA Hackathon 장애 대응 솔루션 jarvis.
 
Main Memory Management in Operating System
Main Memory Management in Operating SystemMain Memory Management in Operating System
Main Memory Management in Operating System
 
Engineering Drawing section of solid
Engineering Drawing     section of solidEngineering Drawing     section of solid
Engineering Drawing section of solid
 
Turn leadership mistakes into a better future.pptx
Turn leadership mistakes into a better future.pptxTurn leadership mistakes into a better future.pptx
Turn leadership mistakes into a better future.pptx
 
Designing pile caps according to ACI 318-19.pptx
Designing pile caps according to ACI 318-19.pptxDesigning pile caps according to ACI 318-19.pptx
Designing pile caps according to ACI 318-19.pptx
 
KCD Costa Rica 2024 - Nephio para parvulitos
KCD Costa Rica 2024 - Nephio para parvulitosKCD Costa Rica 2024 - Nephio para parvulitos
KCD Costa Rica 2024 - Nephio para parvulitos
 
Katarzyna Lipka-Sidor - BIM School Course
Katarzyna Lipka-Sidor - BIM School CourseKatarzyna Lipka-Sidor - BIM School Course
Katarzyna Lipka-Sidor - BIM School Course
 

PROCEDURES & MACROS GUIDE

  • 2. Procedures • While writing programs, sometimes it may be required to use same set of instructions repeatedly. • If these instructions are actually written again & again, the program size increases and occupies more memory space. • To avoid this, these instructions can be written as a separate program (subprogram) and whenever this set of instructions is required, an instruction can be written in the main program CALL this subprogram. • This saves the memory space. • A subprogram which is called from the main program to execute certain set of instructions is called subroutine or procedure.
  • 3. Procedures • Declaring PROCEDURES: • The syntax for procedure declaration: • name PROC [NEAR/FAR] ; Instructions of the procedures ; are written here. RET • name ENDP
  • 4. Procedures • Example: Delay PROC MOV CX,COUNT AGAIN: NOP LOOP AGAIN RET Delay ENDP
  • 5. Procedures • A procedure in 8086 can be accessed with a CALL & RET instruction. • CALL instruction: This performs two operations 1. Saves the return address or the address of the instruction next to the CALL instruction on the stack. Return address is the address where the program will return to after the procedure completes execution. – If the call to procedure is in the same code segment, i.e. a near CALL, then only the contents of IP are pushed on the stack. – If the call to procedure is in another code segment, i.e. a far CALL, then the contents of IP as well as CS are pushed on the stack. 2. It loads the IP & CS register with a new starting address of the procedure and then branches to the procedure.
  • 6. Procedures • RET instruction: • When 8086 executes a CALL instruction, it stores the return address of the CALLing routine on the stack. • A RET instruction at the end of the procedure copies the return address stored on the stack back into the CS and IP registers and then returns execution to the main program.
  • 7. Procedures • Passing Parameters to procedures: • Procedures may require input data or constants for their execution. • Their data or constants may be passed to the procedure by the main program or some procedures may access the readily available data of constants available in memory. • Generally following techniques are used to pass input data/parameter to procedures in assembly language programs, 1. Using global declared variable 2. Using registers of CPU architecture 3. Using memory locations 4. Using stack
  • 8. Example : Using registers CODE SEGMENT START: MOV AX, 5555H MOV BX,7272h : : CALL PROC1 : : PROC1 PROCEDURE : : ADD AX,BX : : RET PROC1 ENDP CODE ENDS END START
  • 9. Procedures • Re-entrant Procedures : • A procedure is said to be re-entrant, if it can be interrupted, used and re-entered without losing or writing over anything. To be a re- entrant, • Procedure must first push all the flags and registers used in the procedure. • It should also use only registers or stack to pass parameters. • The flow of re-entrant procedure for a multiply procedure when interrupt procedure is executed, as shown in the next slide
  • 11. Procedures • Recursive Procedures: • A recursive procedure is a procedure which calls itself. • Here, the program sets aside a few locations in stack for the storage of the parameters which are passed each time the computation is done and the value is returned. • Each value returned is then obtained by popping back from the stack at every RET instruction when executed at the end of the procedure.
  • 12. Program to find the factorial using recursiondata segment n db 04h res dw ? data ends code segment assume cs:code, ds:data start: mov ax,data mov ds,ax mov al,n mov ah,00h call fact int 3
  • 13. fact proc cmp ax,01 ;if n=1, fact=1 else fact=n*fact(n-1) jz exit push ax dec ax ;n-1 call fact ;fact(n-1) , RECURSION pop ax mul res ;n*fact(n-1) mov res,ax ;res=factorial ret exit: mov res,01 ret fact endp code ends end start
  • 14. Advantages of Procedures • Simple modular programming • Reduced workload and development time • Debugging of program and procedure is easier • Reduction in the size of the main program • Reuse of procedures in the same program many times or in another program.
  • 15. MACROS • Small sequences of codes of the same pattern repeated frequently at different places which perform the same operation on the different data of the same data type are called MACRO. • Macro is also called as an Open subroutine. • When Called, the code written within macro are executed automatically. • Macros should be used when it has few program statements. • This simplifies the programming process.
  • 16. MACROS Advantages • Simplify and reduce the amount of repetitive coding • Reduce errors caused by repetitive coding • Makes program more readable • Execution time is less as compared to procedures as no extra instructions required
  • 17. Procedure Vs Macros • Procedure does occupy minimum memory space than macro. • In macro machine code is generated for instructions each time when it is called but in procedure machine code for instruction is put only once in the memory • Procedure is accessed by call Instruction whereas Macro is accessed with the name given.
  • 18. MACROS Defining Macros The Directive MACRO indicates the beginning of a MACRO Name of the Macro followed by MACRO and arguments if any are specified. ENDM is always associated with MACRO which ends the macro. General Form : Macro_name MACRO [Arguement1, arguement2…] : : ENDM
  • 19. MACROS Example: PRINT MACRO MES MOV AX,09H LEA DX, MES INT 21H ENDM The above macro is used to display a string specified in the argument MES on the screen, when evoked by the main program as given in the next slide.
  • 20. MACROS DATA SEGEMENT STR DB 0DH,0AH,”Hello World$” DATA ENDS CODE SEGMENT ASSUME DS:DATA, CS:CODE START: MOV AX, DATA MOV DS, AX PRINT STR ; Calls Macro PRINT to display STR ; STR is the parameter passed which is ;taken as MES in the Macro PRINT. : : CODE ENDS END START