Back to Search
Start Over
Multi-dimensional Kernel Generation for Loop Nest Software Pipelining
- Source :
- Euro-Par 2006 Parallel Processing ISBN: 9783540377832, Euro-Par
- Publication Year :
- 2006
- Publisher :
- Springer Berlin Heidelberg, 2006.
-
Abstract
- Single-dimension Software Pipelining (SSP) has been proposed as an effective software pipelining technique for multi-dimensional loops [16]. This paper introduces for the first time the scheduling methods that actually produce the kernel code. Because of the multi-dimensional nature of the problem, the scheduling problem is more complex and challenging than with traditional modulo scheduling. The scheduler must handle multiple subkernels and initiation rates under specific scheduling constraints, while producing a solution that minimizes the execution time of the final schedule. In this paper three approaches are proposed: the level-by-level method, which schedules operations in loop level order, starting from the innermost, and does not let other operations interfere with the already scheduled levels, the flat method, which schedules operations from different loop levels with the same priority, and the hybrid method, which uses the level-by-level mechanism for the innermost level and the flat solution for the other levels. The methods subsume Huff's modulo scheduling [8] for single loops as a special case. We also break a scheduling constraint introduced in earlier publications and allow for a more compact kernel. The proposed approaches were implemented in the Open64/ORC compiler, and evaluated on loop nests from the Livermore, SPEC200 and NAS benchmarks.
Details
- ISBN :
- 978-3-540-37783-2
- ISBNs :
- 9783540377832
- Database :
- OpenAIRE
- Journal :
- Euro-Par 2006 Parallel Processing ISBN: 9783540377832, Euro-Par
- Accession number :
- edsair.doi...........4d1653cc5e444858912fe986403c09e3
- Full Text :
- https://doi.org/10.1007/11823285_32