EECC551 - Shaaban #1 Fall 2001 lec#3 9-18-2001 Floating Point/Multicycle Pipelining in DLX Completion of DLX EX stage floating point arithmetic operations.

Slides:



Advertisements
Similar presentations
Instruction-Level Parallelism
Advertisements

CS 378 Programming for Performance Single-Thread Performance: Compiler Scheduling for Pipelines Adopted from Siddhartha Chatterjee Spring 2009.
ILP: IntroductionCSCE430/830 Instruction-level parallelism: Introduction CSCE430/830 Computer Architecture Lecturer: Prof. Hong Jiang Courtesy of Yifeng.
CPE 731 Advanced Computer Architecture Instruction Level Parallelism Part I Dr. Gheith Abandah Adapted from the slides of Prof. David Patterson, University.
Instruction-Level Parallelism compiler techniques and branch prediction prepared and Instructed by Shmuel Wimer Eng. Faculty, Bar-Ilan University March.
ENGS 116 Lecture 101 ILP: Software Approaches Vincent H. Berk October 12 th Reading for today: , 4.1 Reading for Friday: 4.2 – 4.6 Homework #2:
Computer Organization and Architecture (AT70.01) Comp. Sc. and Inf. Mgmt. Asian Institute of Technology Instructor: Dr. Sumanta Guha Slide Sources: Based.
CPE 631: ILP, Static Exploitation Electrical and Computer Engineering University of Alabama in Huntsville Aleksandar Milenkovic,
1 4/20/06 Exploiting Instruction-Level Parallelism with Software Approaches Original by Prof. David A. Patterson.
FTC.W99 1 Advanced Pipelining and Instruction Level Parallelism (ILP) ILP: Overlap execution of unrelated instructions gcc 17% control transfer –5 instructions.
Instruction Level Parallelism María Jesús Garzarán University of Illinois at Urbana-Champaign.
COMP4611 Tutorial 6 Instruction Level Parallelism
Eliminating Stalls Using Compiler Support. Instruction Level Parallelism gcc 17% control transfer –5 instructions + 1 branch –Reordering among 5 instructions.
ILP: Loop UnrollingCSCE430/830 Instruction-level parallelism: Loop Unrolling CSCE430/830 Computer Architecture Lecturer: Prof. Hong Jiang Courtesy of Yifeng.
EECC551 - Shaaban #1 Fall 2003 lec# Pipelining and Exploiting Instruction-Level Parallelism (ILP) Pipelining increases performance by overlapping.
1 COMP 740: Computer Architecture and Implementation Montek Singh Tue, Feb 24, 2009 Topic: Instruction-Level Parallelism IV (Software Approaches/Compiler.
EEL Advanced Pipelining and Instruction Level Parallelism Lotzi Bölöni.
Computer Architecture Instruction Level Parallelism Dr. Esam Al-Qaralleh.
CS152 Lec15.1 Advanced Topics in Pipelining Loop Unrolling Super scalar and VLIW Dynamic scheduling.
Instruction Set Issues MIPS easy –Instructions are only committed at MEM  WB transition Other architectures are more difficult –Instructions may update.
EECC551 - Shaaban #1 Fall 2005 lec# Static Compiler Optimization Techniques We examined the following static ISA/compiler techniques aimed.
Instruction-Level Parallelism (ILP)
COMP4211 Seminar Intro to Instruction-Level Parallelism 04S1 Week 02 Oliver Diessel.
COMP4211 (Seminar) Intro to Instruction-Level Parallelism
1 IF IDEX MEM L.D F4,0(R2) MUL.D F0, F4, F6 ADD.D F2, F0, F8 L.D F2, 0(R2) WB IF IDM1 MEM WBM2M3M4M5M6M7 stall.
1 Lecture: Pipeline Wrap-Up and Static ILP Topics: multi-cycle instructions, precise exceptions, deep pipelines, compiler scheduling, loop unrolling, software.
EECC551 - Shaaban #1 Winter 2002 lec# Pipelining and Exploiting Instruction-Level Parallelism (ILP) Pipelining increases performance by overlapping.
EECC551 - Shaaban #1 Spring 2004 lec# Static Compiler Optimization Techniques We already examined the following static compiler techniques aimed.
EECC551 - Shaaban #1 Spring 2006 lec# Pipelining and Instruction-Level Parallelism. Definition of basic instruction block Increasing Instruction-Level.
EECC551 - Shaaban #1 Fall 2005 lec# Pipelining and Instruction-Level Parallelism. Definition of basic instruction block Increasing Instruction-Level.
EECC551 - Shaaban #1 Winter 2003 lec# Static Compiler Optimization Techniques We already examined the following static compiler techniques aimed.
1 Lecture 5: Pipeline Wrap-up, Static ILP Basics Topics: loop unrolling, VLIW (Sections 2.1 – 2.2) Assignment 1 due at the start of class on Thursday.
Chapter 2 Instruction-Level Parallelism and Its Exploitation
EECC551 - Shaaban #1 Fall 2002 lec# Floating Point/Multicycle Pipelining in MIPS Completion of MIPS EX stage floating point arithmetic operations.
COMP381 by M. Hamdi 1 Pipelining Control Hazards and Deeper pipelines.
DLX Instruction Format
\course\ELEG652-03Fall\Topic Exploitation of Instruction-Level Parallelism (ILP)
EECC551 - Shaaban #1 Winter 2011 lec# Pipelining and Instruction-Level Parallelism (ILP). Definition of basic instruction block Increasing Instruction-Level.
EECC551 - Shaaban #1 Lec # 2 Winter Instruction Pipelining Review Instruction pipelining is CPU implementation technique where multiple.
EECC551 - Shaaban #1 Spring 2004 lec# Definition of basic instruction blocks Increasing Instruction-Level Parallelism & Size of Basic Blocks.
EECC551 - Shaaban #1 Winter 2002 lec# Static Compiler Optimization Techniques We already examined the following static compiler techniques aimed.
COMP381 by M. Hamdi 1 Loop Level Parallelism Instruction Level Parallelism: Loop Level Parallelism.
Pipelining and Exploiting Instruction-Level Parallelism (ILP)
Instruction Pipelining Review:
1 Appendix A Pipeline implementation Pipeline hazards, detection and forwarding Multiple-cycle operations MIPS R4000 CDA5155 Spring, 2007, Peir / University.
Pipeline Extensions prepared and Instructed by Shmuel Wimer Eng. Faculty, Bar-Ilan University MIPS Extensions1May 2015.
CIS 662 – Computer Architecture – Fall Class 16 – 11/09/04 1 Compiler Techniques for ILP  So far we have explored dynamic hardware techniques for.
Recap Multicycle Operations –MIPS Floating Point Putting It All Together: the MIPS R4000 Pipeline.
Instruction-Level Parallelism and Its Dynamic Exploitation
CMSC 611: Advanced Computer Architecture
Concepts and Challenges
Appendix C Pipeline implementation
CSCE430/830 Computer Architecture
Pipelining: Advanced ILP
Siddhartha Chatterjee Spring 2008
How to improve (decrease) CPI
Adapted from the slides of Prof
Pipelining and Exploiting Instruction-Level Parallelism (ILP)
Instruction Level Parallelism (ILP)
Pipelining and Exploiting Instruction-Level Parallelism (ILP)
Pipelining and Exploiting Instruction-Level Parallelism (ILP)
Dynamic Hardware Prediction
Pipelining and Exploiting Instruction-Level Parallelism (ILP)
How to improve (decrease) CPI
Pipelining and Exploiting Instruction-Level Parallelism (ILP)
Pipelining and Exploiting Instruction-Level Parallelism (ILP)
CMSC 611: Advanced Computer Architecture
Pipelining and Exploiting Instruction-Level Parallelism (ILP)
Loop-Level Parallelism
Lecture 5: Pipeline Wrap-up, Static ILP
Presentation transcript:

EECC551 - Shaaban #1 Fall 2001 lec# Floating Point/Multicycle Pipelining in DLX Completion of DLX EX stage floating point arithmetic operations in one or two cycles is impractical since it requires: A much longer CPU clock cycle, and/or An enormous amount of logic. Instead, the floating-point pipeline will allow for a longer latency. Floating-point operations have the same pipeline stages as the integer instructions with the following differences: –The EX cycle may be repeated as many times as needed. –There may be multiple floating-point functional units. –A stall will occur if the instruction to be issued will either causes a structural hazard for the functional unit or cause a data hazard. The latency of functional units is defined as the number of intervening cycles between an instruction producing the result and the instruction that uses the result. The initiation or repeat interval is the number of cycles that must elapse between issuing an instruction of a given type.

EECC551 - Shaaban #2 Fall 2001 lec# Extending The DLX Pipeline to Handle Floating-Point Operations: Adding Non-Pipelined Adding Non-Pipelined Floating Point Units Floating Point Units

EECC551 - Shaaban #3 Fall 2001 lec# Extending The DLX Pipeline: Multiple Outstanding Floating Point Operations Multiple Outstanding Floating Point Operations Latency = 0 Initiation Interval = 1 Latency = 3 Initiation Interval = 1 Pipelined Latency = 6 Initiation Interval = 1 Pipelined Latency = 24 Initiation Interval = 25 Non-pipelined Integer Unit Floating Point (FP)/Integer Multiply FP/Integer Divider IFID WB MEM FP Adder EX Hazards: RAW, WAW possible WAR Not Possible Structural: Possible Control: Possible

EECC551 - Shaaban #4 Fall 2001 lec# Pipeline Characteristics With FP Instructions are still processed in-order in IF, ID, EX at the rate of instruction per cycle. Longer RAW hazard stalls likely due to long FP latencies. Structural hazards possible due to varying instruction times and FP latencies: –FP unit may not be available; divide in this case. –MEM, WB reached by several instructions simultaneously. WAW hazards can occur since it is possible for instructions to reach WB out-of-order. WAR hazards impossible, since register reads occur in- order in ID. Instructions are allowed to complete out-of-order requiring special measures to enforce precise exceptions.

EECC551 - Shaaban #5 Fall 2001 lec# FP Operations Pipeline Timing Example All above instructions are assumed independent IFIDA1A4A3A2 MEM WB IFIDM1M6M7M2M3M4M5 MEM WB IFID MEM EXWB IFID MEM EXWB MULTD LD ADDD SD CC 1CC 2CC 3CC 8CC 9CC 4CC 5CC 6CC 7 CC 10 CC 11

EECC551 - Shaaban #6 Fall 2001 lec# FP Code RAW Hazard Stalls Example (with full data forwarding in place) IF MEM IDEX WB IFIDM1M6M7M2M3M4M5 MEM WB IFIDA1A4A3A2 MEM WB CC 1CC 2CC 3CC 8CC 9CC 4CC 5CC 6CC 7 CC 10 CC 11 CC12 CC13 CC14 CC15 CC16 CC17 CC18 IFID MEM EXWB STALL LD F4, 0(R2) MULTD F0, F4, F6 ADDD F2, F0, F8 SD 0(R2), F2 Third stall due to structural hazard in MEM stage

EECC551 - Shaaban #7 Fall 2001 lec# FP Code Structural Hazards Example IFIDA1A4A3A2 MEM WB IFIDM1M6M7M2M3M4M5 MEM WB IFID MEM EXWB IFID MEM EXWB MULTD F0, F4, F6 LD F2, 0(R2) ADDD F2, F4, F6 CC 1CC 2CC 3CC 8CC 9CC 4CC 5CC 6CC 7 CC 10 CC 11 IFID MEM EXWB IFID MEM EXWBIFID MEM EXWB... (integer)

EECC551 - Shaaban #8 Fall 2001 lec# Maintaining Precise Exceptions in Multicycle Pipelining In the DLX code segment: DIVF F0, F2, F4 ADDF F10, F10, F8 SUBF F12, F12, F14 The ADDF, SUBF instructions can complete before DIVF is completed causing out-of-order execution. If SUBF causes a floating-point arithmetic exception it may prevent DIVF from completing and draining the floating-point may not be possible causing an imprecise exception. Four approaches have been proposed to remedy this type of situation: 1 Ignore the problem and settle for imprecise exception. 2 Buffer the results of the operation until all the operations issues earlier are done. (large buffers, multiplexers, comparators) 3 A history file keeps track of the original values of registers (CYBER180/190, VAX) 4 A Future file keeps the newer value of a register; when all earlier instructions have completed the main register file is updated from the future file. On an exception the main register file has the precise values for the interrupted state.

EECC551 - Shaaban #9 Fall 2001 lec# DLX FP SPEC92 Floating Point Stalls Per FP Operation

EECC551 - Shaaban #10 Fall 2001 lec# DLX FP SPEC92 Floating Point Stalls

EECC551 - Shaaban #11 Fall 2001 lec# Pipelining and Exploiting Instruction-Level Parallelism (ILP) Pipelining increases performance by overlapping the execution of independent instructions. The CPI of a real-life pipeline is given by: Pipeline CPI = Ideal Pipeline CPI + Structural Stalls + RAW Stalls + WAR Stalls + WAW Stalls + Control Stalls A basic instruction block is a straight-line code sequence with no branches in, except at the entry point, and no branches out except at the exit point of the sequence. The amount of parallelism in a basic block is limited by instruction dependence present and size of the basic block. In typical integer code, dynamic branch frequency is about 15% (average basic block size of 7 instructions).

EECC551 - Shaaban #12 Fall 2001 lec# Increasing Instruction-Level Parallelism A common way to increase parallelism among instructions is to exploit parallelism among iterations of a loop –(i.e Loop Level Parallelism, LLP). This is accomplished by unrolling the loop either statically by the compiler, or dynamically by hardware, which increases the size of the basic block present. In this loop every iteration can overlap with any other iteration. Overlap within each iteration is minimal. for (i=1; i<=1000; i=i+1;) x[i] = x[i] + y[i]; In vector machines, utilizing vector instructions is an important alternative to exploit loop-level parallelism, Vector instructions operate on a number of data items. The above loop would require just four such instructions.

EECC551 - Shaaban #13 Fall 2001 lec# DLX Loop Unrolling Example For the loop: for (i=1; i<=1000; i++) x[i] = x[i] + s; The straightforward DLX assembly code is given by: Loop: LD F0, 0 (R1) ;F0=array element ADDD F4, F0, F2 ;add scalar in F2 SD 0(R1), F4 ;store result SUBI R1, R1, 8 ;decrement pointer 8 bytes BNEZ R1, Loop ;branch R1!=zero

EECC551 - Shaaban #14 Fall 2001 lec# DLX FP Latency Assumptions Used In Chapter 4 All FP units assumed to be pipelined. The following FP operations latencies are used: Instruction Producing Result FP ALU Op Load Double Instruction Using Result Another FP ALU Op Store Double FP ALU Op Store Double Latency In Clock Cycles

EECC551 - Shaaban #15 Fall 2001 lec# Loop Unrolling Example (continued) This loop code is executed on the DLX pipeline as follows: With delayed branch scheduling (swap SUBI and SD) Loop: LD F0, 0(R1) stall ADDD F4, F0, F2 SUBI R1, R1, #8 BENZ R1, Loop SD 8 (R1), F4 6 cycles per iteration No scheduling Clock cycle Loop: LD F0, 0(R1) 1 stall 2 ADDD F4, F0, F2 3 stall 4 stall 5 SD 0 (R1), F4 6 SUBI R1, R1, #8 7 BNEZ R1, Loop 8 stall 9 9 cycles per iteration

EECC551 - Shaaban #16 Fall 2001 lec# Loop Unrolling Example (continued) The resulting loop code when four copies of the loop body are unrolled without reuse of registers: No scheduling Loop: LD F0, 0(R1) ADDD F4, F0, F2 SD 0 (R1), F4 ; drop SUBI & BNEZ LD F6, -8(R1) ADDD F8, F6, F2 SD -8 (R1), F8 ; drop SUBI & BNEZ LD F10, -16(R1) ADDD F12, F10, F2 SD -16 (R1), F12 ; drop SUBI & BNEZ LD F14, -24 (R1) ADDD F16, F14, F2 SD -24(R1), F16 SUBI R1, R1, #32 BNEZ R1, Loop Three branches and three decrements of R1 are eliminated. Load and store addresses are changed to allow SUBI instructions to be merged. The loop runs in 27 assuming LD takes 2 cycles, each ADDD takes 3 cycles, the branch 2 cycles, other instructions 1 cycle, or 6.8 cycles for each of the four elements.

EECC551 - Shaaban #17 Fall 2001 lec# Loop Unrolling Example (continued) When scheduled for DLX Loop: LD F0, 0(R1) LD F6,-8 (R1) LD F10, -16(R1) LD F14, -24(R1) ADDD F4, F0, F2 ADDD F8, F6, F2 ADDD F12, F10, F2 ADDD F16, F14, F2 SD 0(R1), F4 SD -8(R1), F8 SD -16(R1),F12 SUBI R1, R1,#32 BNEZ R1, Loop SD 8(R1), F16;8-32 =-24 The execution time of the loop has dropped to 14 cycles, or 3.5 clock cycles per element compared to 6.8 before scheduling and 6 when scheduled but unrolled. Unrolling the loop exposed more computation that can be scheduled to minimize stalls.

EECC551 - Shaaban #18 Fall 2001 lec# Loop Unrolling Requirements In the loop unrolling example, the following guidelines where followed: –Determine that it was legal to move SD after SUBI and BENZ; find the SD offset. –Determine that unrolling the loop would be useful by finding that the loop iterations where independent. –Use different registers to avoid constraints of using the same registers (WAR, WAW). –Eliminate extra tests and branches and adjust loop maintenance code. –Determine that loads and stores can be interchanged by observing that they are independent from different loops. –Schedule the code, preserving any dependencies needed to give the same result as the original code.

EECC551 - Shaaban #19 Fall 2001 lec# Instruction Dependencies Determining instruction dependencies is important for pipeline scheduling and to determine the amount of parallelism in the program to be exploited. If two instructions are parallel, they can be executed simultaneously in the pipeline without causing stalls; assuming the pipeline has sufficient resources. Instructions that are dependent are not parallel and cannot be reordered. Instruction dependencies are classified as: – Data dependencies – Name dependencies – Control dependencies

EECC551 - Shaaban #20 Fall 2001 lec# Instruction Data Dependencies An instruction j is data dependent on another instruction i if: –Instruction i produces a result used by instruction j, resulting in a direct RAW hazard, or –Instruction j is data dependent on instruction k and instruction k is data dependent on instruction i which implies a chain of RAW hazard between the two instructions. Example: The arrows indicate data dependencies and point to the dependent instruction which must follow and remain in the original instruction order to ensure correct execution. Loop: LD F0, 0 (R1) ; F0=array element ADDD F4, F0, F2 ; add scalar in F2 SD 0 (R1), F4 ; store result

EECC551 - Shaaban #21 Fall 2001 lec# Instruction Name Dependencies A name dependence occurs when two instructions use the same register or memory location, called a name. No flow of data exist between the instructions involved in the name dependency. If instruction i precedes instruction j then two types of name dependencies can occur: –An antidependence occurs when j writes to a register or memory location and i reads and instruction i is executed first. This corresponds to a WAR hazard. –An output dependence occurs when instruction i and j write to the same register or memory location resulting in a WAW hazard and instruction execution order must be observed.

EECC551 - Shaaban #22 Fall 2001 lec# Name Dependence Example In the unrolled loop, using the same registers results in name (green) and data tendencies (red) Loop: LD F0, 0 (R1) ADDD F4, F0, F2 SD 0(R1), F4 LD F0, -8 (R1) ADDD F4, F0, F2 SD -8 (R1) F4 LD F0, -16 (R1) ADDD F4, F0, F2 SD -16 (R1), F4 LD F0, -24 (R1) ADDD F4, F0, F2 SD -24(R1), F4 SUBI R1, R1, #32 BENZ R1, Loop Renaming the registers used for each copy of the loop body are renamed, only true dependencies remain: Loop: LD F0, 0 (R1) ADDD F4, F0, F2 SD 0(R1), F4 LD F6, -8 (R1) ADDD F8, F6, F2 SD -8 (R1) F8 LD F10, -16 (R1) ADDD F12, F10, F2 SD -16 (R1), F12 LD F14, -24 (R1) ADDD F16, F14, F2 SD -24(R1), F16 SUBI R1, R1, #32 BENZ R1, Loop

EECC551 - Shaaban #23 Fall 2001 lec# Control Dependencies Determines the ordering of an instruction with respect to a branch instruction. Every instruction except in the first basic block of the program is control dependent on some set of branches. An instruction which is control dependent on a branch cannot be moved before the branch. An instruction which is not control dependent on the branch cannot be moved so that its execution is controlled by the branch (in the then portion) It’s possible in some cases to violate these constraints and still have correct execution. Example of control dependence in the then part of an if statement: if p1 { S1; }; If p2 { S2; } S1 is control dependent on p1 S2 is control dependent on p2 but not on p1

EECC551 - Shaaban #24 Fall 2001 lec# Control Dependence Example The unrolled loop code with the branches still in place is shown here. Branch conditions are complemented here to allow the fall-through to execute another loop. BEQZ instructions prevent the overlapping of iterations for scheduling optimizations. Moving the instructions requires a change in the control dependencies present. Removing the branches changes the control dependencies present and makes optimizations possible. Loop: LD F0, 0 (R1) ADDD F4, F0, F2 SD 0 (R1), F4 SUBI R1, R1, #8 BEQZ R1, exit LD F6, 0 (R1) ADDD F8, F6, F2 SD 0 (R1), F8 SUBI R1, R1, #8 BEQZ R1, exit LD F10, 0 (R1) ADDD F12, F10, F2 SD 0 (R1), F12 SUBI R1, R1, #8 BEQZ R1, exit LD F14, 0 (R1) ADDD F16, F14, F2 SD 0 (R1), F16 SUBI R1, R1, #8 BNEZ R1, Loop exit:

EECC551 - Shaaban #25 Fall 2001 lec# Loop-Level Parallelism (LLP) Analysis LLP analysis is normally done at the source level or close to it since assembly language and target machine code generation introduces a loop-carried dependence, in the registers used for addressing and incrementing. Instruction level parallelism (ILP) analysis is usually done when instructions are generated by the compiler. Analysis focuses on whether data accesses in later iterations are data dependent on data values produced in earlier iterations. e.g. in for (i=1; i<=1000; i++) x[i] = x[i] + s; the computation in each iteration is independent of the previous iterations and the loop is thus parallel. The use of X[i] twice is within a single iteration.

EECC551 - Shaaban #26 Fall 2001 lec# LLP Analysis Examples In the loop: for (i=1; i<=100; i=i+1) { A[i+1] = A[i] + C[i]; /* S1 */ B[i+1] = B[i] + A[i+1];} /* S2 */ } –S1 uses a value computed in an earlier iteration, since iteration i computes A[i+1] read in iteration i+1 (loop-carried dependence, prevents parallelism). –S2 uses the value A[i+1], computed by S1 in the same iteration (not loop-carried dependence).

EECC551 - Shaaban #27 Fall 2001 lec# LLP Analysis Examples In the loop: for (i=1; i<=100; i=i+1) { A[i] = A[i] + B[i]; /* S1 */ B[i+1] = C[i] + D[i]; /* S2 */ } –S1 uses a value computed by S2 in a previous iteration (loop-carried dependence) –This dependence is not circular (neither statement depend on itself; S1 depends on S2 but S2 does not depend on S1. –Can be made parallel by replacing the code with the following: A[1] = A[1] + B[1]; for (i=1; ii<=99; i=i+1) { B[i+1] = C[i] + D[i]; A[i+1] = A[i+1] + B[i+1]; } B[101] = C[100] + D[100];

EECC551 - Shaaban #28 Fall 2001 lec# LLP Analysis Example Original Loop: A[100] = A[100] + B[100]; B[101] = C[100] + D[100]; A[1] = A[1] + B[1]; B[2] = C[1] + D[1]; A[2] = A[2] + B[2]; B[3] = C[2] + D[2]; A[99] = A[99] + B[99]; B[100] = C[99] + D[99]; A[100] = A[100] + B[100]; B[101] = C[100] + D[100]; A[1] = A[1] + B[1]; B[2] = C[1] + D[1]; A[2] = A[2] + B[2]; B[3] = C[2] + D[2]; A[99] = A[99] + B[99]; B[100] = C[99] + D[99]; for (i=1; i<=100; i=i+1) { A[i] = A[i] + B[i]; /* S1 */ B[i+1] = C[i] + D[i]; /* S2 */ } A[1] = A[1] + B[1]; for (i=1; i<=99; i=i+1) { B[i+1] = C[i] + D[i]; A[i+1] = A[i+1] + B[i+1]; } B[101] = C[100] + D[100]; Modified Parallel Loop: Iteration 1 Iteration 2 Iteration 100Iteration 99 Loop-carried Dependence Loop Start-up code Loop Completion code Iteration 1 Iteration 98 Iteration 99 Not Loop Carried Dependence.....