University of Washington Roadmap 1 car *c = malloc(sizeof(car)); c->miles = 100; c->gals = 17; float mpg = get_mpg(c); free(c); Car c = new Car(); c.setMiles(100);

Slides:



Advertisements
Similar presentations
Machine Programming I: Basics
Advertisements

Machine-Level Programming I: Basics
University of Washington Instruction Set Architectures ISAs Brief history of processors and architectures C, assembly, machine code Assembly basics: registers,
Carnegie Mellon 1 Machine-Level Programming I: Basics /18-243: Introduction to Computer Systems 4 th Lecture, Sep. 2, 2010 Instructors: Randy Bryant.
Instruction Set Architectures
Carnegie Mellon 1 Machine-Level Programming I: Basics /18-213: Introduction to Computer Systems 5 th Lecture, Tue. May 27, 2015 Instructors: Nathaniel.
Machine-Level Programming I: Introduction Topics Assembly Programmer’s Execution Model Accessing Information Registers Memory Arithmetic operations CS.
Machine-Level Programming I: Introduction January 29, 2002 Topics Assembly Programmer’s Execution Model Accessing Information –Registers –Memory Arithmetic.
Machine-Level Programming I: Introduction Sept. 10, 2002 Topics Assembly Programmer’s Execution Model Accessing Information Registers Memory Arithmetic.
COMP3221: Microprocessors and Embedded Systems Lecture 2: Instruction Set Architecture (ISA) Lecturer: Hui Wu Session.
Machine-Level Programming I: Introduction Apr. 10, 2006 Topics Assembly Programmer’s Execution Model Accessing Information Registers Memory Arithmetic.
Machine-Level Programming I: Introduction Apr. 14, 2008 Topics Assembly Programmer’s Execution Model Accessing Information Registers Memory Arithmetic.
C Prog. To Object Code text text binary binary Code in files p1.c p2.c
Machine-Level Programming I: Introduction Sept. 10, 2002 Topics Assembly Programmer’s Execution Model Accessing Information Registers Memory Arithmetic.
Carnegie Mellon 1 Machine-Level Programming I: Basics /18-213: Introduction to Computer Systems 5 th Lecture, Sep. 11, 2012 Instructors: Dave O’Hallaron,
Lecture 7: Instruction Set Architecture CSE 30: Computer Organization and Systems Programming Winter 2014 Diba Mirza Dept. of Computer Science and Engineering.
1 Machine-Level Programming I: Basics Computer Systems Organization Andrew Case Slides adapted from Jinyang Li, Randy Bryant and Dave O’Hallaron.
Carnegie Mellon 1 Machine-Level Programming I: Basics Lecture, Feb. 14, 2013 These slides are from website which accompanies the.
MACHINE-LEVEL PROGRAMMING I: BASICS COMPUTER ARCHITECTURE AND ORGANIZATION.
Carnegie Mellon 1 Machine-Level Programming I: Basics /18-213: Introduction to Computer Systems 5 th Lecture, Jan 28, 2014 Instructors: Seth Copen.
1 Machine-Level Programming I: Basics Comp 21000: Introduction to Computer Organization & Systems Spring 2015 Instructor: John Barr * Modified slides from.
Introduction CS 104: Applied C++ What is Programming? For some given problem: __________ a solution for it -- identify, organize & store the problem's.
Lee CSCE 312 TAMU 1 Machine-Level Programming I: Basics Instructor: Dr. Hyunyoung Lee Based on slides provided by: Randy Bryant and Dave O’Hallaron.
Machine-Level Programming 1 Introduction Topics Assembly Programmer’s Execution Model Accessing Information Registers Memory Arithmetic operations.
Carnegie Mellon 1 Bryant and O’Hallaron, Computer Systems: A Programmer’s Perspective, Third Edition Machine-Level Programming I: Basics Sep. 15, 2015.
University of Washington Roadmap 1 car *c = malloc(sizeof(car)); c->miles = 100; c->gals = 17; float mpg = get_mpg(c); free(c); Car c = new Car(); c.setMiles(100);
University of Washington Today Finished up virtual memory On to memory allocation Lab 3 grades up HW 4 up later today. Lab 5 out (this afternoon): time.
Carnegie Mellon 1 Machine-Level Programming I: Basics Slides based on from those of Bryant and O’Hallaron.
Lec 4Systems Architecture1 Systems Architecture Lecture 4: Compilers, Assemblers, Linkers & Loaders Jeremy R. Johnson Anatole D. Ruslanov William M. Mongan.
University of Washington Basics of Machine Programming The Hardware/Software Interface CSE351 Winter 2013.
Introduction 1 (Read Chap. 1) What is Programming? For some given problem: design a solution for it -- identify, organize & store the problem's data --
1 COMP 2130 Introduction to Computer Systems Computing Science Thompson Rivers University Ref.: Carnegie Mellon, CSPP, Intel, AMD.
Machine-Level Programming 1 Introduction Topics Assembly Programmer’s Execution Model Accessing Information Registers Memory Arithmetic operations.
University of Washington Exceptional Control Flow The Hardware/Software Interface CSE351 Winter 2013.
Lecture 4 Assembly Language Topics Finish IEEE Floating Point multiplication, addition Lab 1 comments Assembly Language Intro January 25, 2011 CSCE 212.
University of Amsterdam Computer Systems – the instruction set architecture Arnoud Visser 1 Computer Systems The instruction set architecture.
University of Washington Today Lab1, how is it going?  Now due on Sunday HW 1 out! (Integer, FP, …) Luis out of town Monday (no class)  Spend the time.
1 Machine-Level Programming I: Basics Comp 21000: Introduction to Computer Organization & Systems Spring 2015 Instructor: John Barr * Modified slides from.
Carnegie Mellon 1 Bryant and O’Hallaron, Computer Systems: A Programmer’s Perspective, Third Edition Machine-Level Programming I: Basics CS140 – Computer.
Machine-Level Programming I: Introduction Jan. 30, 2001 Topics Assembly Programmer’s Execution Model Accessing Information –Registers –Memory Arithmetic.
Spring 2016Assembly Review Roadmap 1 car *c = malloc(sizeof(car)); c->miles = 100; c->gals = 17; float mpg = get_mpg(c); free(c); Car c = new Car(); c.setMiles(100);
Spring 2016Machine Code & C Roadmap 1 car *c = malloc(sizeof(car)); c->miles = 100; c->gals = 17; float mpg = get_mpg(c); free(c); Car c = new Car(); c.setMiles(100);
1 Binghamton University Machine-Level Programming I: Basics CS220: Computer Systems II.
Machine-Level Programming I: Basics
X86 Assembly - Data.
Instruction Set Architecture
Machine-Level Programming I:
Machine-Level Programming I:
Machine-Level Programming I: Basics
Final exam: Wednesday, March 20, 2:30pm
IA32 Processors Evolutionary Design
Roadmap C: Java: Assembly language: OS: Machine code: Computer system:
ISA's, Compilers, and Assembly
Roadmap C: Java: Assembly language: OS: Machine code: Computer system:
Machine-Level Programming 1 Introduction
C Prog. To Object Code text text binary binary Code in files p1.c p2.c
Machine-Level Programming I: Introduction Feb. 1, 2000
Machine-Level Programming I: Introduction
X86 Assembly - Data.
Machine-Level Programming: Introduction
Jeremy R. Johnson Anatole D. Ruslanov William M. Mongan
Machine-Level Programming I: Basics Comp 21000: Introduction to Computer Organization & Systems Instructor: John Barr * Modified slides from the book.
Machine-Level Programming I: Basics
Machine-Level Programming I: Basics Comp 21000: Introduction to Computer Organization & Systems Instructor: John Barr * Modified slides from the book.
Machine-Level Programming I:
Machine-Level Programming I:
Machine-Level Programming I: Basics Comp 21000: Introduction to Computer Organization & Systems Instructor: John Barr * Modified slides from the book.
The von Neumann Machine
Machine-Level Programming I: Introduction Sept. 10, 2002
Presentation transcript:

