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: Contribution to journalArticlepeer-review

13 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%.

Original languageEnglish
Pages (from-to)181-191
Number of pages11
JournalACM SIGPLAN Notices
Volume48
Issue number4
DOIs
StatePublished - Apr 2013

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