CSC 252: Computer Organization Spring 2018: Lecture 5

Size: px
Start display at page:

Download "CSC 252: Computer Organization Spring 2018: Lecture 5"

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 + 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 information

Machine Level Programming: Basics

Machine 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 information

Chapter 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. 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 information

Machine Level Programming: Basics

Machine 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 information

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

Roadmap. 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 information

Today: 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. 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 information

Machine Level Programming I: Basics

Machine 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 information

Today: Machine Programming I: Basics

Today: 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 information

Machine-Level Programming I: Basics

Machine-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 information

CSC 252: Computer Organization Spring 2018: Lecture 6

CSC 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 information

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

Carnegie 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 information

C 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 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 information

The von Neumann Machine

The 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 information

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

Bryant 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 information

Machine-Level Programming I: Basics

Machine-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 information

CS241 Computer Organization Spring Introduction to Assembly

CS241 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 information

Instruction Set Architectures

Instruction 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 information

Machine-Level Programming I: Basics

Machine-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 information

MACHINE LEVEL PROGRAMMING 1: BASICS

MACHINE 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 information

Intel x86-64 and Y86-64 Instruction Set Architecture

Intel 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 information

The von Neumann Machine

The 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 information

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

Machine 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 information

Today: 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. 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 information

CS429: Computer Organization and Architecture

CS429: 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 information

Last Time: Floating Point. Intel x86 Processors. Lecture 4: Machine Basics Computer Architecture and Systems Programming ( )

Last 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 information

x86 Programming I CSE 351 Winter

x86 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 information

Instruction Set Architectures

Instruction 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 information

Lecture 3 CIS 341: COMPILERS

Lecture 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 information

MACHINE-LEVEL PROGRAMMING I: BASICS

MACHINE-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 information

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

CS 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 information

MACHINE-LEVEL PROGRAMMING I: BASICS COMPUTER ARCHITECTURE AND ORGANIZATION

MACHINE-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 information

Today: 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. 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 information

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

Assembly 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 information

Topics 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. 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 information

Instruction Set Architectures

Instruction 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 information

Lecture (02) x86 programming 1

Lecture (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 information

How Software Executes

How 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 information

Machine Language CS 3330 Samira Khan

Machine 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 information

CSC 252: Computer Organization Spring 2018: Lecture 11

CSC 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 information

Machine-Level Programming I Introduction

Machine-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 information

Machine-Level Programming I Introduction

Machine-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 information

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

x86 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 information

Foundations of Computer Systems

Foundations 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 information

x86-64 Assembly CSE 351 Winter 2018 Instructor: Mark Wyse

x86-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 information

Machine Programming 3: Procedures

Machine 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 information

x86 Programming I CSE 351 Autumn 2016 Instructor: Justin Hsia

x86 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 information

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

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 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 information

Credits and Disclaimers

Credits 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 information

How Software Executes

How 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 information

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

Page # 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 information

CS367 Test 1 Review Guide

CS367 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 information

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

L08: 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 information

Giving credit where credit is due

Giving 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 information

Machine Programming. CSE 351 Autumn Instructor: Justin Hsia

Machine 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 information

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

CISC 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 information

Systems I. Machine-Level Programming I: Introduction

Systems 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 information

Machine Program: Procedure. Zhaoguo Wang

Machine 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 information

CS165 Computer Security. Understanding low-level program execution Oct 1 st, 2015

CS165 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 information

CS241 Computer Organization Spring 2015 IA

CS241 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 information

CS24: INTRODUCTION TO COMPUTING SYSTEMS. Spring 2018 Lecture 4

CS24: 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 information

Computer 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 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 information

Floating Point II, x86 64 Intro

Floating 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 information

x86-64 Programming II

x86-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 information

1 Number Representation(10 points)

1 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 information

x86 Programming II CSE 351 Winter

x86 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 information

void twiddle1(int *xp, int *yp) { void twiddle2(int *xp, int *yp) {

void 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 information

RISC I from Berkeley. 44k Transistors 1Mhz 77mm^2

RISC 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 information

Machine- Level Programming I: Basics

Machine- 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 information

x86-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 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 information

Princeton 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 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 information

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

Assembly 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 information

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

x86 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 information

Assembly Language: Function Calls

Assembly 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 information

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

Assembly 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 information

Machine-level Representation of Programs

Machine-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 information

Representation of Information

Representation 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 information

Data Representation Floating Point

Data 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 information

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

Bryant 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 information

Machine/Assembler Language Putting It All Together

Machine/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 information

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

Bryant 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 information

The Hardware/Software Interface CSE351 Spring 2015

The 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 information

CSE 351 Midterm Exam Spring 2016 May 2, 2015

CSE 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 information

Data Representation Floating Point

Data 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 information

CS429: Computer Organization and Architecture

CS429: 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 information

Floating Point Numbers

Floating 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 information

Floating Point Numbers

Floating 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 information

Floating Point : Introduction to Computer Systems 4 th Lecture, May 25, Instructor: Brian Railing. Carnegie Mellon

Floating 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 information

Lecture 4: x86_64 Assembly Language

Lecture 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 information

CS 107 Lecture 10: Assembly Part I

CS 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 information

CSE351 Spring 2018, Midterm Exam April 27, 2018

CSE351 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 information

6.035 Project 3: Unoptimized Code Generation. Jason Ansel MIT - CSAIL

6.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 information

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

Machine-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 information

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

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 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 information

The Hardware/Software Interface CSE351 Spring 2015

The 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 information

x86 64 Programming II

x86 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 information

Assembly Programming III

Assembly 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 information

Computer Processors. Part 2. Components of a Processor. Execution Unit The ALU. Execution Unit. The Brains of the Box. Processors. Execution Unit (EU)

Computer 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 information

Computer Organization: A Programmer's Perspective

Computer 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 information

Assembly III: Procedures. Jin-Soo Kim Computer Systems Laboratory Sungkyunkwan University

Assembly 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 information

Introduction to Machine/Assembler Language

Introduction 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