University of Washington Roadmap 1 car *c = malloc(sizeof(car)); c->miles = 100; c->gals = 17; float mpg = get_mpg(c); free(c); Car c = new Car(); c.setMiles(100); c.setGals(17); float mpg = c.getMPG(); get_mpg: pushq %rbp movq %rsp, %rbp... popq %rbp ret Java: C: Assembly language: Machine code: Computer system: OS: Memory & data Integers & floats Machine code & C x86 assembly Procedures & stacks Arrays & structs Memory & caches Processes Virtual memory Memory allocation Java vs. C Winter 2015 Machine Code & C

University of Washington Basics of Machine Programming and Architecture What is an ISA (Instruction Set Architecture)? A brief history of Intel processors and architectures C, assembly, machine code x86 basics: registers 2Winter 2015 Machine Code & C

University of Washington 3 What makes programs run fast? Hardware User program in C Assembler C compiler Code TimeCompile TimeRun Time.exe file.c file Translation Winter 2015 Machine Code & C

University of Washington Translation Impacts Performance The time required to execute a program depends on:  The program (as written in C, for instance)  The compiler: what set of assembler instructions it translates the C program into  The instruction set architecture (ISA): what set of instructions it makes available to the compiler  The hardware implementation: how much time it takes to execute an instruction 4 What should the HW/SW interface contain? Winter 2015 Machine Code & C

