Software architectural transformations: a new approach to low energy embedded software
- 22 December 2003
- conference paper
- conference paper
- Published by Institute of Electrical and Electronics Engineers (IEEE) in 2003 Design, Automation and Test in Europe Conference and Exhibition
- p. 1046-1051
- https://doi.org/10.1109/date.2003.1253742
Abstract
Previous work on software optimization for low energy has focussed on instruction-level optimizations and compiler techniques. We argue, and demonstrate, that significant energy savings could be "left on the table" if energy is not considered during the design of the software architecture. As a first step towards addressing this gap, we propose a systematic framework for software architectural transformations to reduce energy consumption. We consider software architectural transformations in the context of the multi-process software style driven by an operating system (OS), which is very commonly employed in energy-sensitive embedded systems. Our methodology for applying software architectural transformations consists of: (i) constructing a software architecture graph representation, (ii) deriving initial energy and performance statistics using a detailed energy simulation framework, (iii) constructing sequences of atomic software architectural transformations, guided by energy change estimates derived from high-level energy macro-models, that result in maximal energy reduction, and (iv) generation of program source code to reflect the optimized software architecture. We employ a wide suite of software architectural transformations whose effects span the application-OS boundary, including how the program functionality is structured into architectural components (e.g., application processes, signal handlers, and device drivers), and connectors between them (inter- component synchronization and communication mechanisms). We present experimental results on several multi-process embedded software programs, in the context of an embedded system that features the Intel StrongARM processor and the embedded Linux OS. The presented results clearly underscore the potential of the proposed methodology (up to 66.1% reduction in energy is obtained). In a broader sense, our work demonstrates the impact of considering energy during the earlier stages of the software design process.Keywords
This publication has 11 references indexed in Scilit:
- Embedded operating system energy analysis and macro-modelingPublished by Institute of Electrical and Electronics Engineers (IEEE) ,2003
- EMSIM: an energy simulation framework for an embedded operating systemPublished by Institute of Electrical and Electronics Engineers (IEEE) ,2003
- Software architectural transformationPublished by Institute of Electrical and Electronics Engineers (IEEE) ,2003
- The benefits of eventPublished by Association for Computing Machinery (ACM) ,2000
- Quantifying the energy consumption of a pocket computer and a Java virtual machinePublished by Association for Computing Machinery (ACM) ,2000
- Operating-system directed power reductionPublished by Association for Computing Machinery (ACM) ,2000
- Energy-aware adaptation for mobile applicationsPublished by Association for Computing Machinery (ACM) ,1999
- Software strategies for portable computer energy managementIEEE Wireless Communications, 1998
- High-Level Power Analysis and OptimizationPublished by Springer Science and Business Media LLC ,1998
- Low Power Design MethodologiesPublished by Springer Science and Business Media LLC ,1996