IA32 Stack. Stack BoDom. Region of memory managed with stack discipline Grows toward lower addresses. Register %esp contains lowest stack address

Similar documents
Machine- Level Programming III: Switch Statements and IA32 Procedures

Sungkyunkwan University

CS213. Machine-Level Programming III: Procedures

Machine- Level Programming III: Switch Statements and IA32 Procedures

The course that gives CMU its Zip! Machine-Level Programming III: Procedures Sept. 17, 2002

ASSEMBLY III: PROCEDURES. Jo, Heeseung

Assembly III: Procedures. Jo, Heeseung

Assembly III: Procedures. Jin-Soo Kim Computer Systems Laboratory Sungkyunkwan University

Machine-level Programming (3)

Region of memory managed with stack discipline Grows toward lower addresses. Register %esp contains lowest stack address = address of top element

Machine-Level Programming III: Procedures

Systems I. Machine-Level Programming V: Procedures

X86 Assembly -Procedure II:1

Stack Discipline Jan. 19, 2018

An Experience Like No Other. Stack Discipline Aug. 30, 2006

University of Washington

Machine-Level Programming III: Procedures

Machine Programming 3: Procedures

Machine-level Programs Procedure

Bryant and O Hallaron, Computer Systems: A Programmer s Perspective, Third Edition. Carnegie Mellon

IA32 Stack. Lecture 5 Machine-Level Programming III: Procedures. IA32 Stack Popping. IA32 Stack Pushing. Topics. Pushing. Popping

IA32 Stack The course that gives CMU its Zip! Machine-Level Programming III: Procedures Sept. 17, IA32 Stack Popping. IA32 Stack Pushing

Giving credit where credit is due

hnp://

CS429: Computer Organization and Architecture

Assembly I: Basic Operations. Jo, Heeseung

ASSEMBLY I: BASIC OPERATIONS. Jo, Heeseung

Procedure Calls. Young W. Lim Sat. Young W. Lim Procedure Calls Sat 1 / 27

Turning C into Object Code Code in files p1.c p2.c Compile with command: gcc -O p1.c p2.c -o p Use optimizations (-O) Put resulting binary in file p

Assembly I: Basic Operations. Computer Systems Laboratory Sungkyunkwan University

Assembly Language: Function Calls

CS241 Computer Organization Spring 2015 IA

Machine- Level Representa2on: Procedure

Assembly Language: Function Calls" Goals of this Lecture"

Mechanisms in Procedures. CS429: Computer Organization and Architecture. x86-64 Stack. x86-64 Stack Pushing

Assembly Language: Function Calls" Goals of this Lecture"

Assembly Language: Function Calls. Goals of this Lecture. Function Call Problems

Procedures and the Call Stack

Procedure Calls. Young W. Lim Mon. Young W. Lim Procedure Calls Mon 1 / 29

Function Calls COS 217. Reading: Chapter 4 of Programming From the Ground Up (available online from the course Web site)

Page 1. IA32 Stack CISC 360. Machine-Level Programming III: Procedures Sept. 22, IA32 Stack Popping Stack Bottom. IA32 Stack Pushing

Machine- Level Programming II: Control Structures and Procedures

Machine- Level Programming II: Control Structures and Procedures

1 /* file cpuid2.s */ 4.asciz "The processor Vendor ID is %s \n" 5.section.bss. 6.lcomm buffer, section.text. 8.globl _start.

CS241 Computer Organization Spring Addresses & Pointers

CS 31: Intro to Systems Functions and the Stack. Martin Gagne Swarthmore College February 23, 2016

Assembly Programmer s View Lecture 4A Machine-Level Programming I: Introduction

Machine Program: Procedure. Zhaoguo Wang

Process Layout and Function Calls

CISC 360. Machine-Level Programming I: Introduction Sept. 18, 2008

Assembly III: Procedures. Jin-Soo Kim Computer Systems Laboratory Sungkyunkwan University

