Procedures and the Stack Chapter 5 S. Dandamudi. 2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,

Slides:



Advertisements
Similar presentations
INSTRUCTION SET ARCHITECTURES
Advertisements

Assembly Language for x86 Processors 6th Edition Chapter 5: Procedures (c) Pearson Education, All rights reserved. You may modify and copy this slide.
C Programming and Assembly Language Janakiraman V – NITK Surathkal 2 nd August 2014.
Procedures and Stacks. Outline Stack organization PUSH and POP instructions Defining and Calling procedures.
Assembly Language for Intel-Based Computers Chapter 8: Advanced Procedures Kip R. Irvine.
Assembly Language for Intel-Based Computers Chapter 5: Procedures Kip R. Irvine.
PC hardware and x86 3/3/08 Frans Kaashoek MIT
1 ICS 51 Introductory Computer Organization Fall 2006 updated: Oct. 2, 2006.
1 Lecture 5: Procedures Assembly Language for Intel-Based Computers, 4th edition Kip R. Irvine.
1 Function Calls Professor Jennifer Rexford COS 217 Reading: Chapter 4 of “Programming From the Ground Up” (available online from the course Web site)
Accessing parameters from the stack and calling functions.
Practical Session 3. The Stack The stack is an area in memory that its purpose is to provide a space for temporary storage of addresses and data items.
Chapter 12: High-Level Language Interface. Chapter Overview Introduction Inline Assembly Code C calls assembly procedures Assembly calls C procedures.
Run time vs. Compile time
1 Homework Reading –PAL, pp , Machine Projects –Finish mp2warmup Questions? –Start mp2 as soon as possible Labs –Continue labs with your.
Semantics of Calls and Returns
Assembly תרגול 8 פונקציות והתקפת buffer.. Procedures (Functions) A procedure call involves passing both data and control from one part of the code to.
CS2422 Assembly Language & System Programming October 24, 2006.
INVOKE Directive The INVOKE directive is a powerful replacement for Intel’s CALL instruction that lets you pass multiple arguments Syntax: INVOKE procedureName.
Web siteWeb site ExamplesExamples Irvine, Kip R. Assembly Language for Intel-Based Computers, Defining and Using Procedures Creating Procedures.
Web siteWeb site ExamplesExamples Irvine, Kip R. Assembly Language for Intel-Based Computers, Stack Operations Runtime Stack PUSH Operation POP.
Assembly Language Procedures and the Stack. Stack A stack is a last-in–first-out (LIFO) data structure. Insert and delete operations are referred to as.
High-Level Language Interface Chapter 17 S. Dandamudi.
Addressing Modes Chapter 11 S. Dandamudi To be used with S. Dandamudi, “Fundamentals of Computer Organization and Design,” Springer,  S.
Chapter 7: Runtime Environment –Run time memory organization. We need to use memory to store: –code –static data (global variables) –dynamic data objects.
CEG 320/520: Computer Organization and Assembly Language ProgrammingIntel Assembly 1 Intel IA-32 vs Motorola
Procedures and the Stack Chapter 10 S. Dandamudi.
Procedures and the Stack Chapter 5 S. Dandamudi To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,
Universal Concepts of Programming Creating and Initializing local variables on the stack Variable Scope and Lifetime Stack Parameters Stack Frames Passing.
6.828: PC hardware and x86 Frans Kaashoek
Dr. José M. Reyes Álamo 1.  The 80x86 memory addressing modes provide flexible access to memory, allowing you to easily access ◦ Variables ◦ Arrays ◦
Chapter 3 Elements of Assembly Language. 3.1 Assembly Language Statements.
Today’s topics Parameter passing on the system stack Parameter passing on the system stack Register indirect and base-indexed addressing modes Register.
Assembly Language for Intel-Based Computers, 6 th Edition Chapter 8: Advanced Procedures (c) Pearson Education, All rights reserved. You may.
The x86 Architecture Lecture 15 Fri, Mar 4, 2005.
Objective At the conclusion of this chapter you will be able to:
Today’s topics Procedures Procedures Passing values to/from procedures Passing values to/from procedures Saving registers Saving registers Documenting.
Assembly Language for x86 Processors 7th Edition Chapter 13: High-Level Language Interface (c) Pearson Education, All rights reserved. You may modify.
Sahar Mosleh California State University San MarcosPage 1 Stack operations, Applications and defining procedures.
CSC 221 Computer Organization and Assembly Language
Microprocessors The ia32 User Instruction Set Jan 31st, 2002.
Addressing Modes Chapter 6 S. Dandamudi To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,
Introduction to Assembly II Abed Asi Extended System Programming Laboratory (ESPL) CS BGU Fall 2013/2014.
Functions/Methods in Assembly
Compiler Construction Code Generation Activation Records
1 The Stack and Procedures Chapter 5. 2 A Process in Virtual Memory  This is how a process is placed into its virtual addressable space  The code is.
Assembly Language for Intel-Based Computers, 4 th Edition Chapter 5: Procedures Lecture 19: Procedures Procedure’s parameters (c) Pearson Education, 2002.
Introduction to Assembly II Abed Asi Extended System Programming Laboratory (ESPL) CS BGU Fall 2014/2015.
Introduction to Intel IA-32 and IA-64 Instruction Set Architectures.
1 Assembly Language: Function Calls Jennifer Rexford.
CSC 221 Computer Organization and Assembly Language Lecture 16: Procedures.
Assembly Language Data Movement Instructions. MOV Instruction Move source operand to destination mov destination, source The source and destination are.
CSC 221 Computer Organization and Assembly Language Lecture 15: STACK Related Instructions.
Preocedures A closer look at procedures. Outline Procedures Procedure call mechanism Passing parameters Local variable storage C-Style procedures Recursion.
Microprocessors CSE- 341 Dr. Jia Uddin Assistant Professor, CSE, BRAC University Dr. Jia Uddin, CSE, BRAC University.
Assembly Language Addressing Modes. Introduction CISC processors usually supports more addressing modes than RISC processors. –RISC processors use the.
Stack Operations Dr. Hadi AL Saadi.
Assembly language.
Chapter 4 Data Movement Instructions
Introduction to Compilers Tim Teitelbaum
CS 301 Fall 2002 Control Structures
Machine-Level Programming 4 Procedures
Stack Frames and Advanced Procedures
Introduction to Intel IA-32 and IA-64 Instruction Set Architectures
Assembly Language Programming II: C Compiler Calling Sequences
Practical Session 4.
Multi-modules programming
Where is all the knowledge we lost with information? T. S. Eliot
Computer Organization and Assembly Language
Presentation transcript:

