Random access memory (RAM) is tightly constrained in the least expensive, lowest-power embedded systems such as sensor network nodes and portable consumer electronics. The most widely used sensor network nodes have only 4 to 10KB of RAM and do not contain memory management units (MMUs). It is difficult to implement complex applications under such tight memory constraints. Nonetheless, price and power-consumption constraints make it unlikely that increases in RAM in these systems will keep pace with the increasing memory requirements of applications.We propose the use of automated compile-time and runtime techniques to increase the amount of usable memory in MMU-less embedded systems. The proposed techniques do not increase hardware cost, and require few or no changes to existing applications. We have developed runtime library routines and compiler transformations to control and optimize the automatic migration of application data between compressed and uncompressed memory regions, as well as a fast compression algorithm well suited to this application. These techniques were experimentally evaluated on Crossbow TelosB sensor network nodes running a number of data-collection and signal-processing applications. Our results indicate that available memory can be increased by up to 50% with less than 10% performance degradation for most benchmarks.
"MEMMU: Memory expansion for MMU-less embedded systems"
Lan S. Bai, Lei Yang, and Robert P. Dick
Proceedings of the ACM Transactions on Embedded Computing Systems (TECS) , New York, NY, April 2009.
@article{1509295, author = {Bai, Lan S. and Yang, Lei and Dick, Robert P.}, title = {MEMMU: Memory expansion for MMU-less embedded systems}, journal = {ACM Trans. Embed. Comput. Syst.}, volume = {8}, number = {3}, year = {2009}, issn = {1539-9087}, pages = {1--33}, doi = {http://doi.acm.org/10.1145/1509288.1509295}, publisher = {ACM}, address = {New York, NY, USA}, }