Instruction Scheduling (Part 2) Software Pipelining

Instruction Scheduling (Part 2) Software Pipelining

Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Instruction Scheduling (Part 2) Software Pipelining Patrick Carribault [email protected] CS 380C: Advanced Compiler Techniques Tuesday, October 23th 2007 Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Lecture Overview Code Generator Back end part of compiler (code generator) Instruction scheduling Register allocation Instruction Scheduling Input: set of instructions Output: total order on that set Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Lecture Outline Previous Lecture 1 Introduction to instruction scheduling 2 Representation of data dependences and resource constraints 3 Acyclic scheduling: list scheduling Today Loop scheduling: definition of software pipelining Parameters of software-pipelined schedules Heuristics: modulo scheduling Hardware support for code generation of software-pipelined loops Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Introduction to Software Pipelining Loop Scheduling Apply list scheduling on the loop body Ignore dependence distance > 0 No iteration overlapping ⇒ any schedule respects the dependence distances But: exploit only intra-iteration parallelism How to benefit from inter-iteration parallelism? 1 Unroll the loop before scheduling (or while scheduling) 2 Overlap consecutive iterations in a continuous flow ⇒ Software Pipelining Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 1 DDG and reservation tables: 1,0 1,0 A B C A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X A valid simple schedule? Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 1 DDG and reservation tables: 1,0 1,0 A B C A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X A valid simple schedule? ⇒ Use list scheduling on loop body Cycle Schedule Cycle r0 r1 r2 Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 1 DDG and reservation tables: 1,0 1,0 A B C A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X A valid simple schedule? ⇒ Use list scheduling on loop body Cycle Schedule Cycle r0 r1 r2 0 A 0 X Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 1 DDG and reservation tables: 1,0 1,0 A B C A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X A valid simple schedule? ⇒ Use list scheduling on loop body Cycle Schedule Cycle r0 r1 r2 0 A 0 X 1 B 1 X Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 1 DDG and reservation tables: 1,0 1,0 A B C A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X A valid simple schedule? ⇒ Use list scheduling on loop body Cycle Schedule Cycle r0 r1 r2 0 A 0 X 1 B 1 X 2 C 2 X Length of 3, but inter-iteration parallelism available Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 1 – cont. DDG and reservation tables: 1,0 1,0 A B C A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X Schedule with overlapped iterations? Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 1 – cont. DDG and reservation tables: 1,0 1,0 A B C A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X Schedule with overlapped iterations? Cycle Schedule Cycle r0 r1 r2 0 1 2 3 Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 1 – cont. DDG and reservation tables: 1,0 1,0 A B C A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X Schedule with overlapped iterations? Cycle Schedule Cycle r0 r1 r2 0 1 2 3 0 X 0 A Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 1 – cont. DDG and reservation tables: 1,0 1,0 A B C A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X Schedule with overlapped iterations? Cycle Schedule Cycle r0 r1 r2 0 1 2 3 0 X 0 A 1 X X 1 B A Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 1 – cont. DDG and reservation tables: 1,0 1,0 A B C A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X Schedule with overlapped iterations? Cycle Schedule Cycle r0 r1 r2 0 1 2 3 0 X 0 A 1 X X 1 B A 2 X X X 2 C B A Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 1 – cont. DDG and reservation tables: 1,0 1,0 A B C A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X Schedule with overlapped iterations? Cycle Schedule Cycle r0 r1 r2 0 1 2 3 0 X 0 A 1 X X 1 B A 2 X X X 2 C B A 3 X X X 3 C B A Kernel (1 cycle), depth of 3 Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 2 DDG and reservation tables: 1,0 1,0 A B C 1,1 A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X Schedule with overlapped iterations? Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 2 DDG and reservation tables: 1,0 1,0 A B C 1,1 A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X Schedule with overlapped iterations? Cycle Schedule Cycle r0 r1 r2 0 1 2 3 Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 2 DDG and reservation tables: 1,0 1,0 A B C 1,1 A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X Schedule with overlapped iterations? Cycle Schedule Cycle r0 r1 r2 0 1 2 3 0 X 0 A Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 2 DDG and reservation tables: 1,0 1,0 A B C 1,1 A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X Schedule with overlapped iterations? Cycle Schedule Cycle r0 r1 r2 0 1 2 3 0 X 0 A 1 X 1 B Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 2 DDG and reservation tables: 1,0 1,0 A B C 1,1 A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X Schedule with overlapped iterations? Cycle Schedule Cycle r0 r1 r2 0 1 2 3 0 X 0 A 1 X 1 B 2 X X 2 C A Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 2 DDG and reservation tables: 1,0 1,0 A B C 1,1 A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X Schedule with overlapped iterations? Cycle Schedule Cycle r0 r1 r2 0 1 2 3 0 X 0 A 1 X 1 B 2 X X 2 C A 3 X 3 B Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 2 DDG and reservation tables: 1,0 1,0 A B C 1,1 A r0 r1 r2 B r0 r1 r2 C r0 r1 r2 0 X 0 X 0 X Schedule with overlapped iterations? Cycle Schedule Cycle r0 r1 r2 0 1 2 3 0 X 0 A 1 X 1 B 2 X X 2 C A 3 X 3 B 4 X X 4 C A Kernel (2 cycles), depth of 2 Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 3 DDG and reservation tables: 1,0 1,0 A B C A r0 r1 B r0 r1 C r0 r1 0 X 0 X 0 X Schedule with overlapped iterations? Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 3 DDG and reservation tables: 1,0 1,0 A B C A r0 r1 B r0 r1 C r0 r1 0 X 0 X 0 X Schedule with overlapped iterations? Cycle Schedule Cycle r0 r1 0 1 2 3 Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 3 DDG and reservation tables: 1,0 1,0 A B C A r0 r1 B r0 r1 C r0 r1 0 X 0 X 0 X Schedule with overlapped iterations? Cycle Schedule Cycle r0 r1 0 1 2 3 0 X 0 A Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 3 DDG and reservation tables: 1,0 1,0 A B C A r0 r1 B r0 r1 C r0 r1 0 X 0 X 0 X Schedule with overlapped iterations? Cycle Schedule Cycle r0 r1 0 1 2 3 0 X 0 A 1 X 1 B Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 3 DDG and reservation tables: 1,0 1,0 A B C A r0 r1 B r0 r1 C r0 r1 0 X 0 X 0 X Schedule with overlapped iterations? Cycle Schedule Cycle r0 r1 0 1 2 3 0 X 0 A 1 X 1 B 2 X X 2 C A Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 3 DDG and reservation tables: 1,0 1,0 A B C A r0 r1 B r0 r1 C r0 r1 0 X 0 X 0 X Schedule with overlapped iterations? Cycle Schedule Cycle r0 r1 0 1 2 3 0 X 0 A 1 X 1 B 2 X X 2 C A 3 X 3 B Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Example 3 DDG and reservation tables: 1,0 1,0 A B C A r0 r1 B r0 r1 C r0 r1 0 X 0 X 0 X Schedule with overlapped iterations? Cycle Schedule Cycle r0 r1 0 1 2 3 0 X 0 A 1 X 1 B 2 X X 2 C A 3 X 3 B 4 X X 4 C A Kernel (2 cycles), depth of 2 Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Software Pipelining – Definition Definition Do not wait for an iteration to finish to launch the next one Constant time between two consecutive iteration launches Initiation Interval (or II) Need to respect constraints (including dependence distance) Prolog/Kernel/Epilog Schedule Several iterations alive in the kernel (depth) One instruction scheduling ⇒ one cycle and one iteration ⇒ 2-dimensional schedule Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Software Pipelining – Parameters Performance Performance in cycles P with n iterations: P = (n − 1) × II + M Linear in II ⇒ lower is better Parameters Initiation Interval II Depth D Makespan M Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Initiation Interval Initiation Interval Time (in cycles) between 2 consecutive iteration launches Corresponds to the kernel size Shape the overall performance of pipelined schedule Parameters influencing II Data dependences: RecMII: latency(θ) RecMII = max ∀circuits θ distance(θ) Resource constraints: ResMII Minimum value MII : MII = max(ResMII, RecMII) Lecture Overview Introduction Modulo Scheduling Hardware Support Conclusion Data Dependences – RecMII Dependence Constraint Let σ be the schedule date of instructions for one iteration, l is the latency and d the distance Consider a and b two instructions: Intra-iteration constraint (d(a, b)=

View Full Text

Details

  • File Type
    pdf
  • Upload Time
    -
  • Content Languages
    English
  • Upload User
    Anonymous/Not logged-in
  • File Pages
    55 Page
  • File Size
    -

Download

Channel Download Status
Express Download Enable

Copyright

We respect the copyrights and intellectual property rights of all users. All uploaded documents are either original works of the uploader or authorized works of the rightful owners.

  • Not to be reproduced or distributed without explicit permission.
  • Not used for commercial purposes outside of approved use cases.
  • Not used to infringe on the rights of the original creators.
  • If you believe any content infringes your copyright, please contact us immediately.

Support

For help with questions, suggestions, or problems, please contact us