Chapter 2: Instructions: Language of the Computer CSCE 212 Introduction to Computer Architecture, Spring

Similar documents
Chapter 2. Instructions: Language of the Computer. Adapted by Paulo Lopes

Two processors sharing an area of memory. P1 writes, then P2 reads Data race if P1 and P2 don t synchronize. Result depends of order of accesses

Chapter 2. Instructions: Language of the Computer

Architecture II. Computer Systems Laboratory Sungkyunkwan University

COMPUTER ORGANIZATION AND DESIGN

MIPS Instruction Set Architecture (2)

MIPS R-format Instructions. Representing Instructions. Hexadecimal. R-format Example. MIPS I-format Example. MIPS I-format Instructions

LECTURE 2: INSTRUCTIONS

CS3350B Computer Architecture MIPS Procedures and Compilation

Computer Architecture Computer Science & Engineering. Chapter 2. Instructions: Language of the Computer BK TP.HCM

Computer Organization and Structure. Bing-Yu Chen National Taiwan University

Instruction Set. The MIPS Instruction Set. Chapter 2

Procedure Calling. Procedure Calling. Register Usage. 25 September CSE2021 Computer Organization

COMPUTER ORGANIZATION AND DESIGN. 5 th Edition. The Hardware/Software Interface. Chapter 2. Instructions: Language of the Computer

Chapter 2. Instructions: Language of the Computer

Computer Architecture

Thomas Polzer Institut für Technische Informatik

Chapter 2. Baback Izadi Division of Engineering Programs

Machine Instructions - II. Hwansoo Han

Rechnerstrukturen. Chapter 2. Instructions: Language of the Computer

Chapter 2. Instructions: Language of the Computer

Chapter 2A Instructions: Language of the Computer

Chapter 2. Instructions: Language of the Computer. HW#1: 1.3 all, 1.4 all, 1.6.1, , , , , and Due date: one week.

COMPUTER ORGANIZATION AND DESIGN. 5 th Edition. The Hardware/Software Interface. Chapter 2. Instructions: Language of the Computer

Chapter 2. Instructions: Language of the Computer

Computer Organization and Structure. Bing-Yu Chen National Taiwan University

Chapter 2. Instructions: Language of the Computer. Baback Izadi ECE Department

Instructions: Language of the Computer. Euiseong Seo Computer Systems Laboratory Sungkyunkwan University

Introduction to the MIPS. Lecture for CPSC 5155 Edward Bosworth, Ph.D. Computer Science Department Columbus State University

Lecture 2. Instructions: Language of the Computer (Chapter 2 of the textbook)

CSCI 402: Computer Architectures. Instructions: Language of the Computer (4) Fengguang Song Department of Computer & Information Science IUPUI

Branch Addressing. Jump Addressing. Target Addressing Example. The University of Adelaide, School of Computer Science 28 September 2015

Chapter 2. Instructions: Language of the Computer. Jiang Jiang

Procedure Call Instructions

Chapter 2. Computer Abstractions and Technology. Lesson 4: MIPS (cont )

Computer Systems Laboratory Sungkyunkwan University

Chapter 2. Instructions: Language of the Computer

Chapter 2. Instructions: Language of the Computer

Chapter 2. Instructions: Language of the Computer

Instructions: MIPS ISA. Chapter 2 Instructions: Language of the Computer 1

Control Instructions. Computer Organization Architectures for Embedded Computing. Thursday, 26 September Summary

Control Instructions

Computer Architecture

Computer Architecture. Chapter 2-2. Instructions: Language of the Computer

CSCI 402: Computer Architectures. Instructions: Language of the Computer (3) Fengguang Song Department of Computer & Information Science IUPUI.

CS3350B Computer Architecture MIPS Instruction Representation

Machine Language Instructions Introduction. Instructions Words of a language understood by machine. Instruction set Vocabulary of the machine

Chapter 2. Instruction Set. The MIPS Instruction Set. Arithmetic Operations. Instructions: Language of the Computer

Instructions: Language of the Computer

COMPSCI 313 S Computer Organization. 7 MIPS Instruction Set

Chapter 1. Computer Abstractions and Technology. Lesson 3: Understanding Performance

CENG3420 Lecture 03 Review

COE608: Computer Organization and Architecture

Chapter 2 Instructions: Language of the Computer

ENGN1640: Design of Computing Systems Topic 03: Instruction Set Architecture Design

CS3350B Computer Architecture

EJEMPLOS DE ARQUITECTURAS

CISC 662 Graduate Computer Architecture. Lecture 4 - ISA MIPS ISA. In a CPU. (vonneumann) Processor Organization

Unsigned Binary Integers

Unsigned Binary Integers

CISC 662 Graduate Computer Architecture. Lecture 4 - ISA

CSE 2021: Computer Organization

All instructions have 3 operands Operand order is fixed (destination first)

MIPS ISA-II: Procedure Calls & Program Assembly

Computer Organization MIPS ISA

ECE 154A Introduction to. Fall 2012

Architecture I. Computer Systems Laboratory Sungkyunkwan University

Stored Program Concept. Instructions: Characteristics of Instruction Set. Architecture Specification. Example of multiple operands

Computer Architecture. Lecture 2 : Instructions

Communicating with People (2.8)

EEC 581 Computer Architecture Lecture 1 Review MIPS

COMPUTER ORGANIZATION AND DESIGN. ARM Edition. The Hardware/Software Interface. Chapter 2. Instructions: Language of the Computer

2.7 Supporting Procedures in hardware. Why procedures or functions? Procedure calls

CENG3420 L03: Instruction Set Architecture

Instructions: MIPS arithmetic. MIPS arithmetic. Chapter 3 : MIPS Downloaded from:

ECE369. Chapter 2 ECE369

EN164: Design of Computing Systems Topic 03: Instruction Set Architecture Design

Systems Architecture I

2. Instructions: Language of the Computer Computer Architecture COMP SCI 2GA3 / SFWR ENG 2GA3

CS3350B Computer Architecture MIPS Introduction

Instruction Set Architecture. "Speaking with the computer"

ELEC / Computer Architecture and Design Fall 2013 Instruction Set Architecture (Chapter 2)

Chapter 2. Instruction Set. RISC vs. CISC Instruction set. The University of Adelaide, School of Computer Science 18 September 2017

Reduced Instruction Set Computer (RISC)

EC 413 Computer Organization

Reduced Instruction Set Computer (RISC)

EEM870 Embedded System and Experiment Lecture 4: ARM Instruction Sets

Chapter 2. lw $s1,100($s2) $s1 = Memory[$s2+100] sw $s1,100($s2) Memory[$s2+100] = $s1

Chapter 3 MIPS Assembly Language. Ó1998 Morgan Kaufmann Publishers 1

Computer Architecture

EECS Computer Organization Fall Based on slides by the author and prof. Mary Jane Irwin of PSU.

Computer Science 324 Computer Architecture Mount Holyoke College Fall Topic Notes: MIPS Instruction Set Architecture

MACHINE LANGUAGE. To work with the machine, we need a translator.

Instruction Set Architecture part 1 (Introduction) Mehran Rezaei

Computer Organization and Design

ECE 486/586. Computer Architecture. Lecture # 8

Instruction Set Design and Architecture

MODULE 4 INSTRUCTIONS: LANGUAGE OF THE MACHINE

Computer Architecture. MIPS Instruction Set Architecture

Lecture 7: Examples, MARS, Arithmetic

Transcription:

Chapter 2: Instructions: Language of the Computer CSCE 212 Introduction to Computer Architecture, Spring 2019 https://passlab.github.io/csce212/ Department of Computer Science and Engineering Yonghong Yan yanyh@cse.sc.edu http://cse.sc.edu/~yanyh

