II:1 x86 Assembly - Control. II:2 Alternate reference source Go to the source: Intel 64 and IA32 

Slides:



Advertisements
Similar presentations
Fabián E. Bustamante, Spring 2007 Machine-Level Programming II: Control Flow Today Condition codes Control flow structures Next time Procedures.
Advertisements

1 Carnegie Mellon Machine-Level Programming II: Arithmetic & Control / : Introduction to Computer Systems 6 th Lecture, Jan 29, 2015 Carnegie.
MACHINE-LEVEL PROGRAMMING II: ARITHMETIC & CONTROL.
University of Washington Announcements Lab 1 due last night Lab 2 release soon HW1 due Monday night 1.
1 Carnegie Mellon Machine-Level Programming II: Arithmetic & Control / : Introduction to Computer Systems 6 th Lecture, May 28, 2015 Carnegie.
Machine-Level Programming II: Control Flow Today Condition codes Control flow structures Next time Procedures.
Machine-Level Programming II: Control Flow Sept. 12, 2002 Topics Condition Codes Setting Testing Control Flow If-then-else Varieties of Loops Switch Statements.
Machine-Level Programming II Control Flow Sept. 13, 2001 Topics Condition Codes –Setting –Testing Control Flow –If-then-else –Varieties of Loops –Switch.
Machine-Level Programming II: Control Flow September 1, 2008 Topics Condition Codes Setting Testing Control Flow If-then-else Varieties of Loops Switch.
1 Introduction to x86 Assembly, part II or “What does my laptop actually do?” Ymir Vigfusson Some slides gracefully borrowed from
Machine-Level Programming 3 Control Flow Topics Control Flow Switch Statements Jump Tables.
Machine-Level Programming II: Control Flow Topics Condition codes Conditional branches Loops Switch statements CS 105 “Tour of the Black Holes of Computing”
1 Carnegie Mellon Machine-Level Programming II: Arithmetic & Control : Introduction to Computer Systems 5 th Lecture, Sep. 7, 2010 Carnegie Mellon.
1 Seoul National University Machine-Level Programming II: Arithmetic & Control.
University of Washington x86 Programming III The Hardware/Software Interface CSE351 Winter 2013.
Machine-Level Programming III: Switch Statements and IA32 Procedures Seoul National University.
Machine-Level Programming V: Switch Statements Comp 21000: Introduction to Computer Systems & Assembly Lang Systems book chapter 3* * Modified slides from.
1 Machine-Level Programming III: Arithmetic & Condition Codes Comp 21000: Introduction to Computer Organization & Systems March 2015 Systems book chapter.
1 Bryant and O’Hallaron, Computer Systems: A Programmer’s Perspective, Third Edition Carnegie Mellon Machine-Level Programming II: Control : Introduction.
Machine-Level Programming II: Control Flow Topics Condition Codes Setting Testing Control Flow If-then-else Varieties of loops Switch statements CS 105.
University of Washington Today Lab 2 due next Monday! Finish-up control flow Switch statements 1.
Machine-Level Programming 3 Control Flow Topics Control Flow Switch Statements Jump Tables.
Machine-Level Programming II: Control Flow Topics Condition Codes Setting Testing Control Flow If-then-else Varieties of loops Switch statements CS 105.
1 Carnegie Mellon Machine-Level Programming II: Arithmetic and Control Lecture, Feb. 28, 2012 These slides are from website which.
Carnegie Mellon 1 Machine-Level Programming I: Basics Lecture, Feb. 21, 2013 These slides are from website which accompanies the.
1 Carnegie Mellon Machine-Level Programming II: Arithmetic & Control / : Introduction to Computer Systems 6 th Lecture, Sep. 11, 2014 Carnegie.
תרגול 5 תכנות באסמבלי, המשך
1 Bryant and O’Hallaron, Computer Systems: A Programmer’s Perspective, Third Edition Carnegie Mellon Machine-Level Programming II: Control Carnegie Mellon.
University of Washington x86 Programming II The Hardware/Software Interface CSE351 Winter 2013.
University of Washington This week Lab 1 due 11pm today  Frustrating? Awesome? Both? Neither? Lab 2 out later today, due 11pm Wednesday July 17  Disassembly,
Lecture 7 Flow of Control Topics Finish Lecture 6 slides Lab 02 = datalab comments Assembly Language flow of control Test 1 – a week from wednesday February.
IA32: Control Flow Topics –Condition Codes Setting Testing –Control Flow If-then-else Varieties of Loops Switch Statements.
Machine-Level Programming II: Control Flow Topics Condition Codes Setting Testing Control Flow If-then-else Varieties of loops Switch statements CS 105.
Carnegie Mellon Machine-Level Programming II: Arithmetic & Control /18-243: Introduction to Computer Systems 6th Lecture, 5 June 2012 Carnegie Mellon.
1 Binghamton University Machine-Level Programming II: Arithmetic & Control CS220: Computer Systems II.
Assembly תרגול 7 תכנות באסמבלי, המשך. Condition Codes Single bit registers  CF – carry flag  ZF – zero flag  SF – sign flag  OF – overflow flag Relevant.
Machine-Level Programming II Control Flow Sept. 14, 2000 Topics Condition Codes –Setting –Testing Control Flow –If-then-else –Varieties of Loops –Switch.
Machine-Level Programming 2 Control Flow Topics Condition Codes Setting Testing Control Flow If-then-else Varieties of Loops Switch Statements.
Machine-Level Programming II: Control Flow Topics Condition Codes Setting Testing Control Flow If-then-else Varieties of Loops Switch Statements class06.ppt.
Reading Condition Codes (Cont.)
Machine-Level Programming 2 Control Flow
X86 Assembly, and C-to-assembly
IA32 Processors Evolutionary Design
Conditional Branch Example
Machine-Level Programming II: Arithmetic & Control
Machine-Level Programming II Control Flow Sept. 9, 1999
Machine-Level Programming II: Control
Machine-Level Representation of Programs II
Machine-Level Programming II: Control Flow
Y86 Processor State Program Registers
Instructors: Majd Sakr and Khaled Harras
Instructor: David Ferry
Condition Codes Single Bit Registers
Machine-Level Programming: Control Flow
Machine-Level Programming 2 Control Flow
Machine-Level Programming II: Control Flow
Machine-Level Programming 2 Control Flow
Machine-Level Representation of Programs III
Machine-Level Programming 2 Control Flow
Machine-Level Programming II: Control Flow
X86 Assembly - Control.
Machine-Level Programming II: Control Flow Sept. 12, 2007
CS201- Lecture 8 IA32 Flow Control
Presentation transcript:

II:1 x86 Assembly - Control

II:2 Alternate reference source Go to the source: Intel 64 and IA32  f f  See fig 3.1, 3.4, 3.5, 3.8  Section 5.1 (Intel format), ENTER/LEAVE (6.5.1, 6.5.2) Or AMD: See Fig 3-3 & rest of chapter 3 for instruction set Or this useful site: Quiz ( out late Friday; do at home (open book but not open neighbor; bring to class and grade in class Tues). ASM Data moves and simple arithmetic (up until end of class today).

II:3 CPU Review: Assembly Programmer’s View Programmer-Visible State  PC: Program counter  Address of next instruction  Called “EIP” (IA32)  Register file  Heavily used program data  Condition codes  Store status information about most recent arithmetic operation  Used for conditional branching  Memory  Byte addressable array  Code, user data, (some) OS data  Includes stack used to support procedures PC Registers Memory Object Code Program Data OS Data Addresses Data Instructions Stack Condition Codes

II:4 Review: x86 instructions mov: movl, movw, movb add/sub/imul: sal/shl/sar/shr: xor/and/or: inc/dec/neq/not: lea:

II:5 Review: movl Operand Combinations Cannot do memory-memory transfer with a single instruction movl Imm Reg Mem Reg Mem Reg Mem Reg SourceDestC Analog movl $0x4,%eaxtemp = 0x4; movl $-147,(%eax)*p = -147; movl %eax,%edxtemp2 = temp1; movl %eax,(%edx)*p = temp; movl (%eax),%edxtemp = *p; Src,Dest

II:6 Review: Memory Addressing Modes Normal(R)Mem[Reg[R]]  Register R specifies memory address movl (%ecx),%eax DisplacementD(R)Mem[Reg[R]+D]  Register R specifies start of memory region  Constant displacement D specifies offset movl 8(%ebp),%edx

II:7 Review: 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]]

