Chapter 9 Procedures. Why use procedures? ? Microprocessors (and assembly languages) provide only minimal support for procedures Must build a standard.

Slides:



Advertisements
Similar presentations
The University of Adelaide, School of Computer Science
Advertisements

10/6: Lecture Topics Procedure call Calling conventions The stack
1 Lecture 4: Procedure Calls Today’s topics:  Procedure calls  Large constants  The compilation process Reminder: Assignment 1 is due on Thursday.
Procedures in more detail. CMPE12cGabriel Hugh Elkaim 2 Why use procedures? –Code reuse –More readable code –Less code Microprocessors (and assembly languages)
Procedure Calls Prof. Sirer CS 316 Cornell University.
Lecture 6: MIPS Instruction Set Today’s topic –Control instructions –Procedure call/return 1.
Computer Architecture CSCE 350
CPS3340 COMPUTER ARCHITECTURE Fall Semester, /17/2013 Lecture 12: Procedures Instructor: Ashraf Yaseen DEPARTMENT OF MATH & COMPUTER SCIENCE CENTRAL.
Ch. 8 Functions.
Procedures II (1) Fall 2005 Lecture 07: Procedure Calls (Part 2)
Apr. 12, 2000Systems Architecture I1 Systems Architecture I (CS ) Lecture 6: Branching and Procedures in MIPS* Jeremy R. Johnson Wed. Apr. 12, 2000.
The University of Adelaide, School of Computer Science
Procedure call frame: Hold values passed to a procedure as arguments
 Procedures (subroutines) allow the programmer to structure programs making them : › easier to understand and debug and › allowing code to be reused.