Instructor: Alvin R. Lebeck

CMSC 313 Lecture 12. Project 3 Questions. How C functions pass parameters. UMBC, CMSC313, Richard Chang

Machine-Level Programming II: Control and Arithmetic

Machine-Level Programming I: Introduction Jan. 30, 2001

Machine Programming 1: Introduction

CSC 2400: Computing Systems. X86 Assembly: Function Calls"

This is a medical robot, guided by a skilled surgeon and designed to get to places doctors are unable to reach without opening a pacent up.

University*of*Washington*

x86 assembly CS449 Fall 2017

211: Computer Architecture Summer 2016

X86 Stack Calling Function POV

Machine-Level Programming II: Arithmetic & Control /18-243: Introduction to Computer Systems 6th Lecture, 5 June 2012

Question 4.2 2: (Solution, p 5) Suppose that the HYMN CPU begins with the following in memory. addr data (translation) LOAD 11110

Data Representa/ons: IA32 + x86-64

CPSC W Term 2 Problem Set #3 - Solution

Page # CISC 360. Machine-Level Programming I: Introduction Sept. 18, IA32 Processors. X86 Evolution: Programmerʼs View.

Instruction Set Architecture

Instruction Set Architecture

The course that gives CMU its Zip! Machine-Level Programming I: Introduction Sept. 10, 2002

CMSC 313 Lecture 12 [draft] How C functions pass parameters

Machine-Level Programming Introduction

Meet & Greet! Come hang out with your TAs and Fellow Students (& eat free insomnia cookies) When : TODAY!! 5-6 pm Where : 3rd Floor Atrium, CIT

Sungkyunkwan University

Ge-ng at things on the chip you can t easily reach from C

The Hardware/Software Interface CSE351 Spring 2015

CIT Week13 Lecture

administrivia today start assembly probably won t finish all these slides Assignment 4 due tomorrow any questions?

Credits to Randy Bryant & Dave O Hallaron

CSE 351: Week 4. Tom Bergan, TA

You may work with a partner on this quiz; both of you must submit your answers.

Instruction Set Architecture

CMSC 313 Fall2009 Midterm Exam 2 Section 01 Nov 11, 2009

Y86 Processor State. Instruction Example. Encoding Registers. Lecture 7A. Computer Architecture I Instruction Set Architecture Assembly Language View

Instruction Set Architecture

CISC 360 Instruction Set Architecture

CS 33: Week 3 Discussion. x86 Assembly (v1.0) Section 1G

Machine-Level Programming II: Arithmetic & Control. Complete Memory Addressing Modes

X86 Assembly -Data II:1

Machine- level Programming

Process Layout, Function Calls, and the Heap

Machine Level Programming II: Arithmetic &Control

Stack -- Memory which holds register contents. Will keep the EIP of the next address after the call

CS429: Computer Organization and Architecture

Machine-Level Programming (2)

MACHINE-LEVEL PROGRAMMING I: BASICS COMPUTER ARCHITECTURE AND ORGANIZATION

! Starting in 1978 with ! Added more features as time goes on. ! Still support old features, although obsolete

Sungkyunkwan University

Machine-Level Programming Introduction

Implementing Threads. Operating Systems In Depth II 1 Copyright 2018 Thomas W. Doeppner. All rights reserved.

Transcription:

IA32 Procedures 1

IA32 Stack Region of memory managed with stack discipline Grows toward lower addresses Stack BoDom Increasing Addresses Register contains lowest stack address address of top element Stack Pointer: Stack Grows Down Stack Top 2

IA32 Stack: Push pushl Src Fetch operand at Src Decrement by 4 Write operand at address given by Stack BoDom Increasing Addresses Stack Pointer: -4 Stack Grows Down Stack Top 3

IA32 Stack: Pop Stack BoDom Increasing Addresses Stack Pointer: +4 Stack Grows Down Stack Top 4

