CSE 141 Computer Architecture Spring Lecture 3 Instruction Set Architecute. Course Schedule. Announcements

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

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

Chapter 2. Instruction Set Architecture (ISA)

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

Instruction Set Architecture. "Speaking with the computer"

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

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

EEC 581 Computer Architecture Lecture 1 Review MIPS

Chapter 2A Instructions: Language of the Computer

Chapter 3. Instructions:

Chapter 2: Instructions:

Computer Architecture

Instructions: Language of the Computer

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

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

CS3350B Computer Architecture MIPS Instruction Representation

COMPSCI 313 S Computer Organization. 7 MIPS Instruction Set

Review of instruction set architectures

Instruction Set Architectures

Announcements HW1 is due on this Friday (Sept 12th) Appendix A is very helpful to HW1. Check out system calls

Course Administration

CENG3420 Lecture 03 Review

CS222: MIPS Instruction Set

Computer Organization MIPS ISA

Computer Architecture

Chapter 2. Instructions:

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

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

ECE 486/586. Computer Architecture. Lecture # 8

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

Communicating with People (2.8)

Lecture 3: The Instruction Set Architecture (cont.)

Lecture 3: The Instruction Set Architecture (cont.)

Lecture Topics. Branch Condition Options. Branch Conditions ECE 486/586. Computer Architecture. Lecture # 8. Instruction Set Principles.

CISC 662 Graduate Computer Architecture. Lecture 4 - ISA

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

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

ECE369. Chapter 2 ECE369

Architecture I. Computer Systems Laboratory Sungkyunkwan University

Computer Architecture. MIPS Instruction Set Architecture

CS/COE1541: Introduction to Computer Architecture

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

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

CENG3420 L03: Instruction Set Architecture

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

Topic Notes: MIPS Instruction Set Architecture

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

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

Instruction Set Design and Architecture

Today s topics. MIPS operations and operands. MIPS arithmetic. CS/COE1541: Introduction to Computer Architecture. A Review of MIPS ISA.

MIPS Instruction Set Architecture (1)

CS3350B Computer Architecture

Character Is a byte quantity (00~FF or 0~255) ASCII (American Standard Code for Information Interchange) Page 91, Fig. 2.21

Reduced Instruction Set Computer (RISC)

101 Assembly. ENGR 3410 Computer Architecture Mark L. Chang Fall 2009

Reduced Instruction Set Computer (RISC)

Systems Architecture I

MIPS (SPIM) Assembler Syntax

Lecture 3: Instruction Set Architecture

1 5. Addressing Modes COMP2611 Fall 2015 Instruction: Language of the Computer

Lecture 4: MIPS Instruction Set

EC 413 Computer Organization

Math 230 Assembly Programming (AKA Computer Organization) Spring 2008

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

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

Computer Systems Laboratory Sungkyunkwan University

Instruction Set Architecture part 1 (Introduction) Mehran Rezaei

Instructions: Language of the Computer

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

Lecture 3 Machine Language. Instructions: Instruction Execution cycle. Speaking computer before voice recognition interfaces

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

CS3350B Computer Architecture MIPS Introduction

LECTURE 2: INSTRUCTIONS

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

MIPS Memory Access Instructions

Instruction Set Principles. (Appendix B)

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

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

Computer Architecture. The Language of the Machine

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

Processor. Han Wang CS3410, Spring 2012 Computer Science Cornell University. See P&H Chapter , 4.1 4

ECE232: Hardware Organization and Design. Computer Organization - Previously covered

ISA and RISCV. CASS 2018 Lavanya Ramapantulu

ECE 154A Introduction to. Fall 2012

5/17/2012. Recap from Last Time. CSE 2021: Computer Organization. The RISC Philosophy. Levels of Programming. Stored Program Computers

Recap from Last Time. CSE 2021: Computer Organization. Levels of Programming. The RISC Philosophy 5/19/2011

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

Control Instructions

CSEE 3827: Fundamentals of Computer Systems

Typical Processor Execution Cycle

MIPS%Assembly% E155%

Rechnerstrukturen. Chapter 2. Instructions: Language of the Computer

Math 230 Assembly Programming (AKA Computer Organization) Spring MIPS Intro

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

ECE 486/586. Computer Architecture. Lecture # 7

Lecture Topics. Announcements. Today: The MIPS ISA (P&H ) Next: continued. Milestone #1 (due 1/26) Milestone #2 (due 2/2)

ECE232: Hardware Organization and Design

Chapter 2 Instruction: Language of the Computer

COMPUTER ORGANIZATION AND DESIGN