Chapter 2: Instructions: Language of the Computer Lecture 07 2.1 Introduction 2.2 Operations of the Computer Hardware 2.3 Operands of the Computer Hardware 2.4 Signed and Unsigned Numbers 2.5 Representing Instructions in the Computer Lecture 08 2.6 Logical Operations 2.7 Instructions for Making Decisions A.4 A.6: Loading, Memory and Procedure Call Convention 2.8 Supporting Procedures in Computer Hardware 2.9 Communicating with People Lecture 09 2.10 MIPS Addressing for 32-Bit Immediates and Addresses 2.11 Parallelism and Instructions: Synchronization 2.12 Translating and Starting a Program We covered in Appendix A and C Basics 2.13 A C Sort Example to Put It All Together 2.14 Arrays versus Pointers 2.15 Advanced Material: Compiling C and Interpreting Java Lecture 10 2.16 Real Stuff: ARMv7 (32-bit) Instructions 2.17 Real Stuff: x86 Instructions 2.18 Real Stuff: ARMv8 (64-bit) Instructions 2.19 Fallacies and Pitfalls 2.20 Concluding Remarks 2.21 Historical Perspective and Further Reading 2

Review of Lecture 06 3

Review: C Basics #include <stdio.h> int main(int argc, char* argv[]) { /* print a greeting */ printf("good evening!\n"); return 0; } 4

C Variable and Pointer & = address of * = contents at 5

C Pointer and Memory & = address of * = contents at 6

Example 2: swap_2 void swap_2(int *a, int *b) { int temp; temp = *a; *a = *b; *b = temp; } void call_swap_2( ) { int x = 3; int y = 4; swap_1(&x, &y); /* values of x and y? */ } Q: Let x=3, y=4, after swap_2(&x,&y); x =? y=? A1: x=3; y=4; A2: x=4; y=3;

Arrays Adjacent memory locations storing the same type of data int a[6]; means space for six integers a is the name of the array s base address 0x0C

int a[6]; Address of Array Elements a is the name of the array s base address 0x0C &a[i]: a + i * sizeof(int) E.g. &a[2]: 0x0C + 2 * 4 = 0x14 By itself, a is also the address of the first integer *a and a[0] mean the same thing The address of a is not stored in memory: the compiler inserts code to compute it when it appears

C Stores Array in Memory in Row Major int A[3][4]; 8 6 5 4 2 1 9 7 3 6 4 2 Offset of A[1][2] Address of element A[1][2]: = A + offset (from A to A[1][2]) = A + sizeof (int) * (1 * 4 + 2) = A + 4 * 6 = A + 24 10

End of Review of Lecture 06 11

Chapter 2: Instructions: Language of the Computer Lecture 07 2.1 Introduction 2.2 Operations of the Computer Hardware 2.3 Operands of the Computer Hardware 2.4 Signed and Unsigned Numbers 2.5 Representing Instructions in the Computer Lecture 08 2.6 Logical Operations 2.7 Instructions for Making Decisions A.4 A.6: Loading, Memory and Procedure Call Convention 2.8 Supporting Procedures in Computer Hardware 2.9 Communicating with People Lecture 09 2.10 MIPS Addressing for 32-Bit Immediates and Addresses 2.11 Parallelism and Instructions: Synchronization 2.12 Translating and Starting a Program We covered in Appendix A and C Basics 2.13 A C Sort Example to Put It All Together 2.14 Arrays versus Pointers 2.15 Advanced Material: Compiling C and Interpreting Java Lecture 10 2.16 Real Stuff: ARMv7 (32-bit) Instructions 2.17 Real Stuff: x86 Instructions 2.18 Real Stuff: ARMv8 (64-bit) Instructions 2.19 Fallacies and Pitfalls 2.20 Concluding Remarks 2.21 Historical Perspective and Further Reading 12

MIPS and X86_64 Assembly Example 2.1 Introduction 13

Instruction Set The repertoire of instructions of a computer Different computers have different instruction sets But with many aspects in common Early computers had very simple instruction sets Simplified implementation Many modern computers also have simple instruction sets 14

Instruction Set Architecture: the Interface between Hardware and Software Instruction Set Architecture the portion of the machine visible to the assembly level programmer or to the compiler writer To use the hardware of a computer, we must speak its language The words of a computer language are called instructions, and its vocabulary is called an instruction set software hardware instruction set Instr. # Operation+Operands i movl -4(%ebp), %eax (i+1) addl %eax, (%edx) (i+2) cmpl 8(%ebp), %eax (i+3) jl L5 : L5: 15

RISC vs. CISC Design philosophies for ISAs: RISC vs. CISC CISC = Complex Instruction Set Computer X86, X86_64 (Intel and AMD, main-stream desktop/laptop/server) X86* internally are still RISC RISC = Reduced Instruction Set Computer ARM: smart phone/pad RISC-V: free ISA, closer to MIPS than other ISAs, the same textbook in RISC-V version Others: Power, SPARC, etc Tradeoff: Instructions Clock cycles CPU Time = Program Instruction RISC: Small instruction set Easier for compilers Limit each instruction to (at most): three register accesses, one memory access, one ALU operation => facilitates parallel instruction execution (ILP) Load-store machine: minimize off-chip access Seconds Clock cycle

The MIPS Instruction Set Used as the example throughout the book Stanford MIPS commercialized by MIPS Technologies (www.mips.com) Large share of embedded core market Applications in consumer electronics, network/storage equipment, cameras, printers, Typical of many modern ISAs See MIPS Reference Data tear-out card, and Appendixes B and E Other Instruction Set Architectures: X86 and X86_32: Intel and AMD, main-stream desktop/laptop/server ARM: smart phone/pad RISC-V: emerging and free ISA, closer to MIPS than other ISAs The same textbook in RISC-V version Others: Power, SPARC, etc 17

Arithmetic Operations Add and subtract, three operands Two sources and one destination add a, b, c # a gets b + c All arithmetic operations have this form Design Principle 1: Simplicity favours regularity Regularity makes implementation simpler Simplicity enables higher performance at lower cost 2.2 Operations of the Computer Hardware 18

Arithmetic Example C code: f = (g + h) - (i + j); Compiled MIPS code: add t0, g, h add t1, i, j sub f, t0, t1 # temp t0 = g + h # temp t1 = i + j # f = t0 - t1 19

Registers in CPU Registers are super-fast small storage used in CPU. Data and instructions need to be loaded to register in order to be processed. 2.3 Operands of the Computer Hardware 20

Register Operands Arithmetic instructions use register operands MIPS has a 32 32-bit register file Use for frequently accessed data Numbered 0 to 31 32-bit data called a word Assembler names $t0, $t1,, $t9 for temporary values $s0, $s1,, $s7 for saved variables Design Principle 2: Smaller is faster c.f. main memory: millions of locations 21

Register Operand Example C code: f = (g + h) - (i + j); f,, j in $s0,, $s4 Compiled MIPS code: add $t0, $s1, $s2 # register $t0 contains g + h add $t1, $s3, $s4 # register $t1 contains i + j sub $s0, $t0, $t1 # $s0 gets $t0 $t1, which is # (g + h) (i + j) 22

Memory Operands Main memory used for composite data Arrays, structures, dynamic data To apply arithmetic operations Load values from memory into registers Store result from register to memory Memory is byte addressed Each address identifies an 8-bit byte Words are aligned in memory Address must be a multiple of 4 MIPS is Big Endian Most-significant byte at least address of a word c.f. Little Endian: least-significant byte at least address 23

Memory Operand Example 1 C code: int a[n] g = h + A[8]; g in $s1, h in $s2, base address of A in $s3 Compiled MIPS code: Index 8 requires offset of 32, A[8] is right-val reference à load 4 bytes per word lw $t0, 32($s3) # load word add $s1, $s2, $t0 offset base register 24

