# **Pipelining** Kevin Walsh CS 3410, Spring 2010 Computer Science Cornell University See: P&H Chapter 4.5 Alice Bob They don't always get along... # N pieces, each built following same sequence: Alice owns the room Bob can enter when Alice is finished Repeat for remaining tasks No possibility for conflicts Latency: 4 hrs / task Throughput: 4 hrs / 4 hrs Concurrency: Can we do better? #### Partition room into stages of a pipeline One person owns a stage at a time 4 stages 4 people working simultaneously Everyone moves right in lockstep 9 #### Principle: Latencies can be masked by parallel execution ## Pipelining: - Identify pipeline stages - Isolate stages from each other - Resolve pipeline hazards ## Five stage "RISC" load-store architecture - 1. Instruction fetch (IF) - get instruction from memory, increment PC - 2. Instruction Decode (ID) - translate opcode into control signals and read registers - 3. Execute (EX) - perform ALU operation, compute jump/branch targets - 4. Memory (MEM) - access memory if needed - 5. Writeback (WB) - update register file Break instructions across multiple clock cycles (five, in this case) Design a separate stage for the execution performed during each clock cycle Add pipeline registers to isolate signals between different stages