Abstract
Efficient use of multiple functional units in superscalar processors requires instruction level parallelism to be detected and exploited. Thus special hardware in the form of dispatch units is used to uncover scheduling opportunities within an instruction window at run-time. Using the superscalar PowerPC 604 as an example we show that such processors still benefit from more broadly scoped scheduling at compile time. In our approach we reuse an existing retargetable VLIW compiler environment by instantiating it for a VLIW processor whose resources and instruction timings resemble those of the PowerPC.
This paper presents the transformation of the resulting horizontal VLIW code into vertical superscalar code and gives measurements showing the improvements gained from compile time scheduling.
Chapter PDF
Keywords
These keywords were added by machine and not by the authors. This process is experimental and the keywords may be updated as the learning algorithm improves.
References
E. G. Coffman. Computer and Job-Shop Scheduling Theory. John Wiley, New York, 1976.
Alexandre E. Eichenberger, Edward S. Davidson, and Santosh G. Abraham. Minimum register requirements for a modulo schedule. In Proceedings of the 27th Annual International Symposium on Microarchitecture, pages 75–84, San Jose, California, November 30-December 2, 1994. ACM SIGMICRO and IEEE Computer Society TC-MICRO.
Chris W. Fraser and David R. Hanson. A Retargetable C Compiler: Design anc Implementation. Benjamin/Cummings Pub. Co., Redwood City, CA, USA, 1995.
Richard A. Huff. Lifetime-sensitive modulo scheduling. SIGPLAN Notices 28(6):258–267, June 1993. Proceedings of the ACM SIGPLAN '93 Conference or Programming Language Design and Implementation.
M. Lam. Software pipelining: An effective scheduing technique for VLIW machines. In Proceedings of the SIGPLAN '88 Conference on Programming Language Desigr and Implementation, pages 318–328, Atlanta, GA, June 1988.
Josep Llosa, Antonio González, Eduard Ayguadé, and Mateo Valero. Swing module scheduling: A lifetime-sensitive approach. In Proceedings of the 1996 Conference on Parallel Architectures and Compilation Techniques (PACT '96), pages 80–86, Boston, Massachusetts, October 20–23, 1996. IEEE Computer Society Press.
Motorola. PowerPC 601: RISC Microprocessor User's Manual. USA: Motorola Literature Distribution, P.O. Box 20912, Phoenix, Arizona 85036, 1994.
Motorola. PowerPC Microprocessor Family: The Programming Environments. USA: Motorola Literature Distribution, P.O. Box 20912, Phoenix, Arizona 85036, 1994.
Peter Pfahler and Georg Piepenbrock. A Comparison of Modulo Scheduling Techniques for Software Pipelining. In Proc. 6th International Conference on Compiler Construction, CC'96, volume 1060, pages 18–32. Lecture Notes in Computer Science, Springer Verlag, 1996.
Author information
Authors and Affiliations
Editor information
Rights and permissions
Copyright information
© 1998 Springer-Verlag Berlin Heidelberg
About this paper
Cite this paper
Stümpel, E., Thies, M., Kastens, U. (1998). VLIW compilation techniques for superscalar architectures. In: Koskimies, K. (eds) Compiler Construction. CC 1998. Lecture Notes in Computer Science, vol 1383. Springer, Berlin, Heidelberg. https://doi.org/10.1007/BFb0026435
Download citation
DOI: https://doi.org/10.1007/BFb0026435
Published:
Publisher Name: Springer, Berlin, Heidelberg
Print ISBN: 978-3-540-64304-3
Online ISBN: 978-3-540-69724-4
eBook Packages: Springer Book Archive