University of Washington Instruction Set Architectures The ISA defines:  The system’s state (e.g. registers, memory, program counter)  The instructions the CPU can execute  The effect that each of these instructions will have on the system state 5 CPU Memory PC Registers Winter 2015 Machine Code & C

University of Washington General ISA Design Decisions Instructions  What instructions are available? What do they do?  How are they encoded? Registers  How many registers are there?  How wide are they? Memory  How do you specify a memory location? 6Winter 2015 Machine Code & C

University of Washington X86 ISA Processors that implement the x86 ISA completely dominate the server, desktop and laptop markets Evolutionary design  Backwards compatible up until 8086, introduced in 1978  Added more features as time goes on Complex instruction set computer (CISC)  Many different instructions with many different formats  But, only small subset encountered with Linux programs  (as opposed to Reduced Instruction Set Computers (RISC), which use simpler instructions) 7Winter 2015 Machine Code & C

University of Washington Intel x86 Evolution: Milestones 8 NameDateTransistorsMHz K5-10  First 16-bit processor. Basis for IBM PC & DOS  1MB address space K16-33  First 32 bit processor, referred to as IA32  Added “flat addressing”  Capable of running Unix  32-bit Linux/gcc targets i386 by default Pentium 4F M  First 64-bit Intel x86 processor, referred to as x86-64 Winter 2015 Machine Code & C

University of Washington Machine Evolution  M  Pentium M  Pentium/MMX M  PentiumPro M  Pentium III M  Pentium M  Core 2 Duo M  Core i M Added Features  Instructions to support multimedia operations  Parallel operations on 1, 2, and 4-byte data  Instructions to enable more efficient conditional operations  More cores! 9 Intel x86 Processors Intel Core i7 Winter 2015 Machine Code & C

University of Washington More information References for Intel processor specifications:  Intel’s “automated relational knowledgebase”:   Wikipedia:  Winter 2015 Machine Code & C

University of Washington x86 Clones: Advanced Micro Devices (AMD) Same ISA, different implementation Historically  AMD has followed just behind Intel  A little bit slower, a lot cheaper Then  Recruited top circuit designers from Digital Equipment and other downward trending companies  Built Opteron: tough competitor to Pentium 4  Developed x86-64, their own extension of x86 to 64 bits 11Winter 2015 Machine Code & C

University of Washington Intel’s Transition to 64-Bit Intel attempted radical shift from IA32 to IA64 (2001)  Totally different architecture (Itanium) and ISA than x86  Executes IA32 code only as legacy  Performance disappointing AMD stepped in with evolutionary solution (2003)  x86-64 (also called “AMD64”) Intel felt obligated to focus on IA64  Hard to admit mistake or that AMD is better Intel announces “EM64T” extension to IA32 (2004)  Extended Memory 64-bit Technology  Almost identical to AMD64! Today: all but low-end x86 processors support x86-64  But, lots of code out there is still just IA32 12Winter 2015 Machine Code & C

University of Washington Our Coverage in 351 IA32  The traditional 32-bit x86 ISA x86-64  The new 64-bit x86 ISA – all lab assignments use x86-64! 13Winter 2015 Machine Code & C

University of Washington Definitions Architecture: (also instruction set architecture or ISA) The parts of a processor design that one needs to understand to write assembly code  “What is directly visible to software” Microarchitecture: Implementation of the architecture  CSE 352 Is cache size “architecture”? How about CPU frequency? And number of registers? 14Winter 2015 Machine Code & C