C code: int a[n] Memory Operand Example 2 A[12] = h + A[8]; h in $s2, base address of A in $s3 Compiled MIPS code: Index 8 requires offset of 32: A[8]: right-val, A[12]: left-val lw $t0, 32($s3) # load word add $t0, $s2, $t0 sw $t0, 48($s3) # store word 25

Registers vs. Memory Registers are faster to access than memory Operating on memory data requires loads and stores More instructions to be executed Compiler must use registers for variables as much as possible Only spill to memory for less frequently used variables Register optimization is important! 26

Immediate Operands Constant data specified in an instruction addi $s3, $s3, 4 No subtract immediate instruction Just use a negative constant addi $s2, $s1, -1 Design Principle 3: Make the common case fast Small constants are common Immediate operand avoids a load instruction 27

The Constant Zero MIPS register 0 ($zero) is the constant 0 Cannot be overwritten Useful for common operations E.g., move between registers add $t2, $s1, $zero 28

Unsigned Binary Integers Given an n-bit number x = x + n-1 n-2 1 0 n- 12 + xn-22 +! + x12 x02 n Range: 0 to +2 n 1 n Example 2.4 Signed and Unsigned Numbers n 0000 0000 0000 0000 0000 0000 0000 1011 2 = 0 + + 1 2 3 + 0 2 2 +1 2 1 +1 2 0 = 0 + + 8 + 0 + 2 + 1 = 11 10 n Using 32 bits n 0 to +4,294,967,295 29

2s-Complement Signed Integers Given an n-bit number x = -x + n-1 n-2 1 0 n- 12 + xn-22 +! + x12 x02 n Range: 2 n 1 to +2 n 1 1 n Example n 1111 1111 1111 1111 1111 1111 1111 1100 2 = 1 2 31 + 1 2 30 + + 1 2 2 +0 2 1 +0 2 0 = 2,147,483,648 + 2,147,483,644 = 4 10 n Using 32 bits n 2,147,483,648 to + 2,147,483,647 30

2s-Complement Signed Integers Bit 31 is sign bit 1 for negative numbers 0 for non-negative numbers 2 n 1 can t be represented 1000 is negative now Non-negative numbers have the same unsigned and 2scomplement representation Some specific numbers 0: 0000 0000 0000 1: 1111 1111 1111 x = -x + n-1 n-2 1 0 n- 12 + xn-22 +! + x12 x02 Most-negative: 1000 0000 0000, which is 2,147,483,648 Most-positive: 0111 1111 1111, which is 2,147,483,647 31

Signed Negation Complement and add 1 Complement means 1 0, 0 1 x + x = 1111...1112 = -1 x + 1= -x n Example: negate +2 n +2 = 0000 0000 0010 2 n 2 = +2 +1 = 0000 0000 0010 2 + 1 = 1111 1111 1101 2 + 1 = 1111 1111 1110 2 32

Sign Extension Representing a number using more bits E.g. short a = -5; int b = a; Preserve the numeric value Replicate the sign bit to the left c.f. unsigned values: extend with 0s Examples: 8-bit to 16-bit +2: 0000 0010 => 0000 0000 0000 0010 2: 1111 1110 => 1111 1111 1111 1110 In MIPS instruction set addi: extend immediate value lb, lh: extend loaded byte/halfword beq, bne: extend the displacement 33

Representing Instructions Instructions are encoded in binary Called machine code MIPS instructions Encoded as 32-bit instruction words Small number of formats encoding operation code (opcode), register numbers, Regularity! Register numbers (total 32 registers) mapping convention $t0 $t7 are reg s $8 $15 $t8 $t9 are reg s $24 $25 $s0 $s7 are reg s $16 $23 34 2.5 Representing Instructions in the Computer

MIPS R-format Instructions op rs rt rd shamt funct 6 bits 5 bits 5 bits 5 bits 5 bits 6 bits Instruction fields op: operation code (opcode) rs: first source register number rt: second source register number rd: destination register number shamt: shift amount (00000 for now) funct: function code (extends opcode) 35

R-format Example op rs rt rd shamt funct 6 bits 5 bits 5 bits 5 bits 5 bits 6 bits add $t0, $s1, $s2 special $s1 $s2 $t0 0 add 0 17 18 8 0 32 000000 10001 10010 01000 00000 100000 00000010001100100100000000100000 2 = 02324020 16 36

Hexadecimal Base 16 Compact representation of bit strings 4 bits per hex digit 0 0000 4 0100 8 1000 c 1100 1 0001 5 0101 9 1001 d 1101 2 0010 6 0110 a 1010 e 1110 3 0011 7 0111 b 1011 f 1111 n Example: eca8 6420 n 1110 1100 1010 1000 0110 0100 0010 0000 37

MIPS I-format Instructions op rs rt constant or address 6 bits 5 bits 5 bits 16 bits Immediate arithmetic and load/store instructions rt: destination or source register number Constant: 2 15 to +2 15 1 Address: offset added to base address in rs g = h + A[8]; Design Principle 4: Good design demands good compromises Different formats complicate decoding, but allow 32-bit instructions uniformly Keep formats as similar as possible 38

MIPS Instruction Encoding Textbook Example in page 84-85 39

Stored Program Computers The BIG Picture Instructions represented in binary, just like data Instructions and data stored in memory Programs can operate on programs e.g., compilers, linkers, Binary compatibility allows compiled programs to work on different computers Standardized ISAs 40

End of Lecture 07 41

Chapter 2: Instructions: Language of the Computer Lecture 07 2.1 Introduction 2.2 Operations of the Computer Hardware 2.3 Operands of the Computer Hardware 2.4 Signed and Unsigned Numbers 2.5 Representing Instructions in the Computer Lecture 08 2.6 Logical Operations 2.7 Instructions for Making Decisions A.4 A.6: Loading, Memory and Procedure Call Convention 2.8 Supporting Procedures in Computer Hardware 2.9 Communicating with People Lecture 09 2.10 MIPS Addressing for 32-Bit Immediates and Addresses 2.11 Parallelism and Instructions: Synchronization 2.12 Translating and Starting a Program We covered in Appendix A and C Basics 2.13 A C Sort Example to Put It All Together 2.14 Arrays versus Pointers 2.15 Advanced Material: Compiling C and Interpreting Java Lecture 10 2.16 Real Stuff: ARMv7 (32-bit) Instructions 2.17 Real Stuff: x86 Instructions 2.18 Real Stuff: ARMv8 (64-bit) Instructions 2.19 Fallacies and Pitfalls 2.20 Concluding Remarks 2.21 Historical Perspective and Further Reading 42

Review of Lecture 07 43

Review: Instruction Set Architecture: the Interface between Hardware and Software Instruction Set Architecture the portion of the machine visible to the assembly level programmer or to the compiler writer To use the hardware of a computer, we must speak its language The words of a computer language are called instructions, and its vocabulary is called an instruction set software hardware instruction set Instr. # Operation+Operands i movl -4(%ebp), %eax (i+1) addl %eax, (%edx) (i+2) cmpl 8(%ebp), %eax (i+3) jl L5 : L5: 44

Arithmetic-Logic Instructions (add, sub, addi, and, or, shift left right, etc) C code: f = (g + h) - (i + j); f,, j in $s0,, $s4 Compiled MIPS code: (R-type, i.e. Registers as operands) add $t0, $s1, $s2 # register $t0 contains g + h add $t1, $s3, $s4 # register $t1 contains i + j sub $s0, $t0, $t1 # $s0 gets $t0 $t1, which is # (g + h) (i + j) I-type (Immediate as one of the operands) addi $s3, $s3, 4 45

