CSC 252: Computer Organization Spring 2018: Lecture 5
|
|
- Mae Maxwell
- 5 years ago
- Views:
Transcription
1 CSC 252: Computer Organization Spring 2018: Lecture 5 Instructor: Yuhao Zhu Department of Computer Science University of Rochester Action Items: Assignment 1 is due tomorrow, midnight Assignment 2 is out Trivia 2 is due on the coming Tues, noon
2 Carnegie Mellon Announcement 2
3 Carnegie Mellon Announcement Programming Assignment 2 is out Due on Feb 16, 11:59 PM Trivia due Feb 6, noon You have 3 slip days Trivia Due 2
4 Carnegie Mellon Announcement Programming Assignment 2 is out Due on Feb 16, 11:59 PM Trivia due Feb 6, noon You have 3 slip days Read the instructions before getting started!!! You get 1/4 point off for every wrong answer Maxed out at 10 2
5 Carnegie Mellon Floating Point Review v = ( 1) s x 1.frac x 2 E s exp frac 3
6 Carnegie Mellon Floating Point Review v = ( 1) s x 1.frac x 2 E s exp frac Denormalized s exp frac Value Value x x 2-2 3/16 Denormalized E = (exp + 1) bias M = 0.frac 3
7 Carnegie Mellon Floating Point Review v = ( 1) s x 1.frac x 2 E s exp frac Denormalized E = (exp + 1) bias M = 0.frac Normalized E = exp bias M = 1.frac Denormalized Normalized s exp frac Value Value x x 2-2 3/ x 2-2 1/ x 2-2 7/ x 2-1 1/ x 2-1 7/ x x / x x / x x
8 Carnegie Mellon Floating Point Review v = ( 1) s x 1.frac x 2 E s exp frac Denormalized E = (exp + 1) bias M = 0.frac Normalized E = exp bias M = 1.frac Denormalized Normalized Special Value s exp frac Value Value x x 2-2 3/ x 2-2 1/ x 2-2 7/ x 2-1 1/ x 2-1 7/ x x / x x / x x infinite infinite NaN NaN 3
9 Carnegie Mellon Floating Point Review Denormalized Normalized Special Value s exp frac Value Value x x 2-2 3/ x 2-2 1/ x 2-2 7/ x 2-1 1/ x 2-1 7/ x x / x x / x x infinite infinite NaN NaN 4
10 Carnegie Mellon Floating Point Review If you do an integer increment on a positive FP number, you get the next larger FP number. Denormalized Normalized Special Value s exp frac Value Value x x 2-2 3/ x 2-2 1/ x 2-2 7/ x 2-1 1/ x 2-1 7/ x x / x x / x x infinite infinite NaN NaN 4
11 Carnegie Mellon Floating Point Review If you do an integer increment on a positive FP number, you get the next larger FP number. Bit patterns representing nonnegative numbers are ordered the same way as integers, so could use regular integer comparison. Denormalized Normalized Special Value s exp frac Value Value x x 2-2 3/ x 2-2 1/ x 2-2 7/ x 2-1 1/ x 2-1 7/ x x / x x / x x infinite infinite NaN NaN 4
12 Carnegie Mellon Floating Point Review If you do an integer increment on a positive FP number, you get the next larger FP number. Bit patterns representing nonnegative numbers are ordered the same way as integers, so could use regular integer comparison. You don t get this property if: exp is interpreted as signed exp and frac are swapped Denormalized Normalized Special Value s exp frac Value Value x x 2-2 3/ x 2-2 1/ x 2-2 7/ x 2-1 1/ x 2-1 7/ x x / x x / x x infinite infinite NaN NaN 4
13 Carnegie Mellon Floating Point in C Fixed point (implicit binary point){ SP floating point DP floating point C Data Type Bits Max Value Max Value (Decimal) char short int long ~ float 32 ( ) ~ double 64 ( ) ~
14 Carnegie Mellon Floating Point in C Fixed point (implicit binary point){ SP floating point DP floating point C Data Type Bits Max Value Max Value (Decimal) char short int long ~ float 32 ( ) ~ double 64 ( ) ~ To represent 2 31 in fixed-point, you need at least 32 bits Because fixed-point is a weighted positional representation In floating-point, we directly encode the exponent Floating point is based on scientific notation Encoding 31 only needs 7 bits in the exp field 5
15 Carnegie Mellon Floating Point Conversions/Casting in C double/float int Truncates fractional part Like rounding toward zero Not defined when out of range or NaN: Generally sets to TMin 6
16 Carnegie Mellon Floating Point Conversions/Casting in C double/float int Truncates fractional part Like rounding toward zero Not defined when out of range or NaN: Generally sets to TMin int float Can t guarantee exact casting. Will round according to rounding mode s exp frac 1 8-bit 23-bit 6
17 Carnegie Mellon Floating Point Conversions/Casting in C double/float int Truncates fractional part Like rounding toward zero Not defined when out of range or NaN: Generally sets to TMin int float Can t guarantee exact casting. Will round according to rounding mode s exp frac int double 1 8-bit 23-bit Exact conversion s exp frac 1 11-bit 52-bit 6
18 Carnegie Mellon So far in 252 C Program int, float if, else +, -, >> 7
19 Carnegie Mellon So far in 252 C Program int, float if, else +, -, >> Machine Code
20 Carnegie Mellon So far in 252 C Program int, float if, else +, -, >> Machine Code Processor Ripple-carry Adder 7
21 Carnegie Mellon So far in 252 C Program int, float if, else +, -, >> Machine Code Processor Ripple-carry Adder Transistor NAND Gate NOR Gate 7
22 Carnegie Mellon So far in 252 Compiler C Program Assembly Program int, float if, else +, -, >> ret, call movq, addq jmp, jne Machine Code Processor Ripple-carry Adder Transistor NAND Gate NOR Gate 7
23 Carnegie Mellon So far in 252 Compiler C Program Assembly Program Semantically Equivalent int, float if, else +, -, >> ret, call movq, addq jmp, jne Machine Code Processor Ripple-carry Adder Transistor NAND Gate NOR Gate 7
24 Carnegie Mellon So far in 252 Compiler Assembler C Program Assembly Program Machine Code Semantically Equivalent int, float if, else +, -, >> ret, call movq, addq jmp, jne Processor Ripple-carry Adder Transistor NAND Gate NOR Gate 7
25 Carnegie Mellon So far in 252 Compiler Assembler C Program Assembly Program Machine Code Semantically Equivalent Semantically Equivalent int, float if, else +, -, >> ret, call movq, addq jmp, jne Processor Ripple-carry Adder Transistor NAND Gate NOR Gate 7
26 Carnegie Mellon So far in 252 High-Level Language C Program Assembly Program Machine Code Processor Transistor 8
27 Carnegie Mellon So far in 252 High-Level Language Instruction Set Architecture (ISA) C Program Assembly Program Machine Code ISA: Assembly programmers view of a computer Provide all info for someone wants to write assembly/machine code Contract between assembly/ machine code and processor Processor Transistor 8
28 Carnegie Mellon So far in 252 High-Level Language Instruction Set Architecture (ISA) C Program Assembly Program Machine Code Processor ISA: Assembly programmers view of a computer Provide all info for someone wants to write assembly/machine code Contract between assembly/ machine code and processor Processors execute machine code (binary). Assembly program is merely a text representation of machine code Transistor 8
29 Carnegie Mellon So far in 252 High-Level Language Instruction Set Architecture (ISA) Microarchitecture Circuit C Program Assembly Program Machine Code Processor Transistor ISA: Assembly programmers view of a computer Provide all info for someone wants to write assembly/machine code Contract between assembly/ machine code and processor Processors execute machine code (binary). Assembly program is merely a text representation of machine code Microarchitecture: Hardware implementation of the ISA (with the help of circuit technologies) 8
30 Carnegie Mellon This Module (4 Lectures) High-Level Language Instruction Set Architecture (ISA) Microarchitecture Circuit C Program Assembly Program Machine Code Processor Transistor Assembly Programming Explain how various C constructs are implemented in assembly code Effectively translating from C to assembly program manually Helps us understand how compilers work Helps us understand how assemblers work Microarchitecture is the topic of the next module 9
31 Today: Assembly Programming I: Basics Different ISAs and history behind them C, assembly, machine code Move operations (and addressing modes) 10
32 Instruction Set Architecture 11
33 Instruction Set Architecture There used to be many ISAs x86, ARM, Power/PowerPC, Sparc, MIPS, IA64, z Very consolidated today: ARM for mobile, x86 for others 11
34 Instruction Set Architecture There used to be many ISAs x86, ARM, Power/PowerPC, Sparc, MIPS, IA64, z Very consolidated today: ARM for mobile, x86 for others There are even more microarchitectures Apple/Samsung/Qualcomm have their own microarchitecture (implementation) of the ARM ISA Intel and AMD have different microarchitectures for x86 11
35 Instruction Set Architecture There used to be many ISAs x86, ARM, Power/PowerPC, Sparc, MIPS, IA64, z Very consolidated today: ARM for mobile, x86 for others There are even more microarchitectures Apple/Samsung/Qualcomm have their own microarchitecture (implementation) of the ARM ISA Intel and AMD have different microarchitectures for x86 ISA is lucrative business: ARM s Business Model Patent the ISA, and then license the ISA Every implementer pays a royalty to ARM Apple/Samsung pays ARM whenever they sell a smartphone The ARM Diaries, Part 1: How ARM s Business Model Works: the-arm-diaries-part-1-how-arms-business-model-works 11
36 Intel x86 ISA Dominate laptop/desktop/cloud market 12
37 Intel x86 ISA Dominate laptop/desktop/cloud market 12
38 Intel x86 ISA Dominate laptop/desktop/cloud market 12
39 Intel x86 ISA Evolution (Milestones) Evolutionary design: Added more features as time goes on 13
40 Intel x86 ISA Evolution (Milestones) Evolutionary design: Added more features as time goes on Date Feature Notable Implementation bit ISA bit ISA (Basis for IBM PC & DOS) Add Floating Point instructions bit ISA (Refer to as IA32) Add Multi-Media extension (MMX) Pentium/MMX 1999 Add Streaming SIMD Extension (SSE) Pentium III 2001 Intel s first attempt at 64-bit ISA (IA64, failed) Itanium 2004 Implement AMD s 64-bit ISA (x86-64, AMD64) Pentium 4E 2008 Add Advanced Vector Extension (AVE) Core i7 Sandy Bridge 13
41 Intel x86 ISA Evolution (Milestones) Evolutionary design: Added more features as time goes on Date Feature Notable Implementation bit ISA bit ISA (Basis for IBM PC & DOS) Add Floating Point instructions bit ISA (Refer to as IA32) Add Multi-Media extension (MMX) Pentium/MMX 1999 Add Streaming SIMD Extension (SSE) Pentium III 2001 Intel s first attempt at 64-bit ISA (IA64, failed) Itanium 2004 Implement AMD s 64-bit ISA (x86-64, AMD64) Pentium 4E 2008 Add Advanced Vector Extension (AVE) Core i7 Sandy Bridge 13
42 Backward Compatibility Binary executable generated for an older processor can execute on a newer processor Allows legacy code to be executed on newer machines Buy new machines without changing the software x86 is backward compatible up until 8086 (16-bit ISA) i.e., an 8086 binary executable can be executed on any of today s x86 machines Great for users, nasty for processor implementers Every instruction you put into the ISA, you are stuck with it FOREVER 14
43 x86 Clones: Advanced Micro Devices (AMD) Historically AMD build processors for x86 ISA A little bit slower, a lot cheaper Then Recruited top circuit designers from Digital Equipment Corp. and other downward trending companies Developed x86-64, their own 64-bit x86 extension to IA32 Built first 1 GHz CPU Intel felt hard to admit mistake or that AMD was better 2004: Intel Announces EM64T extension to IA32 Almost identical to x86-64! Today s 64-bit x86 ISA is basically AMD s original proposal 15
44 x86 Clones: Advanced Micro Devices (AMD) Today: Holding up not too badly 16
45 x86 Clones: Advanced Micro Devices (AMD) Today: Holding up not too badly 16
46 x86 Clones: Advanced Micro Devices (AMD) Today: Holding up not too badly 16
47 Our Coverage IA32 The traditional x86 2 nd edition of the textbook x86-64 The standard CSUG machine 3 rd edition of the textbook Our focus 17
48 Aside: Moore s Law More instructions require more transistors to implement 18
49 Aside: Moore s Law More instructions require more transistors to implement 18
50 Aside: Moore s Law More instructions require more transistors to implement 18
51 Aside: Moore s Law More instructions require more transistors to implement 19
52 Aside: Moore s Law More instructions require more transistors to implement Gordon Moore in 1965 predicted that the number of transistors doubles every year 19
53 Aside: Moore s Law More instructions require more transistors to implement Gordon Moore in 1965 predicted that the number of transistors doubles every year 19
54 Aside: Moore s Law More instructions require more transistors to implement Gordon Moore in 1965 predicted that the number of transistors doubles every year 19
55 Aside: Moore s Law More instructions require more transistors to implement Gordon Moore in 1965 predicted that the number of transistors doubles every year 19
56 Aside: Moore s Law More instructions require more transistors to implement Gordon Moore in 1965 predicted that the number of transistors doubles every year In 1975 he revised the prediction to doubling every 2 years 19
57 Aside: Moore s Law More instructions require more transistors to implement Gordon Moore in 1965 predicted that the number of transistors doubles every year In 1975 he revised the prediction to doubling every 2 years Today s widely-known Moore s Law: number of transistors double about every 18 months Moore never used the number 18 19
58 Aside: Moore s Law 20
59 Aside: Moore s Law Question: why is transistor count increasing but computers are becoming smaller? 20
60 Aside: Moore s Law Question: why is transistor count increasing but computers are becoming smaller? Because transistors are becoming smaller 20
61 Aside: Moore s Law Question: why is transistor count increasing but computers are becoming smaller? Because transistors are becoming smaller ~1.4x smaller each dimension(1.4 2 ~ 2) 20
62 Aside: Moore s Law Question: why is transistor count increasing but computers are becoming smaller? Because transistors are becoming smaller ~1.4x smaller each dimension(1.4 2 ~ 2) Moore s Law is: 20
63 Aside: Moore s Law Question: why is transistor count increasing but computers are becoming smaller? Because transistors are becoming smaller ~1.4x smaller each dimension(1.4 2 ~ 2) Moore s Law is: A law of physics? 20
64 Aside: Moore s Law Question: why is transistor count increasing but computers are becoming smaller? Because transistors are becoming smaller ~1.4x smaller each dimension(1.4 2 ~ 2) Moore s Law is: A law of physics? No 20
65 Aside: Moore s Law Question: why is transistor count increasing but computers are becoming smaller? Because transistors are becoming smaller ~1.4x smaller each dimension(1.4 2 ~ 2) Moore s Law is: A law of physics? A law of circuits? No 20
66 Aside: Moore s Law Question: why is transistor count increasing but computers are becoming smaller? Because transistors are becoming smaller ~1.4x smaller each dimension(1.4 2 ~ 2) Moore s Law is: A law of physics? A law of circuits? No No 20
67 Aside: Moore s Law Question: why is transistor count increasing but computers are becoming smaller? Because transistors are becoming smaller ~1.4x smaller each dimension(1.4 2 ~ 2) Moore s Law is: A law of physics? A law of circuits? A law of economy? No No 20
68 Aside: Moore s Law Question: why is transistor count increasing but computers are becoming smaller? Because transistors are becoming smaller ~1.4x smaller each dimension(1.4 2 ~ 2) Moore s Law is: A law of physics? A law of circuits? A law of economy? No No Yes 20
69 Aside: Moore s Law Question: why is transistor count increasing but computers are becoming smaller? Because transistors are becoming smaller ~1.4x smaller each dimension(1.4 2 ~ 2) Moore s Law is: A law of physics? A law of circuits? A law of economy? No No Yes 20
70 Aside: Moore s Law Question: why is transistor count increasing but computers are becoming smaller? Because transistors are becoming smaller ~1.4x smaller each dimension(1.4 2 ~ 2) Moore s Law is: A law of physics? A law of circuits? A law of economy? No No Yes 20
71 Aside: Moore s Law Question: why is transistor count increasing but computers are becoming smaller? Because transistors are becoming smaller ~1.4x smaller each dimension(1.4 2 ~ 2) Moore s Law is: A law of physics? A law of circuits? A law of economy? A law of psychology? No No Yes 20
72 Aside: Moore s Law Question: why is transistor count increasing but computers are becoming smaller? Because transistors are becoming smaller ~1.4x smaller each dimension(1.4 2 ~ 2) Moore s Law is: A law of physics? A law of circuits? A law of economy? A law of psychology? No No Yes Yes 20
73 Aside: Moore s Law Question: why is transistor count increasing but computers are becoming smaller? Because transistors are becoming smaller ~1.4x smaller each dimension(1.4 2 ~ 2) Moore s Law is: A law of physics? A law of circuits? A law of economy? A law of psychology? No No Yes Yes Questions? 20
74 Today: Assembly Programming I: Basics Different ISAs and history behind them C, assembly, machine code Move operations (and addressing modes) 21
75 Assembly Code s View of Computer: ISA 22
76 Assembly Code s View of Computer: ISA Assembly Programmer s Perspective of a Computer CPU Memory 22
77 Assembly Code s View of Computer: ISA Assembly Programmer s Perspective of a Computer CPU Memory Code Data Stack (Byte Addressable) Memory Code: instructions Data Stack to support function call 22
78 Assembly Code s View of Computer: ISA Assembly Programmer s Perspective of a Computer CPU Memory Code Data Stack (Byte Addressable) Memory Code: instructions Data Stack to support function call Data 22
79 Assembly Code s View of Computer: ISA Assembly Programmer s Perspective of a Computer CPU Memory Code Data Stack (Byte Addressable) Memory Code: instructions Data Stack to support function call Data 0x53 0x48 0x89 0xd3 22
80 Assembly Code s View of Computer: ISA Assembly Programmer s Perspective of a Computer CPU Memory Code Data Stack (Byte Addressable) Memory Code: instructions Data Stack to support function call Code (Instructions) Data Instruction is the fundamental unit of work. All instructions are coded as bits (just like data!) 0x78 0xfe 0xe3 0x05 22
81 Assembly Code s View of Computer: ISA Assembly Programmer s Perspective of a Computer CPU Memory Code Data Stack (Byte Addressable) Memory Code: instructions Data Stack to support function call Code (Instructions) Data Stack 0x53 0x48 0x89 0xd3 22
82 Assembly Code s View of Computer: ISA Assembly Programmer s Perspective of a Computer CPU Register File Memory Code Data Stack (Byte Addressable) Memory Code: instructions Data Stack to support function call Register file Faster memory (e.g., 0.5 ns vs. 15 ns) Small memory (e.g., 128 B vs. 16 GB) Heavily used program data 22
83 x86-64 Integer Register File 8 Bytes %rax %r8 %rbx %rcx %rdx %rsi %rdi %rsp %rbp %r9 %r10 %r11 %r12 %r13 %r14 %r15 23
84 x86-64 Integer Register File Lower-half of each register can be independently addressed (until 8 bytes) 24
85 x86-64 Integer Register File Lower-half of each register can be independently addressed (until 8 bytes) %rax 8 Bytes 24
86 x86-64 Integer Register File Lower-half of each register can be independently addressed (until 8 bytes) %rax %eax 8 Bytes 4 Bytes 24
87 x86-64 Integer Register File Lower-half of each register can be independently addressed (until 8 bytes) %rax %eax 8 Bytes %ax 4 Bytes 2 Bytes 24
88 x86-64 Integer Register File Lower-half of each register can be independently addressed (until 8 bytes) %rax %eax %ax %al 8 Bytes 4 Bytes 2 Bytes 1 B 24
89 x86-64 Integer Register File Lower-half of each register can be independently addressed (until 8 bytes) %rax %eax %ax %al C Data Type Size (Bytes) char 1 short 2 int 4 long 8 Pointer 8 8 Bytes 4 Bytes 2 Bytes 1 B 24
90 x86-64 Integer Register File Lower-half of each register can be independently addressed (until 8 bytes) %rax %eax %ax %al C Data Type Size (Bytes) char 1 short 2 8 Bytes 4 Bytes 2 Bytes 1 B int 4 long 8 Pointer 8 Floating point data is stored in a separate set of register file (in 3 lectures ) 24
91 Assembly Code s View of Computer: ISA Assembly Programmer s Perspective of a Computer CPU Register File Memory Code Data Stack (Byte Addressable) Memory Code: instructions Data Stack to support function call Register file Faster memory (e.g., 0.5 ns vs. 15 ns) Small memory (e.g., 128 B vs. 16 GB) Heavily used program data 25
92 Assembly Code s View of Computer: ISA Assembly Programmer s Perspective of a Computer CPU PC Register File Memory Code Data Stack (Byte Addressable) Memory Code: instructions Data Stack to support function call Register file Faster memory (e.g., 0.5 ns vs. 15 ns) Small memory (e.g., 128 B vs. 16 GB) PC: Program counter A special register containing address of next instruction Called RIP in x86-64 Heavily used program data 25
93 Assembly Code s View of Computer: ISA Assembly Programmer s Perspective of a Computer CPU PC Register File Addresses Memory Code Data Stack (Byte Addressable) Memory Code: instructions Data Stack to support function call Register file Faster memory (e.g., 0.5 ns vs. 15 ns) Small memory (e.g., 128 B vs. 16 GB) PC: Program counter A special register containing address of next instruction Called RIP in x86-64 Heavily used program data 25
94 Assembly Code s View of Computer: ISA Assembly Programmer s Perspective of a Computer CPU PC Register File Addresses Instructions Memory Code Data Stack (Byte Addressable) Memory Code: instructions Data Stack to support function call Register file Faster memory (e.g., 0.5 ns vs. 15 ns) Small memory (e.g., 128 B vs. 16 GB) PC: Program counter A special register containing address of next instruction Called RIP in x86-64 Heavily used program data 25
95 Assembly Code s View of Computer: ISA Assembly Programmer s Perspective of a Computer CPU PC Register File Addresses Data Instructions Memory Code Data Stack (Byte Addressable) Memory Code: instructions Data Stack to support function call Register file Faster memory (e.g., 0.5 ns vs. 15 ns) Small memory (e.g., 128 B vs. 16 GB) PC: Program counter A special register containing address of next instruction Called RIP in x86-64 Heavily used program data 25
96 Assembly Code s View of Computer: ISA Assembly Programmer s Perspective of a Computer CPU PC ALU Register File Addresses Data Instructions Memory Code Data Stack (Byte Addressable) Memory Code: instructions Data Stack to support function call Register file Faster memory (e.g., 0.5 ns vs. 15 ns) Small memory (e.g., 128 B vs. 16 GB) PC: Program counter A special register containing address of next instruction Called RIP in x86-64 Arithmetic logic unit (ALU) Where computation happens Heavily used program data 25
97 Assembly Code s View of Computer: ISA Assembly Programmer s Perspective of a Computer CPU PC ALU Register File Condition Codes Addresses Data Instructions Memory Code Data Stack (Byte Addressable) Memory Code: instructions Data Stack to support function call Register file Faster memory (e.g., 0.5 ns vs. 15 ns) Small memory (e.g., 128 B vs. 16 GB) Heavily used program data PC: Program counter A special register containing address of next instruction Called RIP in x86-64 Arithmetic logic unit (ALU) Where computation happens Condition codes Store status information about most recent arithmetic or logical operation Used for conditional branch 25
98 Assembly Program Instructions Assembly Programmer s Perspective of a Computer CPU PC ALU Register File Condition Codes Addresses Data Instructions Memory Code Data Stack Heap 26
99 Assembly Program Instructions Assembly Programmer s Perspective of a Computer CPU PC ALU Register File Condition Codes Addresses Data Instructions Memory Code Data Stack Heap Compute Instruction: Perform arithmetics on register or memory data addq %eax, %ebx C constructs: +, -, >>, etc. 26
100 Assembly Program Instructions Assembly Programmer s Perspective of a Computer CPU PC ALU Register File Condition Codes Addresses Data Instructions Memory Code Data Stack Heap Compute Instruction: Perform arithmetics on register or memory data addq %eax, %ebx C constructs: +, -, >>, etc. Data Movement Instruction: Transfer data between memory and register movq %eax, (%ebx) 26
101 Assembly Program Instructions Assembly Programmer s Perspective of a Computer CPU PC ALU Register File Condition Codes Addresses Data Instructions Memory Code Data Stack Heap Compute Instruction: Perform arithmetics on register or memory data addq %eax, %ebx C constructs: +, -, >>, etc. Data Movement Instruction: Transfer data between memory and register movq %eax, (%ebx) Control Instruction: Alter the sequence of instructions (by changing PC) jmp, call C constructs: if-else, do-while, function call, etc. 26
102 Turning C into Object Code C Code (sum.c) long plus(long x, long y); void sumstore(long x, long y, long *dest) { long t = plus(x, y); *dest = t; } 27
103 Turning C into Object Code C Code (sum.c) long plus(long x, long y); void sumstore(long x, long y, long *dest) { long t = plus(x, y); *dest = t; } Generated x86-64 Assembly sumstore: pushq movq call movq popq ret %rbx %rdx, %rbx plus %rax, (%rbx) %rbx 27
104 Turning C into Object Code C Code (sum.c) long plus(long x, long y); void sumstore(long x, long y, long *dest) { long t = plus(x, y); *dest = t; } Generated x86-64 Assembly sumstore: pushq movq call movq popq ret %rbx %rdx, %rbx plus %rax, (%rbx) %rbx Obtain (on CSUG machine) with command gcc Og S sum.c -o sum.s 27
105 Turning C into Object Code Generated x86-64 Assembly sumstore: pushq movq call movq popq ret %rbx %rdx, %rbx plus %rax, (%rbx) %rbx 28
106 Turning C into Object Code Generated x86-64 Assembly Binary Code for sumstore sumstore: pushq movq call movq popq ret %rbx %rdx, %rbx plus %rax, (%rbx) %rbx Memory 0x53 0x48 0x89 0xd3 0xe8 0xf2 0xff 0xff 0xff 0x48 0x89 0x03 0x5b 0xc3 28
107 Turning C into Object Code Generated x86-64 Assembly Binary Code for sumstore sumstore: pushq movq call movq popq ret %rbx %rdx, %rbx plus %rax, (%rbx) %rbx Address 0x Memory 0x53 0x48 0x89 0xd3 0xe8 0xf2 0xff 0xff 0xff 0x48 0x89 0x03 0x5b 0xc3 28
108 Turning C into Object Code Generated x86-64 Assembly Binary Code for sumstore sumstore: pushq movq call movq popq ret %rbx %rdx, %rbx plus %rax, (%rbx) %rbx Obtain (on CSUG machine) with command gcc c sum.s -o sum.o Address 0x Memory 0x53 0x48 0x89 0xd3 0xe8 0xf2 0xff 0xff 0xff 0x48 0x89 0x03 0x5b 0xc3 28
109 Turning C into Object Code Generated x86-64 Assembly Binary Code for sumstore sumstore: pushq movq call movq popq ret Obtain (on CSUG machine) with command gcc c sum.s -o sum.o Total of 14 bytes %rbx %rdx, %rbx plus %rax, (%rbx) %rbx Instructions have variable lengths: e.g., 1, 3, or 5 bytes Code starts at memory address 0x Address 0x Memory 0x53 0x48 0x89 0xd3 0xe8 0xf2 0xff 0xff 0xff 0x48 0x89 0x03 0x5b 0xc3 28
110 Machine Instruction Example 29
111 Machine Instruction Example long t; long *dest; t += *dest; C Code Add value t with value in memory location whose address is dest and store the result back to t 29
112 Machine Instruction Example long t; long *dest; t += *dest; addq %rax, (%rbx) C Code Add value t with value in memory location whose address is dest and store the result back to t Assembly Instruction Operator: Add two 8-byte values Quad words in x86-64 parlance Operands: t: Register %rax dest: Register %rbx *dest: Memory M[%rbx] 29
113 Machine Instruction Example long t; long *dest; t += *dest; Operator addq %rax, (%rbx) C Code Add value t with value in memory location whose address is dest and store the result back to t Assembly Instruction Operator: Add two 8-byte values Quad words in x86-64 parlance Operands: t: Register %rax dest: Register %rbx *dest: Memory M[%rbx] 29
114 Machine Instruction Example long t; long *dest; t += *dest; Operand(s) addq %rax, (%rbx) C Code Add value t with value in memory location whose address is dest and store the result back to t Assembly Instruction Operator: Add two 8-byte values Quad words in x86-64 parlance Operands: t: Register %rax dest: Register %rbx *dest: Memory M[%rbx] 29
115 Machine Instruction Example long t; long *dest; t += *dest; addq %rax, (%rbx) t C Code Add value t with value in memory location whose address is dest and store the result back to t Assembly Instruction Operator: Add two 8-byte values Quad words in x86-64 parlance Operands: t: Register %rax dest: Register %rbx *dest: Memory M[%rbx] 29
116 Machine Instruction Example long t; long *dest; t += *dest; addq %rax, (%rbx) t dest C Code Add value t with value in memory location whose address is dest and store the result back to t Assembly Instruction Operator: Add two 8-byte values Quad words in x86-64 parlance Operands: t: Register %rax dest: Register %rbx *dest: Memory M[%rbx] 29
117 Machine Instruction Example long t; long *dest; t += *dest; addq %rax, (%rbx) t *dest dest C Code Add value t with value in memory location whose address is dest and store the result back to t Assembly Instruction Operator: Add two 8-byte values Quad words in x86-64 parlance Operands: t: Register %rax dest: Register %rbx *dest: Memory M[%rbx] 29
118 Machine Instruction Example long t; long *dest; t += *dest; addq %rax, (%rbx) t 0xf0059e: 0x d8 *dest dest C Code Add value t with value in memory location whose address is dest and store the result back to t Assembly Instruction Operator: Add two 8-byte values Quad words in x86-64 parlance Operands: t: Register %rax dest: Register %rbx *dest: Memory M[%rbx] Object Code 3-byte instruction Stored at address 0xf0059e 29
119 Instruction Processing Sequence Assembly Programmer s Perspective of a Computer CPU PC ALU Register File Condition Codes Addresses Data Instructions Memory Code Data Stack Fetch Instruction (According to PC) 30
120 Instruction Processing Sequence Assembly Programmer s Perspective of a Computer CPU PC ALU Register File Condition Codes Addresses Data Instructions Memory Code Data Stack Fetch Instruction (According to PC) 0x4801d8 30
121 Instruction Processing Sequence Assembly Programmer s Perspective of a Computer CPU PC ALU Register File Condition Codes Addresses Data Instructions Memory Code Data Stack Fetch Instruction (According to PC) Decode Instruction addq %rax,(%rbx) 30
122 Instruction Processing Sequence Assembly Programmer s Perspective of a Computer CPU PC ALU Register File Condition Codes Addresses Data Instructions Memory Code Data Stack Fetch Instruction (According to PC) Decode Instruction Fetch Operands 30
123 Instruction Processing Sequence Assembly Programmer s Perspective of a Computer CPU PC ALU Register File Condition Codes Addresses Data Instructions Memory Code Data Stack Fetch Instruction (According to PC) Decode Instruction Fetch Operands Execute Instruction 30
124 Instruction Processing Sequence Assembly Programmer s Perspective of a Computer CPU PC ALU Register File Condition Codes Addresses Data Instructions Memory Code Data Stack Fetch Instruction (According to PC) Decode Instruction Fetch Operands Execute Instruction Update Condition Codes 30
125 Instruction Processing Sequence Assembly Programmer s Perspective of a Computer CPU PC ALU Register File Condition Codes Addresses Data Instructions Memory Code Data Stack Fetch Instruction (According to PC) Decode Instruction Fetch Operands Execute Instruction Store Results Update Condition Codes 30
126 Instruction Processing Sequence Assembly Programmer s Perspective of a Computer CPU PC ALU Register File Condition Codes Addresses Data Instructions Memory Code Data Stack Fetch Instruction (According to PC) Decode Instruction Fetch Operands Execute Instruction Store Results Update Condition Codes Adjust PC 30
127 Instruction Processing Sequence Assembly Programmer s Perspective of a Computer CPU PC ALU Register File Condition Codes Addresses Data Instructions Memory Code Data Stack Fetch Instruction (According to PC) Decode Instruction Fetch Operands Execute Instruction Store Results Update Condition Codes Adjust PC 30
128 Instruction Processing Sequence Assembly Programmer s Perspective of a Computer CPU PC ALU Register File Condition Codes Addresses Data Instructions Memory Code Data Stack Fetch Instruction (According to PC) Decode Instruction Fetch Operands Execute Instruction Store Results Questions? Update Condition Codes Adjust PC 30
129 Today: Assembly Programming I: Basics Different ISAs and history behind them C, assembly, machine code Move operations (and addressing modes) 31
130 Data Movement Instructions movq Source, Dest 32
131 Data Movement Instructions movq Source, Dest Operator Operands 32
132 Data Movement Instructions movq Source, Dest Operator Operands Register: One of 16 integer registers Example: %rax, %r13 But %rsp reserved for special use 32
133 Data Movement Instructions movq Source, Dest Operator Operands Register: One of 16 integer registers Example: %rax, %r13 But %rsp reserved for special use Immediate: Constant integer data Example: $0x400, $-533; like C constant, but prefixed with $ Encoded with 1, 2, or 4 bytes; can only be source 32
134 Data Movement Instructions movq Source, Dest Operator Operands Register: One of 16 integer registers Example: %rax, %r13 But %rsp reserved for special use Immediate: Constant integer data Example: $0x400, $-533; like C constant, but prefixed with $ Encoded with 1, 2, or 4 bytes; can only be source Memory: 8 consecutive bytes in memory at given address Simplest example: (%rax) How to obtain the address is called addressing mode (later ) 32
135 movq Operand Combinations Source Dest Src,Dest C Analog movq Imm Reg Reg Mem Reg Mem Mem Reg Cannot do memory-memory transfer with a single instruction in x86. 33
136 movq Operand Combinations Source Dest Src,Dest C Analog Imm Reg Mem movq $0x4,%rax movq Reg Reg Mem Mem Reg Cannot do memory-memory transfer with a single instruction in x86. 33
137 movq Operand Combinations Source Dest Src,Dest C Analog Imm Reg Mem movq $0x4,%rax temp = 0x4; movq Reg Reg Mem Mem Reg Cannot do memory-memory transfer with a single instruction in x86. 33
138 movq Operand Combinations Source Dest Src,Dest C Analog Imm Reg Mem movq $0x4,%rax temp = 0x4; movq $-147,(%rax) movq Reg Reg Mem Mem Reg Cannot do memory-memory transfer with a single instruction in x86. 33
139 movq Operand Combinations Source Dest Src,Dest C Analog Imm Reg Mem movq $0x4,%rax temp = 0x4; movq $-147,(%rax) *p = -147; movq Reg Reg Mem Mem Reg Cannot do memory-memory transfer with a single instruction in x86. 33
140 movq Operand Combinations Source Dest Src,Dest C Analog Imm Reg Mem movq $0x4,%rax temp = 0x4; movq $-147,(%rax) *p = -147; movq Reg Reg Mem movq %rax,%rdx Mem Reg Cannot do memory-memory transfer with a single instruction in x86. 33
141 movq Operand Combinations Source Dest Src,Dest C Analog Imm Reg Mem movq $0x4,%rax temp = 0x4; movq $-147,(%rax) *p = -147; movq Reg Reg Mem movq %rax,%rdx temp2 = temp1; Mem Reg Cannot do memory-memory transfer with a single instruction in x86. 33
142 movq Operand Combinations Source Dest Src,Dest C Analog Imm Reg Mem movq $0x4,%rax temp = 0x4; movq $-147,(%rax) *p = -147; movq Reg Reg Mem movq %rax,%rdx movq %rax,(%rdx) temp2 = temp1; Mem Reg Cannot do memory-memory transfer with a single instruction in x86. 33
143 movq Operand Combinations Source Dest Src,Dest C Analog Imm Reg Mem movq $0x4,%rax temp = 0x4; movq $-147,(%rax) *p = -147; movq Reg Reg Mem movq %rax,%rdx movq %rax,(%rdx) temp2 = temp1; *p = temp; Mem Reg Cannot do memory-memory transfer with a single instruction in x86. 33
144 movq Operand Combinations Source Dest Src,Dest C Analog Imm Reg Mem movq $0x4,%rax temp = 0x4; movq $-147,(%rax) *p = -147; movq Reg Reg Mem movq %rax,%rdx movq %rax,(%rdx) temp2 = temp1; *p = temp; Mem Reg movq (%rax),%rdx Cannot do memory-memory transfer with a single instruction in x86. 33
145 movq Operand Combinations Source Dest Src,Dest C Analog Imm Reg Mem movq $0x4,%rax temp = 0x4; movq $-147,(%rax) *p = -147; movq Reg Reg Mem movq %rax,%rdx movq %rax,(%rdx) temp2 = temp1; *p = temp; Mem Reg movq (%rax),%rdx temp = *p; Cannot do memory-memory transfer with a single instruction in x86. 33
146 Memory Addressing Modes An addressing mode specifies: how to calculate the effective memory address of an operand by using information held in registers and/or constants 34
147 Memory Addressing Modes An addressing mode specifies: how to calculate the effective memory address of an operand by using information held in registers and/or constants Normal: (R) Memory address: content of Register R (Reg[R]) Pointer dereferencing in C movq (%rcx),%rax; // address = %rcx 34
148 Memory Addressing Modes An addressing mode specifies: how to calculate the effective memory address of an operand by using information held in registers and/or constants Normal: (R) Memory address: content of Register R (Reg[R]) Pointer dereferencing in C movq (%rcx),%rax; // address = %rcx Displacement: D(R) Memory address: Reg[R]+D Register R specifies start of memory region Constant displacement D specifies offset movq 8(%rbp),%rdx; // address = %rbp
149 Example of Simple Addressing Modes void swap (long *xp, long *yp) { long t0 = *xp; long t1 = *yp; *xp = t1; *yp = t0; } 35
150 Example of Simple Addressing Modes void swap (long *xp, long *yp) { long t0 = *xp; long t1 = *yp; *xp = t1; *yp = t0; } Memory 35
151 Example of Simple Addressing Modes void swap (long *xp, long *yp) { long t0 = *xp; long t1 = *yp; *xp = t1; *yp = t0; } Memory *xp Addr xp 35
152 Example of Simple Addressing Modes void swap (long *xp, long *yp) { long t0 = *xp; long t1 = *yp; *xp = t1; *yp = t0; } Memory *xp *yp Addr xp yp 35
153 Example of Simple Addressing Modes void swap (long *xp, long *yp) { long t0 = *xp; long t1 = *yp; *xp = t1; *yp = t0; } Registers %rdi %rsi %rax %rdx xp yp Memory *xp *yp Addr xp yp 35
154 Example of Simple Addressing Modes void swap (long *xp, long *yp) { long t0 = *xp; long t1 = *yp; *xp = t1; *yp = t0; } Registers %rdi %rsi %rax %rdx xp yp Memory *xp *yp Addr xp yp swap: movq movq movq movq ret (%rdi), %rax # t0 = *xp (%rsi), %rdx # t1 = *yp %rdx, (%rdi) # *xp = t1 %rax, (%rsi) # *yp = t0 35
155 Example of Simple Addressing Modes void swap (long *xp, long *yp) { long t0 = *xp; long t1 = *yp; *xp = t1; *yp = t0; } swap: movq movq movq movq ret Registers %rdi %rsi %rax %rdx xp yp How Does This Work? Memory *xp *yp (%rdi), %rax # t0 = *xp (%rsi), %rdx # t1 = *yp %rdx, (%rdi) # *xp = t1 %rax, (%rsi) # *yp = t0 Addr xp yp 35
156 Understanding Swap() Registers Memory Addr %rdi %rsi %rax %rdx 0x120 0x x120 0x118 0x110 0x108 0x100 xp yp swap: movq movq movq movq ret (%rdi), %rax # t0 = *xp (%rsi), %rdx # t1 = *yp %rdx, (%rdi) # *xp = t1 %rax, (%rsi) # *yp = t0 36
157 Understanding Swap() Registers Memory Addr %rdi %rsi %rax %rdx 0x120 0x x120 0x118 0x110 0x108 0x100 xp yp swap: movq movq movq movq ret (%rdi), %rax # t0 = *xp (%rsi), %rdx # t1 = *yp %rdx, (%rdi) # *xp = t1 %rax, (%rsi) # *yp = t0 36
158 Understanding Swap() Registers Memory Addr %rdi %rsi %rax %rdx 0x120 0x x120 0x118 0x110 0x108 0x100 xp yp swap: movq movq movq movq ret (%rdi), %rax # t0 = *xp (%rsi), %rdx # t1 = *yp %rdx, (%rdi) # *xp = t1 %rax, (%rsi) # *yp = t0 36
159 Understanding Swap() Registers Memory Addr %rdi %rsi %rax %rdx 0x120 0x x120 0x118 0x110 0x108 0x100 xp yp swap: movq movq movq movq ret (%rdi), %rax # t0 = *xp (%rsi), %rdx # t1 = *yp %rdx, (%rdi) # *xp = t1 %rax, (%rsi) # *yp = t0 36
160 Understanding Swap() Registers Memory Addr %rdi %rsi %rax %rdx 0x120 0x x120 0x118 0x110 0x108 0x100 xp yp swap: movq movq movq movq ret (%rdi), %rax # t0 = *xp (%rsi), %rdx # t1 = *yp %rdx, (%rdi) # *xp = t1 %rax, (%rsi) # *yp = t0 36
161 Understanding Swap() Registers Memory Addr %rdi %rsi %rax %rdx 0x120 0x x120 0x118 0x110 0x108 0x100 xp yp swap: movq movq movq movq ret (%rdi), %rax # t0 = *xp (%rsi), %rdx # t1 = *yp %rdx, (%rdi) # *xp = t1 %rax, (%rsi) # *yp = t0 36
162 Understanding Swap() Registers Memory Addr %rdi %rsi %rax %rdx 0x120 0x x120 0x118 0x110 0x108 0x100 xp yp swap: movq movq movq movq ret (%rdi), %rax # t0 = *xp (%rsi), %rdx # t1 = *yp %rdx, (%rdi) # *xp = t1 %rax, (%rsi) # *yp = t0 36
163 Understanding Swap() Registers Memory Addr %rdi %rsi %rax %rdx 0x120 0x x120 0x118 0x110 0x108 0x100 xp yp swap: movq movq movq movq ret (%rdi), %rax # t0 = *xp (%rsi), %rdx # t1 = *yp %rdx, (%rdi) # *xp = t1 %rax, (%rsi) # *yp = t0 36
164 Understanding Swap() Registers Memory Addr %rdi %rsi %rax %rdx 0x120 0x x120 0x118 0x110 0x108 0x100 xp yp swap: movq movq movq movq ret (%rdi), %rax # t0 = *xp (%rsi), %rdx # t1 = *yp %rdx, (%rdi) # *xp = t1 %rax, (%rsi) # *yp = t0 36
+ Machine Level Programming: x86-64 History
+ Machine Level Programming: x86-64 History + Intel x86 Processors Dominate laptop/desktop/server market Evolutionary design Backwards compatible up until 8086, introduced in 1978 Added more features as
More informationMachine Level Programming: Basics
Machine Level Programming: Basics Computer Systems Organization (Spring 2017) CSCI-UA 201, Section 2 Instructor: Joanna Klukowska Slides adapted from Randal E. Bryant and David R. O Hallaron (CMU) Mohamed
More informationChapter 3 Machine-Level Programming I: Basics. Bryant and O Hallaron, Computer Systems: A Programmer s Perspective, Third Edition
Chapter 3 Machine-Level Programming I: Basics 1 Machine Programming I: Basics History of Intel processors and architectures C, assembly, machine code Assembly Basics: Registers, operands, move Arithmetic
More informationMachine Level Programming: Basics
Machine Level Programming: Basics Computer Systems Organization (Spring 2017) CSCI-UA 201, Section 2 Instructor: Joanna Klukowska Why do we look at machine code? understanding how the high-level programming
More informationRoadmap. Java: Assembly language: OS: Machine code: Computer system:
Roadmap C: car *c = malloc(sizeof(car)); c->miles = 100; c->gals = 17; float mpg = get_mpg(c); free(c); Assembly language: Machine code: Computer system: get_mpg: pushq movq... popq ret %rbp %rsp, %rbp
More informationToday: Machine Programming I: Basics. Machine Level Programming I: Basics. Intel x86 Processors. Intel x86 Evolution: Milestones
Today: Machine Programming I: Basics Machine Level Programming I: Basics 15 213/1 213: Introduction to Computer Systems 5 th Lecture, Jan 29, 2013 History of Intel processors and architectures C, assembly,
More informationMachine Level Programming I: Basics
Carnegie Mellon Machine Level Programming I: Basics Kai Shen Why do I care for machine code? Chances are, you ll never write programs in machine code Compilers are much better & more patient than you are
More informationToday: Machine Programming I: Basics
Today: Machine Programming I: Basics History of Intel processors and architectures C, assembly, machine code Assembly Basics: Registers, operands, move Intro to x86-64 1 Intel x86 Processors Totally dominate
More informationMachine-Level Programming I: Basics
Machine-Level Programming I: Basics CSE 238/2038/2138: Systems Programming Instructor: Fatma CORUT ERGİN Slides adapted from Bryant & O Hallaron s slides 1 Today: Machine Programming I: Basics History
More informationCSC 252: Computer Organization Spring 2018: Lecture 6
CSC 252: Computer Organization Spring 2018: Lecture 6 Instructor: Yuhao Zhu Department of Computer Science University of Rochester Action Items: Assignment 2 is out Announcement Programming Assignment
More informationCarnegie Mellon. 5 th Lecture, Jan. 31, Instructors: Todd C. Mowry & Anthony Rowe
Machine Level Programming I: Basics 15 213/18 213: 213: Introduction to Computer Systems 5 th Lecture, Jan. 31, 2012 Instructors: Todd C. Mowry & Anthony Rowe 1 Today: Machine Programming gi: Basics History
More informationC to Machine Code x86 basics: Registers Data movement instructions Memory addressing modes Arithmetic instructions
C to Machine Code x86 basics: Registers Data movement instructions Memory addressing modes Arithmetic instructions Program, Application Software Hardware next few weeks Programming Language Compiler/Interpreter
More informationThe von Neumann Machine
The von Neumann Machine 1 1945: John von Neumann Wrote a report on the stored program concept, known as the First Draft of a Report on EDVAC also Alan Turing Konrad Zuse Eckert & Mauchly The basic structure
More informationBryant and O Hallaron, Computer Systems: A Programmer s Perspective, Third Edition. Carnegie Mellon
Carnegie Mellon Machine-Level Programming I: Basics 15-213/18-213/15-213: Introduction to Computer Systems 5 th Lecture, September 12, 2017 Today s Instructor: Phil Gibbons 2 Today: Machine Programming
More informationMachine-Level Programming I: Basics
Machine-Level Programming I: Basics 15-213/18-213: Introduction to Computer Systems 5 th Lecture, September 13, 2016 Instructor: Phil Gibbons 1 Today: Machine Programming I: Basics History of Intel processors
More informationCS241 Computer Organization Spring Introduction to Assembly
CS241 Computer Organization Spring 2015 Introduction to Assembly 2-05 2015 Outline! Rounding floats: round-to-even! Introduction to Assembly (IA32) move instruction (mov) memory address computation arithmetic
More informationInstruction Set Architectures
Instruction Set Architectures! ISAs! Brief history of processors and architectures! C, assembly, machine code! Assembly basics: registers, operands, move instructions 1 What should the HW/SW interface
More informationMachine-Level Programming I: Basics
Machine-Level Programming I: Basics 15-213/18-213: Introduction to Computer Systems 5 th Lecture, January 30, 2018 Instructors: Franz Franchetti and Seth C. Goldstein 1 Office Hours Not too well attended
More informationMACHINE LEVEL PROGRAMMING 1: BASICS
MACHINE LEVEL PROGRAMMING 1: BASICS CS 045 Computer Organization and Architecture Prof. Donald J. Patterson Adapted from Bryant and O Hallaron, Computer Systems: A Programmer s Perspective, Third Edition
More informationIntel x86-64 and Y86-64 Instruction Set Architecture
CSE 2421: Systems I Low-Level Programming and Computer Organization Intel x86-64 and Y86-64 Instruction Set Architecture Presentation J Read/Study: Bryant 3.1 3.5, 4.1 Gojko Babić 03-07-2018 Intel x86
More informationThe von Neumann Machine
The von Neumann Machine 1 1945: John von Neumann Wrote a report on the stored program concept, known as the First Draft of a Report on EDVAC also Alan Turing Konrad Zuse Eckert & Mauchly The basic structure
More informationMachine Level Programming I: Basics. Credits to Randy Bryant & Dave O Hallaron
Machine Level Programming I: Basics Lecture 3, Feb. 24, 2011 Alexandre David Credits to Randy Bryant & Dave O Hallaron from Carnegie Mellon 1 Today: Machine Programming I: Basics History of Intel processors
More informationToday: Machine Programming I: Basics. Machine-Level Programming I: Basics. Intel x86 Processors. Intel x86 Evolution: Milestones
Today: Machine Programming I: Basics Machine-Level Programming I: Basics CSci 2021: Machine Architecture and Organization Lectures #7-8, February 3th-5th, 2016 Assembly Basics:, operands, move Arithmetic
More informationCS429: Computer Organization and Architecture
CS429: Computer Organization and Architecture Dr. Bill Young Department of Computer Sciences University of Texas at Austin Last updated: October 9, 2017 at 10:51 CS429 Slideset 7: 1 Topics of this Slideset
More informationLast Time: Floating Point. Intel x86 Processors. Lecture 4: Machine Basics Computer Architecture and Systems Programming ( )
Last Time: Floating Point Lecture : Machine Basics Computer Architecture and Systems Programming (252-0061-00) Timothy Roscoe Herbstsemester 2012 Fractional binary numbers IEEE floating point standard:
More informationx86 Programming I CSE 351 Winter
x86 Programming I CSE 351 Winter 2017 http://xkcd.com/409/ Administrivia Lab 2 released! Da bomb! Go to section! No Luis OH Later this week 2 Roadmap C: car *c = malloc(sizeof(car)); c->miles = 100; c->gals
More informationInstruction Set Architectures
Instruction Set Architectures ISAs Brief history of processors and architectures C, assembly, machine code Assembly basics: registers, operands, move instructions 1 What should the HW/SW interface contain?
More informationLecture 3 CIS 341: COMPILERS
Lecture 3 CIS 341: COMPILERS HW01: Hellocaml! Announcements is due tomorrow tonight at 11:59:59pm. HW02: X86lite Will be available soon look for an announcement on Piazza Pair-programming project Simulator
More informationMACHINE-LEVEL PROGRAMMING I: BASICS
MACHINE-LEVEL PROGRAMMING I: BASICS CS 429H: SYSTEMS I Instructor: Emmett Witchel Today: Machine Programming I: Basics History of Intel processors and architectures C, assembly, machine code Assembly Basics:
More informationCS 261 Fall Machine and Assembly Code. Data Movement and Arithmetic. Mike Lam, Professor
CS 261 Fall 2018 0000000100000f50 55 48 89 e5 48 83 ec 10 48 8d 3d 3b 00 00 00 c7 0000000100000f60 45 fc 00 00 00 00 b0 00 e8 0d 00 00 00 31 c9 89 0000000100000f70 45 f8 89 c8 48 83 c4 10 5d c3 Mike Lam,
More informationMACHINE-LEVEL PROGRAMMING I: BASICS COMPUTER ARCHITECTURE AND ORGANIZATION
MACHINE-LEVEL PROGRAMMING I: BASICS COMPUTER ARCHITECTURE AND ORGANIZATION Today: Machine Programming I: Basics History of Intel processors and architectures C, assembly, machine code Assembly Basics:
More informationToday: Machine Programming I: Basics. Machine-Level Programming I: Basics. Intel x86 Processors. Intel x86 Evolution: Milestones
Today: Machine Programming I: Basics Machine-Level Programming I: Basics CSci 2021: Machine Architecture and Organization Lectures #7-, February th-6th, 2015 Your instructor: Stephen McCamant Intro to
More informationAssembly I: Basic Operations. Jin-Soo Kim Computer Systems Laboratory Sungkyunkwan University
Assembly I: Basic Operations Jin-Soo Kim (jinsookim@skku.edu) Computer Systems Laboratory Sungkyunkwan University http://csl.skku.edu Basic Execution Environment RAX RBX RCX RDX RSI RDI RBP RSP R8 R9 R10
More informationTopics of this Slideset. CS429: Computer Organization and Architecture. x86 Evolution: Programmer s View. Intel x86 Processors
Topics of this Slideset CS429: Computer Organization and Architecture Dr. Bill Young Department of Computer Science University of Texas at Austin Last updated: October 29, 2018 at 11:54 Assembly Programmer
More informationInstruction Set Architectures
Instruction Set Architectures Computer Systems: Section 4.1 Suppose you built a computer What Building Blocks would you use? Arithmetic Logic Unit (ALU) OP1 OP2 OPERATION ALU RES ALU + Registers R0: 0x0000
More informationLecture (02) x86 programming 1
Lecture (02) x86 programming 1 By: Dr. Ahmed ElShafee ١ TOC Historical Perspective Basic component of microprocessor based system Types of instruction set The Memory Map of a Personal Computers The 80x86
More informationHow Software Executes
How Software Executes CS-576 Systems Security Instructor: Georgios Portokalidis Overview Introduction Anatomy of a program Basic assembly Anatomy of function calls (and returns) Memory Safety Programming
More informationMachine Language CS 3330 Samira Khan
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
More informationCSC 252: Computer Organization Spring 2018: Lecture 11
CSC 252: Computer Organization Spring 2018: Lecture 11 Instructor: Yuhao Zhu Department of Computer Science University of Rochester Action Items: Assignment 3 is due March 2, midnight Announcement Programming
More informationMachine-Level Programming I Introduction
Machine-Level Programming I Introduction CSCI 224 / ECE 317: Computer Architecture Instructor: Prof. Jason Fritts Slides adapted from Bryant & O Hallaron s slides 1 Machine Programming I Basics Instruction
More informationMachine-Level Programming I Introduction
Machine-Level Programming I Introduction CSCI 2400: Computer Architecture Instructor: David Ferry Slides adapted from Bryant & O Hallaron s slides via Jason Fritts 1 Turning a corner Course theme: Low
More informationx86 64 Programming I CSE 351 Autumn 2018 Instructor: Justin Hsia
x86 64 Programming I CSE 351 Autumn 2018 Instructor: Justin Hsia Teaching Assistants: Akshat Aggarwal An Wang Andrew Hu Brian Dai Britt Henderson James Shin Kevin Bi Kory Watson Riley Germundson Sophie
More informationFoundations of Computer Systems
18-600 Foundations of Computer Systems Lecture 5: Data and Machine-Level Programming I: Basics September 13, 2017 Required Reading Assignment: Chapter 3 of CS:APP (3 rd edition) by Randy Bryant & Dave
More informationx86-64 Assembly CSE 351 Winter 2018 Instructor: Mark Wyse
x86-64 Assembly CSE 351 Winter 2018 Instructor: Mark Wyse Teaching Assistants: Kevin Bi Parker DeWilde Emily Furst Sarah House Waylon Huang Vinny Palaniappan http://xkcd.com/409/ Administrivia Lab 1 due
More informationMachine Programming 3: Procedures
Machine Programming 3: Procedures CS61, Lecture 5 Prof. Stephen Chong September 15, 2011 Announcements Assignment 2 (Binary bomb) due next week If you haven t yet please create a VM to make sure the infrastructure
More informationx86 Programming I CSE 351 Autumn 2016 Instructor: Justin Hsia
x86 Programming I CSE 351 Autumn 2016 Instructor: Justin Hsia Teaching Assistants: Chris Ma Hunter Zahn John Kaltenbach Kevin Bi Sachin Mehta Suraj Bhat Thomas Neuman Waylon Huang Xi Liu Yufang Sun http://xkcd.com/409/
More informationMeet & Greet! Come hang out with your TAs and Fellow Students (& eat free insomnia cookies) When : TODAY!! 5-6 pm Where : 3rd Floor Atrium, CIT
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 CS33 Intro to Computer Systems XI 1 Copyright 2017 Thomas
More informationCredits and Disclaimers
Credits and Disclaimers 1 The examples and discussion in the following slides have been adapted from a variety of sources, including: Chapter 3 of Computer Systems 3 nd Edition by Bryant and O'Hallaron
More informationHow Software Executes
How Software Executes CS-576 Systems Security Instructor: Georgios Portokalidis Overview Introduction Anatomy of a program Basic assembly Anatomy of function calls (and returns) Memory Safety Intel x86
More informationPage # CISC 360. Machine-Level Programming I: Introduction Sept. 18, IA32 Processors. X86 Evolution: Programmerʼs View.
Machine-Level Programming I: Introduction Sept. 18, 2008 Topics CISC 360 Assembly Programmerʼs Execution Model Accessing Information Registers Memory Arithmetic operations IA32 Processors Totally Dominate
More informationCS367 Test 1 Review Guide
CS367 Test 1 Review Guide This guide tries to revisit what topics we've covered, and also to briefly suggest/hint at types of questions that might show up on the test. Anything on slides, assigned reading,
More informationL08: Assembly Programming II. Assembly Programming II. CSE 351 Spring Guest Lecturer: Justin Hsia. Instructor: Ruth Anderson
Assembly Programming II CSE 351 Spring 2017 Guest Lecturer: Justin Hsia Instructor: Ruth Anderson Teaching Assistants: Dylan Johnson Kevin Bi Linxing Preston Jiang Cody Ohlsen Yufang Sun Joshua Curtis
More informationGiving credit where credit is due
CSCE 230J Computer Organization Machine-Level Programming I: Introduction Dr. Steve Goddard goddard@cse.unl.edu Giving credit where credit is due Most of slides for this lecture are based on slides created
More informationMachine Programming. CSE 351 Autumn Instructor: Justin Hsia
Machine Programming CSE 351 Autumn 2016 Instructor: Justin Hsia Teaching Assistants: Chris Ma Hunter Zahn John Kaltenbach Kevin Bi Sachin Mehta Suraj Bhat Thomas Neuman Waylon Huang Xi Liu Yufang Sun http://www.smbc
More informationCISC 360. Machine-Level Programming I: Introduction Sept. 18, 2008
CISC 360 Machine-Level Programming I: Introduction Sept. 18, 2008 Topics Assembly Programmerʼs Execution Model Accessing Information Registers Memory Arithmetic operations IA32 Processors Totally Dominate
More informationSystems I. Machine-Level Programming I: Introduction
Systems I Machine-Level Programming I: Introduction Topics Assembly Programmerʼs Execution Model Accessing Information Registers IA32 Processors Totally Dominate General Purpose CPU Market Evolutionary
More informationMachine Program: Procedure. Zhaoguo Wang
Machine Program: Procedure Zhaoguo Wang Requirements of procedure calls? P() { y = Q(x); y++; 1. Passing control int Q(int i) { int t, z; return z; Requirements of procedure calls? P() { y = Q(x); y++;
More informationCS165 Computer Security. Understanding low-level program execution Oct 1 st, 2015
CS165 Computer Security Understanding low-level program execution Oct 1 st, 2015 A computer lets you make more mistakes faster than any invention in human history - with the possible exceptions of handguns
More informationCS241 Computer Organization Spring 2015 IA
CS241 Computer Organization Spring 2015 IA-32 2-10 2015 Outline! Review HW#3 and Quiz#1! More on Assembly (IA32) move instruction (mov) memory address computation arithmetic & logic instructions (add,
More informationCS24: INTRODUCTION TO COMPUTING SYSTEMS. Spring 2018 Lecture 4
CS24: INTRODUCTION TO COMPUTING SYSTEMS Spring 2018 Lecture 4 LAST TIME Enhanced our processor design in several ways Added branching support Allows programs where work is proportional to the input values
More informationComputer Architecture I: Outline and Instruction Set Architecture. CENG331 - Computer Organization. Murat Manguoglu
Computer Architecture I: Outline and Instruction Set Architecture CENG331 - Computer Organization Murat Manguoglu Adapted from slides of the textbook: http://csapp.cs.cmu.edu/ Outline Background Instruction
More informationFloating Point II, x86 64 Intro
Floating Point II, x86 64 Intro CSE 351 Autumn 2017 Instructor: Justin Hsia Teaching Assistants: Lucas Wotton Michael Zhang Parker DeWilde Ryan Wong Sam Gehman Sam Wolfson Savanna Yee Vinny Palaniappan
More informationx86-64 Programming II
x86-64 Programming II CSE 351 Winter 2018 Instructor: Mark Wyse Teaching Assistants: Kevin Bi Parker DeWilde Emily Furst Sarah House Waylon Huang Vinny Palaniappan http://xkcd.com/409/ Administrative Homework
More information1 Number Representation(10 points)
Name: Sp15 Midterm Q1 1 Number Representation(10 points) 1 NUMBER REPRESENTATION(10 POINTS) Let x=0xe and y=0x7 be integers stored on a machine with a word size of 4bits. Show your work with the following
More informationx86 Programming II CSE 351 Winter
x86 Programming II CSE 351 Winter 2017 http://xkcd.com/1652/ Administrivia 2 Address Computation Instruction v leaq src, dst lea stands for load effective address src is address expression (any of the
More informationvoid twiddle1(int *xp, int *yp) { void twiddle2(int *xp, int *yp) {
Optimization void twiddle1(int *xp, int *yp) { *xp += *yp; *xp += *yp; void twiddle2(int *xp, int *yp) { *xp += 2* *yp; void main() { int x = 3; int y = 3; twiddle1(&x, &y); x = 3; y = 3; twiddle2(&x,
More informationRISC I from Berkeley. 44k Transistors 1Mhz 77mm^2
The Case for RISC RISC I from Berkeley 44k Transistors 1Mhz 77mm^2 2 MIPS: A Classic RISC ISA Instructions 4 bytes (32 bits) 4-byte aligned Instructions operate on memory and registers Memory Data types
More informationMachine- Level Programming I: Basics
Machine- Level Programming I: Basics Computer Architecture Instructor: Norbert Lu1enberger based on the book by Randy Bryant and Dave O Hallaron 1 Today: Machine Programming I: Basics History of Intel
More informationx86-64 Programming I CSE 351 Summer 2018 Instructor: Justin Hsia Teaching Assistants: Josie Lee Natalie Andreeva Teagan Horkan
x86-64 Programming I CSE 351 Summer 2018 Instructor: Justin Hsia Teaching Assistants: Josie Lee Natalie Andreeva Teagan Horkan http://www.smbc-comics.com/?id=2999 Administrivia Lab 1b due on Thursday (7/5)
More informationPrinceton University Computer Science 217: Introduction to Programming Systems. Assembly Language: Function Calls
Princeton University Computer Science 217: Introduction to Programming Systems Assembly Language: Function Calls 1 Goals of this Lecture Help you learn: Function call problems x86-64 solutions Pertinent
More informationAssembly level Programming. 198:211 Computer Architecture. (recall) Von Neumann Architecture. Simplified hardware view. Lecture 10 Fall 2012
19:211 Computer Architecture Lecture 10 Fall 20 Topics:Chapter 3 Assembly Language 3.2 Register Transfer 3. ALU 3.5 Assembly level Programming We are now familiar with high level programming languages
More informationx86 64 Programming I CSE 351 Autumn 2017 Instructor: Justin Hsia
x86 64 Programming I CSE 351 Autumn 2017 Instructor: Justin Hsia Teaching Assistants: Lucas Wotton Michael Zhang Parker DeWilde Ryan Wong Sam Gehman Sam Wolfson Savanna Yee Vinny Palaniappan Administrivia
More informationAssembly Language: Function Calls
Assembly Language: Function Calls 1 Goals of this Lecture Help you learn: Function call problems x86-64 solutions Pertinent instructions and conventions 2 Function Call Problems (1) Calling and returning
More informationAssembly Programmer s View Lecture 4A Machine-Level Programming I: Introduction
Assembly Programmer s View Lecture 4A Machine-Level Programming I: Introduction E I P CPU isters Condition Codes Addresses Data Instructions Memory Object Code Program Data OS Data Topics Assembly Programmer
More informationMachine-level Representation of Programs
Machine-level Representation of Programs Jinkyu Jeong (jinkyu@skku.edu) Computer Systems Laboratory Sungkyunkwan University http://csl.skku.edu SSE2030: Introduction to Computer Systems, Spring 2018, Jinkyu
More informationRepresentation of Information
Representation of Information CS61, Lecture 2 Prof. Stephen Chong September 6, 2011 Announcements Assignment 1 released Posted on http://cs61.seas.harvard.edu/ Due one week from today, Tuesday 13 Sept
More informationData Representation Floating Point
Data Representation Floating Point CSCI 2400 / ECE 3217: Computer Architecture Instructor: David Ferry Slides adapted from Bryant & O Hallaron s slides via Jason Fritts Today: Floating Point Background:
More informationBryant and O Hallaron, Computer Systems: A Programmer s Perspective, Third Edition. Carnegie Mellon
Carnegie Mellon Machine-Level Programming III: Procedures 15-213/18-213/14-513/15-513: Introduction to Computer Systems 7 th Lecture, September 18, 2018 Today Procedures Mechanisms Stack Structure Calling
More informationMachine/Assembler Language Putting It All Together
COMP 40: Machine Structure and Assembly Language Programming Fall 2015 Machine/Assembler Language Putting It All Together Noah Mendelsohn Tufts University Email: noah@cs.tufts.edu Web: http://www.cs.tufts.edu/~noah
More informationBryant and O Hallaron, Computer Systems: A Programmer s Perspective, Third Edition. Carnegie Mellon
Carnegie Mellon Floating Point 15-213/18-213/14-513/15-513: Introduction to Computer Systems 4 th Lecture, Sept. 6, 2018 Today: Floating Point Background: Fractional binary numbers IEEE floating point
More informationThe Hardware/Software Interface CSE351 Spring 2015
The Hardware/Software Interface CSE351 Spring 2015 Lecture 6 Instructor: Katelin Bailey Teaching Assistants: Kaleo Brandt, Dylan Johnson, Luke Nelson, Alfian Rizqi, Kritin Vij, David Wong, and Shan Yang
More informationCSE 351 Midterm Exam Spring 2016 May 2, 2015
Name: CSE 351 Midterm Exam Spring 2016 May 2, 2015 UWNetID: Solution Please do not turn the page until 11:30. Instructions The exam is closed book, closed notes (no calculators, no mobile phones, no laptops,
More informationData Representation Floating Point
Data Representation Floating Point CSCI 2400 / ECE 3217: Computer Architecture Instructor: David Ferry Slides adapted from Bryant & O Hallaron s slides via Jason Fritts Today: Floating Point Background:
More informationCS429: Computer Organization and Architecture
CS429: Computer Organization and Architecture Dr. Bill Young Department of Computer Sciences University of Texas at Austin Last updated: October 11, 2017 at 17:42 CS429 Slideset 6: 1 Topics of this Slideset
More informationFloating Point Numbers
Floating Point Numbers Computer Systems Organization (Spring 2016) CSCI-UA 201, Section 2 Instructor: Joanna Klukowska Slides adapted from Randal E. Bryant and David R. O Hallaron (CMU) Mohamed Zahran
More informationFloating Point Numbers
Floating Point Numbers Computer Systems Organization (Spring 2016) CSCI-UA 201, Section 2 Fractions in Binary Instructor: Joanna Klukowska Slides adapted from Randal E. Bryant and David R. O Hallaron (CMU)
More informationFloating Point : Introduction to Computer Systems 4 th Lecture, May 25, Instructor: Brian Railing. Carnegie Mellon
Floating Point 15-213: Introduction to Computer Systems 4 th Lecture, May 25, 2018 Instructor: Brian Railing Today: Floating Point Background: Fractional binary numbers IEEE floating point standard: Definition
More informationLecture 4: x86_64 Assembly Language
CSCI-GA.1144-001 PAC II Lecture 4: x86_64 Assembly Language Some slides adapted (and slightly modified) from: Randy Bryant Dave O Hallaron Mohamed Zahran (aka Z) mzahran@cs.nyu.edu http://www.mzahran.com
More informationCS 107 Lecture 10: Assembly Part I
CS 107 Lecture 10: Assembly Part I Friday, February 9th, 2018 Computer Systems Winter 2018 Stanford University Computer Science Department Reading: Course Reader: x86-64 Assembly Language, Textbook: Chapter
More informationCSE351 Spring 2018, Midterm Exam April 27, 2018
CSE351 Spring 2018, Midterm Exam April 27, 2018 Please do not turn the page until 11:30. Last Name: First Name: Student ID Number: Name of person to your left: Name of person to your right: Signature indicating:
More information6.035 Project 3: Unoptimized Code Generation. Jason Ansel MIT - CSAIL
6.035 Project 3: Unoptimized Code Generation Jason Ansel MIT - CSAIL Quiz Monday 50 minute quiz Monday Covers everything up to yesterdays lecture Lexical Analysis (REs, DFAs, NFAs) Syntax Analysis (CFGs,
More informationMachine-Level Programming I: Introduction Jan. 30, 2001
15-213 Machine-Level Programming I: Introduction Jan. 30, 2001 Topics Assembly Programmer s Execution Model Accessing Information Registers Memory Arithmetic operations IA32 Processors Totally Dominate
More informationTurning 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
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 text C program (p1.c p2.c) Compiler (gcc -S) text Asm
More informationThe Hardware/Software Interface CSE351 Spring 2015
The Hardware/Software Interface CSE351 Spring 2015 Lecture 7 Instructor: Katelin Bailey Teaching Assistants: Kaleo Brandt, Dylan Johnson, Luke Nelson, Alfian Rizqi, Kritin Vij, David Wong, and Shan Yang
More informationx86 64 Programming II
x86 64 Programming II CSE 351 Autumn 2018 Instructor: Justin Hsia Teaching Assistants: Akshat Aggarwal An Wang Andrew Hu Brian Dai Britt Henderson James Shin Kevin Bi Kory Watson Riley Germundson Sophie
More informationAssembly Programming III
Assembly Programming III CSE 410 Winter 2017 Instructor: Justin Hsia Teaching Assistants: Kathryn Chan, Kevin Bi, Ryan Wong, Waylon Huang, Xinyu Sui Facebook Stories puts a Snapchat clone above the News
More informationComputer Processors. Part 2. Components of a Processor. Execution Unit The ALU. Execution Unit. The Brains of the Box. Processors. Execution Unit (EU)
Part 2 Computer Processors Processors The Brains of the Box Computer Processors Components of a Processor The Central Processing Unit (CPU) is the most complex part of a computer In fact, it is the computer
More informationComputer Organization: A Programmer's Perspective
A Programmer's Perspective Instruction Set Architecture Gal A. Kaminka galk@cs.biu.ac.il Outline: CPU Design Background Instruction sets Logic design Sequential Implementation A simple, but not very fast
More informationAssembly III: Procedures. Jin-Soo Kim Computer Systems Laboratory Sungkyunkwan University
Assembly III: Procedures Jin-Soo Kim (jinsookim@skku.edu) Computer Systems Laboratory Sungkyunkwan University http://csl.skku.edu Mechanisms in Procedures Passing control To beginning of procedure code
More informationIntroduction to Machine/Assembler Language
COMP 40: Machine Structure and Assembly Language Programming Fall 2017 Introduction to Machine/Assembler Language Noah Mendelsohn Tufts University Email: noah@cs.tufts.edu Web: http://www.cs.tufts.edu/~noah
More information