130 likes | 141 Views
This lecture discusses the concept of supporting procedures in computer hardware, including the execution steps, parameter placement, control transfer, storage resource acquisition, and task performance. It also covers MIPS register conventions and instructions for accessing procedures, as well as procedure register requirements and the process of compiling a C procedure.
E N D
Computer Architecture & Organization Instructions: Language of Computer Engr. Umbreen Sabir Computer Engineering Department, University of Engg. & Technology Taxila. CA&O Lecture 04 by Engr. Umbreen Sabir
Supporting Procedures in Computer Hardware • Procedure: A stored subroutine that performs a specific task based on the parameters with which it is provided. • Procedure execution step • Place Parameters. • Transfer control to the procedure. • Acquire storage resources • Perform desired task. • Place result value. • Return control back. CA&O Lecture 04 by Engr. Umbreen Sabir
Supporting Procedures in Computer Hardware cont. • MIPS register conventions for procedures: • $a0 - $a3: argument registers • $v0 - $v1: two registers to return values. • $ra – return address register • MIPS instruction for procedures is jump and link instruction (jal). • It jumps to an address and simultaneously saves the address of following instruction in return register $ra. CA&O Lecture 04 by Engr. Umbreen Sabir
Instructions for Accessing Procedures • MIPS procedure call instruction:jal ProcedureAddress #jump n link • Machine format (J format): • Then can do procedure return with a jr $ra #return • Instruction format (R format): op 26 bit address op rs funct CA&O Lecture 04 by Engr. Umbreen Sabir
Procedure Register Requirements • Compiler need more registers for a procedure. • Spill registers to memory. • Structure for spilling registers is stack: • Stack pointer is needed. • Push n Pop are required. • $sp is used to save the registers needed by the callee. • Stacks grows from higher addresses to lower addresses. • Push by subtracting from stack. • Pop by adding to stack pointer. CA&O Lecture 04 by Engr. Umbreen Sabir
Compiling a C Procedure • C procedure is: int leaf_example( int g, int h, iny I, int j) { int f; f = ( g + h) – (i + j); return f; } • The parameters g, h, I, j and f are in $a0, $a1, $a2, $a3 and $s0. • Start with label leaf_example CA&O Lecture 04 by Engr. Umbreen Sabir
MIPS code is: • Save three registers • Addi $sp, $sp, -12 • Sw $t1, 8( $sp) • Sw $t0 4( $sp) • Sw $s0, 0( $sp) • Procedure body • Add $t0, $a0, $a1 • Add $t1, $a2, $a3 • Sub $s0, $t0, $t1 CA&O Lecture 04 by Engr. Umbreen Sabir
Compiling if-then-else into Conditional Branches: • Return value • Add $v0, $s0, $zero • Restore registers • Lw $s0, 0( $sp) • Lw $t0, 4($sp) • Lw $t1, 8($sp) • Return • Jr $ra CA&O Lecture 04 by Engr. Umbreen Sabir
Nested Procedures • Procedure that do not call others are called leaf procedures. • Caller pushes ($a0- $a3) and ($t0 - $t7). • Callee pushes $ra and any saved registers ($s0 - $s7) used by callee. CA&O Lecture 04 by Engr. Umbreen Sabir
Allocating Space for New Data on the Stack • Stack is also used to store variables that are local to procedure and that do not fit in the registers e.g. local arrays or structures. • The segment of stack containing a procedures saved registers and local variables is called a procedure frame or activation record. • MIPS frame pointer $fp points to the first word of the frame of a procedure. • $sp may change during procedure execution but frame pointer is a stable base register within a procedure for local memory references. CA&O Lecture 04 by Engr. Umbreen Sabir
Allocating Space for New Data on the Heap • Space is needed for static variables and for dynamic data structures. • Stack starts in the high end and grows down. • First part of the low end of memory is reserved. • Next is the portion for MIPS machine code called the text segment. • Above it is static data segment, which is the place for constants and other static variables. • Linked lists tend to grow and shrink their lifetimes, segment for such data is called heap and is placed next in memory. CA&O Lecture 04 by Engr. Umbreen Sabir
Next Lecture and Reminders • Next lecture • MIPS ISA • Assignment Due – 19 Feb 2009 CA&O Lecture 04 by Engr. Umbreen Sabir
END OF LECTURE 4 CA&O Lecture 04 by Engr. Umbreen Sabir