II:8 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 ) %eip General purpose registers Current stack top Current stack frame Instruction pointer CFZFSFOF Condition codes %eax %ecx %edx %ebx %esi %edi %esp %ebp

II:9 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 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) Not set by lea instruction

II:10 Condition Codes (Explicit Setting: Compare) Explicit Setting by Compare Instruction cmpl Src2,Src1# NOTE THE OPERANDS ORDER 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)

II:11 Condition Codes (Explicit Setting: Test) Explicit Setting by Test instruction testl 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

II:12 Reading Condition Codes SetX Instructions  Set single byte based on combinations of condition codes SetXConditionDescription seteZF Equal / Zero setne~ZF Not Equal / Not Zero setsSF 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) setbCF Below (unsigned)

II:13 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; } movl 12(%ebp),%eax# eax = y cmpl %eax,8(%ebp)# Compare x and y setg %al# al = x > y movzbl %al,%eax# Zero rest of %eax Note inverted ordering! Body %eax %ecx %edx %ebx %esi %edi %esp %ebp %al%ah %cl%ch %dl%dh %bl%bh

II:14 Explanation: MOVSBL and MOVZBL MOVSBL and MOVZBL  * MOVSBL sign-extends a single byte, and copies it into a double- word destination  * MOVZBL expands a single byte to 32 bits with 24 leading zeros, and copies it into a double-word destination Example: %eax = 0x %edx = 0xAAAABBBB MOVB %dh, %al %eax = 0x123456BB MOVSBL %dh, %eax %eax = 0xFFFFFFBB MOVZBL %dh, %eax %eax = 0x000000BB

II:15 Jumping jX Instructions  Jump to different part of code depending on condition codes jXConditionDescription jmp1 Unconditional jeZF Equal / Zero jne~ZF Not Equal / Not Zero jsSF 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) jbCF Below (unsigned)

II:16 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.L7 subl %eax, %edx movl %edx, %eax.L8: leave ret.L7: subl %edx, %eax jmp.L8 Body1 Setup Finish Body2

II:17 Review: stack movl 8(%ebp), %edx movl 12(%ebp), %eax cmpl %eax, %edx jle.L7 subl %eax, %edx movl %edx, %eax Stack (in memory) y x Rtn adr Old % ebp %ebp Offset Old % ebx -4 int absdiff(int x, int y) { int result; if (x > y) { result = x-y; } else { result = y-x; } return result; } Review: stack & function parameters

II:18 Review: stack & function parameters movl 8(%ebp), %edx# edx = x movl 12(%ebp), %eax# eax = y cmpl %eax, %edx jle.L7 subl %eax, %edx movl %edx, %eax Stack (in memory) y x Rtn adr Old % ebp %ebp Offset Old % ebx -4 int absdiff(int x, int y) { int result; if (x > y) { result = x-y; } else { result = y-x; } return result; }

II:19 Conditional Branch Example (Cont.) C allows “goto” as means of transferring control  Closer to machine-level programming style Generally considered bad coding style int goto_ad(int x, int y) { int result; if (x <= y) goto Else; result = x-y; Exit: return result; Else: result = y-x; goto Exit; } absdiff: pushl %ebp movl %esp, %ebp movl 8(%ebp), %edx #x movl 12(%ebp), %eax #y cmpl %eax, %edx jle.L7 subl %eax, %edx movl %edx, %eax.L8: leave ret.L7: subl %edx, %eax jmp.L8

II:20 Conditional Branch Example (Cont.) int goto_ad(int x, int y) { int result; if (x <= y) goto Else; result = x-y; Exit: return result; Else: result = y-x; goto Exit; } absdiff: pushl %ebp movl %esp, %ebp movl 8(%ebp), %edx #x movl 12(%ebp), %eax #y cmpl %eax, %edx jle.L7 subl %eax, %edx movl %edx, %eax.L8: leave ret.L7: subl %edx, %eax jmp.L8

