Register allocation deconstructed.

SCOPES '09: Proceedings of th 12th International Workshop on Software and Compilers for Embedded Systems(2009)

引用 9|浏览6
暂无评分
摘要
Register allocation is a fundamental part of any optimizing compiler. Effectively managing the limited register resources of the constrained architectures commonly found in embedded systems is essential in order to maximize code quality. In this paper we deconstruct the register allocation problem into distinct components: coalescing, spilling, move insertion, and assignment. Using an optimal register allocation framework, we empirically evaluate the importance of each of the components, the impact of component integration, and the effectiveness of existing heuristics. We evaluate code quality both in terms of code performance and code size and consider four distinct instruction set architectures: ARM, Thumb, x86, and x86-64. The results of our investigation reveal general principles for register allocation design.
更多
查看译文
关键词
code quality,limited register resource,optimal register allocation framework,register allocation,register allocation design,register allocation problem,code performance,code size,distinct component,distinct instruction set architecture
AI 理解论文
溯源树
样例
生成溯源树,研究论文发展脉络
Chat Paper
正在生成论文摘要