Machine Language CS 3330 Samira Khan

Similar documents
Machine-Level Programming II: Control

Machine Level Programming: Control

Machine-Level Programming II: Control

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

Machine-Level Programming II: Control

Machine-Level Programming (2)

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

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

CSC 252: Computer Organization Spring 2018: Lecture 6

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

Intel x86-64 and Y86-64 Instruction Set Architecture

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

CS429: Computer Organization and Architecture

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

x86-64 Programming II

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

Credits to Randy Bryant & Dave O Hallaron

Assembly Programming III

x86 Programming II CSE 351 Winter

Machine- Level Representa2on: Procedure

Assembly II: Control Flow

Machine-Level Programming II: Control and Arithmetic

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

Machine- Level Programming II: Arithme6c & Control

The Hardware/Software Interface CSE351 Spring 2013

Foundations of Computer Systems

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

x86 Programming III CSE 351 Autumn 2016 Instructor: Justin Hsia

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

Lecture 4: x86_64 Assembly Language

x86 Programming I CSE 351 Winter

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

Assembly I: Basic Operations. Jin-Soo Kim Computer Systems Laboratory Sungkyunkwan University

CS241 Computer Organization Spring Addresses & Pointers

x86 64 Programming I CSE 351 Autumn 2018 Instructor: Justin Hsia

Machine Program: Procedure. Zhaoguo Wang

Machine- Level Programming II: Arithme c & Control

How Software Executes

C to Machine Code x86 basics: Registers Data movement instructions Memory addressing modes Arithmetic instructions

Areas for growth: I love feedback

+ Machine Level Programming: x86-64 History

CS367. Program Control

Chapter 3 Machine-Level Programming I: Basics. Bryant and O Hallaron, Computer Systems: A Programmer s Perspective, Third Edition

%r8 %r8d. %r9 %r9d. %r10 %r10d. %r11 %r11d. %r12 %r12d. %r13 %r13d. %r14 %r14d %rbp. %r15 %r15d. Sean Barker

Machine Level Programming II: Arithmetic &Control

x86 64 Programming II

Control flow (1) Condition codes Conditional and unconditional jumps Loops Conditional moves Switch statements

Assembly Language II: Addressing Modes & Control Flow

Machine- Level Programming II: Arithme6c & Control

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

x86 Programming I CSE 351 Autumn 2016 Instructor: Justin Hsia

Machine Level Programming: Basics

x86-64 Programming III

Machine-Level Programming I: Basics

L08: Assembly Programming II. Assembly Programming II. CSE 351 Spring Guest Lecturer: Justin Hsia. Instructor: Ruth Anderson

Process Layout and Function Calls

CS429: Computer Organization and Architecture

Machine-level Programs Procedure

MACHINE LEVEL PROGRAMMING 1: BASICS

CS 261 Fall Mike Lam, Professor. x86-64 Control Flow

CS 261 Fall Mike Lam, Professor. x86-64 Control Flow

CS241 Computer Organization Spring 2015 IA

Sungkyunkwan University

Machine-Level Programming III: Procedures

CS 107. Lecture 13: Assembly Part III. Friday, November 10, Stack "bottom".. Earlier Frames. Frame for calling function P. Increasing address

CSE351 Spring 2018, Midterm Exam April 27, 2018

CSCI 2021: x86-64 Control Flow

How Software Executes

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

CS 261 Fall Machine and Assembly Code. Data Movement and Arithmetic. Mike Lam, Professor

Machine Level Programming: Basics

Assembly Programming IV

Machine-Level Programming I: Basics

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

Today: Machine Programming I: Basics

Carnegie Mellon. 5 th Lecture, Jan. 31, Instructors: Todd C. Mowry & Anthony Rowe

Sungkyunkwan University

Machine Level Programming I: Basics

Procedures and the Call Stack

Where We Are. Optimizations. Assembly code. generation. Lexical, Syntax, and Semantic Analysis IR Generation. Low-level IR code.

MACHINE-LEVEL PROGRAMMING I: BASICS COMPUTER ARCHITECTURE AND ORGANIZATION