Memory Load/Store Instructions: Lw and Sw C code: int a[n] A[12] = h + A[8]; h in $s2, base address of A in $s3 Compiled MIPS code: Index 8 requires offset of 32: A[8]: right-val, A[12]: left-val lw $t0, 32($s3) # load word add $t0, $s2, $t0 sw $t0, 48($s3) # store word 46

2s-Complement Signed Integers Bit 31 is sign bit 1 for negative numbers 0 for non-negative numbers 2 n 1 can t be represented 1000 is negative now Non-negative numbers have the same unsigned and 2scomplement representation Some specific numbers 0: 0000 0000 0000 1: 1111 1111 1111 x = -x + n-1 n-2 1 0 n- 12 + xn-22 +! + x12 x02 Most-negative: 1000 0000 0000, which is 2,147,483,648 Most-positive: 0111 1111 1111, which is 2,147,483,647 47

Signed Negation Complement and add 1 Complement means 1 0, 0 1 x + x = 1111...1112 = -1 x + 1= -x n Example: negate +2 n +2 = 0000 0000 0010 2 n 2 = +2 +1 = 0000 0000 0010 2 + 1 = 1111 1111 1101 2 + 1 = 1111 1111 1110 2 48

Sign Extension Representing a number using more bits E.g. short a = -5; int b = a; Preserve the numeric value Replicate the sign bit to the left c.f. unsigned values: extend with 0s Examples: 8-bit to 16-bit +2: 0000 0010 => 0000 0000 0000 0010 2: 1111 1110 => 1111 1111 1111 1110 In MIPS instruction set addi: extend immediate value lb, lh: extend loaded byte/halfword beq, bne: extend the displacement 49

Instruction Encoding: R-format, MIPS 32-bit instruction word, 32 registers op rs rt rd shamt funct 6 bits 5 bits 5 bits 5 bits 5 bits 6 bits add $t0, $s1, $s2 special $s1 $s2 $t0 0 add 0 17 18 8 0 32 000000 10001 10010 01000 00000 100000 00000010001100100100000000100000 2 = 02324020 16 50

MIPS I-format Instructions op rs rt constant or address 6 bits 5 bits 5 bits 16 bits Immediate arithmetic and load/store instructions rt: destination or source register number Constant: 2 15 to +2 15 1 Address: offset added to base address in rs g = h + A[8]; Design Principle 4: Good design demands good compromises Different formats complicate decoding, but allow 32-bit instructions uniformly Keep formats as similar as possible 51

MIPS Instruction Encoding Textbook Example in page 84-85 52

End of Review of Lecture 07 53

Chapter 2: Instructions: Language of the Computer Lecture 07 2.1 Introduction 2.2 Operations of the Computer Hardware 2.3 Operands of the Computer Hardware 2.4 Signed and Unsigned Numbers 2.5 Representing Instructions in the Computer Lecture 08 2.6 Logical Operations 2.7 Instructions for Making Decisions A.4 A.6: Loading, Memory and Procedure Call Convention 2.8 Supporting Procedures in Computer Hardware 2.9 Communicating with People Lecture 09 2.10 MIPS Addressing for 32-Bit Immediates and Addresses 2.11 Parallelism and Instructions: Synchronization 2.12 Translating and Starting a Program We covered in Appendix A and C Basics 2.13 A C Sort Example to Put It All Together 2.14 Arrays versus Pointers 2.15 Advanced Material: Compiling C and Interpreting Java Lecture 10 2.16 Real Stuff: ARMv7 (32-bit) Instructions 2.17 Real Stuff: x86 Instructions 2.18 Real Stuff: ARMv8 (64-bit) Instructions 2.19 Fallacies and Pitfalls 2.20 Concluding Remarks 2.21 Historical Perspective and Further Reading 54

Three Classes of Instructions We Will Focus On: 1. Arithmetic-logic instructions add, sub, addi, and, or, shift left right, etc 2. Memory load and store instructions lw and sw: Load/store word Lb and sb: Load/store byte Control transfer instructions Conditional branch: bne, beq Unconditional jump: j Procedure call and return: jal and jr 55

Logical Operations Instructions for bitwise manipulation Operation C Java MIPS Shift left << << sll Shift right >> >>> srl Bitwise AND & & and, andi Bitwise OR or, ori Bitwise NOT ~ ~ nor 2.6 Logical Operations n Useful for extracting and inserting groups of bits in a word 56

Shift Operations op rs rt rd shamt funct 6 bits 5 bits 5 bits 5 bits 5 bits 6 bits shamt: how many positions to shift Shift left logical Shift left and fill with 0 bits sll by i bits multiplies by 2 i E.g. int a = b<<2; //a = b * 2 (2 2 ) Shift right logical Shift right and fill with 0 bits srl by i bits divides by 2 i (unsigned only) E.g. int a = b>>2; //a = b / 4 (2 2 ) 57

AND Operations Useful to mask bits in a word Select some bits, clear others to 0 and $t0, $t1, $t2 $t2 $t1 $t0 0000 0000 0000 0000 0000 1101 1100 0000 0000 0000 0000 0000 0011 1100 0000 0000 0000 0000 0000 0000 0000 1100 0000 0000 58

OR Operations Useful to include bits in a word Set some bits to 1, leave others unchanged or $t0, $t1, $t2 $t2 $t1 $t0 0000 0000 0000 0000 0000 1101 1100 0000 0000 0000 0000 0000 0011 1100 0000 0000 0000 0000 0000 0000 0011 1101 1100 0000 59

NOT Operations Useful to invert bits in a word Change 0 to 1, and 1 to 0 MIPS has NOR 3-operand instruction a NOR b == NOT ( a OR b ) nor $t0, $t1, $zero Register 0: always read as zero $t1 $t0 0000 0000 0000 0000 0011 1100 0000 0000 1111 1111 1111 1111 1100 0011 1111 1111 60

Conditional Branch and Unconditional Jump Branch to a labeled instruction if a condition is true Otherwise, continue sequentially Label is the symbolic representation of the memory address of an instruction. beq rs, rt, L1 if (rs == rt) branch to instruction labeled L1; bne rs, rt, L1 if (rs!= rt) branch to instruction labeled L1; Unconditional Jump j L1 unconditional jump to instruction labeled L1 2.7 Instructions for Making Decisions 61

C code: Compiling If Statements if (i==j) f = g+h; else f = g-h; f, g, in $s0, $s1, Compiled MIPS code: bne $s3, $s4, Else add $s0, $s1, $s2 j Exit Else: sub $s0, $s1, $s2 Exit: Assembler calculates addresses 62

C code: Compiling Loop Statements while (save[i] == k) i += 1; i in $s3, k in $s5, address of save in $s6 Compiled MIPS code: Loop: sll $t1, $s3, 2 #i=i*4 add $t1, $t1, $s6 #base+offset lw $t0, 0($t1) #newbase in $t1 bne $t0, $s5, Exit #bne addi $s3, $s3, 1 #i=i+1; j Loop Exit: 63

More Conditional Operations Set result to 1 if a condition is true Otherwise, set to 0 slt rd, rs, rt if (rs < rt) rd = 1; else rd = 0; slti rt, rs, constant if (rs < constant) rt = 1; else rt = 0; Use in combination with beq, bne slt $t0, $s1, $s2 # if ($s1 < $s2) bne $t0, $zero, L # branch to L 64

Branch Instruction Design Why not blt, bge, etc? Hardware for <,, slower than =, Combining with branch involves more work per instruction, requiring a slower clock All instructions penalized! beq and bne are the common case This is a good design compromise 65

Signed vs. Unsigned Signed comparison: slt, slti Unsigned comparison: sltu, sltui Example $s0 = 1111 1111 1111 1111 1111 1111 1111 1111 $s1 = 0000 0000 0000 0000 0000 0000 0000 0001 slt $t0, $s0, $s1 # signed 1 < +1 Þ $t0 = 1 sltu $t0, $s0, $s1 # unsigned +4,294,967,295 > +1 Þ $t0 = 0 66

