Pingali, Keshav2007-04-232007-04-231988-08http://techreports.library.cornell.edu:8081/Dienst/UI/1.0/Display/cul.cs/TR88-934https://hdl.handle.net/1813/6774Computer architecture design requires careful attention to the balance between the complexity of code scheduling problems and the cost and feasibility of building a machine. In this paper, we show that recently developed software pipelining algorithms produce optimal or near-optimal code for a large class of loops when the target architecture is a clean pipelined parallel machine. The important feature of these machines is the absence of structural hazards. We argue that the robustness of the scheduling algorithms and relatively simple hardware make these machines realistic and cost-effective. To illustrate the delicate balance between architecture and scheduling complexity, we show that scheduling with structural hazards is NP-hard, and that there are machines with simple structural hazards for which vectorization and the software pipelining techniques generate poor code.1752164 bytes459341 bytesapplication/pdfapplication/postscripten-UScomputer sciencetechnical reportFine-Grain Compilation for Pipelined Machinestechnical report