Soft-OLP: Improving Hardware Cache Performance Through Software-Controlled Object-Level Partitioning

被引:30
|
作者
Lu, Qingda [1 ]
Lin, Jiang [2 ]
Ding, Xiaoning [1 ]
Zhang, Zhao [2 ]
Zhang, Xiaodong [1 ]
Sadayappan, P. [1 ]
机构
[1] Ohio State Univ, Dept Comp Sci & Engn, Columbus, OH 43210 USA
[2] Iowa State Univ, Ames, IA USA
基金
美国国家科学基金会;
关键词
Cache Partitioning; Software-Controlled Caching; Reuse Distance; Page Coloring;
D O I
10.1109/PACT.2009.35
中图分类号
TP3 [计算技术、计算机技术];
学科分类号
0812 ;
摘要
Performance degradation of memory-intensive programs caused by the LRU policy's inability to handle weak-locality data accesses in the last level cache is increasingly serious for two reasons. First, the last-level cache remains in the CPU's critical path, where only simple management mechanisms, such as LRU, can be used, precluding some sophisticated hardware mechanisms to address the problem. Second, the commonly used shared cache structure of multi-core processors has made this critical path even more performance-sensitive due to intensive inter-thread contention for shared cache resources. Researchers have recently made efforts to address the problem with the LRU policy by partitioning the cache using hardware or OS facilities guided by run-time locality information. Such approaches often rely on special hardware support or lack enough accuracy. In contrast, for a large class of programs, the locality information can be accurately predicted if access patterns are recognized through small training runs at the data object level. To achieve this goal, we present a system-software framework referred to as Soft-OLP (Software-based Object-Level cache Partitioning). We first collect per-object reuse distance histograms and inter-object interference histograms via memory-trace sampling. With several low-cost training runs, we are able to determine the locality patterns of data objects. For the actual runs, we categorize data objects into different locality types and partition the cache space among data objects with a heuristic algorithm, in order to reduce cache misses through segregation of contending objects. The object-level cache partitioning framework has been implemented with a modified Linux kernel, and tested on a commodity multi-core processor. Experimental results show that in comparison with a standard L2 cache managed by LRU, Soft-OLP significantly reduces the execution time by reducing L2 cache misses across inputs for a set of single- and multi-threaded programs from the SPEC CPU2000 benchmark suite, NAS benchmarks and a computational kernel set.
引用
收藏
页码:246 / +
页数:2
相关论文
共 3 条
  • [1] Improving Performance in VLIW Soft-core Processors through Software-controlled ScratchPads
    Jost, Tiago
    Nazar, Gabriel
    Carro, Luigi
    PROCEEDINGS OF 2016 INTERNATIONAL CONFERENCE ON EMBEDDED COMPUTER SYSTEMS: ARCHITECTURES, MODELING AND SIMULATION (SAMOS), 2016, : 172 - 179
  • [2] Improving the reliability of object-oriented software through object-level behavioral simulation
    Deshpande, M
    Coyle, F
    Tian, J
    RELIABLE SOFTWARE TECHNOLOGIES ADA-EUROPE 2000, 2000, 1845 : 266 - 279
  • [3] Improving Performance through Path-Based Hardware/Software Partitioning
    Azari, Elham
    Koc, Hakduran
    2015 FIFTH INTERNATIONAL CONFERENCE ON DIGITAL INFORMATION PROCESSING AND COMMUNICATIONS (ICDIPC), 2015, : 54 - 59