Memory layout of a program (process) and hardware support for function calls 67

./a.out: Loading a File for Execution Steps: It reads the executable s header to determine the size of the text and data segments. It creates a new address space for the program. It copies instructions and data from the executable into the new address space. It copies arguments passed to the program onto the stack. It initializes the machine registers. In general, most registers are cleared, but the stack pointer must be assigned the address of the rst free stack location (see Section A.5). It jumps to a start-up routine that copies the program s arguments from the stack to registers and calls the program s main routine. When the main routine returns, the start-up routine terminates the program with the exit system call. 68 A.4 Loading

Process Memory Layout Text: program code Static data: global variables e.g., static variables in C, constant arrays and strings $gp initialized to address allowing ±offsets into this segment Dynamic data: heap E.g., malloc in C, new in Java Stack: automatic storage 69

Program Counter (PC) A register to hold the address of the current instruction being executed. A better name: instruction address register. Relative address 70

Linux Process Memory in 32-bit System (4G space) Code (machine instructions) à Text segment Static variables à Data or BSS segment Function variables à stack (i, A[100] and B) A is a variable that stores memory address, the memory for A s 100 int elements is in the stack B is a memory address, it is stored in stack, but the memory B points to is in heap (100 int elements) Dynamic allocated memory using malloc or C++ new à heap (B[100)), memory across funtion calls Stack size limit. If 8MB, int A[10,000,000] won t work. A.5 Memory Usage #include <stdio.h> static char *gonzo = God s own prototype ; static char *username; int main(int argc, char* argv[]){ int i; /* stack */ int A[100]; /* stack */ int *B = (int*)malloc(sizeof(int)*100); //heap } for(i = 0; i < 100; i++) { A[i] = i*i; B[i] = A[i] * 20; printf( A[i]: %d, B[i]: %d\n",a[i], B[i]); } 71

Procedure Calling Steps required Place parameters in registers Transfer control to procedure Acquire storage for procedure Perform procedure s operations Place result in register for caller Return to place of call A.6 Procedure Call Convention 2.8 Supporting Procedures in Computer Hardware 72

Sum Example: sum_full.c https://passlab.github.io/csce212/exercises/sum 73

Sum Example, sum_full_mips.s Arguments for sum call Return to caller Memory address of sum e https://passlab.github.io/csce212/exercises/sum Store return address in $31 and call transfer to sum 74

Procedure Call Instructions Procedure call: jump and link jal ProcedureLabel Address of following instruction put in $ra Jumps to target address Procedure return: jump register jr $ra Copies $ra to program counter Can also be used for computed jumps e.g., for case/switch statements 75

Register Usage $a0 $a3: arguments (reg s 4 7) $v0, $v1: result values (reg s 2 and 3) $t0 $t9: temporaries Can be overwritten by callee $s0 $s7: saved Must be saved/restored by callee $gp: global pointer for static data (reg 28) $sp: stack pointer (reg 29) $fp: frame pointer (reg 30) $ra: return address (reg 31) 76

Stack Memory Used for Function Calls Stack is Last-In-First-Out (LIFO) data structure to store the info of each function of the call path Main() calls foo(), foo() calls bar(), bar() calls tar() Call in: push function to the stack top Return: pop function from the top Stack frame, function frame, activation record The memory and the data of the info for each function call main() foo() bar() tar() push pop top 77

Stack Frame (Activation Record) of a Function Call Information: Parameters Local variables Return address Location to put return value when function exits Control link to the caller s activation record Saved registers Temporary variables and intermediate results (not always) Access link to the function s static parent Frame pointer (fp register): the starting address of AR Stack pointer (sp register): the ending address of AR 78

Leaf Procedure Example Leaf procedure A procedure does not call other procedures Thinking of procedure calls as a tree C code: int leaf_example (int g, h, i, j) { int f; f = (g + h) - (i + j); return f; } Arguments g,, j in $a0,, $a3 f in $s0 (hence, need to save $s0 on stack) Result in $v0 79

Leaf Procedure Example MIPS code: leaf_example: addi $sp, $sp, -4 sw $s0, 0($sp) add $t0, $a0, $a1 add $t1, $a2, $a3 sub $s0, $t0, $t1 add $v0, $s0, $zero lw $s0, 0($sp) addi $sp, $sp, 4 jr $ra Save $s0 on stack Procedure body Result Restore $s0 Return push pop 80

Non-Leaf Procedures Procedures that call other procedures For nested call, caller needs to save on the stack: Its return address Any arguments and temporaries needed after the call Restore from the stack after the call 81

Non-Leaf Procedure Example C code: int fact (int n) { if (n < 1) return f; else return n * fact(n - 1); } Argument n in $a0 Result in $v0 82

MIPS code: fact: Non-Leaf Procedure Example addi $sp, $sp, -8 sw $ra, 4($sp) # save return address sw $a0, 0($sp) # save argument n slti $t0, $a0, 1 # test for n < 1 # adjust stack for 2 items push beq $t0, $zero, L1 addi $v0, $zero, 1 # if so, result is 1 addi $sp, $sp, 8 # pop 2 items from stack jr $ra # and return L1: addi $a0, $a0, -1 # else decrement n jal fact # recursive call lw $a0, 0($sp) # restore original n lw $ra, 4($sp) # and return address addi $sp, $sp, 8 # pop 2 items from stack mul $v0, $a0, $v0 # multiply to get result jr $ra # and return pop pop 83

Reading After Class Read and understand the examples in 2.8 and A.6 84

Character Data Byte-encoded character sets ASCII: 128 characters 95 graphic, 33 control char v = `a`; //store byte-size character a in variable v Latin-1: 256 characters ASCII, +96 more graphic characters 2.9 Communicating with People Unicode: 32-bit character set Used in Java, C++ wide characters, Most of the world s alphabets, plus symbols UTF-8, UTF-16: variable-length encodings 85

Byte/Halfword Operations Could use bitwise operations MIPS byte/halfword load/store to a 32-bit register String processing is a common case lb rt, offset(rs) Sign extend to 32 bits in rt lbu rt, offset(rs) Zero extend to 32 bits in rt lh rt, offset(rs) lhu rt, offset(rs) sb rt, offset(rs) sh rt, offset(rs) Store just rightmost byte/halfword 86

String Copy Example C code (naïve): Null-terminated string void strcpy (char x[], char y[]) { int i; i = 0; while ((x[i]=y[i])!='\0') i += 1; } Addresses of x, y in $a0, $a1 i in $s0 87

MIPS code: String Copy Example strcpy: addi $sp, $sp, -4 # adjust stack for 1 item sw $s0, 0($sp) # save $s0 add $s0, $zero, $zero # i = 0 L1: add $t1, $s0, $a1 # addr of y[i] in $t1 lbu $t2, 0($t1) # $t2 = y[i] add $t3, $s0, $a0 # addr of x[i] in $t3 sb $t2, 0($t3) # x[i] = y[i] beq $t2, $zero, L2 # exit loop if y[i] == 0 addi $s0, $s0, 1 # i = i + 1 j L1 # next iteration of loop L2: lw $s0, 0($sp) # restore saved $s0 addi $sp, $sp, 4 # pop 1 item from stack jr $ra # and return 88

End of Lecture 8 89