Controlling Program Flow

x86-64 Programming III & The Stack

Machine Programming 3: Procedures

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

Lecture 3 CIS 341: COMPILERS

Computer Organization: A Programmer's Perspective

Computer Architecture I: Outline and Instruction Set Architecture. CENG331 - Computer Organization. Murat Manguoglu

x86 64 Programming I CSE 351 Autumn 2017 Instructor: Justin Hsia

Do not turn the page until 5:10.

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

How Software Executes

Machine-Level Programming I: Basics

CSE 351 Midterm Exam Spring 2016 May 2, 2015

Today: Machine Programming I: Basics. Machine Level Programming I: Basics. Intel x86 Processors. Intel x86 Evolution: Milestones

CSE 351 Midterm Exam

Changelog. Assembly (part 1) logistics note: lab due times. last time: C hodgepodge

Corrections made in this version not seen in first lecture:

Machine Level Programming I: Basics. Credits to Randy Bryant & Dave O Hallaron

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

Transcription:

Machine Language CS 3330 Samira Khan University of Virginia Feb 2, 2017

AGENDA Logistics Review of Abstractions Machine Language 2

Logistics Feedback Not clear Hard to hear Use microphone Good feedback I'm just confused how you think that you've prepared us for the homework or lab. In class today we learned about logical ANDs. Why the fuck are we learning that? Teach us assembly or something else that is actually useful. I agree these are easy; May be can get rid of binary operations next time Reviewing is still useful More useful things to come throughout the semester The goal is to learn 3

Logistics Declaring BACS major Applications are open to apply to declare the BACS Deadline is on Feb 20, 2017 Full details on how to apply are found here: http://bit.ly/apply-bacs-s17 4

Logistics Next Lab: In-lab quiz on lab machines during assigned lab times without assistance (TAs will be proctoring) Coding assignment: strlen, strsep https://archimedes.cs.virginia.edu/cs3330/c/lab1.php Interface is available outside of lab But only work done in lab will count We check IPs + submission times It's okay if you memorize the code, but we don't think that's best strategy" No homework due before it -- the homework is prepping for it Follow-up "lists in C" homework assignment 5

Reading for Next Week ISA s and Y86-64 4.1 Sequential Processor 4.2; 4.3.1 6

AGENDA Logistics Review of Abstractions Machine Language 7

LEVELS OF TRANSFORMATION Problem Algorithm Program ISA Microarchitecture Software Hardware Circuits Transistors 8

What is Computer Architecture ISA (Instruction Set Architecture) Agreed upon interface between software and hardware SW/compiler assumes, HW promises What the software writer needs to know to write and debug system/user programs Microarchitecture Specific implementation of an ISA Not visible to the software Microprocessor ISA, uarch, circuits Architecture = ISA + microarchitecture Problem Algorithm Program ISA Microarchitecture Circuits Transistors 9

How to interpret zeros and ones? At the lowest level, all the machine sees are zeros and ones How to interpret this strings of zeros and ones? ISA determines how to interpret the software instructions So that hardware can understand those Each bit in the instruction means different things 0110 0000 0000 0010 à What does it mean? 10

x86 format 11

ARM 12

So what language we can use that resembles the machine language? 0110 0000 0000 0010 à What does it mean? Problem Algorithm Program x += y à Higher-level language: C add %rbx, %rax à Assembly: X86-64 60 03 à Machine code ISA Microarchitecture Circuits Transistors 13

Summary Microarchitecture Specific implementation of an ISA Not visible to the software Microprocessor ISA, uarch, circuits Architecture = ISA + microarchitecture Example ISAs: Intel: x86, x86-64 ARM: Used in almost all mobile phones Code Forms: Machine Code: The byte-level programs that a processor executes Assembly Code: A text representation of machine code 14

AGENDA Logistics Review of Abstractions Machine Language 15