Procedure Control Flow Use stack to support procedure call and return Procedure call: call label Push return address on stack Jump to label Return address: Address of the next instrucbon right acer call Example from disassembly 804854e: e8 3d 06 00 00 call 8048b90 <main> 8048553: 50 pushl %eax Return address = 0x8048553 Procedure return: ret Pop address from stack Jump to address 5

Procedure Call Example 804854e: e8 3d 06 00 00 call 8048b90 <main> 8048553: 50 pushl %eax call 8048b90 0x110 0x110 0x10c 0x10c 0x108 123 0x108 123 0x104 0x8048553 0x108 0x104 %eip 0x804854e %eip 0x8048b90 %eip: program counter 6

Procedure Return Example 8048591: c3 ret ret 0x110 0x110 0x10c 0x10c 0x108 123 0x108 123 0x104 0x8048553 0x8048553 0x104 0x108 %eip 0x8048591 %eip 0x8048553 %eip: program counter 7

Stack-Based Languages Languages that support recursion e.g., C, Pascal, Java Code must be Reentrant MulBple simultaneous instanbabons of single procedure Need some place to store state of each instanbabon Arguments Local variables Return pointer Stack discipline State for given procedure needed for limited Bme From when called to when return Callee returns before caller does Stack allocated in Frames state for single procedure instanbabon 8