CS31001 COMPUTER ORGANIZATION AND ARCHITECTURE. Debdeep Mukhopadhyay, CSE, IIT Kharagpur. Instructions and Addressing

Transcription:

CSE141: Introduction to Computer Architecture CSE 141 Computer Architecture Spring 2005 Lecture 3 Instruction Set Architecute Pramod V. Argade April 4, 2005 Instructor: TAs: Pramod V. Argade (p2argade@cs.ucsd.edu) Office Hour: Mon. 5:00-6:00 PM (AP&M 5218) Wed. 5:00-6:00 PM (AP&M 2444) Baris Arslan: barslan@cs.ucsd.edu Chris Roedel: croedel@cs.ucsd.edu Raid Ayoub: rayoub@cs.ucsd.edu Leo Porter: leporter@cs.ucsd.edu Textbook: Web-page: Computer Organization & Design The Hardware Software Interface, 3 nd Edition. Authors: Patterson and Hennessy http://www.cse.ucsd.edu/classes/sp05/cse141 3-2 Announcements Discussions Sections for 141: Fridays, 10:00-10:50 am, Peterson Hall 104 (Chris) Fridays, 2:00-2:50 pm, Peterson Hall 104 (Leo) Reading Assignment Chapter 2. Instructions: Language of the Computer Sec. 2.1-2.9, 2-16 Homework 2: Due Mon., April 11 in class 2.2, 2.4, 2.6, 2.29, 2.30, 2.32, 2.47 Quiz When: Mon., April 11th, First 10 minutes of the class Topic: ISA, Chapter 2 Need: Paper, pen Course Schedule Homework Lecture # Date Day Lecture Topic Quiz Topic Due 1 3/28 Monday Introduction, Ch. 1 - - 2 3/30 Wednesday Performance, Ch. 4 - - 3 4/4 Monday ISA, Ch. 2 Performance #1 4 4/6 Wednesday Arithmetic, Ch. 3 - - 5 4/11 Monday Arithmetic, Ch. 3 ISA #2 6 4/13 Wednesday Single cycle CPU, Ch. 5 - - 7 4/18 Monday Single cycle CPU, Ch. 5 Arithmetic #3 8 4/20 Wednesday Multi-cycle CPU, Ch. 5 - - 9 4/25 Monday Multi-cycle CPU, Ch. 5 Single Cycle CPU #4 10 4/27 Wednesday Review for the Midterm - - 5/2 Monday Mid-term Exam - - 11 5/4 Wednesday Exceptions, Ch. 5 and Pipelining, Ch. 6 - - 12 5/9 Monday Pipelining, Ch. 6 - - 13 5/11 Wednesday Data and control hazards, Ch. 6 - - 14 5/16 Monday Data and control hazards, Ch. 6 Pipeline Hazards #5 15 5/18 Wednesday Memory & cache design, Ch. 7 - - 16 5/23 Monday Memory & cache design, Ch. 7 Cache #6 17 5/25 Wednesday Virtual Memory & cache design, Ch. 7 - - No Class 5/30 Monday Memorial Day Holiday - - 18 6/1 Wednesday Course Review - - 6/10 Friday Final Exam 3-3 3-4

Stored Program Concept Instruction Set Architecture (ISA) General Considerations Instructions are bits Control Datapath Memory for Program & Data Input Output Programs are stored in memory to be read or written just like data Fetch & Execute Cycle Instructions are fetched and put into a special register Bits in the register "control" the subsequent actions Fetch the next instruction and continue 3-5 3-6 Memory Organization Memory Organization Viewed as a large, single-dimension array, with an address. A memory address is an index into the array "Byte addressing" means that the index points to a byte of memory. 0 1 2 3 4 5 6... Bytes are nice, but most data items use larger "words" For MIPS, a word is 32 bits or 4 bytes. 0 4 8 12... 32 bits of data 32 bits of data 32 bits of data 32 bits of data Words are aligned on 4-byte boundary i.e., what are the least 2 significant bits of a word address? 32 bits address 2 32 bytes with byte addresses from 0 to 2 32-1 2 30 words with byte addresses 0, 4, 8,... 2 32-4 3-7 3-8