University of Washington CPU Assembly Programmer’s View Programmer-Visible State  PC: Program counter  Address of next instruction  Called “EIP” (IA32) or “RIP” (x86-64)  Register file  Heavily used program data  Condition codes  Store status information about most recent arithmetic operation  Used for conditional branching PC Registers Memory Object Code Program Data OS Data Addresses Data Instructions Stack Condition Codes Memory  Byte addressable array  Code, user data, (some) OS data  Includes stack used to support procedures (we’ll come back to that) 15Winter 2015 Machine Code & C

University of Washington text binary Compiler ( gcc -S ) Assembler ( gcc or as ) Linker ( gcc or ld ) C program ( p1.c p2.c ) Asm program ( p1.s p2.s ) Object program ( p1.o p2.o ) Executable program ( p ) Static libraries (.a ) Turning C into Object Code Code in files p1.c p2.c Compile with command: gcc -O1 p1.c p2.c -o p  Use basic optimizations ( -O1 )  Put resulting machine code in file p 16Winter 2015 Machine Code & C

University of Washington Jan 21 Announcements  Lab 2 out  No class on Friday, watch the video assignment! Compiling C->Assembly Assembly programming Winter Machine Code & C

University of Washington Compiling Into Assembly 18 C Code int sum(int x, int y) { int t = x+y; return t; } Generated IA32 Assembly sum: pushl %ebp movl %esp,%ebp movl 12(%ebp),%eax addl 8(%ebp),%eax movl %ebp,%esp popl %ebp ret Obtain with command gcc -O1 -S code.c Produces file code.s Winter 2015 Machine Code & C

University of Washington Machine Instruction Example 19 C Code: add two signed integers Assembly  Add two 4-byte integers  “Long” words in GCC speak  Same instruction whether signed or unsigned  Operands: x :Register %eax y :MemoryM[ %ebp+8] t :Register %eax - Return function value in %eax Object Code  3-byte instruction  Stored at address 0x int t = x+y; addl 8(%ebp),%eax 0x401046: Similar to expression: x += y More precisely: int eax; int *ebp; eax += ebp[2] Winter 2015 Machine Code & C

University of Washington Code for sum 0x : 0x55 0x89 0xe5 0x8b 0x45 0x0c 0x03 0x45 0x08 0x89 0xec 0x5d 0xc3 Object Code 20 Assembler  Translates.s into.o  Binary encoding of each instruction  Nearly-complete image of executable code  Missing links between code in different files Linker  Resolves references between object files and (re)locates their data  Combines with static run-time libraries  E.g., code for malloc, printf  Some libraries are dynamically linked  Linking occurs when program begins execution Total of 13 bytes Each instruction 1, 2, or 3 bytes Starts at address 0x Not at all obvious where each instruction starts and ends Winter 2015 Machine Code & C

University of Washington Disassembled : 0:55 push %ebp 1:89 e5 mov %esp,%ebp 3:8b 45 0c mov 0xc(%ebp),%eax 6: add 0x8(%ebp),%eax 9:89 ec mov %ebp,%esp b:5d pop %ebp c:c3 ret Disassembling Object Code Disassembler objdump -d p  Useful tool for examining object code ( man 1 objdump )  Analyzes bit pattern of series of instructions (delineates instructions)  Produces near-exact rendition of assembly code  Can be run on either p (complete executable) or p1.o / p2.o file 21Winter 2015 Machine Code & C

University of Washington Disassembled 0x :push %ebp 0x :mov %esp,%ebp 0x :mov 0xc(%ebp),%eax 0x :add 0x8(%ebp),%eax 0x :mov %ebp,%esp 0x40104b :pop %ebp 0x40104c :ret Alternate Disassembly 22 Within gdb debugger gdb p disassemble sum (disassemble function) x/13b sum (examine the 13 bytes starting at sum ) Object 0x401040: 0x55 0x89 0xe5 0x8b 0x45 0x0c 0x03 0x45 0x08 0x89 0xec 0x5d 0xc3 Winter 2015 Machine Code & C

University of Washington What Can be Disassembled? Anything that can be interpreted as executable code Disassembler examines bytes and reconstructs assembly source 23 % objdump -d WINWORD.EXE WINWORD.EXE: file format pei-i386 No symbols in "WINWORD.EXE". Disassembly of section.text: : :55 push %ebp :8b ec mov %esp,%ebp :6a ff push $0xffffffff : push $0x a:68 91 dc 4c 30 push $0x304cdc91 Winter 2015 Machine Code & C