II:21 Conditional Branch Example (Cont.) int goto_ad(int x, int y) { int result; if (x <= y) goto Else; result = x-y; Exit: return result; Else: result = y-x; goto Exit; } absdiff: pushl %ebp movl %esp, %ebp movl 8(%ebp), %edx #x movl 12(%ebp), %eax #y cmpl %eax, %edx jle.L7 subl %eax, %edx movl %edx, %eax.L8: leave ret.L7: subl %edx, %eax jmp.L8

II:22 Conditional Branch Example (Cont.) int goto_ad(int x, int y) { int result; if (x <= y) goto Else; result = x-y; Exit: return result; Else: result = y-x; goto Exit; } absdiff: pushl %ebp movl %esp, %ebp movl 8(%ebp), %edx #x movl 12(%ebp), %eax #y cmpl %eax, %edx jle.L7 subl %eax, %edx movl %edx, %eax.L8: leave ret.L7: subl %edx, %eax jmp.L8

II:23 Conditional Branch Example (Cont.) int goto_ad(int x, int y) { int result; if (x <= y) goto Else; result = x-y; Exit: return result; Else: result = y-x; goto Exit; } absdiff: pushl %ebp movl %esp, %ebp movl 8(%ebp), %edx #x movl 12(%ebp), %eax #y cmpl %eax, %edx jle.L7 subl %eax, %edx movl %edx, %eax.L8: leave ret.L7: subl %edx, %eax jmp.L8

II:24 C Code val = Test ? Then-Expr : Else-Expr ; Goto Version nt = !Test ; if (nt) goto Else; val = Then-Expr ; Done:... Else: val = Else-Expr ; goto Done; General Conditional Expression Translation  Test is expression returning integer = 0 interpreted as false  0 interpreted as true  Create separate code regions for then & else expressions  Execute appropriate one val = x>y ? x-y : y-x; Conditional transfer of control

II:25 Conditional transfer of data Conditional move instruction  cmovC src, dest  Move value from src to dest if condition C holds  More efficient than conditional branching (simple control flow)  Overhead: both possible return values are computed absdiff: # x in %edi, y in %esi movl %edi, %eax # eax = x movl %esi, %edx # edx = y subl %esi, %eax # eax = x-y subl %edi, %edx # edx = y-x cmpl %esi, %edi # x:y cmovle %edx, %eax # eax=edx if <= ret int absdiff( int x, int y) { int result; if (x > y) { result = x-y; } else { result = y-x; } return result; }

II:26 C Code Conditional Move Version val1 = Then-Expr ; val2 = Else-Expr ; val1 = val2 if ! Test ; General Form with Conditional Move Both values get computed Overwrite then-value with else-value if condition doesn’t hold Don’t use when:  Then or else expression have side effects  Then and else expression are too expensive val1 = Test ? Then-Expr : Else-Expr ;

II:27 C Code int fact_do(int x) { int result = 1; do { result *= x; x = x-1; } while (x > 1); return result; } Goto Version int fact_goto(int x) { int result = 1; loop: result *= x; x = x-1; if (x > 1) goto loop; return result; } “Do-While” Loop Example Use backward branch to continue looping Only take branch when “while” condition holds

II:28 Goto Version int fact_goto(int x) { int result = 1; loop: result *= x; x = x-1; if (x > 1) goto loop; return result; } “Do-While” Loop Compilation Registers: %edxx %eaxresult fact_goto: pushl %ebp# Setup movl %esp,%ebp# Setup movl $1,%eax# eax = 1 movl 8(%ebp),%edx# edx = x.L11: imull %edx,%eax# result *= x decl %edx# x-- cmpl $1,%edx# Compare x : 1 jg.L11# if > goto loop movl %ebp,%esp# Finish popl %ebp# Finish ret# Finish Assembly

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

II:30 C Code int fact_while(int x) { int result = 1; while (x > 1) { result *= x; x = x-1; }; return result; } Goto Version #1 int fact_while_goto(int x) { int result = 1; loop: if (!(x > 1)) goto done; result *= x; x = x-1; goto loop; done: return result; } “While” Loop Example Is this code equivalent to the do-while version? Must jump out of loop if test fails

II:31 C Code int fact_while(int x) { int result = 1; while (x > 1) { result *= x; x = x-1; }; return result; } Goto Version #2 int fact_while_goto2(int x) { int result = 1; if (!(x > 1)) goto done; loop: result *= x; x = x-1; if (x > 1) goto loop; done: return result; } Alternative “While” Loop Translation Historically used by GCC Uses same inner loop as do- while version Guards loop entry with extra test