Procedures and the Stack Chapter 5 S. Dandamudi

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 2 Outline What is stack? Pentium implementation of stack Stack instructions Uses of stack Procedures  Pentium instructions Parameter passing  Register method  Stack method Examples  Call-by-value  Call-by-reference  Bubble sort Procedures with variable number of parameters Local variables Multiple source program modules Performance: Procedure overheads

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 3 What is a Stack? Stack is a last-in-first-out (LIFO) data structure If we view the stack as a linear array of elements, both insertion and deletion operations are restricted to one end of the array Only the element at the top-of-stack (TOS) is directly accessible Two basic stack operations:  push (insertion)  pop (deletion)

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 4 What is a Stack? (cont’d) Example  Insertion of data items into the stack »Arrow points to the top-of-stack

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 5 What is a Stack? (cont’d) Example  Deletion of data items from the stack »Arrow points to the top-of-stack

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 6 Pentium Implementation of the Stack Stack segment is used to implement the stack  Registers SS and ESP are used  SS:ESP represents the top-of-stack Pentium stack implementation characteristics are:  Only words (i.e., 16-bit data) or doublewords (i.e., 32- bit data) are saved on the stack, never a single byte  Stack grows toward lower memory addresses (i.e., stack grows “downward”)  Top-of-stack (TOS) always points to the last data item placed on the stack

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 7 Pentium Stack Instructions Pentium provides two basic instructions: push source pop destination source and destination can be a  16- or 32-bit general register  a segment register  a word or doubleword in memory source of push can also be an immediate operand of size 8, 16, or 32 bits

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 8 Pentium Stack Example - 1

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 9 Pentium Stack Instructions: Examples On an empty stack, the following sequence of push instructions push 21ABH push 7FBD329AH results in the stack state shown in (c) in the last figure On this stack, executing pop EBX results in the stack state shown in (b) in the next figure and the register EBX gets the value 7FBD329AH

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 10 Pentium Stack Example - 2

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 11 Additional Pentium Stack Instructions Stack Operations on Flags push and pop instructions cannot be used with the Flags register Two special instructions for this purpose are pushfd (push 32-bit flags) popfd (pop 32-bit flags) No operands are required Use pushfw and popfw for 16-bit flags (FLAGS)

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 12 Additional Pentium Stack Instructions (cont’d) Stack Operations on All General-Purpose Registers pushad and popad instructions can be used to save and restore the eight general-purpose registers EAX, ECX, EDX, EBX, ESP, EBP, ESI, and EDI Pushad pushes these eight registers in the above order (EAX first and EDI last) popad restores these registers except that ESP value is not loaded into the ESP register Use pushaw and popaw for saving and restoring 16-bit registers

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 13 Uses of the Stack Three main uses »Temporary storage of data »Transfer of control »Parameter passing Temporary Storage of Data Example: Exchanging value1 and value2 can be done by using the stack to temporarily hold data push value1 push value2 pop value1 pop value2

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 14 Uses of the Stack (cont’d) Often used to free a set of registers ;save EAX & EBX registers on the stack push EAX push EBX ;EAX and EBX registers can now be used mov EAX,value1 mov EBX,value2 mov value1,EBX mov value2,EAX ;restore EAX & EBX registers from the stack pop EBX pop EAX...

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 15 Uses of the Stack (cont’d) Transfer of Control In procedure calls and interrupts, the return address is stored on the stack Our discussion on procedure calls clarifies this particular use of the stack Parameter Passing Stack is extensively used for parameter passing Our discussion later on parameter passing describes how the stack is used for this purpose

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 16 Procedures Two types  Call-by-value »Receives only values »Similar to mathematical functions  Call-by-reference »Receives pointers »Directly manipulates parameter storage

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 17 Pentium Instructions for Procedures Pentium provides two instructions: call and ret call instruction is used to invoke a procedure The format is call proc-name proc-name is the procedure name Actions taken during a near procedure call: ESP = ESP - 4 ; push return address SS:ESP = EIP ; onto the stack EIP = EIP + relative displacement ; update EIP to point to the procedure

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 18 Pentium Instructions for Procedures (cont’d) ret instruction is used to transfer control back to the calling procedure How will the processor know where to return?  Uses the return address pushed onto the stack as part of executing the call instruction  Important that TOS points to this return address when ret instruction is executed Actions taken during the execution of ret are: EIP = SS:ESP ; pop return address ESP = ESP + 4; from the stack

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 19 Pentium Instructions for Procedures (cont’d) We can specify an optional integer in the ret instruction  The format is ret optional-integer  Example: ret 8 Actions taken on ret with optional-integer are: EIP = SS:ESP ESP = ESP optional-integer

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 20 How Is Program Control Transferred? Offset(hex) machine code(hex) main: E call sum C3mov EBX,EAX.... ; end of main procedure sum: D55 push EBP.... ; end of sum procedure avg: E8F0FFFFFFcall sum D89D8mov EAX,EBX.... ; end of avg procedure

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 21 Parameter Passing Parameter passing is different and complicated than in a high-level language In assembly language »You should first place all required parameters in a mutually accessible storage area »Then call the procedure Type of storage area used »Registers (general-purpose registers are used) »Memory (stack is used) Two common methods of parameter passing: »Register method »Stack method

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 22 Parameter Passing: Register Method Calling procedure places the necessary parameters in the general-purpose registers before invoking the procedure through the call instruction Examples:  PROCEX1.ASM »call-by-value using the register method »a simple sum procedure  PROCEX2.ASM »call-by-reference using the register method »string length procedure

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 23 Pros and Cons of the Register Method Advantages  Convenient and easier  Faster Disadvantages  Only a few parameters can be passed using the register method –Only a small number of registers are available  Often these registers are not free –freeing them by pushing their values onto the stack negates the second advantage

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 24 Parameter Passing: Stack Method All parameter values are pushed onto the stack before calling the procedure Example: push number1 push number2 call sum

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 25 Accessing Parameters on the Stack Parameter values are buried inside the stack We can use the following to read number2 mov EBX,[ESP+4] Problem: The ESP value changes with push and pop operations »Relative offset depends of the stack operations performed »Not desirable Is there a better alternative?  Use EBP to access parameters on the stack

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 26 Using BP Register to Access Parameters Preferred method of accessing parameters on the stack is mov EBP,ESP mov EAX,[EBP+4] to access number2 in the previous example Problem: BP contents are lost!  We have to preserve the contents of BP  Use the stack (caution: offset value changes) push EBP mov EBP,ESP

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 27 Clearing the Stack Parameters Stack state after saving EBP Stack state after pop EBP Stack state after executing ret

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 28 Clearing the Stack Parameters (cont’d) Two ways of clearing the unwanted parameters on the stack:  Use the optional-integer in the ret instruction »Use ret 4 in the previous example  Add the constant to ESP in calling procedure (C uses this method) push number1 push number2 call sum add ESP,4

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 29 Housekeeping Issues Who should clean up the stack of unwanted parameters?  Calling procedure »Need to update ESP with every procedure call »Not really needed if procedures use fixed number of parameters »C uses this method because C allows variable number of parameters  Called procedure »Code becomes modular (parameter clearing is done in only one place) »Cannot be used with variable number of parameters

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 30 Housekeeping Issues (cont’d) Need to preserve the state (contents of the registers) of the calling procedure across a procedure call. »Stack is used for this purpose Which registers should be saved?  Save those registers that are used by the calling procedure but are modified by the called procedure »Might cause problems as the set of registers used by the calling and called procedures changes over time  Save all registers (brute force method) by using pusha »Increased overhead ( pusha takes 5 clocks as opposed 1 to save a register)

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 31 Housekeeping Issues (cont’d) Who should preserve the state of the calling procedure?  Calling procedure »Need to know the registers used by the called procedure »Need to include instructions to save and restore registers with every procedure call »Causes program maintenance problems  Called procedure »Preferred method as the code becomes modular (state preservation is done only once and in one place) »Avoids the program maintenance problems mentioned

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 32 Housekeeping Issues (cont’d) Need to preserve the state across a procedure call »Stack is used for this purpose Which registers should be saved?  Save those registers that are used by the calling procedure but are modified by the called procedure »Might cause problems  Save all registers (brute force method) »Done by using pusha »Increased overhead –pusha takes 5 clocks as opposed 1 to save a register

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 33 Housekeeping Issues (cont’d) Stack state after pusha

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 34 Stack Frame Instructions ENTER instruction  Facilitates stack frame (discussed later) allocation enter bytes,level bytes = local storage space level = nesting level (we use 0)  Example enter XX,0 Equivalent to push EBP mov EBP,ESP sub ESP,XX

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 35 Stack Frame Instructions (cont’d) LEAVE instruction  Releases stack frame leave »Takes no operands »Equivalent to mov ESP,EBP pop EBP

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 36 A Typical Procedure Template proc-name: enter XX, leave ret YY

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 37 Stack Parameter Passing: Examples PROCEX3.ASM  call-by-value using the stack method  a simple sum procedure PROCSWAP.ASM  call-by-reference using the stack method  first two characters of the input string are swapped BBLSORT.ASM  implements bubble sort algorithm  uses pusha and popa to save and restore registers

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 38 Variable Number of Parameters For most procedures, the number of parameters is fixed  Every time the procedure is called, the same number of parameter values are passed) In procedures that can have variable number of parameters  With each procedure call, the number of parameter values passed can be different »C supports procedures with variable number of parameters  Easy to support variable number of parameters using the stack method

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 39 Variable Number of Parameters (cont’d) To implement variable number of parameter passing:  Parameter count should be one of the parameters passed  This count should be the last parameter pushed onto the stack

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 40 Memory Layout of a Linux Process

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 41 Local Variables Local variables are dynamic in nature  Local variables of a procedure come into existence when the procedure is invoked and disappear when the procedure terminates. Cannot reserve space for these variable in the data segment for two reasons: »Such space allocation is static (remains active even when the procedure is not) »It does not work with recursive procedures For these reasons, space for local variables is reserved on the stack

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 42 Local Variables (cont’d) Example N and temp  Two local variables  Each requires two bytes of storage

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 43 Local Variables (cont’d) The information stored in the stack »parameters »returns address »old BP value »local variables is collectively called stack frame In high-level languages, stack frame is also referred to as the activation record »Because each procedure activation requires all this information The EBP value is referred to as the frame pointer »Once the EBP value is known, we can access all the data in the stack frame

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 44 Local Variables: Examples PROCFIB1.ASM  For simple procedures, registers can also be used for local variable storage  Uses registers for local variable storage  Outputs the largest Fibonacci number that is less than the given input number PROCFIB2.ASM  Uses the stack for local variable storage  Performance implications of using registers versus stack are discussed later

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 45 Multiple Module Programs In multi-module programs, a single program is split into multiple source files Advantages »If a module is modified, only that module needs to be reassembled (not the whole program) »Several programmers can share the work »Making modifications is easier with several short files »Unintended modifications can be avoided To facilitate separate assembly, two assembler directives are provided: »GLOBAL and EXTERN

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 46 GLOBAL Assembler Directive The GLOBAL directive makes the associated labels public »Makes these labels available for other modules of the program The format is global label1, label2,... Almost any label can be made public including »procedure names »variable names »equated labels  In the GLOBAL statement, it is not necessary to specify the type of label

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 47 Example: GLOBAL Assembler Directive global error_msg, total, sample......DATA error_msg db ‘Out of range!’,0 total dw CODE..... sample:..... ret

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 48 EXTRN Assembler Directive The EXTERN directive tells the assembler that certain labels are not defined in the current module  The assembler leaves “holes” in the object file for the linker to fill in later on The format is extern label1, label2,... where label1 and label2 are labels made public by a GLOBAL directive in some other module

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 49 EXTERN Assembler Directive (cont’d) Example module1.asm –main procedure module2.asm –string length procedure

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 50 Performance: Procedure Overheads Stack versus Registers No swap procedure (Program 5.5, lines 95-99) swap: mov [ESI+4],EAX mov [ESI],EBX mov EDX,UNSORTED SWAP procedure (replaces the above code) swap_proc: mov [ESI+4],EAX mov [ESI],EBX mov EDX,UNSORTED ret

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 51 Performance: Procedure Overheads (cont’d) With sort procedure Without sort procedure

2005 To be used with S. Dandamudi, “Introduction to Assembly Language Programming,” Second Edition, Springer,  S. Dandamudi Chapter 5: Page 52 Performance: Local Variable Overhead Local variables in stack Local variables in registers Last slide