Assembly/Machine Code View CPU PC Registers Condition Codes Addresses Data Instructions Memory Code Data Stack Programmer-Visible State PC: Program counter Address of next instruction Called RIP (x86-64) Register file Heavily used program data Condition codes Store status information about most recent arithmetic or logical operation Used for conditional branching Memory Byte addressable array Code and user data Stack to support procedures Why do we need PC? 16

The Von Neumann Model/Architecture Also called stored program computer (instructions in memory). Two key properties: Stored program Instructions stored in a linear memory array Memory is unified between instructions and data The interpretation of a stored value depends on the control signals Sequential instruction processing One instruction processed (fetched, executed, and completed) at a time Program counter (instruction pointer) identifies the current instr. Program counter is advanced sequentially except for control transfer instructions 17

A Sample Program Address of the function sumstore 0000000000400595 <sumstore>: 400595: 53 push %rbx 400596: 48 89 d3 mov %rdx,%rbx 400599: e8 f2 ff ff ff callq 400590 <plus> 40059e: 48 89 03 mov %rax,(%rbx) 4005a1: 5b pop %rbx 4005a2: c3 retq PC will store the address of the next instruction 18

Assembly Language Operations Data types Registers Addressing modes Branches 19

Assembly Language: Operations Arithmetic Perform arithmetic function on register or memory data Data Transfer Transfer data between memory and register Load data from memory into register Store register data into memory Control Transfer control Unconditional jumps to/from procedures Conditional branches 20

Instructions movq Source, Dest: movq $42, (%rbx) memory[rbx] ß 42 subq %rax, %rbx rbx ß rbx rax addq 0x1000, %rax rax ß rax + memory[0x1000] addq $0x1000, %rax rax ß rax + 0x1000 21

Assembly Language Operations Data types Registers Addressing modes Branches 22

Data Types movq $42, (%rbx) memory[rbx] ß 42 q indicates length (8 bytes) l: 4; w: 2; b: 1 movl, movw, movb Type Specifier Bytes addressed BYTE 1 WORD 2 DWORD 4 QWORD 8 23

Assembly Language Operations Data types Registers Addressing modes Branches 24

x86-64 Integer Registers %rax %eax %r8 %r8d %rbx %ebx %r9 %r9d %rcx %ecx %r10 %r10d %rdx %edx %r11 %r11d %rsi %esi %r12 %r12d %rdi %edi %r13 %r13d %rsp %esp %r14 %r14d %rbp %ebp %r15 %r15d 25

Assembly Language Operations Data types Registers Addressing modes Branches 26

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 16 integer registers Ri: Index register: Any, except for %rsp S: Scale: 1, 2, 4, or 8 Special Cases (Rb,Ri) D(Rb,Ri) (Rb,Ri,S) Mem[Reg[Rb]+Reg[Ri]] Mem[Reg[Rb]+Reg[Ri]+D] Mem[Reg[Rb]+S*Reg[Ri]] 27

Carnegie Mellon Address Computation Examples %rdx %rcx 0xf000 0x0100 Expression Address Computation Address 0x8(%rdx) (%rdx,%rcx) (%rdx,%rcx,4) 0x80(,%rdx,2) 28

Carnegie Mellon Address Computation Examples %rdx %rcx 0xf000 0x0100 Expression Address Computation Address 0x8(%rdx) (%rdx,%rcx) (%rdx,%rcx,4) 0x80(,%rdx,2) 0xf000 + 0x8 0xf008 29

Carnegie Mellon Address Computation Examples %rdx %rcx 0xf000 0x0100 Expression Address Computation Address 0x8(%rdx) (%rdx,%rcx) (%rdx,%rcx,4) 0x80(,%rdx,2) 0xf000 + 0x8 0xf000 + 0x100 0xf008 0xf100 30

Carnegie Mellon Address Computation Examples %rdx %rcx 0xf000 0x0100 Expression Address Computation Address 0x8(%rdx) (%rdx,%rcx) (%rdx,%rcx,4) 0x80(,%rdx,2) 0xf000 + 0x8 0xf000 + 0x100 0xf000 + 4*0x100 0xf008 0xf100 0xf400 31