II:32 While version while ( Test ) Body Do-While Version if (! Test ) goto done; do Body while( Test ); done: General “While” Translation Goto Version if (! Test ) goto done; loop: Body if ( Test ) goto loop; done:

II:33 C Code int fact_while(int x) { int result = 1; while (x > 1) { result *= x; x = x-1; }; return result; } Goto Version int fact_while_goto3(int x) { int result = 1; goto middle; loop: result *= x; x = x-1; middle: if (x > 1) goto loop; return result; } New Style “While” Loop Translation Recent technique for GCC  Both IA32 & x86-64 First iteration jumps over body computation within loop

II:34 C Code while ( Test ) Body Jump-to-Middle While Translation Avoids duplicating test code Unconditional goto incurs no performance penalty for loops compiled in similar fashion Goto Version goto middle; loop: Body middle: if ( Test ) goto loop; Goto (Previous) Version if (! Test ) goto done; loop: Body if ( Test ) goto loop; done:

II:35 int fact_while(int x) { int result = 1; while (x > 1) { result *= x; x--; }; return result; } # x in %edx, result in %eax jmp.L34 # goto Middle.L35: # Loop: imull %edx, %eax # result *= x decl %edx # x--.L34: # Middle: cmpl $1, %edx # x:1 jg.L35 # if >, goto Loop Jump-to-Middle Example

II:36 Summary Do-While loop While-Do loop C Code do Body while ( Test ); Goto Version loop: Body if ( Test ) goto loop 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: goto middle; loop: Body middle: if ( Test ) goto loop; or

II:37 “For” Loop Example: Square-and-Multiply Algorithm  Exploit bit representation: p = p 0 + 2p p 2 + … 2 n–1 p n–1  Gives: x p = z 0 · z 1 2 · (z 2 2 ) 2 · … · (…((z n –1 2 ) 2 )…) 2 z i = 1 when p i = 0 z i = x when p i = 1  Complexity O(log p) /* Compute x raised to nonnegative power p */ int ipwr_for(int x, unsigned p) { int result; for (result = 1; p != 0; p = p>>1) { if (p & 0x1) result *= x; x = x*x; } return result; } n–1 times Example 3 10 = 3 2 * 3 8 = 3 2 * ((3 2 ) 2 ) 2

II:38 ipwr Computation /* Compute x raised to nonnegative power p */ int ipwr_for(int x, unsigned p) { int result; for (result = 1; p != 0; p = p>>1) { if (p & 0x1) result *= x; x = x*x; } return result; } before iteration resultx=3p= = = = =

II:39 “For” Loop Example for ( Init ; Test ; Update ) Body int result; for (result = 1; p != 0; p = p>>1) { if (p & 0x1) result *= x; x = x*x; } General Form Init result = 1 Test p != 0 Update p = p >> 1 Body { if (p & 0x1) result *= x; x = x*x; }

II:40 “For”  “While”  “Do-While” for ( Init ; Test ; Update ) Body Init ; while ( Test ) { Body Update ; } Goto Version Init ; if (! Test ) goto done; loop: Body Update ; if ( Test ) goto loop; done: While Version For Version Do-While Version Init ; if (! Test ) goto done; do { Body Update ; } while ( Test ) done:

II:41 For-Loop: Compilation #1 for ( Init ; Test ; Update ) Body Goto Version Init ; if (! Test ) goto done; loop: Body Update ; if ( Test ) goto loop; done: For Version for (result = 1; p != 0; p = p>>1) { if (p & 0x1) result *= x; x = x*x; } result = 1; if (p == 0) goto done; loop: if (p & 0x1) result *= x; x = x*x; p = p >> 1; if (p != 0) goto loop; done:

II:42 “For”  “While” (Jump-to-Middle) for ( Init ; Test ; Update ) Body Init ; while ( Test ) { Body Update ; } Init ; goto middle; loop: Body Update ; middle: if ( Test ) goto loop; done: While Version For Version Goto Version