CSCI-365 Computer Organization Lecture Note: Some slides and/or pictures in the following are adapted from: Computer Organization and Design, Patterson.
Informationsteknologi Saturday, September 29, 2007 Computer Architecture I - Class 41 Today’s class More assembly language programming.
1 Storage Registers vs. memory Access to registers is much faster than access to memory Goal: store as much data as possible in registers Limitations/considerations:
Procedures in more detail. CMPE12cCyrus Bazeghi 2 Procedures Why use procedures? Reuse of code More readable Less code Microprocessors (and assembly languages)
CS 536 Spring Code generation I Lecture 20.
Intro to Computer Architecture
Run time vs. Compile time
28/06/2015CMPUT Functions (2)  Function calling convention  Various conventions available  One is specified by CMPUT229  Recursive functions.
COMPUTER ARCHITECTURE & OPERATIONS I Instructor: Hao Ji.
Lecture 7: MIPS Instruction Set Today’s topic –Procedure call/return –Large constants Reminders –Homework #2 posted, due 9/17/
Chapter 8 :: Subroutines and Control Abstraction
CS-2710 Dr. Mark L. Hornick 1 Defining and calling procedures (subroutines) in assembly And using the Stack.
Memory/Storage Architecture Lab Computer Architecture MIPS Instruction Set Architecture ( Supporting Procedures )
13/02/2009CA&O Lecture 04 by Engr. Umbreen Sabir Computer Architecture & Organization Instructions: Language of Computer Engr. Umbreen Sabir Computer Engineering.
Programming Language Principles Lecture 24 Prepared by Manuel E. Bermúdez, Ph.D. Associate Professor University of Florida Subroutines.
Functions and Procedures. Function or Procedure u A separate piece of code u Possibly separately compiled u Located at some address in the memory used.
MIPS function continued. Recursive functions So far, we have seen how to write – A simple function – A simple function that have to use the stack to save.
Copyright © 2005 Elsevier Chapter 8 :: Subroutines and Control Abstraction Programming Language Pragmatics Michael L. Scott.
Lecture 18: 11/5/2002CS170 Fall CS170 Computer Organization and Architecture I Ayman Abdel-Hamid Department of Computer Science Old Dominion University.
1 Control Abstraction (Section ) CSCI 431 Programming Languages Fall 2003 A compilation of material developed by Felix Hernandez-Campos and Michael.
Procedure Calls and the Stack (Lectures #18) ECE 445 – Computer Organization The slides included herein were taken from the materials accompanying Computer.
Procedures. Why use procedures? ? Microprocessors (and assembly languages) provide only minimal support for procedures Must build a standard form for.
Adapted from Computer Organization and Design, Patterson & Hennessy, UCB ECE232: Hardware Organization and Design Part 7: MIPS Instructions III
COP4020 Programming Languages Subroutines and Parameter Passing Prof. Xin Yuan.
Lecture 19: 11/7/2002CS170 Fall CS170 Computer Organization and Architecture I Ayman Abdel-Hamid Department of Computer Science Old Dominion University.
Procedure Basics Computer Organization I 1 October 2009 © McQuain, Feng & Ribbens Procedure Support From previous study of high-level languages,
Procedure (Method) Calls Ellen Spertus MCS 111 September 25, 2003.
Lecture 4: MIPS Instruction Set
MAL 3 - Procedures Lecture 13. MAL procedure call The use of procedures facilitates modular programming. Four steps to transfer to and return from a procedure:
Computer Architecture CSE 3322 Lecture 4 Assignment: 2.4.1, 2.4.4, 2.6.1, , Due 2/10/09
© G. Drew Kessler and William M. Pottenger1 Subroutines, Part 2 CSE 262, Spring 2003.
1 CS/COE0447 Computer Organization & Assembly Language Chapter 2 Part 3.
Function Calling. Mips Assembly Call and Return Steps for procedure calling –Save the return address –Jump to the procedure (function) –Execute the procedure.
DR. SIMING LIU SPRING 2016 COMPUTER SCIENCE AND ENGINEERING UNIVERSITY OF NEVADA, RENO Session 12 Procedure Calling.
LECTURE 19 Subroutines and Parameter Passing. ABSTRACTION Recall: Abstraction is the process by which we can hide larger or more complex code fragments.
Computer Architecture & Operations I
Computer Science 210 Computer Organization
Computer structure: Procedure Calls
© Craig Zilles (adapted from slides by Howard Huang)
CSCI206 - Computer Organization & Programming
Procedures (Functions)
Procedures (Functions)
Functions and Procedures
CSCI206 - Computer Organization & Programming
MIPS Instructions.
The University of Adelaide, School of Computer Science
Topic 3-a Calling Convention 1/10/2019.
10/4: Lecture Topics Overflow and underflow Logical operations
Program and memory layout
Program and memory layout
Computer Architecture
Program and memory layout
Where is all the knowledge we lost with information? T. S. Eliot
Program and memory layout
© Craig Zilles (adapted from slides by Howard Huang)
Presentation transcript:

Chapter 9 Procedures

Why use procedures? ? Microprocessors (and assembly languages) provide only minimal support for procedures Must build a standard form for procedures

Procedures Procedure call {.. x = larger (a, b);. } Procedure header and parameters int larger (int one, int two) Procedure body { if (one > two) larger = one; else larger = two; }

Procedures Steps in the execution of the procedure: 1.Save return address 2.Procedure call 3.Execute procedure 4.Return What is the return address? What is the procedure call? What is the return? MAL uses registers rather than variables for return address

Procedures Modern load/store machines (MAL, MIPS, SPARC,…) have a jump and link instruction for procedure calls jal procname Place the address of the instruction following it into the register $ra ($31) $31 is an arbitrary (and common) choice made at architecture time. Why isn’t $31 specified in the instruction as: jal $31, procname #NOT VALID CODE Branches (jumps) to the address given by the label (procname).

Procedures The example becomes: jal proc1 # use of $ra is implied. jal proc1. proc1:# 1 st instruction of procedure here. jr $ra# $ra is the alias for $31

Nested Procedures What happens if a procedure calls another procedure (nesting) using jal? jal proc1. jal proc1. proc1:. jal proc2. jr $ra proc2:.. jr $ra

Nested Procedures Even more exciting, what happens if a procedure calls itself (recursion)? jal proc1. jal proc1. Proc1:.. jal proc1. jr $ra

Nested Procedures Must save return address as generated Unknown how many to save Needed in reverse order of saved Use a …

System Stack A stack is so frequently used for procedure call/return, that many computer systems predefine a system stack. The system stack is for dynamic data (vs static, known before runtime) Return addresses Saving registers to move other data into register bank (“spilling”) Local variables – several instances may be defined at once with multiple calls ?? The system stack is very large In a multi-user environment, how many system stacks are there?

System Stack The MIPS system stack (as with most machines) is defined to grow toward smaller addresses The stack pointer points to an empty location at the top of the stack The stack pointer is register #29, also called $sp It is defined before program execution begins If $sp ($29) is used for any other purpose, then the stack pointer is lost. This would be bad, very bad. address 0 your program here very large addresses system stack here Grows towards smaller addresses

System Stack push, in MAL: sw$?, ($sp)# the $? Is replaced by some register sub$sp, $sp, 4# contains the data to be pushed Or sub$sp, $sp, 4 sw$?, 4($sp) pop, in MAL: Or Which forms are better if there is an interrupt that uses the same stack?

System Stack Often a procedure pushes/pops many things. add$sp, $sp, -4 sw$8, 4($sp) add$sp, $sp, -4 sw$9, 4($sp) add$sp,$sp, -4 sw$10, 4($sp) But we do not need to change $sp each time. add$sp, $sp, -12 sw$8, 12($sp) sw$9, 8($sp) sw$10,4($sp) And with pop as well (do the add first or last?)

System Stack: Saving Return Addresses jaldoit. jaldoit. doit:sub $sp, $sp, 4#push return address sw $ra, 4($sp). jal another#this would overwrite the return.#address if it had not been saved. lw$ra, 4($sp)#pop return address add$sp, $sp, 4 jr$ra Note how every pop has a push. Never leave a procedure without popping everything that was pushed. Always match up your pushes and pops.

Stack Frames The compiler will put many things on the stack for each procedure call ? The combination of all these (different for each call) is called a stack frame or activation record (AR). Space for a stack frame is made each time a procedure is called. The space is removed each time a return occurs. These stack frames are pushed/popped dynamically.

Stack Frame What happens to the stack when: Example: jalA jalB. A:jalC jalD jr$ra B:jalD jr$ra C:jalE jr$ra D:jr$ra E:jr$ra

Stack Frames A:sub$sp, $sp, 20# allocate frame for A sw$ra, 16($sp)# save A’s return address jalC jalD lw$ra,16($sp)# restore A’s return address add$sp,$sp,20#remove A’s frame from stack jr$ra# return from A The allocation and removal of a frame is done within the body of the procedure. The compiler does not need to know the size of a procedure’s frame. Accesses to A’s frame are done via offsets from stack pointer.

Parameter Passing Parameter = Argument There is even less architectural support for parameter passing Create a convention Follow the convention Follow the convention carefully Follow the convention consistently Never change the convention once defined Place data in a specific parameter location Both the calling program and the procedure need to know where the parameters are. Procedure may place return values there.

Parameter Passing Call by value (C, C++) The parameter passed may not be modified by the procedure. This can be implemented by passing a copy of the value. The procedure can modify the value (copy) passed to it, but the value is not changed outside the scope of the procedure. Call by reference (Fortran, C++ &, Pascal var) The parameter passed to the subroutine can be modified. The modification is seen outside the scope of the subroutine. Similar to having access to global variable. Ways of implementing these 2 variable types? ?

Parameter Passing Simplest mechanism – registers The calling program puts the parameter(s) into specific registers, and the procedure uses them.. move$s4, $s2# put parameter in register 4 jaldecrement move$s2, $s4# recopy parameter to its correct place. decrement: add$s4, $s4, -1 jr$ra This is a trivial example Why not just use $s2 within the procedure?

Parameters on Stack When there aren’t enough registers for all parameters, use the activation record (AR). Used for all parameters in machines with few registers. eg. Hc11, 6502, 8086, … sub$sp, $sp, 8# allocate space for parameters sw$9, 8($sp)# place parameter 1 into AR of proc sw$18, 4($sp)# place parameter 2 into AR of proc jalproc. proc: sub$sp, $sp, 12# allocate remainder of AR for proc # assume fixed size (too big) activation record lw$10, 20($sp)# retrieve parameter 1 lw$11, 16($sp)# retrieve parameter 2 # use parameters in procedure calculations add$sp, $sp, 20# remove AR of proc jr$ra

Parameters on a stack Calling program Allocate space for parameters Places parameters into stack Calls procedure Procedure: Allocates AR (or remainder of AR) De-allocates AR of procedure (or at least most of it) MIPS convention The first 4 parameters are passed in register The alias for $4-$7 is $a0-$a3. The first parameter is passed in $a0. Space for all parameters passed in $a0-$a3 is allocated in the procedure’s AR.

MIPS Convention If there are nested subroutine calls, and registers $a0-$a3 are used for parameters, the values would be lost procA:#receives 3 parameters in $a0, $a1, $a2 # set up procB’s parameters move $a0, $24# overwrites procA’s parameter in $a0 move $a1, $9# overwrites procA’s parameter in $a1 jal procB# the nested procedure call # procA continues after procB returns # procA’s parameters are needed, but have been overwritten Solutions…

MIPS Convention Caller Place parameters in $a0 to $a3 jal procedure Procedure Allocate remainder of AR and push $ra Procedure calculations To call proc2 Place current parameters (from $a0-$a3) into AR Set up parameters to proc2 in $a0-$a3 Call proc2 (jal proc2) Copy any return values out of $v0-v1, $a0-$a3 Restore current parameters from AR back to $a0-$a3 More procedure calculations Get procedure’s return address from AR De-allocate AR Return (jr $ra)

MIPS Convention # a set of procedures that do the following: # if a<b, then switch a with b and decrement both # a is in register 20 # b is in register 21.text sub$8, $20, $21 bgtz$8, othercode move$a0, $20# place parameters in a registers move$a1, $21 jals_and_d move$20, $a0# copy the return values move$21, $a1 othercode: done

MIPS Convention # s_and_d: swap its 2 parameters, and then both decrement both #$a0 ($4) – first parameter #$a1 ($5) – second parameter #$8 – temporary for switching s_and_d: sub$sp, $sp, 20# allocate frame for switch sw$ra, 20($sp)# save return address on stack move$t0, $a0# switch the 2 parameters move$a0, $a1# $t0 is alias for $8 move$a1, $t0 sw $a0, 16($sp)# save current parameters sw$a1, 12($sp) jaldecrement# the parameter to decrement is already # in $a0 lw$a0, 12($sp)# set up parameter in $a0 jaldecrement move$a1, $a0# copy return value lw$a0, 16($sp)# restore current parameter lw$ra, 20($sp)# get return address jr$ra # procedure decrement: subtracts 1 from parameter $a0 decrement: addi$a0, $a0, -1 jr$ra

Summary: Parameter Passing Styles 1.Use registers Advantages Disadvantages 2.Use some registers, and place the rest on the stack Advantages Disadvantages 3.Put all parameters on the stack (an unsophisticated compiler might do this) Advantages Disadvantages 4.Put parameters in memory set aside for them Advantages Disadvantages

Frame Pointers During a procedure call, the stack can grow and shrink Why? Example: At one point parameter 2 might be at 16($sp) At another point within the same procedure, parameter 2 might be at 24($sp) param2 $sp procedure’s frame base of frame temp2 temp1 param2 $sp procedure’s frame base of frame

Frame Pointers temp2 temp1 param2 $sp procedure’s frame frame pointer A Frame Pointer points to the base of the AR Parameter, etc. locations are constant wrt the frame Parameter 2 will be at…

Frame Pointers A new register is needed for the FP The FP must be initialized at the start and restored at the end of every procedure By the compiler or assembly-code writer On the MIPS, all data with a stack frame is accessed via the stack pointer, $sp. Why?

Frame Pointers # the frame (AR) is 4 words: 2 words for 2 parameters # passed in $a0 and $a1, 1 for ra, and 1 for FP proc:sub$sp, $sp, 8# allocate remainder of frame # assumes that caller allocates space # for the 2 parameters sw$ra, 8($sp)#save procedure’s return address sw$16, 4($sp)# save caller’s frame pointer add$16, $sp, 16# set procedure’s frame pointer ## procedure’s code in here lw$ra, -8($16)#restore return address move$8, $16# save frame pointer temporarily lw$16, -12($16)# restore callers frame pointer move$sp, $8# remove procedure’s frame (AR) jr$ra frame pointer return address space for P2 space for P1 $sp $16 (frame pointer)

Register Spilling On calling a procedure, many registers may be in use What should be done? Two solutions Callee saved A procedure clears out some registers for its own use Register values are preserved across procedure calls MIPS calls these saved registers: $s0-$s8 (aliases for $16-$23, $30) The called procedure Saves register values in its AR, Uses the register for local variables, Restores register values before it returns.

Register Spilling Caller Saved The calling program saves the registers that it does not want a called procedure to overwrite Register values are NOT preserved across procedure calls MIPS calls these temporary registers: $t0-$t9 (aliases for $8-$15, $24-$25) Procedures use there registers for local variables The values do not need to be preserved outside the scope of the procedure. How about $v0-$v1, and $a0-$a3?

Procedure Calls From the compiler’s point of view, a procedure call looks like: call setup procedure call return cleanup. procedure: prologue calculations epilogue

Procedure Calls The full convention includes Call Setup Save any callee-save registers that are currently in use Place current parameters into current stack frame Allocate space for all parameters for procedure to be called Change $sp by the total parameter size Place first 4 parameters to procedure into $a0-$a3 Place remaining parameters on stack Procedure Call JAL

Procedure Calls Prologue Allocate space for remainder of stack frame Save return address in stack frame Copy needed parameters from stack frame into registers Save any needed saved registers into current stack frame Epilogue Restore (copy) return address from stack frame into $ra Restore any saved registers De-allocate stack frame (or most of it) Move $sp so the space for the procedure’s frame is gone Return Cleanup Copy needed return values and parameters from $v0-$v1, $a0-$a3, or stack frame to correct places De-allocate remainder of procedure’s stack frame Move $sp so the space for the procedure’s frame is gone Restore any saved registers from call setup

Summary: Procedure Calls Minimal ASM support Need formal and consistent mechanism Why? Activation record includes ? Caller must… Callee must…