Sciweavers

CGO
2010
IEEE

Integrated instruction selection and register allocation for compact code generation exploiting freeform mixing of 16- and 32-bi

14 years 6 months ago
Integrated instruction selection and register allocation for compact code generation exploiting freeform mixing of 16- and 32-bi
For memory constrained embedded systems code size is at least as important as performance. One way of increasing code density is to exploit compact instruction formats, e.g. ARM Thumb, where the processor either operates in standard or compact instruction mode. The ARCompact ISA considered in this paper is different in that it allows freeform mixing of 16- and 32-bit instructions without a mode switch. Compact 16-bit instructions can be used anywhere in the code given that additional register constraints are satisfied. In this paper we present an integrated instruction selection and register allocation methodology and develop two approaches for mixed-mode code generation: a simple opportunistic scheme and a more advanced feedback-guided instruction selection scheme. We have implemented a code generator targeting the ARCompact ISA and evaluated its effectiveness against the ARC750D embedded processor and the EEMBC benchmark suite. On average, we achieve a code size reduction of 16.7% ...
Tobias J. K. Edler von Koch, Igor Böhm, Bj&ou
Added 16 May 2010
Updated 16 May 2010
Type Conference
Year 2010
Where CGO
Authors Tobias J. K. Edler von Koch, Igor Böhm, Björn Franke
Comments (0)