II:43 For-Loop: Compilation #2 for ( Init ; Test ; Update ) Body Init ; goto middle; loop: Body Update ; middle: if ( Test ) goto loop; done: For Version Goto Version for (result = 1; p != 0; p = p>>1) { if (p & 0x1) result *= x; x = x*x; } result = 1; goto middle; loop: if (p & 0x1) result *= x; x = x*x; p = p >> 1; middle: if (p != 0) goto loop; done:

II:44 Switch Statement Example Multiple case labels  Here: 5, 6 Fall through cases  Here: 2 Missing cases  Here: 4 long switch_eg (long x, long y, long z) { long w = 1; switch(x) { case 1: w = y*z; break; case 2: w = y/z; /* Fall Through */ case 3: w += z; break; case 5: case 6: w -= z; break; default: w = 2; } return w; }

II:45 Jump Table Structure Code Block 0 Targ0: Code Block 1 Targ1: Code Block 2 Targ2: Code Block n–1 Targn-1: Targ0 Targ1 Targ2 Targn-1 jtab: target = JTab[x]; goto *target; switch(x) { case val_0: Block 0 case val_1: Block 1 case val_n-1: Block n–1 } Switch Form Approximate Translation Jump Table Jump Targets +4...

II:46 Switch Statement Example Setup: switch_eg: pushl %ebp# Setup movl %esp, %ebp# Setup pushl %ebx# Setup movl $1, %ebx# w = 1 movl 8(%ebp), %edx# edx = x movl 16(%ebp), %ecx# ecx = z cmpl $6, %edx# x:6 ja.L61# if > goto default jmp *.L62(,%edx,4)# goto JTab[x] long switch_eg(long x, long y, long z) { long w = 1; switch(x) {... } return w; } Indirect jump Jump table.section.rodata.align 4.L62:.long.L61 # x = 0.long.L56 # x = 1.long.L57 # x = 2.long.L58 # x = 3.long.L61 # x = 4.long.L60 # x = 5.long.L60 # x = 6

II:47 Assembly Setup Explanation Table Structure  Each target requires 4 bytes  Base address at.L62 Jumping Direct: jmp.L61  Jump target is denoted by label.L61 Indirect: jmp *.L62(,%edx,4)  Start of jump table:. L62  Must scale by factor of 4 (labels have 32-bit = 4 Bytes on IA32)  Fetch target from effective Address. L61 + edx*4  Only for 0  x  6.section.rodata.align 4.L62:.long.L61 # x = 0.long.L56 # x = 1.long.L57 # x = 2.long.L58 # x = 3.long.L61 # x = 4.long.L60 # x = 5.long.L60 # x = 6 Jump table

II:48 Jump Table.section.rodata.align 4.L62:.long.L61 # x = 0.long.L56 # x = 1.long.L57 # x = 2.long.L58 # x = 3.long.L61 # x = 4.long.L60 # x = 5.long.L60 # x = 6 Jump table switch(x) { case 1: //.L56 w = y*z; break; case 2: //.L57 w = y/z; /* Fall Through */ case 3: //.L58 w += z; break; case 5: case 6: //.L60 w -= z; break; default: //.L61 w = 2; }

II:49 Code Blocks (Partial).L61: // Default case movl $2, %ebx # w = 2 movl %ebx, %eax # Return w popl %ebx leave ret.L57: // Case 2: movl 12(%ebp), %eax # y cltd # Div prep idivl %ecx # y/z movl %eax, %ebx # w = y/z # Fall through.L58: // Case 3: addl %ecx, %ebx # w+= z movl %ebx, %eax # Return w popl %ebx leave ret switch(x) {... case 2: //.L57 w = y/z; /* Fall Through */ case 3: //.L58 w += z; break;... default: //.L61 w = 2; }

II:50 IA32 Object Code Setup  Label.L61 becomes address 0x  Label.L62 becomes address 0x80488dc : : 77 0c ja : ff dc jmp *0x80488dc(,%edx,4) switch_eg:... ja.L61# if > goto default jmp *.L62(,%edx,4)# goto JTab[x] Assembly Code Disassembled Object Code

II:51 Types of jumps Direct jump  Absolute jump je $0x  PC relative jump je $14 je $-14 Indirect jump jmp %eax jmp 8(%eax) jmp (%eax, %ebx, 4)