Endian-ness: How to address bytes within words? Addressing: Alignment Big Endian: address of most significant byte = word address IBM 360/370, Motorola 68k, MIPS, Sparc, HP PA Little Endian: address of least significant byte = word address Intel 80x86, DEC Vax, DEC Alpha (Windows NT) 3 2 1 0 little endian byte # msb 0 1 2 3 4 5 6 0x00 0x11 0x22 0x33 0x44 0x55 0x66... Big-endian 0 4 8 12... 0x00112233 0x44556677 0x8899aabb 0xccddeeff Word Data lsb 0 1 2 3 big endian byte # 0 1 2 3 4 5 6 0x33 0x22 0x11 0x00 0x77 0x66 0x55... Little-endian Aligned Not Aligned 0 1 2 3 Alignment: require that objects fall on address that is multiple of their size. MIPS requires address alignment Word addresses must be multiple of 4 Half word addresses must be multiple of 2 3-9 3-10 The Instruction Execution Cycle The Instruction Set Architecture Instruction Fetch Instruction Decode Obtain instruction from program storage Determine required actions and instruction size Is the interface between all the software that runs on the machine and the hardware that executes it. Application Operand Fetch Execute Result Store Next Instruction Locate and obtain operand data Compute result value or status Deposit results in storage for later use Determine successor instruction Compiler Micro-code Digital Design Circuit Design Operating System I/O system Instruction Set Architecture Provides a level of abstraction in both directions Modern instruction set architectures: 80x86/Pentium, MIPS, SPARC, PowerPC, ARM, Tensilica,... 3-12

Instruction Set Architecture (ISA) Key ISA Decisions Instructions: Words of a machine s language Instruction Set: Machine s vocabulary ISA: A very important abstraction Interface between hardware and low-level software Standardizes instructions, machine language bit patterns, etc. Advantage: different implementations of the same architecture Disadvantage: sometimes prevents using new innovations True or False? Binary compatibility is extraordinarily important. Part of the architecture that is visible to the programmer opcodes (available instructions) number and types of registers instruction formats storage access, addressing modes exceptional conditions 3-13 Instruction length Fixed length Variable length Registers How many? Operand access Register Memory Instruction format Meaning of group of bits within machine instruction Operands How many per instruction, size (byte, word,..) Operations ADD, SUB, MUL,... 3-14 Accessing the Operands Operands are generally in one of two places: Registers: fast on-chip storage (how many, how wide?) Memory (how many locations?) Registers are Easy to specify Close to the processor Provide fast access Can read two operands and write one result per clock cycle The idea that we want to access registers whenever possible led to load-store architectures. Normal arithmetic instructions only access registers Only access memory with explicit loads and stores Basic ISA Classes Comparing the Number of Instructions Code sequence for C = A + B for four classes of instruction sets: Stack Accumulator Register Register (register-memory) (load-store) Push A Load A Load R1,A Load R1,A Push B Add B Add R1,B Load R2,B Add Store C Store C, R1 Add R3,R1,R2 Pop C Store C,R3 3-15 3-16

MIPS Instruction Set Architecture MIPS Instruction Set Architecture Typical RISC Instruction Set designed in 1980 s MIPS is found in products from: Silicon Graphics NEC Cisco Broadcom Nintendo Sony Ti Toshiba We will study various implementations of MIPS instruction set Later part of the course! 3-17 3-18 MIPS ISA: Key Points Overview of MIPS ISA MIPS is a general-purpose register, load-store, fixedinstruction-length architecture. MIPS is optimized for fast pipelined performance, not for low instruction count Four principles of ISA Simplicity favors regularity: regular instruction set Smaller is faster: small number of formats, registers Good design demands good compromises: e.g. fixed length instructions Make the common case fast: encode constant within the instruction Fixed 32-bit instructions 3-operand, load-store architecture 32 general-purpose registers Registers are 32-bits wide (word) R0 always equals zero. Addressing modes Register, immediate, base+displacement, PC-relative and pseudodirect addressing modes 3 instruction formats will be covered in the class 3-19 3-20

Notes on MIPS Assembly MIPS Instructions (Covered in this course) Comments start with # Destination first (except for store instructions) ADD $t0, $s1, $s2 # $t0 = $s1 + $s2 Register access $n: register n (e.g. $1 is register 1) Register naming convention Name Register number Usage $zero 0 the constant value 0 $v0-$v1 2-3 values for results and expression evaluation $a0-$a3 4-7 arguments $t0-$t7 8-15 temporaries $s0-$s7 16-23 saved $t8-$t9 24-25 more temporaries $gp 28 global pointer $sp 29 stack pointer $fp 30 frame pointer $ra 31 return address Arithmetic add, sub, addi Logical sll, srl, and, andi, or, ori, nor Data transfer lw, sw, lb, sb, lui Conditional branch beq, bne, slt, slti Unconditional jump j, jr Jump and link jal 3-21 3-22 MIPS Arithmetic Instructions How to specify constants? All instructions have 3 operands Operand order is fixed (destination first) Example: C code: A = B + C MIPS code: add $s0, $s1, $s2 (associated with variables by compiler) Operands must be registers, only 32 registers provided Instruction format: 6 bits 5 bits 5 bits 5 bits 5 bits 6 bits R op rs rt rd shamt funct Design Principle: simplicity favors regularity. Design Principle: smaller is faster. Why? Why? Small constants are used quite frequently (50% of operands) e.g., A = A + 5; B = B + 1; C = C - 18; Solutions Put 'typical constants'in memory and load them. create hard-wired registers (like $zero) for constants like one. Specify constant in the instruction: this commonly used MIPS Instructions: addi $s3, $t0, 4 slti $s0, $t1, 10 Instruction Format I 6 bits 5 bits 5 bits op rs rt 16 bit address 3-23 3-24