Chapter 2: Instructions: Language of the Computer Lecture 07 2.1 Introduction 2.2 Operations of the Computer Hardware 2.3 Operands of the Computer Hardware 2.4 Signed and Unsigned Numbers 2.5 Representing Instructions in the Computer Lecture 08 2.6 Logical Operations 2.7 Instructions for Making Decisions A.4 A.6: Loading, Memory and Procedure Call Convention 2.8 Supporting Procedures in Computer Hardware 2.9 Communicating with People Lecture 09 2.10 MIPS Addressing for 32-Bit Immediates and Addresses 2.11 Parallelism and Instructions: Synchronization 2.12 Translating and Starting a Program We covered in Appendix A and C Basics 2.13 A C Sort Example to Put It All Together 2.14 Arrays versus Pointers 2.15 Advanced Material: Compiling C and Interpreting Java Lecture 10 2.16 Real Stuff: ARMv7 (32-bit) Instructions 2.17 Real Stuff: x86 Instructions 2.18 Real Stuff: ARMv8 (64-bit) Instructions 2.19 Fallacies and Pitfalls 2.20 Concluding Remarks 2.21 Historical Perspective and Further Reading 90

Review of of Lecture 8 IMPORTANT: Read and understand each assembly instruction and code in the examples 91

Review: Conditional Branch and Unconditional Jump Branch to a labeled instruction if a condition is true Otherwise, continue sequentially Label is the symbolic representation of the memory address of an instruction. beq rs, rt, L1 if (rs == rt) branch to instruction labeled L1; bne rs, rt, L1 if (rs!= rt) branch to instruction labeled L1; 2.7 Instructions for Making Decisions Unconditional Jump j L1 unconditional jump to instruction labeled L1 92

C code: Compiling If Statements if (i==j) f = g+h; else f = g-h; f, g, in $s0, $s1, Compiled MIPS code: bne $s3, $s4, Else add $s0, $s1, $s2 j Exit Else: sub $s0, $s1, $s2 Exit: Assembler calculates addresses 93

C code: Compiling Loop Statements while (save[i] == k) i += 1; i in $s3, k in $s5, address of save in $s6 Compiled MIPS code: Loop: sll $t1, $s3, 2 #i=i*4 add $t1, $t1, $s6 #base+offset lw $t0, 0($t1) #newbase in $t1 bne $t0, $s5, Exit #bne addi $s3, $s3, 1 #i=i+1; j Loop Exit: 94

More Conditional Operations Set result to 1 if a condition is true Otherwise, set to 0 slt rd, rs, rt if (rs < rt) rd = 1; else rd = 0; slti rt, rs, constant if (rs < constant) rt = 1; else rt = 0; Use in combination with beq, bne slt $t0, $s1, $s2 # if ($s1 < $s2) bne $t0, $zero, L # branch to L 95

Procedure Call Instructions Procedure call: jump and link jal ProcedureLabel Address of following instruction put in $ra Jumps to target address Procedure return: jump register jr $ra Copies $ra to program counter Can also be used for computed jumps e.g., for case/switch statements 96

Stack Memory Used for Function Calls Stack is Last-In-First-Out (LIFO) data structure to store the info of each function of the call path Main() calls foo(), foo() calls bar(), bar() calls tar() Call in: push function to the stack top Return: pop function from the top Stack frame, function frame, activation record The memory and the data of the info for each function call main() foo() bar() tar() push pop top 97

Leaf Procedure Example Leaf procedure A procedure does not call other procedures Thinking of procedure calls as a tree C code: int leaf_example (int g, h, i, j) { int f; f = (g + h) - (i + j); return f; } Arguments g,, j in $a0,, $a3 f in $s0 (hence, need to save $s0 on stack) Result in $v0 98

Leaf Procedure Example MIPS code: leaf_example: addi $sp, $sp, -4 sw $s0, 0($sp) add $t0, $a0, $a1 add $t1, $a2, $a3 sub $s0, $t0, $t1 add $v0, $s0, $zero lw $s0, 0($sp) addi $sp, $sp, 4 jr $ra Save $s0 on stack Procedure body Result Restore $s0 Return push pop 99

Non-Leaf Procedure Example C code: int fact (int n) { if (n < 1) return f; else return n * fact(n - 1); } Argument n in $a0 Result in $v0 100

MIPS code: fact: Non-Leaf Procedure Example addi $sp, $sp, -8 sw $ra, 4($sp) # save return address sw $a0, 0($sp) # save argument n slti $t0, $a0, 1 # test for n < 1 # adjust stack for 2 items push beq $t0, $zero, L1 addi $v0, $zero, 1 # if so, result is 1 addi $sp, $sp, 8 # pop 2 items from stack jr $ra # and return L1: addi $a0, $a0, -1 # else decrement n jal fact # recursive call lw $a0, 0($sp) # restore original n lw $ra, 4($sp) # and return address addi $sp, $sp, 8 # pop 2 items from stack mul $v0, $a0, $v0 # multiply to get result jr $ra # and return pop pop 101

End of Review of of Lecture 8 102

Chapter 2: Instructions: Language of the Computer Lecture 07 2.1 Introduction 2.2 Operations of the Computer Hardware 2.3 Operands of the Computer Hardware 2.4 Signed and Unsigned Numbers 2.5 Representing Instructions in the Computer Lecture 08 2.6 Logical Operations 2.7 Instructions for Making Decisions A.4 A.6: Loading, Memory and Procedure Call Convention 2.8 Supporting Procedures in Computer Hardware 2.9 Communicating with People Lecture 09 2.10 MIPS Addressing for 32-Bit Immediates and Addresses 2.11 Parallelism and Instructions: Synchronization 2.12 Translating and Starting a Program We covered in Appendix A and C Basics 2.13 A C Sort Example to Put It All Together 2.14 Arrays versus Pointers 2.15 Advanced Material: Compiling C and Interpreting Java Lecture 10 2.16 Real Stuff: ARMv7 (32-bit) Instructions 2.17 Real Stuff: x86 Instructions 2.18 Real Stuff: ARMv8 (64-bit) Instructions 2.19 Fallacies and Pitfalls 2.20 Concluding Remarks 2.21 Historical Perspective and Further Reading 103

32-bit Constants Most constants are small I-format 32-bit instruction word includes 16-bit for constant 16-bit immediate is sufficient op rs rt constant or address 6 bits 5 bits 5 bits 16 bits For the occasional 32-bit constant lui rt, constant Copies the left (upper) 16 bits of the constant of rt Clears right 16 bits of rt to 0 2.10 MIPS Addressing for 32-Bit Immediates and Addresses 104

Loading a 32-Bit Constant 105

Branch Addressing Branch instructions (I-format) specify Opcode, two registers, target address Most branch targets are near branch Forward or backward op rs rt constant or address as offset 6 bits 5 bits 5 bits 16 bits n PC-relative addressing n Target address = PC + offset 4 n PC already incremented by 4 by this time 106

Jump Addressing Jump (j and jal) targets could be anywhere in text segment Encode full address in instruction op address 6 bits 26 bits n (Pseudo) Direct jump addressing n Target address = PC 31 28 : (address 4) 107

Target Addressing Example Loop code from earlier example Assume Loop at location 80000 Loop: sll $t1, $s3, 2 80000 0 0 19 9 4 0 add $t1, $t1, $s6 80004 0 9 22 9 0 32 lw $t0, 0($t1) 80008 35 9 8 0 bne $t0, $s5, Exit 80012 5 8 21 2 addi $s3, $s3, 1 80016 8 19 19 1 j Loop 80020 2 20000 Exit: 80024 PC = 80000, which is address * 4 = 20000 * 4 = 80000 PC = 80024, which is PC + offset * 4 = 80016 + 2 * 4 = 80024 108

Branching Far Away If branch target is too far to encode with 16-bit offset, assembler rewrites the code Example beq $s0,$s1, L1 bne $s0,$s1, L2 j L1 L2: 109