Carnegie Mellon Address Computation Examples %rdx %rcx 0xf000 0x0100 Expression Address Computation Address 0x8(%rdx) (%rdx,%rcx) (%rdx,%rcx,4) 0x80(,%rdx,2) 0xf000 + 0x8 0xf000 + 0x100 0xf000 + 4*0x100 2*0xf000 + 0x80 0xf008 0xf100 0xf400 0x1e080 32

Why so many modes? Advantage of more addressing modes: Enables better mapping of high-level constructs to the machine: some accesses are better expressed with a different mode à reduced number of instructions and code size Think array accesses Disadvantage: More work for the compiler More work for the microarchitect (Remember that these addressing modes need to be supported by the ISAs and implemented in the microarchitecture) 33

Assembly Language Operations Data types Registers Addressing modes Branches 34

Carnegie Mellon Branches Control: Condition codes Conditional branches Loops 35

Carnegie Mellon Review: Processor State (x86-64) Information about currently executing program Temporary data ( %rax, ) Location of runtime stack ( %rsp ) Location of current code control point ( %rip, ) Status of recent tests ( CF, ZF, SF, OF ) Current stack top Registers %rax %r8 %rbx %r9 %rcx %r10 %rdx %r11 %rsi %r12 %rdi %r13 %rsp %r14 %rbp %r15 %rip Instruction pointer CF ZF SF OF Condition codes 36

Condition Codes Carnegie Mellon Single bit registers CF SF ZF OF Carry Flag (for unsigned) Sign Flag (for signed) Zero Flag Overflow Flag (for signed) Implicitly set (think of it as side effect) by arithmetic operations Example: 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) 37

Carnegie Mellon Condition Codes (Explicit Setting: Compare) Explicit Setting by Compare Instruction cmpq Src2, Src1 cmpq 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) 38

Carnegie Mellon Branches Control: Condition codes Conditional branches Loops 39

Carnegie Mellon Jumping jx Instructions Jump to different part of code depending on condition codes jx jmp je jne jg jge jl jle Description Unconditional Equal / Zero Not Equal / Not Zero Greater (Signed) Greater or Equal (Signed) Less (Signed) Less or Equal (Signed) 40

Conditional Branch Example Carnegie Mellon long absdiff (long x, long y) long result; if (x > y) result = x-y; else result = y-x; absdiff: cmpq %rsi, %rdi # x-y jle.l4 movq %rdi, %rax subq %rsi, %rax # x-y ret.l4: # x <= y How should we go from conditional branch Register %rdi %rsi %rax Use(s) Argument x Argument y Return value to assembly movq code? %rsi, %rax subq %rdi, %rax # y-x ret 41

Step 1: Expressing with Goto Code Test the condition Label the else part Place the if part Jump to position designated by label Carnegie Mellon long absdiff (long x, long y) long result; if (x > y) result = x-y; else result = y-x; long absdiff_j(long x, long y) long result; int ntest = x <= y; if (ntest) goto Else; result = x-y; goto Done; Else: result = y-x; Done: 42

Step 1: Expressing with Goto Code Test the condition Label the else part Place the if part Jump to position designated by label Carnegie Mellon long absdiff (long x, long y) long result; if (x > y) result = x-y; else result = y-x; long absdiff_j(long x, long y) long result; int ntest = x <= y; if (ntest) goto Else; result = x-y; goto Done; Else: result = y-x; Done: 43

Step 1: Expressing with Goto Code Test the condition Label the else part Place the if part Jump to position designated by label Carnegie Mellon long absdiff (long x, long y) long result; if (x > y) result = x-y; else result = y-x; long absdiff_j(long x, long y) long result; int ntest = x <= y; if (ntest) goto Else; result = x-y; goto Done; Else: result = y-x; Done: 44

Step 1: Expressing with Goto Code Test the condition Label the else part Place the if part Jump to position designated by label Carnegie Mellon long absdiff (long x, long y) long result; if (x > y) result = x-y; else result = y-x; long absdiff_j(long x, long y) long result; int ntest = x <= y; if (ntest) goto Else; result = x-y; goto Done; Else: result = y-x; Done: 45