How about larger constants? Memory Access Instructions We'd like to be able to load a 32 bit constant into a register Must use two instructions, new "load upper immediate" instruction lui $t0, 1010101010101010 1010101010101010 0000000000000000 Then must get the lower order bits right, i.e., ori $t0, $t0, 1010101010101010 ori 1010101010101010 0000000000000000 0000000000000000 1010101010101010 1010101010101010 1010101010101010 filled with zeros Load and store instructions Example: C code: A[8] = h + A[8]; MIPS code: Store word has destination last lw $t0, 32($s3) add $t0, $s2, $t0 sw $t0, 32($s3) Remember arithmetic operands are registers, not memory! Instruction format: I 6 bits 5 bits 5 bits op rs rt 16 bit address 3-25 3-26 Control Transfer Instructions MIPS Conditional Branches Decision making instructions Alter the control flow, i.e., change the "next" instruction to be executed MIPS conditional branch instructions: bne $t0, $t1, Label beq $t0, $t1, Label Example: if (i==j) h = i + j; bne $s0, $s1, Label add $s3, $s0, $s1 Label:... Instruction format: 6 bits 5 bits 5 bits I op rs rt 16 bit address MIPS branches use PC-relative addressing BEQ, BNE BEQ $1, $2, addr => if( r1 == r2 ) goto addr MIPS has no Branch-If-Lless-Than It is in timing critical path Set-Less-Than, SLT SLT $1, $2, $3 => if( $2 < $3) $1 = 1; else 1 = 0 BEQ, BNE, SLT combined with $0 can implement all branch conditions: always, never,!=, ==, <=, >=, <, >, >(unsigned), <=(unsigned),... 3-27 3-28

MIPS Jump Instructions Unconditional Jumps Need to transfer control Jump to an absolute address Jump to an address in a register Jump-And-Link to do procedure call and return Jump example: j 0x20000 => PC = 0x20000 Jump and Link example jal 0x40000 => $31 = PC+4, PC = 0x40000 Jump register example: jr $31 => PC = $31 (This is return instruction!) MIPS unconditional branch instructions: j label Instruction format: 6 bits J op 26 bit address Jump uses pseudo-direct addressing mode Program Counter 4 26 Instruction 6 26 4 26 00 Jump Destination Address 3-29 3-30 MIPS Instruction Format & Machine code Instruction format Summary of MIPS Instructions MIPS operands Name Example Comments $s0-$s7, $t0-$t9, $zero, Fast locations for data. In MIPS, data must be in registers to perform R I J 6 bits 5 bits 5 bits 5 bits 5 bits 6 bits op rs rt rd shamt funct op rs rt 16 bit address op 26 bit address The opcode tells the machine which format Machine instruction add r1, r2, r3 has opcode=0, funct=32, rs=2, rt=3, rd=1, sa=0 Machine code: 000000 00010 00011 00001 00000 100000 0000 0000 0100 0011 0000 1000 0010 0000 0x00430820 Expected to assemble and disassemble machine code 32 registers $a0-$a3, $v0-$v1, $gp, arithmetic. MIPS register $zero always equals 0. Register $at is $fp, $sp, $ra, $at reserved for the assembler to handle large constants. Memory[0], Accessed only by data transfer instructions. MIPS uses byte addresses, so 2 memory Memory[4],..., sequential words differ by 4. Memory holds data structures, such as arrays, words Memory[4294967292] and spilled registers, such as those saved on procedure calls. MIPS assembly language Category Instruction Example Meaning Comments $s1, $s2, $s2 + $s3 operands; data in add add $s3 $s1 = Three registers Arithmetic subtract sub $s1, $s2, $s3 $s1 = $s2 - $s3 Three operands; data in registers add immediate addi $s1, $s2, 100 $s1 = $s2 + 100 Used to add constants load word lw $s1, 100($s2) $s1 = Memory[$s2 + 100] Word from memory to register store word sw $s1, 100($s2) Memory[$s2 + 100] = $s1 Word from register to memory Data transfer load byte lb $s1, 100($s2) $s1 = Memory[$s2 + 100] Byte from memory to register store byte sb $s1, 100($s2) Memory[$s2 + 100] = $s1 Byte from register to memory load upper immediate lui $s1, 100 16 $s1 = 100 * 2 Loads constant in upper 16 bits branch on equal beq $s1, $s2, 25 if ($s1 == $s2) go to PC + 4 + 100 branch on not equal bne $s1, $s2, 25 if ($s1!= $s2) go to PC + 4 + 100 Conditional branch set on less than slt $s1, $s2, $s3 if ($s2 < $s3) $s1 = 1; else $s1 = 0 set less than immediate slti $s1, $s2, 100 if ($s2 < 100) $s1 = 1; else $s1 = 0 Equal test; PC-relative branch Not equal test; PC-relative Compare less than; for beq, bne Compare less than constant jump j 2500 go to 10000 Jump to target address Uncondi- jump register jr $ra go to $ra For switch, procedure return tional jump jump and link jal 2500 $ra = PC + 4; go to 10000 For procedure call 3-31 3-32

