Full metadata
Title
Optimizing Heap Data Management on Software Managed Manycore Architectures
Description
Caches pose a serious limitation in scaling many-core architectures since the demand of area and power for maintaining cache coherence increases rapidly with the number of cores. Scratch-Pad Memories (SPMs) provide a cheaper and lower power alternative that can be used to build a more scalable many-core architecture. The trade-off of substituting SPMs for caches is however that the data must be explicitly managed in software. Heap management on SPM poses a major challenge due to the highly dynamic nature of of heap data access. Most existing heap management techniques implement a software caching scheme on SPM, emulating the behavior of hardware caches. The state-of-the-art heap management scheme implements a 4-way set-associative software cache on SPM for a single program running with one thread on one core. While the technique works correctly, it suffers from signifcant performance overhead. This paper presents a series of compiler-based efficient heap management approaches that reduces heap management overhead through several optimization techniques. Experimental results on benchmarks from MiBenchGuthaus et al. (2001) executed on an SMM processor modeled in gem5Binkert et al. (2011) demonstrate that our approach (implemented in llvm v3.8Lattner and Adve (2004)) can improve execution time by 80% on average compared to the previous state-of-the-art.
Date Created
2017
Contributors
- Lin, Jinn-Pean (Author)
- Shrivastava, Aviral (Thesis advisor)
- Ren, Fengbo (Committee member)
- Ogras, Umit Y. (Committee member)
- Arizona State University (Publisher)
Topical Subject
Resource Type
Extent
44 pages
Language
eng
Copyright Statement
In Copyright
Primary Member of
Peer-reviewed
No
Open Access
No
Handle
https://hdl.handle.net/2286/R.I.45507
Level of coding
minimal
Note
Masters Thesis Computer Science 2017
System Created
- 2017-10-02 07:18:50
System Modified
- 2021-08-26 09:47:01
- 3 years 2 months ago
Additional Formats