Step 2: Convert Goto Code to Assembly Carnegie Mellon long absdiff (long x, long y) long result; if (x > y) result = x-y; else result = y-x; long absdiff_j(long x, long y) long result; int ntest = x <= y; if (ntest) goto Else; result = x-y; goto Done; Else: result = y-x; Done: absdiff: cmpq %rsi, %rdi # x-y jle.l4 movq %rdi, %rax subq %rsi, %rax # x-y ret.l4: # x <= y movq %rsi, %rax subq %rdi, %rax # y-x ret 46

Expressing with Goto Code Carnegie Mellon long absdiff (long x, long y) long result; if (x > y) result = x-y; else result = y-x; long absdiff_j(long x, long y) long result; int ntest = x <= y; if (ntest) goto Else; result = x-y; goto Done; Else: result = y-x; Done: absdiff: cmpq %rsi, %rdi # x-y jle.l4 movq %rdi, %rax subq %rsi, %rax # x-y ret.l4: # x <= y movq %rsi, %rax subq %rdi, %rax # y-x ret 47

Expressing with Goto Code Carnegie Mellon long absdiff (long x, long y) long result; if (x > y) result = x-y; else result = y-x; long absdiff_j(long x, long y) long result; int ntest = x <= y; if (ntest) goto Else; result = x-y; goto Done; Else: result = y-x; Done: absdiff: cmpq %rsi, %rdi # x-y jle.l4 movq %rdi, %rax subq %rsi, %rax # x-y ret.l4: # x <= y movq %rsi, %rax subq %rdi, %rax # y-x ret 48

Expressing with Goto Code Carnegie Mellon long absdiff (long x, long y) long result; if (x > y) result = x-y; else result = y-x; long absdiff_j(long x, long y) long result; int ntest = x <= y; if (ntest) goto Else; result = x-y; goto Done; Else: result = y-x; Done: absdiff: cmpq %rsi, %rdi # x-y jle.l4 movq %rdi, %rax subq %rsi, %rax # x-y ret.l4: # x <= y movq %rsi, %rax subq %rdi, %rax # y-x ret 49

Carnegie Mellon Summary: Conditional Branch C Code val = Test? Then_Expr : Else_Expr; val = x>y? x-y : y-x; Goto Version ntest =!Test; if (ntest) goto Else; val = Then_Expr; goto Done; Else: val = Else_Expr; Done:... Create separate code regions for then & else expressions Execute appropriate one 50

Carnegie Mellon Branches Control: Condition codes Conditional branches Loops Do-while While for 51

1. Do-While Loop Example Step 1: Expressing with Goto Code C Code long pcount_do (unsigned long x) long result = 0; do result += x & 0x1; x >>= 1; while (x); Carnegie Mellon 52

1. Do-While Loop Example Step 1: Expressing with Goto Code C Code long pcount_do (unsigned long x) long result = 0; do result += x & 0x1; x >>= 1; while (x); Goto Version long pcount_goto (unsigned long x) long result = 0;.loop result += x & 0x1; x >>= 1; if(x) goto loop; Carnegie Mellon Declare the goto label where the body starts 53

1. Do-While Loop Example Step 1: Expressing with Goto Code C Code long pcount_do (unsigned long x) long result = 0; do result += x & 0x1; x >>= 1; while (x); Goto Version long pcount_goto (unsigned long x) long result = 0;.loop result += x & 0x1; x >>= 1; if(x) goto loop; Carnegie Mellon Use conditional branch to either continue looping or to exit loop 54

Step 2: Convert Goto Code to Assembly Goto Version long pcount_goto (unsigned long x) long result = 0; loop: result += x & 0x1; x >>= 1; if(x) goto loop; Carnegie Mellon movl $0, %eax # result = 0.L2: # loop: movq %rdi, %rdx andl $1, %edx # t = x & 0x1 addq %rdx, %rax # result += t shrq %rdi # x >>= 1 jne.l2 # if (x) goto loop ret Register %rdi %rax Use(s) Argument x result 55