C Sort Example Illustrates use of assembly instructions for a C bubble sort function Swap procedure (leaf) void swap(int v[], int k) { int temp; temp = v[k]; v[k] = v[k+1]; v[k+1] = temp; } v in $a0, k in $a1, temp in $t0 2.13 A C Sort Example to Put It All Together 110

The Procedure Swap 4-byte per element swap: sll $t1, $a1, 2 # $t1 = k * 4 add $t1, $a0, $t1 # $t1 = v+(k*4) # (address of v[k]) lw $t0, 0($t1) # $t0 (temp) = v[k] lw $t2, 4($t1) # $t2 = v[k+1] sw $t2, 0($t1) # v[k] = $t2 (v[k+1]) sw $t0, 4($t1) # v[k+1] = $t0 (temp) jr $ra # return to calling routine Note: 1. Array references (V[k] and V[k+1]) are translated to LW/SW depending on whether it is a read or write (right-val or left-val). 2. v[k] = v[k+1] is translated to two instructions, i.e. LW and SW 111

The Sort Procedure in C Bubble sort Double nested loop Non-leaf (calls swap) void sort (int v[], int n) { int i, j; for (i = 0; i < n; i += 1) { for (j = i 1; j >= 0 && v[j] > v[j + 1];j -= 1) { swap(v,j); } } } v in $a0, n in $a1, i in $s0, j in $s1 112

113

114

Effect of Compiler Optimization Compiled with gcc for Pentium 4 under Linux 3 Relative Performance 140000 Instruction count 2.5 2 1.5 1 0.5 120000 100000 80000 60000 40000 20000 0 none O1 O2 O3 0 none O1 O2 O3 180000 160000 140000 120000 100000 80000 60000 40000 20000 0 Clock Cycles none O1 O2 O3 2 1.5 1 0.5 0 CPI none O1 O2 O3 115

Effect of Language and Algorithm 3 Bubblesort Relative Performance 2.5 2 1.5 1 0.5 0 C/none C/O1 C/O2 C/O3 Java/int Java/JIT 2.5 Quicksort Relative Performance 2 1.5 1 0.5 0 C/none C/O1 C/O2 C/O3 Java/int Java/JIT 3000 Quicksort vs. Bubblesort Speedup 2500 2000 1500 1000 500 0 C/none C/O1 C/O2 C/O3 Java/int Java/JIT 116

Lessons Learnt Instruction count and CPI are not good performance indicators in isolation Compiler optimizations are sensitive to the algorithm High-level optimization à better performance 02 is generally the default optimization level Java/JIT compiled code is significantly faster than JVM interpreted Comparable to optimized C in some cases Nothing can fix a dumb algorithm! 117

Arrays vs. Pointers Array indexing involves Multiplying index by element size Adding to array base address Pointers correspond directly to memory addresses Can avoid indexing complexity 2.14 Arrays versus Pointers 118

Example: Clearing and Array clear1(int array[], int size) { int i; for (i = 0; i < size; i += 1) array[i] = 0; } clear2(int *array, int size) { int *p; for (p = &array[0]; p < &array[size]; p = p + 1) *p = 0; } move $t0,$zero # i = 0 loop1: sll $t1,$t0,2 # $t1 = i * 4 add $t2,$a0,$t1 # $t2 = # &array[i] sw $zero, 0($t2) # array[i] = 0 addi $t0,$t0,1 # i = i + 1 slt $t3,$t0,$a1 # $t3 = # (i < size) bne $t3,$zero,loop1 # if ( ) # goto loop1 move $t0,$a0 # p = & array[0] sll $t1,$a1,2 # $t1 = size * 4 add $t2,$a0,$t1 # $t2 = # &array[size] loop2: sw $zero,0($t0) # Memory[p] = 0 addi $t0,$t0,4 # p = p + 4 slt $t3,$t0,$t2 # $t3 = #(p<&array[size]) bne $t3,$zero,loop2 # if ( ) # goto loop2 6 instructions per iteration vs 4 instructions per iteration If we use p!= &array[size] for loop condition, we do not need slt in the loop. 119

Comparison of Array vs. Ptr Multiply strength reduced to shift Array version requires shift to be inside loop Part of index calculation for incremented i c.f. incrementing pointer Compiler can achieve same effect as manual use of pointers Induction variable elimination Better to make program clearer and safer 120

End of Lecture 09 121

Review of Lecture 09 122

Review: Target Addressing Example Loop code from earlier example Assume Loop at location 80000 Loop: sll $t1, $s3, 2 80000 0 0 19 9 4 0 add $t1, $t1, $s6 80004 0 9 22 9 0 32 lw $t0, 0($t1) 80008 35 9 8 0 bne $t0, $s5, Exit 80012 5 8 21 2 addi $s3, $s3, 1 80016 8 19 19 1 j Loop 80020 2 20000 Exit: 80024 PC = 80000, which is address * 4 = 20000 * 4 = 80000 PC = 80024, which is PC + offset * 4 = 80016 + 2 * 4 = 80024 123

Example: C Sort, and Array vs Pointer IMPORTANT: Read and understand each assembly instruction and code in the examples 124

End of Review of Lecture 09 125

Chapter 2: Instructions: Language of the Computer Lecture 07 2.1 Introduction 2.2 Operations of the Computer Hardware 2.3 Operands of the Computer Hardware 2.4 Signed and Unsigned Numbers 2.5 Representing Instructions in the Computer Lecture 08 2.6 Logical Operations 2.7 Instructions for Making Decisions A.4 A.6: Loading, Memory and Procedure Call Convention 2.8 Supporting Procedures in Computer Hardware 2.9 Communicating with People Lecture 09 2.10 MIPS Addressing for 32-Bit Immediates and Addresses 2.11 Parallelism and Instructions: Synchronization 2.12 Translating and Starting a Program We covered in Appendix A and C Basics 2.13 A C Sort Example to Put It All Together 2.14 Arrays versus Pointers 2.15 Advanced Material: Compiling C and Interpreting Java Lecture 10 2.16 Real Stuff: ARMv7 (32-bit) Instructions 2.17 Real Stuff: x86 Instructions 2.18 Real Stuff: ARMv8 (64-bit) Instructions 2.19 Fallacies and Pitfalls 2.20 Concluding Remarks 2.21 Historical Perspective and Further Reading 126 Introduction of MARS MIPS assembler and simulator

ARM & MIPS Similarities ARM: the most popular embedded core Similar basic set of instructions to MIPS ARM MIPS Date announced 1985 1985 Instruction size 32 bits 32 bits Address space 32-bit flat 32-bit flat Data alignment Aligned Aligned Data addressing modes 9 3 Registers 15 32-bit 31 32-bit Input/output Memory mapped Memory mapped 2.16 Real Stuff: ARM Instructions 127

Compare and Branch in ARM Uses condition codes for result of an arithmetic/logical instruction Negative, zero, carry, overflow Compare instructions to set condition codes without keeping the result Each instruction can be conditional Top 4 bits of instruction word: condition value Can avoid branches over single instructions 128

ARM vs MIPS 129

Instruction Encoding 130

The Intel x86 ISA Evolution with backward compatibility 8080 (1974): 8-bit microprocessor Accumulator, plus 3 index-register pairs 8086 (1978): 16-bit extension to 8080 Complex instruction set (CISC) 8087 (1980): floating-point coprocessor Adds FP instructions and register stack 80286 (1982): 24-bit addresses, MMU Segmented memory mapping and protection 80386 (1985): 32-bit extension (now IA-32) Additional addressing modes and operations Paged memory mapping as well as segments 2.17 Real Stuff: x86 Instructions 131