MIPS Addressing Modes Assembly Language vs. Machine Language 1. Immediate addressing e.g. addi $t0, $t1, 4 op rs rt Immediate 2. Register addressing e.g. sub $t0, $t1, $t2 op rs rt rd... funct 3. Base addressing e.g. lw $t0, 4( $t2) op rs rt Address Register + 4. PC-relative addressing e.g. beq $t1, $t2, 32 op rs rt Address PC + 5. Pseudodirect addressing e.g. j 0x1000 op Address Note: Parts 3 and 4 in Figure 2.24 (page 101) Edition 3 are incorrect! Registers Register Memory Byte Halfword Word Memory Word Memory Assembly provides convenient symbolic representation Much easier than writing down numbers e.g., destination first Machine language is the underlying reality Used by the processor at run time Assembly can provide 'pseudo-instructions' e.g., move $t0, $t1 exists only in Assembly would be implemented using add $t0,$t1,$zero When considering performance you should count real instructions PC Word 3-33 3-34 Other Issues Alternative Architectures Things we are not going to cover support for procedures linkers, loaders, memory layout stacks, frames, recursion manipulating strings and pointers interrupts and exceptions system calls and conventions We've focused on architectural issues Basics of MIPS assembly language and machine code We ll build a processor to execute these instructions. Design alternative: Provide more powerful operations Goal is to reduce number of instructions executed Danger is a slower cycle time and/or a higher CPI Sometimes referred to as RISC vs. CISC Virtually all new instruction sets since 1982 have been RISC VAX: minimize code size, make assembly language easy instructions from 1 to 54 bytes long! 3-35 3-36

Intel IA-32 Architecture A dominant architecture: 80x86 1978: The Intel 8086 is announced (16 bit architecture) 1980: The 8087 floating point coprocessor is added 1982: The 80286 increases address space to 24 bits, +instructions 1985: The 80386 extends to 32 bits, new addressing modes 1989-1995: The 80486, Pentium, Pentium Pro add a few instructions (mostly designed for higher performance) 1997: MMX is added 1999 Pentium II (same architecture) 2000 Pentium 4 (144 new multimedia instructions 2001 Itanium (new ISA which executes x86 code) See Section 2-16 for a more detailed description Complexity: Instructions from 1 to 17 bytes long One operand must act as both a source and destination One operand can come from memory Complex addressing modes e.g., base or scaled index with 8 or 32 bit displacement Saving grace: The most frequently used instructions are not too difficult to build Compilers avoid the portions of the architecture that are slow 3-37 3-38 Summary Announcements Instruction complexity is only one variable Lower instruction count vs. higher CPI / lower clock rate Four principles of ISA Simplicity favors regularity: regular instruction set Smaller is faster: small number of formats, small number of registers Good design demands good compromises: fixed length instructions Make the common case fast: encode constant within the instruction Instruction set architecture A very important abstraction indeed! In subsequent lectures we will show how to implement a subset of this ISA Discussions Sections for 141: Fridays, 10:00-10:50 am, Peterson Hall 104 (Chris) Fridays, 2:00-2:50 pm, Peterson Hall 104 (Leo) Reading Assignment Chapter 2. Instructions: Language of the Computer Sec. 2.1-2.9, 2-16 Homework 2: Due Mon., April 11 in class 2.2, 2.4, 2.6, 2.29, 2.30, 2.32, 2.47 Quiz When: Mon., April 11th, First 10 minutes of the class Topic: ISA, Chapter 2 Need: Paper, pen 3-39 3-40