1 / 84

CS161 – Design and Architecture of Computer Systems

Learn the concept of pipelining using a laundry analogy - wash, dry, fold, put away. Understand pipeline stages, speedup, MIPS pipeline, single-cycle vs. multi-cycle diagrams, hazards, and control signals. Discover strategies to avoid data hazards and optimize performance.

trentj
Download Presentation

CS161 – Design and Architecture of Computer Systems

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. CS161 – Design and Architecture of Computer Systems Pipelined CPU Design

  2. Pipelining Analogy • Laundry steps: • Wash • Dry • Fold • Put it away – Closet / Dresser / Neat pile on floor

  3. Pipelining Analogy Assuming each step take 1 hour, 4 loads would take 16 hours! 1 2 3 4

  4. Pipelining Analogy • To speed things up, overlap steps • 4 loads of laundry now only takes 7 hours! 1 2 3 4

  5. Speedup of Pipelining • k stages pipeline, t time per stage, n jobs • Non-pipelined time = n*k*t • Pipelined time = (k+n-1)*t • This is an ideal case: • No job depends on a previous job • All jobs behave exactly the same • Not realistic.

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

  7. Pipeline Performance Single-cycle (Tc= 800ps) Pipelined (Tc= 200ps)

  8. Pipeline Speedup • If all stages are balanced • i.e., all take the same time • If not balanced, speedup is less • Speedup due to increased throughput • Latency (time for each instruction) does not decrease

  9. 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 3rd stage, access memory in 4th stage • Alignment of memory operands • Memory access takes only one cycle

  10. 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 The BIG Picture

  11. MIPS Pipelined Datapath MEM Right-to-left flow leads to hazards WB

  12. Pipeline registers • Need registers between stages • To hold information produced in previous cycle

  13. 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

  14. Single-Cycle Pipeline Diagram • State of pipeline in a given cycle

  15. IF for Load, Store, …

  16. ID for Load, Store, …

  17. EX for Load

  18. MEM for Load

  19. WB for Load Wrongregisternumber

  20. Corrected Datapath for Load

  21. EX for Store

  22. MEM for Store

  23. WB for Store

  24. Multi-Cycle Pipeline Diagram • Form showing resource usage

  25. Multi-Cycle Pipeline Diagram • Traditional form

  26. Pipelined Control (Simplified)

  27. Pipelined Control • Control signals derived from instruction, in ID stage • As in single-cycle implementation

  28. Pipelined Control

  29. Hazards • Situations that prevent starting the next instruction in the next cycle • Structure hazards • A required resource is busy: why we have I$ and D$ • Data hazard • Need to wait for previous instruction to complete its data read/write • Control hazard • Deciding on control action depends on previous instruction

  30. 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

  31. Data Hazards • An instruction depends on completion of data access by a previous instruction • add $s0, $t0, $t1sub $t2, $s0, $t3

  32. General framework of data hazards • Range and Domain of Instructions • D(i): domain of i = all values read by I prior to execution • R(i): range of instruction i = all values written by I, after execution • Read After Write (RAW), true, or dataflow, dependence i1: add r1, r2, r3 i2: add r4, r1, r5 • Write After Read (WAR), anti dependence i1: add r1, r2, r3 i2: add r2, r4, r5 • Write After Write (WAW), output dependence i1: add r1, r2, r3 i2: add r1, r4, r5

  33. WAR & WAW • WAR & WAW are name dependencies • Dependence is on the container’s name not on the value contained. • Can be eliminated by renaming, static (in software) or dynamic (in hardware) • WAW & WAR cannot occur in the 5-stage pipeline • All the writing happens in WB stage, in order issue of all instructions

  34. 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

  35. Load-Use Data Hazard • Can’t always avoid stalls by forwarding • If value not computed when needed • Can’t forward backward in time!

  36. 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; • Reordering is commonly done by modern compilers 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) 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) stall stall 13 cycles 11 cycles

  37. Data Hazards in ALU Instructions • Consider this sequence: sub $2, $1,$3and $12,$2,$5or $13,$6,$2add $14,$2,$2sw $15,100($2) • We can resolve hazards with forwarding • How do we detect when to forward?

  38. Dependencies & Forwarding Forwarding

  39. Detecting the Need to Forward • Pass register numbers along pipeline • e.g., ID/EX.RegisterRs = register number for Rs sitting in ID/EX pipeline register • ALU operand register numbers in EX stage are given by • ID/EX.RegisterRs, ID/EX.RegisterRt • Data hazards when 1a. EX/MEM.RegisterRd = ID/EX.RegisterRs 1b. EX/MEM.RegisterRd = ID/EX.RegisterRt 2a. MEM/WB.RegisterRd = ID/EX.RegisterRs 2b. MEM/WB.RegisterRd = ID/EX.RegisterRt If dest == either src register Fwd from EX/MEM pipeline reg If dest == src register Fwd from MEM/WB pipeline reg

  40. Detecting the Need to Forward • But only if forwarding instruction will write to a register! • EX/MEM.RegWrite, MEM/WB.RegWrite • And only if Rd for that instruction is not $zero • EX/MEM.RegisterRd ≠ 0,MEM/WB.RegisterRd ≠ 0

  41. Forwarding Paths

  42. Forwarding Conditions • EX hazard • if (EX/MEM.RegWrite and (EX/MEM.RegisterRd ≠ 0) and (EX/MEM.RegisterRd = ID/EX.RegisterRs))ForwardA = 10 • if (EX/MEM.RegWrite and (EX/MEM.RegisterRd ≠ 0) and (EX/MEM.RegisterRd = ID/EX.RegisterRt))ForwardB = 10 • MEM hazard • if (MEM/WB.RegWrite and (MEM/WB.RegisterRd ≠ 0) and (MEM/WB.RegisterRd = ID/EX.RegisterRs))ForwardA = 01 • if (MEM/WB.RegWrite and (MEM/WB.RegisterRd ≠ 0) and (MEM/WB.RegisterRd = ID/EX.RegisterRt))ForwardB = 01

  43. Double Data Hazard • Consider the sequence: add $1,$1,$2add $1,$1,$3add $1,$1,$4 • Both hazards occur • Want to use the most recent • Revise MEM hazard condition • Only fwd if EX hazard condition isn’t true

  44. Revised Forwarding Condition • MEM hazard • if (MEM/WB.RegWrite and (MEM/WB.RegisterRd ≠ 0)and not (EX/MEM.RegWrite and (EX/MEM.RegisterRd ≠ 0) and (EX/MEM.RegisterRd = ID/EX.RegisterRs)) and (MEM/WB.RegisterRd = ID/EX.RegisterRs)) ForwardA = 01 • if (MEM/WB.RegWrite and (MEM/WB.RegisterRd ≠ 0)and not (EX/MEM.RegWrite and (EX/MEM.RegisterRd ≠ 0) and (EX/MEM.RegisterRd = ID/EX.RegisterRt)) and (MEM/WB.RegisterRd = ID/EX.RegisterRt)) ForwardB = 01

  45. Datapath with Forwarding

  46. Load-Use Data Hazard Need to stall for one cycle

  47. Load-Use Hazard Detection • Check when using instruction is decoded in ID stage • ALU operand register numbers in ID stage are given by • IF/ID.RegisterRs, IF/ID.RegisterRt • Load-use hazard when • ID/EX.MemRead and ((ID/EX.RegisterRt = IF/ID.RegisterRs) or (ID/EX.RegisterRt = IF/ID.RegisterRt)) • If detected, stall and insert bubble

  48. How to Stall the Pipeline • Force control values in ID/EX register to 0 • EX, MEM and WB do nop (no-operation) • Prevent update of PC and IF/ID register • Current instruction is decoded again • Following instruction is fetched again • 1-cycle stall allows MEM to read data for lw • Can subsequently forward to EX stage

  49. Stall/Bubble in the Pipeline Stall inserted here

  50. Stall/Bubble in the Pipeline Or, more accurately…

More Related