Machine-Level Programming II: Control and Arithmetic

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

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

Credits to Randy Bryant & Dave O Hallaron

Machine- Level Programming II: Arithme c & Control

Machine- Level Programming II: Arithme6c & Control

Machine Level Programming II: Arithmetic &Control

CS241 Computer Organization Spring Addresses & Pointers

Sungkyunkwan University

Machine- Level Programming II: Arithme6c & Control

Questions about last homework? (Would more feedback be useful?) New reading assignment up: due next Monday

The Hardware/Software Interface CSE351 Spring 2013

Homework 0: Given: k-bit exponent, n-bit fraction Find: Exponent E, Significand M, Fraction f, Value V, Bit representation

The Hardware/Software Interface CSE351 Spring 2015

ASSEMBLY II: CONTROL FLOW. Jo, Heeseung

Assembly II: Control Flow. Jin-Soo Kim Computer Systems Laboratory Sungkyunkwan University

CS 33. Machine Programming (2) CS33 Intro to Computer Systems XI 1 Copyright 2018 Thomas W. Doeppner. All rights reserved.

Machine Level Programming: Control

Machine-Level Programming II: Control Flow

CS 33. Machine Programming (2) CS33 Intro to Computer Systems XII 1 Copyright 2017 Thomas W. Doeppner. All rights reserved.

Sungkyunkwan University

Assembly I: Basic Operations. Computer Systems Laboratory Sungkyunkwan University

Condition Codes The course that gives CMU its Zip! Machine-Level Programming II Control Flow Sept. 13, 2001 Topics

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

Machine-Level Programming II: Control

Chapter 3 Machine-Level Programming II Control Flow

Machine-Level Programming II: Control