Call Chain Example yoo( ) { who(); who( ) { (); (); ( ) { (); Example Call Chain yoo who Procedure () is recursive 9

Stack Frames Contents Local variables Return informabon Temporary space Management Space allocated when enter procedure Set-up code Deallocated when return Finish code Frame Pointer: Stack Pointer: Previous Frame Frame for proc Stack Top 10

Example Stack yoo( ) { who(); yoo who yoo yoo 11

Example Stack yoo( ) { who( ) { who(); (); (); yoo who yoo yoo who 12

Example Stack yoo( ) { who( ) { ( ) who(); (); { (); (); yoo who yoo yoo who 13

Example Stack yoo( ) { who( ) { ( ) who(); (); { ( ) (); { (); (); yoo who yoo yoo who 14

Example Stack yoo( ) { who( ) { ( ) who(); (); { ( ) (); { (); ( ) { (); (); yoo who yoo yoo who 15

Example Stack yoo( ) { who( ) { ( ) who(); (); { ( ) (); { (); (); yoo who yoo yoo who 16

Example Stack yoo( ) { who( ) { ( ) who(); (); { (); (); yoo who yoo yoo who 17

Example Stack yoo( ) { who( ) { who(); (); (); yoo who yoo yoo who 18

Example Stack yoo( ) { who( ) { ( ) who(); (); { (); (); yoo who yoo yoo who 19

Example Stack yoo( ) { who( ) { who(); (); (); yoo who yoo yoo who 20

Example Stack yoo( ) { who(); yoo who yoo yoo 21

IA32/Linux Stack Frame Current Stack Frame ( Top to BoDom) Argument build: Parameters for funcbon about to call Local variables If can t keep in registers Saved register context Old frame pointer Caller Stack Frame Return address Pushed by call instrucbon Arguments for this call Frame pointer Stack pointer Caller Frame Arguments Return Addr Old Saved Registers + Local Variables Argument Build 22

RevisiWng swap int course1 = 15213; int course2 = 18243; void call_swap() { swap(&course1, &course2); Calling swap from call_swap call_swap: subl $8, movl $course2, 4() movl $course1, () call swap void swap(int *xp, int *yp) { int t0 = *xp; int t1 = *yp; *xp = t1; *yp = t0; &course 2 &course 1 Rtn adr ResulWng Stack subl call 23

RevisiWng swap void swap(int *xp, int *yp) { int t0 = *xp; int t1 = *yp; *xp = t1; *yp = t0; swap: pushl movl, pushl %ebx movl 8(), %edx movl 12(), %ecx movl (%edx), %ebx movl (%ecx), %eax movl %eax, (%edx) movl %ebx, (%ecx) popl %ebx popl ret Set Up Body Finish 24

swap Setup #1 Entering Stack ResulWng Stack &course2 yp &course1 xp Rtn adr Rtn adr Old swap: pushl movl, pushl %ebx 25

swap Setup #2 Entering Stack ResulWng Stack &course2 yp &course1 xp Rtn adr Rtn adr Old swap: pushl movl, pushl %ebx 26

swap Setup #3 Entering Stack ResulWng Stack &course2 &course1 Rtn adr yp xp Rtn adr swap: pushl movl, pushl %ebx Old Old %ebx 27

swap Body Entering Stack ResulWng Stack Offset relawve to &course2 &course1 Rtn adr 12 8 4 yp xp Rtn adr Old Old %ebx movl 8(),%edx # get xp movl 12(),%ecx # get yp... 28

swap Finish Stack Before Finish popl %ebx popl ResulWng Stack yp xp Rtn adr Old Old %ebx yp xp Rtn adr Observation Saved and restored register %ebx Not so for %eax, %ecx, %edx 29

Disassembled swap 08048384 <swap>: 8048384: 55 push 8048385: 89 e5 mov, 8048387: 53 push %ebx 8048388: 8b 55 08 mov 0x8(),%edx 804838b: 8b 4d 0c mov 0xc(),%ecx 804838e: 8b 1a mov (%edx),%ebx 8048390: 8b 01 mov (%ecx),%eax 8048392: 89 02 mov %eax,(%edx) 8048394: 89 19 mov %ebx,(%ecx) 8048396: 5b pop %ebx 8048397: 5d pop 8048398: c3 ret Calling Code 80483b4: movl $0x8049658,0x4() # Copy &course2 80483bc: movl $0x8049654,() # Copy &course1 80483c3: call 8048384 <swap> # Call swap 80483c8: leave # Prepare to return 80483c9: ret # Return 30

Today Switch statements IA 32 Procedures Stack Structure Calling ConvenBons IllustraBons of Recursion & Pointers 31

Register Saving ConvenWons When procedure yoo calls who: yoo is the caller who is the callee Can register be used for temporary storage? yoo: movl $15213, %edx call who addl %edx, %eax ret who: movl 8(), %edx addl $18243, %edx ret Contents of register %edx overwriuen by who This could be trouble something should be done! Need some coordinabon 32

Register Saving ConvenWons When procedure yoo calls who: yoo is the caller who is the callee Can register be used for temporary storage? ConvenWons Caller Save Caller saves temporary values in its frame before the call Callee Save Callee saves temporary values in its frame before using 33

IA32/Linux+Windows Register Usage %eax, %edx, %ecx Caller saves prior to call if values are used later %eax also used to return integer value %ebx, %esi, %edi Callee saves if wants to use them, special form of callee save Restored to original values upon exit from procedure Caller-Save Temporaries Callee-Save Temporaries Special %eax %edx %ecx %ebx %esi %edi 34

Today Switch statements IA 32 Procedures Stack Structure Calling ConvenBons IllustraBons of Recursion & Pointers 35

Recursive FuncWon /* Recursive popcount */ int pcount_r(unsigned x) { if (x == 0) return 0; else return (x & 1) + pcount_r(x >> 1); Registers %eax, %edx used without first saving %ebx used, but saved at beginning & restored at end pcount_r: pushl movl, pushl %ebx subl $4, movl 8(), %ebx movl $0, %eax testl %ebx, %ebx je.l3 movl %ebx, %eax shrl %eax movl %eax, () call pcount_r movl %ebx, %edx andl $1, %edx leal (%edx,%eax), %eax.l3: addl $4, popl %ebx popl ret 36

Recursive Call #1 /* Recursive popcount */ int pcount_r(unsigned x) { if (x == 0) return 0; else return (x & 1) + pcount_r(x >> 1); AcWons Save old value of %ebx on stack Allocate space for argument to recursive call Store x in %ebx %ebx x pcount_r: pushl movl, pushl %ebx subl $4, movl 8(), %ebx x Rtn adr Old Old %ebx 37

Recursive Call #2 /* Recursive popcount */ int pcount_r(unsigned x) { if (x == 0) return 0; else return (x & 1) + pcount_r(x >> 1); movl $0, %eax testl %ebx, %ebx je.l3.l3: ret AcWons If x == 0, return with %eax set to 0 %ebx x 38

Recursive Call #3 /* Recursive popcount */ int pcount_r(unsigned x) { if (x == 0) return 0; else return (x & 1) + pcount_r(x >> 1); movl %ebx, %eax shrl %eax movl %eax, () call pcount_r AcWons Store x >> 1 on stack Make recursive call Effect %eax set to function result %ebx still has value of x %ebx x Rtn adr Old Old %ebx x >> 1 39

Recursive Call #4 /* Recursive popcount */ int pcount_r(unsigned x) { if (x == 0) return 0; else return (x & 1) + pcount_r(x >> 1); movl %ebx, %edx andl $1, %edx leal (%edx,%eax), %eax Assume %eax holds value from recursive call %ebx holds x AcWons Compute (x & 1) + computed value Effect %eax set to function result %ebx x 40

Recursive Call #5 /* Recursive popcount */ int pcount_r(unsigned x) { if (x == 0) return 0; else return (x & 1) + pcount_r(x >> 1); L3: addl$4, popl%ebx popl ret AcWons Restore values of %ebx and Restore Rtn adr Old Old %ebx %ebx Old %ebx 41

ObservaWons About Recursion Handled Without Special ConsideraWon Stack frames mean that each funcbon call has private storage Saved registers & local variables Saved return pointer Register saving convenbons prevent one funcbon call from corrupbng another s data Stack discipline follows call / return pauern If P calls Q, then Q returns before P Last-In, First-Out Also works for mutual recursion P calls Q; Q calls P 42

Pointer Code GeneraWng Pointer /* Compute x + 3 */ int add3(int x) { int localx = x; incrk(&localx, 3); return localx; Referencing Pointer /* Increment value by k */ void incrk(int *ip, int k) { *ip += k; add3 creates pointer and passes it to incrk 43

CreaWng and IniWalizing Local Variable int add3(int x) { int localx = x; incrk(&localx, 3); return localx; Variable localx must be stored on stack Because: Need to create pointer to it Compute pointer as -4() 8 4 x Rtn adr 0 Old First part of add3-4 localx add3: = x pushl -8 movl, -12 Unused subl $24, # Alloc. 24 bytes movl 8(), %eax -16 movl %eax, -4()# Set localx to x -20-24 44

CreaWng Pointer as Argument int add3(int x) { int localx = x; incrk(&localx, 3); return localx; Use leal instrucwon to compute address of localx Middle part of add3 movl $3, 4() # 2 nd arg = 3 leal -4(), %eax# &localx movl %eax, () # 1 st arg = &localx call incrk 8 x 4 Rtn adr 0 Old -4 localx -8-12 Unused -16-20 3 +4-24 45

Retrieving local variable int add3(int x) { int localx = x; incrk(&localx, 3); return localx; Retrieve localx from stack as return value Final part of add3 movl -4(), %eax # Return val= localx leave ret 8 x 4 Rtn adr 0 Old -4 localx -8-12 Unused -16-20 -24 46

IA 32 Procedure Summary Important Points Stack is the right data structure for procedure call / return If P calls Q, then Q returns before P Recursion (& mutual recursion) handled by normal calling convenwons Can safely store values in local stack frame and in callee-saved registers Put funcbon arguments at top of stack Result return in %eax Pointers are addresses of values On stack or global Caller Frame Arguments Return Addr Old Saved Registers + Local Variables Argument Build 47