1. Do-While Loop Example Goto Version long pcount_goto (unsigned long x) long result = 0; loop: result += x & 0x1; x >>= 1; if(x) goto loop; Carnegie Mellon movl $0, %eax # result = 0.L2: # loop: movq %rdi, %rdx andl $1, %edx # t = x & 0x1 addq %rdx, %rax # result += t shrq %rdi # x >>= 1 jne.l2 # if (x) goto loop ret Register %rdi %rax Use(s) Argument x result 56

1. Do-While Loop Example Goto Version long pcount_goto (unsigned long x) long result = 0; loop: result += x & 0x1; x >>= 1; if(x) goto loop; Carnegie Mellon movl $0, %eax # result = 0.L2: # loop: movq %rdi, %rdx andl $1, %edx # t = x & 0x1 addq %rdx, %rax # result += t shrq %rdi # x >>= 1 jne.l2 # if (x) goto loop ret Register %rdi %rax Use(s) Argument x result 57

1. Do-While Loop Example Goto Version long pcount_goto (unsigned long x) long result = 0; loop: result += x & 0x1; x >>= 1; if(x) goto loop; Carnegie Mellon movl $0, %eax # result = 0.L2: # loop: movq %rdi, %rdx andl $1, %edx # t = x & 0x1 addq %rdx, %rax # result += t shrq %rdi # x >>= 1 jne.l2 # if (x) goto loop ret Register %rdi %rax Use(s) Argument x result 58

1. General Do-While Translation Carnegie Mellon C Code do Body while (Test); Goto Version loop: Body if (Test) goto loop Body: Statement 1 ; Statement 2 ; Statement n ; 59

Carnegie Mellon Branches Control: Condition codes Conditional branches Loops Do-while While for 60

Carnegie Mellon 2. 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: 61

Carnegie Mellon Branches Control: Condition codes Conditional branches Loops Do-while While for 62

3. For Loop Form Carnegie Mellon General Form for (Init; Test; Update ) Body #define WSIZE 8*sizeof(int) long pcount_for (unsigned long x) size_t i; long result = 0; for (i = 0; i < WSIZE; i++) unsigned bit = (x >> i) & 0x1; result += bit; i = 0 i < WSIZE i++ Init Test Update Body unsigned bit = (x >> i) & 0x1; result += bit; 63

Carnegie Mellon 3. For Loop à While Loop for (Init; Test; Update ) Body For Version While Version Init; while (Test ) Body Update; 64

3. For-While Conversion Carnegie Me Init i = 0 Test i < WSIZE Update i++ Init; while (Test ) Body long pcount_for_while (unsigned long x) size_t i; long result = 0; Body unsigned bit = (x >> i) & 0x1; result += bit; Update; 65

3. For-While Conversion Carnegie Me Init i = 0 Test i < WSIZE Update i++ Init; while (Test ) Body long pcount_for_while (unsigned long x) size_t i; long result = 0; i = 0; Body unsigned bit = (x >> i) & 0x1; result += bit; Update; 66

3. For-While Conversion Carnegie Me Init i = 0 Test i < WSIZE Update i++ Init; while (Test ) Body long pcount_for_while (unsigned long x) size_t i; long result = 0; i = 0; while (i < WSIZE) Body unsigned bit = (x >> i) & 0x1; result += bit; Update; 67

3. For-While Conversion Carnegie Me Init i = 0 Test i < WSIZE Update i++ Body unsigned bit = (x >> i) & 0x1; result += bit; Init; while (Test ) Body Update; long pcount_for_while (unsigned long x) size_t i; long result = 0; i = 0; while (i < WSIZE) unsigned bit = (x >> i) & 0x1; result += bit; 68

3. For-While Conversion Carnegie Me Init i = 0 Test i < WSIZE Update i++ Body unsigned bit = (x >> i) & 0x1; result += bit; Init; while (Test ) Body Update; long pcount_for_while (unsigned long x) size_t i; long result = 0; i = 0; while (i < WSIZE) unsigned bit = (x >> i) & 0x1; result += bit; i++; 69