Condition Codes. Lecture 4B Machine-Level Programming II: Control Flow. Setting Condition Codes (cont.) Setting Condition Codes (cont.

ASSEMBLY I: BASIC OPERATIONS. Jo, Heeseung

CF Carry Flag SF Sign Flag ZF Zero Flag OF Overflow Flag. ! CF set if carry out from most significant bit. "Used to detect unsigned overflow

Assembly I: Basic Operations. Jo, Heeseung

Giving credit where credit is due

Process Layout and Function Calls

CISC 360. Machine-Level Programming II: Control Flow Sep 23, 2008

Page # CISC 360. Machine-Level Programming II: Control Flow Sep 23, Condition Codes. Setting Condition Codes (cont.)

CISC 360. Machine-Level Programming II: Control Flow Sep 17, class06

Process Layout, Function Calls, and the Heap

Control flow. Condition codes Conditional and unconditional jumps Loops Switch statements

Page 1. Condition Codes CISC 360. Machine-Level Programming II: Control Flow Sep 17, Setting Condition Codes (cont.)

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

Machine Programming 2: Control flow

Machine- level Programming II: Control Flow

System Programming and Computer Architecture (Fall 2009)

X86 Addressing Modes Chapter 3" Review: Instructions to Recognize"

2/12/2016. Today. Machine-Level Programming II: Control. Condition Codes (Implicit Setting) Processor State (x86-64, Partial)

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

Assembly II: Control Flow. Jin-Soo Kim Computer Systems Laboratory Sungkyunkwan University

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

CS241 Computer Organization Spring 2015 IA

CS 31: Intro to Systems ISAs and Assembly. Kevin Webb Swarthmore College February 9, 2016

x86-64 Programming II

Three Kinds of Instruc;ons

x86 Programming II CSE 351 Winter

CS 31: Intro to Systems ISAs and Assembly. Kevin Webb Swarthmore College September 25, 2018

Assembly II: Control Flow

Instructor: Alvin R. Lebeck

CSC 8400: Computer Systems. Machine-Level Representation of Programs

Machine Language CS 3330 Samira Khan

Assembly Programming III

Outline. Review: Assembly/Machine Code View. Processor State (x86-64, Par2al) Condi2on Codes (Explicit Se^ng: Compare) Condi2on Codes (Implicit Se^ng)

Assembly level Programming. 198:211 Computer Architecture. (recall) Von Neumann Architecture. Simplified hardware view. Lecture 10 Fall 2012

Machine-Level Programming (2)

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

CS429: Computer Organization and Architecture

Credits and Disclaimers

Machine-Level Programming I: Introduction

The Hardware/Software Interface CSE351 Spring 2015

Giving credit where credit is due

L09: Assembly Programming III. Assembly Programming III. CSE 351 Spring Guest Lecturer: Justin Hsia. Instructor: Ruth Anderson

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

X86 Assembly -Data II:1

Handout #2: Machine-Level Programs

CS367. Program Control

Machine-Level Programming II: Control

Software. Hardware. x86 basics. ISA View. a brief history of x86 10/6/15. Program, Application. Programming Language. Compiler/Interpreter

Instruction Set Architecture

Instruction Set Architecture

CSC 2400: Computer Systems. Towards the Hardware: Machine-Level Representation of Programs

x86 64 Programming II

Assembly Language: IA-32 Instructions

Machine Programming 1: Introduction

Machine-Level Programming Introduction

Controlling Program Flow

Machine- Level Programming II: Control Structures and Procedures

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

Second Part of the Course

Machine- Level Programming II: Control Structures and Procedures

Instruction Set Architecture

Roadmap. Java: Assembly language: OS: Machine code: Computer system:

CS241 Computer Organization Spring Loops & Arrays

CS61 Section Solutions 3

CISC 360 Instruction Set Architecture

hnp://

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

Instruction Set Architecture

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.

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

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

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

Machine- level Programming

Control. Young W. Lim Mon. Young W. Lim Control Mon 1 / 16

Transcription:

Machine-Level Programming II: Control and Arithmetic CSCI 2400: Computer Architecture Instructor: David Ferry Slides adapted from Bryant & O Hallaron s slides 1

Today Complete addressing mode, address computation (leal) Arithmetic operations x86 Calling Convention (functions) Control: Condition codes Conditional branches While loops 2

Complete Memory Addressing Modes Most General Form D(Rb,Ri,S) Mem[Reg[Rb]+S*Reg[Ri]+ D] D: Constant displacement 1, 2, or 4 bytes Rb: Base register: Any of 8 integer registers Ri: Index register: Any, except for %esp Unlikely you d use %ebp, either S: Scale: 1, 2, 4, or 8 (why these numbers?) Special Cases (Rb,Ri) Mem[Reg[Rb]+Reg[Ri]] D(Rb,Ri) Mem[Reg[Rb]+Reg[Ri]+D] (Rb,Ri,S) Mem[Reg[Rb]+S*Reg[Ri]] 3

Quick Check D(Rb,Ri,S) = Mem[Reg[Rb]+S*Reg[Ri]+ D] %edx %ecx 0xf000 0x0100 Expression Address Computation Address 0x8(%edx) 0xf000 + 0x8 0xf008 (%edx,%ecx) 0xf000 + 0x100 0xf100 (%edx,%ecx,4) 0xf000 + 4*0x100 0xf400 0x80(,%edx,2) 2*0xf000 + 0x80 0x1e080 4

Address Computation Instruction leal Src,Dest Src is address mode expression Set Dest to address denoted by expression Uses Computing addresses without a memory reference E.g., translation of p = &x[i]; Computing arithmetic expressions of the form x + k*y k = 1, 2, 4, or 8 Example int mul12(int x) { return x*12; Converted to ASM by compiler: leal (%eax,%eax,2), %eax ;t <- x+x*2 sall $2, %eax ;return t<<2 5

Today Complete addressing mode, address computation (leal) Arithmetic operations x86 Calling Convention (functions) Control: Condition codes Conditional branches While loops 6

Some Arithmetic Operations Two Operand Instructions: Format Computation addl Src,Dest Dest = Dest + Src subl Src,Dest Dest = Dest Src imull Src,Dest Dest = Dest * Src sall Src,Dest Dest = Dest << Src Also called shll sarl Src,Dest Dest = Dest >> Src Arithmetic shrl Src,Dest Dest = Dest >> Src Logical xorl Src,Dest Dest = Dest ^ Src andl Src,Dest Dest = Dest & Src orl Src,Dest Dest = Dest Src Watch out for argument order! No distinction between signed and unsigned int (why?) 7

Some Arithmetic Operations One Operand Instructions incl Dest Dest = Dest + 1 decl Dest Dest = Dest 1 negl Dest Dest = Dest notl Dest Dest = ~Dest See book for more instructions 8

Arithmetic Expression Example int arith(int x, int y, int z) { int t1 = x+y; int t2 = z+t1; int t3 = x+4; int t4 = y * 48; int t5 = t3 + t4; int rval = t2 * t5; return rval; arith: pushl %ebp movl %esp, %ebp movl 8(%ebp), %ecx movl 12(%ebp), %edx leal (%edx,%edx,2), %eax sall $4, %eax leal 4(%ecx,%eax), %eax addl %ecx, %edx addl 16(%ebp), %edx imull %edx, %eax Set Up Body popl ret %ebp Finish 9

Understanding arith int arith(int x, int y, int z) { int t1 = x+y; int t2 = z+t1; int t3 = x+4; int t4 = y * 48; int t5 = t3 + t4; int rval = t2 * t5; return rval; Offset 16 z 12 y 8 x 4 Rtn Addr 0 Old %ebp %ebp movl 8(%ebp), %ecx movl 12(%ebp), %edx leal (%edx,%edx,2), %eax sall $4, %eax leal 4(%ecx,%eax), %eax addl %ecx, %edx addl 16(%ebp), %edx imull %edx, %eax 10

Understanding arith int arith(int x, int y, int z) { int t1 = x+y; int t2 = z+t1; int t3 = x+4; int t4 = y * 48; int t5 = t3 + t4; int rval = t2 * t5; return rval; Offset 16 z 12 y 8 x 4 Rtn Addr 0 Old %ebp Stack %ebp movl 8(%ebp), %ecx # ecx = x movl 12(%ebp), %edx # edx = y leal (%edx,%edx,2), %eax # eax = y*3 sall $4, %eax # eax *= 16 (t4) leal 4(%ecx,%eax), %eax # eax = t4 +x+4 (t5) addl %ecx, %edx # edx = x+y (t1) addl 16(%ebp), %edx # edx += z (t2) imull %edx, %eax # eax = t2 * t5 (rval) 11

Observations about arith int arith(int x, int y, int z) { int t1 = x+y; int t2 = z+t1; int t3 = x+4; int t4 = y * 48; int t5 = t3 + t4; int rval = t2 * t5; return rval; Instructions in different order from C code Some expressions require multiple instructions Some instructions cover multiple expressions Get exact same code when compile: (x+y+z)*(x+4+48*y) movl 8(%ebp), %ecx # ecx = x movl 12(%ebp), %edx # edx = y leal (%edx,%edx,2), %eax # eax = y*3 sall $4, %eax # eax *= 16 (t4) leal 4(%ecx,%eax), %eax # eax = t4 +x+4 (t5) addl %ecx, %edx # edx = x+y (t1) addl 16(%ebp), %edx # edx += z (t2) imull %edx, %eax # eax = t2 * t5 (rval) 12

Another Example int logical(int x, int y) { int t1 = x^y; int t2 = t1 >> 17; int mask = (1<<13) - 7; int rval = t2 & mask; return rval; logical: pushl %ebp movl %esp,%ebp movl 12(%ebp),%eax xorl 8(%ebp),%eax sarl $17,%eax andl $8185,%eax popl %ebp ret Set Up Body Finish movl 12(%ebp),%eax # eax = y xorl 8(%ebp),%eax # eax = x^y (t1) sarl $17,%eax # eax = t1>>17 (t2) andl $8185,%eax # eax = t2 & mask (rval) 13

Another Example int logical(int x, int y) { int t1 = x^y; int t2 = t1 >> 17; int mask = (1<<13) - 7; int rval = t2 & mask; return rval; logical: pushl %ebp movl %esp,%ebp movl 12(%ebp),%eax xorl 8(%ebp),%eax sarl $17,%eax andl $8185,%eax popl %ebp ret Set Up Body Finish movl 12(%ebp),%eax # eax = y xorl 8(%ebp),%eax # eax = x^y (t1) sarl $17,%eax # eax = t1>>17 (t2) andl $8185,%eax # eax = t2 & mask (rval) 14

Another Example int logical(int x, int y) { int t1 = x^y; int t2 = t1 >> 17; int mask = (1<<13) - 7; int rval = t2 & mask; return rval; logical: pushl %ebp movl %esp,%ebp movl 12(%ebp),%eax xorl 8(%ebp),%eax sarl $17,%eax andl $8185,%eax popl %ebp ret Set Up Body Finish movl 12(%ebp),%eax # eax = y xorl 8(%ebp),%eax # eax = x^y (t1) sarl $17,%eax # eax = t1>>17 (t2) andl $8185,%eax # eax = t2 & mask (rval) 15

Another Example int logical(int x, int y) { int t1 = x^y; int t2 = t1 >> 17; int mask = (1<<13) - 7; int rval = t2 & mask; return rval; logical: pushl %ebp movl %esp,%ebp movl 12(%ebp),%eax xorl 8(%ebp),%eax sarl $17,%eax andl $8185,%eax popl %ebp ret Set Up Body Finish 2 13 = 8192, 2 13 7 = 8185 movl 12(%ebp),%eax # eax = y xorl 8(%ebp),%eax # eax = x^y (t1) sarl $17,%eax # eax = t1>>17 (t2) andl $8185,%eax # eax = t2 & mask (rval) 16

Today Complete addressing mode, address computation (leal) Arithmetic operations x86 Calling Convention (functions) Control: Condition codes Conditional branches While loops 17

x86 Function Calling Conventions Functions are the basis for code re-use Calling a function interferes with the processor state We have to worry about saving this state in assembly Compiler handles the details in higher level languages A function is allowed (by convention) to modify: EAX ECX EDC These are called caller-saved Return values from a function are stored in EAX 18

x86 Argument Passing Function arguments must be stored in registers or somewhere in memory X86 has relatively few registers The stack stores arguments in memory For example: int arith(int x, int y, int z) Caller pushes values from right to left call instruction pushes function return address Callee pushes ebp in function preamble Callee accesses leftmost arguments as 8(%ebp) Offset 16 z 12 y 8 x Other arguments as 12, 16, and so on Compiler sometimes generates code that uses esp instead 4 Rtn Addr 0 Old %ebp Stack %ebp 19

Today Complete addressing mode, address computation (leal) Arithmetic operations x86 Calling Convention (functions) Control: Condition codes Conditional branches Loops 20

Processor State (IA32, Partial) Information about currently executing program Temporary data ( %eax, ) Location of runtime stack ( %ebp,%esp ) Location of current code control point ( %eip, ) Status of recent tests ( CF, ZF, SF, OF ) %eax %ecx %edx %ebx %esi %edi %esp %ebp %eip General purpose registers Current stack top Current stack frame Instruction pointer CF ZF SF OF Condition codes 21

Condition Codes (Implicit Setting) Single bit registers CF Carry Flag (for unsigned) SF Sign Flag (for signed) ZF Zero Flag OF Overflow Flag (for signed) Implicitly set (think of it as side effect) by arithmetic operations Example: addl/addq Src,Dest t = a+b CF set if carry out from most significant bit (unsigned overflow) ZF set if t == 0 SF set if t < 0 (as signed) OF set if two s-complement (signed) overflow (a>0 && b>0 && t<0) (a<0 && b<0 && t>=0) Not set by lea instruction Full documentation (IA32), link on course website 22

Condition Codes (Explicit Setting: Compare) Explicit Setting by Compare Instruction cmpl/cmpq Src2, Src1 cmpl b,a like computing a-b without setting destination CF set if carry out from most significant bit (used for unsigned comparisons) ZF set if a == b SF set if (a-b) < 0 (as signed) OF set if two s-complement (signed) overflow (a>0 && b<0 && (a-b)<0) (a<0 && b>0 && (a-b)>0) 23

Condition Codes (Explicit Setting: Test) Explicit Setting by Test instruction testl/testq Src2, Src1 testl b,a like computing a&b without setting destination Sets condition codes based on value of Src1 & Src2 Useful to have one of the operands be a mask ZF set when a&b == 0 SF set when a&b < 0 24

Reading Condition Codes SetX Instructions Set single byte based on combinations of condition codes SetX Condition Description sete ZF Equal / Zero setne ~ZF Not Equal / Not Zero sets SF Negative setns ~SF Nonnegative setg ~(SF^OF)&~ZF Greater (Signed) setge ~(SF^OF) Greater or Equal (Signed) setl (SF^OF) Less (Signed) setle (SF^OF) ZF Less or Equal (Signed) seta ~CF&~ZF Above (unsigned) setb CF Below (unsigned) 25

Reading Condition Codes (Cont.) SetX Instructions: Set single byte based on combination of condition codes One of 8 addressable byte registers Does not alter remaining 3 bytes Typically use movzbl to finish job int gt (int x, int y) { return x > y; %eax %ecx %edx %ebx %esi %ah %al %ch %cl %dh %dl %bh %bl Body %edi movl 12(%ebp),%eax cmpl %eax,8(%ebp) setg %al movzbl %al,%eax # eax = y # Compare x : y # al = x > y # Zero rest of %eax %esp %ebp 26

Today Complete addressing mode, address computation (leal) Arithmetic operations x86 Calling Convention (functions) Control: Condition codes Conditional branches & Moves Loops 28

Jumping jx Instructions Jump to different part of code depending on condition codes jx Condition Description jmp 1 Unconditional je ZF Equal / Zero jne ~ZF Not Equal / Not Zero js SF Negative jns ~SF Nonnegative jg ~(SF^OF)&~ZF Greater (Signed) jge ~(SF^OF) Greater or Equal (Signed) jl (SF^OF) Less (Signed) jle (SF^OF) ZF Less or Equal (Signed) ja ~CF&~ZF Above (unsigned) jb CF Below (unsigned) 29

Conditional Branch Example int absdiff(int x, int y) { int result; if (x > y) { result = x-y; else { result = y-x; return result; absdiff: pushl %ebp movl %esp, %ebp movl 8(%ebp), %edx movl 12(%ebp), %eax cmpl %eax, %edx jle.l6 subl %eax, %edx movl %edx, %eax jmp.l7.l6: subl %edx, %eax.l7: popl %ebp ret Setup Body1 Body2a Body2b Finish 30

Conditional Branch Example (Cont.) int goto_ad(int x, int y) { int result; if (x <= y) goto Else; result = x-y; goto Exit; Else: result = y-x; Exit: return result; C allows goto as means of transferring control Closer to machine-level programming style Generally considered bad coding style absdiff: pushl %ebp movl %esp, %ebp movl 8(%ebp), %edx movl 12(%ebp), %eax cmpl %eax, %edx jle.l6 subl %eax, %edx movl %edx, %eax jmp.l7.l6: subl %edx, %eax.l7: popl %ebp ret Setup Body1 Body2a Body2b Finish 31

Conditional Branch Example (Cont.) int goto_ad(int x, int y) { int result; if (x <= y) goto Else; result = x-y; goto Exit; Else: result = y-x; Exit: return result; absdiff: pushl %ebp movl %esp, %ebp movl 8(%ebp), %edx movl 12(%ebp), %eax cmpl %eax, %edx jle.l6 subl %eax, %edx movl %edx, %eax jmp.l7.l6: subl %edx, %eax.l7: popl %ebp ret Setup Body1 Body2a Body2b Finish 32

Conditional Branch Example (Cont.) int goto_ad(int x, int y) { int result; if (x <= y) goto Else; result = x-y; goto Exit; Else: result = y-x; Exit: return result; absdiff: pushl %ebp movl %esp, %ebp movl 8(%ebp), %edx movl 12(%ebp), %eax cmpl %eax, %edx jle.l6 subl %eax, %edx movl %edx, %eax jmp.l7.l6: subl %edx, %eax.l7: popl %ebp ret Setup Body1 Body2a Body2b Finish 33

Conditional Branch Example (Cont.) int goto_ad(int x, int y) { int result; if (x <= y) goto Else; result = x-y; goto Exit; Else: result = y-x; Exit: return result; absdiff: pushl %ebp movl %esp, %ebp movl 8(%ebp), %edx movl 12(%ebp), %eax cmpl %eax, %edx jle.l6 subl %eax, %edx movl %edx, %eax jmp.l7.l6: subl %edx, %eax.l7: popl %ebp ret Setup Body1 Body2a Body2b Finish 34

Today Complete addressing mode, address computation (leal) Arithmetic operations x86 Calling Convention (functions) x86-64 Control: Condition codes Conditional branches and moves Loops 39

Do-While Loop Example C Code int pcount_do(unsigned x) { int result = 0; do { result += x & 0x1; x >>= 1; while (x); return result; Goto Version int pcount_do(unsigned x) { int result = 0; loop: result += x & 0x1; x >>= 1; if (x) goto loop; return result; Count number of 1 s in argument x ( popcount ) Use conditional branch to either continue looping or to exit loop 40

Do-While Loop Compilation Goto Version int pcount_do(unsigned x) { int result = 0; loop: result += x & 0x1; x >>= 1; if (x) goto loop; return result; Registers: %edx %ecx x result movl $0, %ecx # result = 0.L2: # loop: movl %edx, %eax andl $1, %eax # t = x & 1 addl %eax, %ecx # result += t shrl %edx # x >>= 1 jne.l2 # If!0, goto loop 41

General Do-While Translation C Code do Body while (Test); Body: { Statement 1 ; Statement 2 ; Statement n ; Goto Version loop: Body if (Test) goto loop Test returns integer = 0 interpreted as false 0 interpreted as true 42

While Loop Example C Code int pcount_while(unsigned x) { int result = 0; while (x) { result += x & 0x1; x >>= 1; return result; Goto Version int pcount_do(unsigned x) { int result = 0; if (!x) goto done; loop: result += x & 0x1; x >>= 1; if (x) goto loop; done: return result; Is this code equivalent to the do-while version? Must jump out of loop if test fails 43

General While Translation While version while (Test) Body Do-While Version if (!Test) goto done; do Body while(test); done: Goto Version if (!Test) goto done; loop: Body if (Test) goto loop; done: 44

For Loop Example C Code #define WSIZE 8*sizeof(int) int pcount_for(unsigned x) { int i; int result = 0; for (i = 0; i < WSIZE; i++) { unsigned mask = 1 << i; result += (x & mask)!= 0; return result; Is this code equivalent to other versions? 45

For Loop Form General Form for (Init; Test; Update ) Body for (i = 0; i < WSIZE; i++) { unsigned mask = 1 << i; result += (x & mask)!= 0; i = 0 i < WSIZE i++ { Init Test Update Body unsigned mask = 1 << i; result += (x & mask)!= 0; 46

For Loop While Loop For Version for (Init; Test; Update ) Body While Version Init; while (Test ) { Body Update; 47

For Loop Goto For Version for (Init; Test; Update ) Body While Version Init; while (Test ) { Body Update; Init; if (!Test) goto done; do Body Update while(test); done: Init; if (!Test) goto done; loop: Body Update if (Test) goto loop; done: 48

For Loop Conversion Example C Code #define WSIZE 8*sizeof(int) int pcount_for(unsigned x) { int i; int result = 0; for (i = 0; i < WSIZE; i++) { unsigned mask = 1 << i; result += (x & mask)!= 0; return result; Initial test can be optimized away Goto Version int pcount_for_gt(unsigned x) { int i; int result = 0; i = 0; if (!(i < WSIZE)) goto done; loop: { unsigned mask = 1 << i; result += (x & mask)!= 0; i++; Update if (i < WSIZE) goto loop; done: return result; Test Init!Test Body 49

Summary Today Complete addressing mode, address computation (leal) Arithmetic operations Control: Condition codes Conditional branches & conditional moves Loops Next Time Switch statements Stack Call / return Procedure call discipline 50