Regularities considered harmful: Forcing randomness to memory accesses to reduce row buffer conflicts for multi-core, multi-bank systems

Heekwon Park, Seungjae Baek, Jongmoo Choi, Donghee Lee, Sam H. Noh

Research output: Chapter in Book/Report/Conference proceedingConference contributionpeer-review

22 Scopus citations

Abstract

We propose a novel kernel-level memory allocator, called M3 (Mcube, Multi-core Multi-bank Memory allocator), that has the following two features. First, it introduces and makes use of a notion of a memory container, which is defined as a unit of memory that comprises the minimum number of page frames that can cover all the banks of the memory organization, by exclusively assigning a container to a core so that each core achieves bank parallelism as much as possible. Second, it orchestrates page frame allocation so that pages that threads access are dispersed randomly across multiple banks so that each thread's access pattern is randomized. The development of M3 is based on a tool that we develop to fully understand the architectural characteristics of the underlying memory organization. Using an extension of this tool, we observe that the same application that accesses pages in a random manner outperforms one that accesses pages in a regular pattern such as sequential or same ordered accesses. This is because such randomized accesses reduces inter-thread access interference on the rowbuffer in memory banks. We implement M3 in the Linux kernel version 2.6.32 on the Intel Xeon system that has 16 cores and 32GB DRAM. Performance evaluation with various workloads show that M3 improves the overall performance for memory intensive benchmarks by up to 85% with an average of about 40%. Categories and Subject Descriptors B.3.1 [Memory Structures]: Semiconductor Memories-Dynamic memory (DRAM); D.4.2 [Operating Systems]: Storage Management-Allocation/deallocation strategies; D.4.2 [Operating Systems]: Storage Management-Main memory; D.4.8 [Operating Systems]: Performance- Measurements General Terms Algorithms, Design, Experimentation, Measurement, Performance.

Original languageEnglish
Title of host publicationASPLOS 2013 - 18th International Conference on Architectural Support for Programming Languages and Operating Systems
Pages181-191
Number of pages11
DOIs
StatePublished - 2013
Event18th International Conference on Architectural Support for Programming Languages and Operating Systems, ASPLOS 2013 - Houston, TX, United States
Duration: 16 Mar 201320 Mar 2013

Publication series

NameInternational Conference on Architectural Support for Programming Languages and Operating Systems - ASPLOS

Conference

Conference18th International Conference on Architectural Support for Programming Languages and Operating Systems, ASPLOS 2013
Country/TerritoryUnited States
CityHouston, TX
Period16/03/1320/03/13

Keywords

  • Analysis tool
  • Memory container
  • Memory management
  • Randomized algorithm
  • Row-buffer conflict

Fingerprint

Dive into the research topics of 'Regularities considered harmful: Forcing randomness to memory accesses to reduce row buffer conflicts for multi-core, multi-bank systems'. Together they form a unique fingerprint.

Cite this