The Intel x86 ISA Further evolution i486 (1989): pipelined, on-chip caches and FPU Compatible competitors: AMD, Cyrix, Pentium (1993): superscalar, 64-bit datapath Later versions added MMX (Multi-Media extension) instructions The infamous FDIV bug Pentium Pro (1995), Pentium II (1997) New microarchitecture (see Colwell, The Pentium Chronicles) Pentium III (1999) Added SSE (Streaming SIMD Extensions) and associated registers Pentium 4 (2001) New microarchitecture Added SSE2 instructions 132

The Intel x86 ISA And further AMD64 (2003): extended architecture to 64 bits EM64T Extended Memory 64 Technology (2004) AMD64 adopted by Intel (with refinements) Added SSE3 instructions Intel Core (2006) Added SSE4 instructions, virtual machine support AMD64 (announced 2007): SSE5 instructions Intel declined to follow, instead Advanced Vector Extension (announced 2008) Longer SSE registers, more instructions If Intel didn t extend with compatibility, its competitors would! Technical elegance market success 133

Basic x86 Registers 134

Basic x86 Addressing Modes Two operands per instruction Source/dest operand Register Register Register Memory Memory Second source operand Register Immediate Memory Register Immediate n Memory addressing modes n n Address in register Address = R base + displacement n Address = R base + 2 scale R index (scale = 0, 1, 2, or 3) n Address = R base + 2 scale R index + displacement 135

x86 Instruction Encoding Variable length encoding Postfix bytes specify addressing mode Prefix bytes modify operation Operand length, repetition, locking, 136

Implementing IA-32 Complex instruction set makes implementation difficult Hardware translates instructions to simpler microoperations Simple instructions: 1 1 Complex instructions: 1 many Microengine similar to RISC Market share makes this economically viable Comparable performance to RISC Compilers avoid complex instructions 137

Concluding Remarks Design principles 1. Simplicity favors regularity 2. Smaller is faster 3. Make the common case fast 4. Good design demands good compromises Layers of software/hardware Compiler, assembler, hardware MIPS: typical of RISC ISAs c.f. x86 2.20 Concluding Remarks 138

Concluding Remarks Measure MIPS instruction executions in benchmark programs Consider making the common case fast Consider compromises Instruction class MIPS examples SPEC2006 Int SPEC2006 FP Arithmetic add, sub, addi 16% 48% Data transfer Logical Cond. Branch lw, sw, lb, lbu, lh, lhu, sb, lui and, or, nor, andi, ori, sll, srl beq, bne, slt, slti, sltiu 35% 36% 12% 4% 34% 8% Jump j, jr, jal 2% 0% 139

Three Classes of Instructions 1. Arithmetic-logic instructions add, sub, addi, and, or, shift left right, etc 2. Memory load and store instructions lw and sw: Load/store word Lb and sb: Load/store byte Control transfer instructions Conditional branch: bne, beq Unconditional jump: j Procedure call and return: jal and jr 140

MIPS Simulator MARS (MIPS Assembler and Runtime Simulator) http://courses.missouristate.edu/kenvollmar/mars/index.htm https://courses.missouristate.edu/kenvollmar/mars/tutorial.htm 141

Write Assembly Code in MARS https://courses.missouristate.edu/kenvollmar/mars/tutorial.htm.data segment.text segment row-major.asm example 142

row-major.asm: Offset and Address for row-major 2-dimensional array Slides 49 https://passlab.github.io/csce212/notes/lecture06_cbasic.pdf 143

Multiplication in MIPS Multiplication, Textbook 3.3, page 188 MIPS multiply unit contains two 32-bit registers called hi and lo They are not general purpose registers The product of multiplying two 32-bits operands are stored in hi and lo registers Need mfhi and mflo to load values in hi and lo to general purpose register 144

row-major.asm Example 145

row-major.asm Example in MARS Edit window and To Assembly 146

row-major.asm Example in MARS Assembly window 147

row-major.asm Example in MARS After Execution 148

Download and Try Examples MARS Tutorial: https://courses.missouristate.edu/kenvollmar/mars/tutorial.htm Fibonacci.asm row-major.asm column-major.asm Rewrite textbook example to make it run C sort Array vs pointer 149

End of Chapter 02 150

Other slides of the chapter 151

Synchronization Two processors sharing an area of memory P1 writes, then P2 reads Data race if P1 and P2 don t synchronize Result depends of order of accesses Hardware support required Atomic read/write memory operation No other access to the location allowed between the read and write Could be a single instruction E.g., atomic swap of register memory Or an atomic pair of instructions 2.11 Parallelism and Instructions: Synchronization 152

Synchronization in MIPS Load linked: ll rt, offset(rs) Store conditional: sc rt, offset(rs) Succeeds if location not changed since the ll Returns 1 in rt Fails if location is changed Returns 0 in rt Example: atomic swap (to test/set lock variable) try: add $t0,$zero,$s4 ;copy exchange value ll $t1,0($s1) ;load linked sc $t0,0($s1) ;store conditional beq $t0,$zero,try ;branch store fails add $s4,$zero,$t1 ;put load value in $s4 153

Translation and Startup Many compilers produce object modules directly Static linking 2.12 Translating and Starting a Program 154

Assembler Pseudoinstructions Most assembler instructions represent machine instructions one-to-one Pseudoinstructions: figments of the assembler s imagination move $t0, $t1 add $t0, $zero, $t1 blt $t0, $t1, L slt $at, $t0, $t1 bne $at, $zero, L $at (register 1): assembler temporary 155

Producing an Object Module Assembler (or compiler) translates program into machine instructions Provides information for building a complete program from the pieces Header: described contents of object module Text segment: translated instructions Static data segment: data allocated for the life of the program Relocation info: for contents that depend on absolute location of loaded program Symbol table: global definitions and external refs Debug info: for associating with source code 156

Linking Object Modules Produces an executable image 1. Merges segments 2. Resolve labels (determine their addresses) 3. Patch location-dependent and external refs Could leave location dependencies for fixing by a relocating loader But with virtual memory, no need to do this Program can be loaded into absolute location in virtual memory space 157

Loading a Program Load from image file on disk into memory 1. Read header to determine segment sizes 2. Create virtual address space 3. Copy text and initialized data into memory Or set page table entries so they can be faulted in 4. Set up arguments on stack 5. Initialize registers (including $sp, $fp, $gp) 6. Jump to startup routine Copies arguments to $a0, and calls main When main returns, do exit syscall 158

Dynamic Linking Only link/load library procedure when it is called Requires procedure code to be relocatable Avoids image bloat caused by static linking of all (transitively) referenced libraries Automatically picks up new library versions 159

Lazy Linkage Indirection table Stub: Loads routine ID, Jump to linker/loader Linker/loader code Dynamically mapped code 160

Starting Java Applications Simple portable instruction set for the JVM Compiles bytecodes of hot methods into native code for host machine Interprets bytecodes 161

ARM v8 Instructions In moving to 64-bit, ARM did a complete overhaul ARM v8 resembles MIPS Changes from v7: No conditional execution field Immediate field is 12-bit constant Dropped load/store multiple PC is no longer a GPR GPR set expanded to 32 Addressing modes work for all word sizes Divide instruction Branch if equal/branch if not equal instructions 2.18 Real Stuff: ARM v8 (64-bit) Instructions 162

Fallacies Powerful instruction Þ higher performance Fewer instructions required But complex instructions are hard to implement May slow down all instructions, including simple ones Compilers are good at making fast code from simple instructions Use assembly code for high performance But modern compilers are better at dealing with modern processors More lines of code Þ more errors and less productivity 2.19 Fallacies and Pitfalls 163

Fallacies Backward compatibility Þ instruction set doesn t change But they do accrete more instructions x86 instruction set 164

Pitfalls Sequential words are not at sequential addresses Increment by 4, not by 1! Keeping a pointer to an automatic variable after procedure returns e.g., passing pointer back via an argument Pointer becomes invalid when stack popped 165