University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell CS352H: Computer Systems Architecture Topic 8: MIPS Pipelined.

Slides:



Advertisements
Similar presentations
Morgan Kaufmann Publishers The Processor
Advertisements

Lecture Objectives: 1)Define branch prediction. 2)Draw a state machine for a 2 bit branch prediction scheme 3)Explain the impact on the compiler of branch.
Pipeline Computer Organization II 1 Hazards Situations that prevent starting the next instruction in the next cycle Structural hazards – A required resource.
Lecture Objectives: 1)Define pipelining 2)Calculate the speedup achieved by pipelining for a given number of instructions. 3)Define how pipelining improves.
The Pipelined CPU Lecture for CPSC 5155 Edward Bosworth, Ph.D. Computer Science Department Columbus State University Revised 9/22/2013.
CMPT 334 Computer Organization
Chapter Six 1.
MIPS Pipelined Datapath
Instructor: Senior Lecturer SOE Dan Garcia CS 61C: Great Ideas in Computer Architecture Pipelining Hazards 1.
ECE 445 – Computer Organization
Pipelined Datapath and Control (Lecture #13) ECE 445 – Computer Organization The slides included herein were taken from the materials accompanying Computer.
Prof. John Nestor ECE Department Lafayette College Easton, Pennsylvania Computer Organization Pipelined Processor Design 1.
1  2004 Morgan Kaufmann Publishers Chapter Six. 2  2004 Morgan Kaufmann Publishers Pipelining The laundry analogy.
Pipelining Andreas Klappenecker CPSC321 Computer Architecture.
1 Stalling  The easiest solution is to stall the pipeline  We could delay the AND instruction by introducing a one-cycle delay into the pipeline, sometimes.
 The actual result $1 - $3 is computed in clock cycle 3, before it’s needed in cycles 4 and 5  We forward that value to later instructions, to prevent.
Pipelined Processor II CPSC 321 Andreas Klappenecker.
Appendix A Pipelining: Basic and Intermediate Concepts
Chapter 4 Pipelining and Instruction Level Parallelism.
Pipelined Datapath and Control (Lecture #15) ECE 445 – Computer Organization The slides included herein were taken from the materials accompanying Computer.
Prof. John Nestor ECE Department Lafayette College Easton, Pennsylvania ECE Computer Organization Lecture 17 - Pipelined.
Lecture 15: Pipelining and Hazards CS 2011 Fall 2014, Dr. Rozier.
Lecture 8: Processors, Introduction EEN 312: Processors: Hardware, Software, and Interfacing Department of Electrical and Computer Engineering Spring 2014,
Lecture 14: Processors CS 2011 Fall 2014, Dr. Rozier.
Pipelined Datapath and Control
Pipeline Computer Organization II 1 Pipelining Analogy Pipelined laundry: overlapping execution – Parallelism improves performance Four loads: – Speedup.
Computer Organization CS224 Fall 2012 Lesson 28. Pipelining Analogy  Pipelined laundry: overlapping execution l Parallelism improves performance §4.5.
Pipelining Enhancing Performance. Datapath as Designed in Ch. 5 Consider execution of: lw $t1,100($t0) lw $t2,200($t0) lw $t3,300($t0) Datapath segments.
Morgan Kaufmann Publishers
Chapter 4 CSF 2009 The processor: Pipelining. Performance Issues Longest delay determines clock period – Critical path: load instruction – Instruction.
Chapter 4 The Processor. Chapter 4 — The Processor — 2 Introduction We will examine two MIPS implementations A simplified version A more realistic pipelined.
Chapter 4 The Processor CprE 381 Computer Organization and Assembly Level Programming, Fall 2012 Revised from original slides provided by MKP.
Analogy: Gotta Do Laundry
CSCI-365 Computer Organization Lecture Note: Some slides and/or pictures in the following are adapted from: Computer Organization and Design, Patterson.
CS 1104 Help Session IV Five Issues in Pipelining Colin Tan, S
Chapter 6 Pipelined CPU Design. Spring 2005 ELEC 5200/6200 From Patterson/Hennessey Slides Pipelined operation – laundry analogy Text Fig. 6.1.
1  1998 Morgan Kaufmann Publishers Chapter Six. 2  1998 Morgan Kaufmann Publishers Pipelining Improve perfomance by increasing instruction throughput.
Oct. 18, 2000Machine Organization1 Machine Organization (CS 570) Lecture 4: Pipelining * Jeremy R. Johnson Wed. Oct. 18, 2000 *This lecture was derived.
1/24/ :00 PM 1 of 86 Pipelining Chapter 6. 1/24/ :00 PM 2 of 86 Overview of Pipelining Pipelining is an implementation technique in which.
Pipelining Example Laundry Example: Three Stages
University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell CS352H: Computer Systems Architecture Topic 9: MIPS Pipeline.
Instructor: Senior Lecturer SOE Dan Garcia CS 61C: Great Ideas in Computer Architecture Pipelining Hazards 1.
LECTURE 7 Pipelining. DATAPATH AND CONTROL We started with the single-cycle implementation, in which a single instruction is executed over a single cycle.
C OMPUTER O RGANIZATION AND D ESIGN The Hardware/Software Interface 5 th Edition Chapter 4 The Processor.
Introduction to Computer Organization Pipelining.
Lecture 9. MIPS Processor Design – Pipelined Processor Design #1 Prof. Taeweon Suh Computer Science Education Korea University 2010 R&E Computer System.
CSCI-365 Computer Organization Lecture Note: Some slides and/or pictures in the following are adapted from: Computer Organization and Design, Patterson.
CS203 – Advanced Computer Architecture Pipelining Review.
Lecture 5. MIPS Processor Design Pipelined MIPS #1 Prof. Taeweon Suh Computer Science & Engineering Korea University COSE222, COMP212 Computer Architecture.
CS 352H: Computer Systems Architecture
Morgan Kaufmann Publishers
Morgan Kaufmann Publishers The Processor
Morgan Kaufmann Publishers The Processor
Single Clock Datapath With Control
Pipeline Implementation (4.6)
CDA 3101 Spring 2016 Introduction to Computer Organization
Morgan Kaufmann Publishers The Processor
Chapter 4 The Processor Part 3
Morgan Kaufmann Publishers The Processor
Morgan Kaufmann Publishers The Processor
Chapter 4 The Processor Part 2
CS 5513 Computer Architecture Pipelining Examples
Morgan Kaufmann Publishers Enhancing Performance with Pipelining
Pipelining in more detail
CS203 – Advanced Computer Architecture
CSC3050 – Computer Architecture
Morgan Kaufmann Publishers The Processor
Wackiness Algorithm A: Algorithm B:
Guest Lecturer: Justin Hsia
CS 3853 Computer Architecture Pipelining Examples
Presentation transcript:

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell CS352H: Computer Systems Architecture Topic 8: MIPS Pipelined Implementation September 29, 2009

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 2 MIPS Pipeline Five stages, one step per stage IF: Instruction fetch from memory ID: Instruction decode & register read EX: Execute operation or calculate address MEM: Access memory operand WB: Write result back to register

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 3 Pipeline Performance Assume time for stages is 100ps for register read or write 200ps for other stages Compare pipelined datapath with single-cycle datapath InstrInstr fetchRegister read ALU opMemory access Register write Total time lw200ps100 ps200ps 100 ps800ps sw200ps100 ps200ps 700ps R-format200ps100 ps200ps100 ps600ps beq200ps100 ps200ps500ps j200ps

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 4 Pipeline Performance Single-cycle (T c = 800ps) Pipelined (T c = 200ps)

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 5 Pipeline Speedup If all stages are balanced i.e., all take the same time Time between instructions pipelined = Time between instructions nonpipelined Number of stages If not balanced, speedup is less Speedup due to increased throughput Latency (time for each instruction) does not decrease

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 6 Pipelining and ISA Design MIPS ISA designed for pipelining All instructions are 32-bits Easier to fetch and decode in one cycle c.f. x86: 1- to 17-byte instructions Few and regular instruction formats Can decode and read registers in one step Load/store addressing Can calculate address in 3 rd stage, access memory in 4 th stage Alignment of memory operands Memory access takes only one cycle

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 7 Hazards Situations that prevent starting the next instruction in the next cycle Structure hazards A required resource is busy Data hazard Need to wait for previous instruction to complete its data read/write Control hazard Deciding on control action depends on previous instruction

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 8 Structure Hazards Conflict for use of a resource In MIPS pipeline with a single memory Load/store requires data access Instruction fetch would have to stall for that cycle Would cause a pipeline “bubble” Hence, pipelined datapaths require separate instruction/data memories Or separate instruction/data caches

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 9 Data Hazards An instruction depends on completion of data access by a previous instruction add$s0, $t0, $t1 sub$t2, $s0, $t3

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 10 Forwarding (aka Bypassing) Use result when it is computed Don’t wait for it to be stored in a register Requires extra connections in the datapath

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 11 Load-Use Data Hazard Can’t always avoid stalls by forwarding If value not computed when needed Can’t forward backward in time!

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 12 Code Scheduling to Avoid Stalls Reorder code to avoid use of load result in the next instruction C code for A = B + E; C = B + F; lw$t1, 0($t0) lw$t2, 4($t0) add$t3, $t1, $t2 sw$t3, 12($t0) lw$t4, 8($t0) add$t5, $t1, $t4 sw$t5, 16($t0) stall lw$t1, 0($t0) lw$t2, 4($t0) lw$t4, 8($t0) add$t3, $t1, $t2 sw$t3, 12($t0) add$t5, $t1, $t4 sw$t5, 16($t0) 11 cycles13 cycles

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 13 Control Hazards Branch determines flow of control Fetching next instruction depends on branch outcome Pipeline can’t always fetch correct instruction Still working on ID stage of branch In MIPS pipeline Need to compare registers and compute target early in the pipeline Add hardware to do it in ID stage

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 14 Stall on Branch Wait until branch outcome determined before fetching next instruction

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 15 Branch Prediction Longer pipelines can’t readily determine branch outcome early Stall penalty becomes unacceptable Predict outcome of branch Only stall if prediction is wrong In MIPS pipeline Can predict branches not taken Fetch instruction after branch, with no delay

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 16 MIPS with Predict Not Taken Prediction correct Prediction incorrect

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 17 More-Realistic Branch Prediction Static branch prediction Based on typical branch behavior Example: loop and if-statement branches Predict backward branches taken Predict forward branches not taken Dynamic branch prediction Hardware measures actual branch behavior e.g., record recent history of each branch Assume future behavior will continue the trend When wrong, stall while re-fetching, and update history

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 18 Pipeline Summary Pipelining improves performance by increasing instruction throughput Executes multiple instructions in parallel Each instruction has the same latency Subject to hazards Structure, data, control Instruction set design affects complexity of pipeline implementation

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 19 MIPS Pipelined Datapath WB MEM Right-to-left flow leads to hazards

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 20 Pipeline registers Need registers between stages To hold information produced in previous cycle

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 21 Pipeline Operation Cycle-by-cycle flow of instructions through the pipelined datapath “Single-clock-cycle” pipeline diagram Shows pipeline usage in a single cycle Highlight resources used c.f. “multi-clock-cycle” diagram Graph of operation over time We’ll look at “single-clock-cycle” diagrams for load & store

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 22 IF for Load, Store, …

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 23 ID for Load, Store, …

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 24 EX for Load

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 25 MEM for Load

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 26 WB for Load Wrong register number

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 27 Corrected Datapath for Load

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 28 EX for Store

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 29 MEM for Store

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 30 WB for Store

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 31 Multi-Cycle Pipeline Diagram Form showing resource usage

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 32 Multi-Cycle Pipeline Diagram Traditional form

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 33 Single-Cycle Pipeline Diagram State of pipeline in a given cycle

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 34 Pipelined Control (Simplified)

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 35 Pipelined Control Control signals derived from instruction As in single-cycle implementation

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 36 Pipelined Control

University of Texas at Austin CS352H - Computer Systems Architecture Fall 2009 Don Fussell 37 Concluding Remarks ISA influences design of datapath and control Datapath and control influence design of ISA Pipelining improves instruction throughput using parallelism More instructions completed per second Latency for each instruction not reduced Hazards: structural, data, control