Carnegie Mellon 3 : For Loop à Do-While Loop For Version for (Init; Test; Update ) Body Do-While Version Init; Loop: Body Update; Test; goto Loop; 70

Carnegie Mellon 3 : For Loop Do-While Conversion Init i = 0 Init; long pcount_for_goto_dw (unsigned long x) size_t i; long result = 0; Test i < WSIZE Loop: Update Body i++ Body Update; unsigned bit = (x >> i) & 0x1; result += bit; Test; goto Loop; done: 71

3 : For Loop Do-While Conversion Carnegie Mellon Init i = 0 Test i < WSIZE Update Init; Loop: Body long pcount_for_goto_dw (unsigned long x) size_t i; long result = 0; i = 0; i++ Body unsigned bit = (x >> i) & 0x1; result += bit; Update; Test; goto Loop; done: 72

Carnegie Mellon 3 : For Loop Do-While Conversion Init i = 0 Test i < WSIZE Init; Loop: long pcount_for_goto_dw (unsigned long x) size_t i; long result = 0; i = 0; loop: Update Body i++ Body Update; unsigned bit = (x >> i) & 0x1; result += bit; Test; goto Loop; done: 73

Carnegie Mellon 3 : For Loop Do-While Conversion Init i = 0 Test i < WSIZE Update i++ Init; Loop: Body long pcount_for_goto_dw (unsigned long x) size_t i; long result = 0; i = 0; loop: unsigned bit = (x >> i) & 0x1; result += bit; Body Update; unsigned bit = (x >> i) & 0x1; result += bit; Test; goto Loop; done: 74

Carnegie Mellon 3 : For Loop Do-While Conversion Init i = 0 Test i < WSIZE Update i++ Body Init; Loop: Body Update; long pcount_for_goto_dw (unsigned long x) size_t i; long result = 0; i = 0; loop: unsigned bit = (x >> i) & 0x1; result += bit; i++; unsigned bit = (x >> i) & 0x1; result += bit; Test; goto Loop; done: 75

3 : For Loop Do-While Conversion Carnegie Mellon Init i = 0 Test i < WSIZE Update i++ Body unsigned bit = (x >> i) & 0x1; result += bit; Init; Loop: Body Update; Test; goto Loop; long pcount_for_goto_dw (unsigned long x) size_t i; long result = 0; i = 0; loop: unsigned bit = (x >> i) & 0x1; result += bit; i++; if (i < WSIZE) done: 76

Carnegie Mellon 3 : For Loop Do-While Conversion Init i = 0 Test i < WSIZE Update i++ Body Init; Loop: Body Update; long pcount_for_goto_dw (unsigned long x) size_t i; long result = 0; i = 0; loop: unsigned bit = (x >> i) & 0x1; result += bit; i++; unsigned bit = (x >> i) & 0x1; result += bit; Test; goto Loop; if (i < WSIZE) goto loop; done: 77

Carnegie Mellon 3 : For Loop Do-While Conversion Init i = 0 Test i < WSIZE Update i++ Init; Loop: Body long pcount_for_goto_dw (unsigned long x) size_t i; long result = 0; i = 0; loop: unsigned bit = (x >> i) & 0x1; result += bit; i++; Body Update; unsigned bit = (x >> i) & 0x1; result += bit; Test; goto Loop; if (i < WSIZE) goto loop; done: 78

Machine Language Summary Carnegie Mellon A text representation of machine code Three types of operations Arithmetic Data Transfer Control Can represent high-level branches Do-While, While, for 79

Machine Language CS 3330 Samira Khan University of Virginia Feb 2, 2017

Carnegie Mellon While Loop Example C Code long pcount_while (unsigned long x) long result = 0; while (x) result += x & 0x1; x >>= 1; Do-While Version long pcount_goto_dw (unsigned long x) long result = 0; if (!x) goto done; loop: result += x & 0x1; x >>= 1; if(x) goto loop; done: Initial conditional guards entrance to loop 81