English

Persistent Memory Objects: Fast and Easy Crash Consistency for Persistent Memory

Operating Systems 2022-04-08 v1

Abstract

DIMM-compatible persistent memory unites memory and storage. Prior works utilize persistent memory either by combining the filesystem with direct access on memory mapped files or by managing it as a collection of objects while abolishing the POSIX abstraction. In contrast, we propose retaining the POSIX abstraction and extending it to provide support for persistent memory, using Persistent Memory Objects (PMOs). In this work, we design and implement PMOs, a crash-consistent abstraction for managing persistent memory. We introduce psync, a single system call, that a programmer can use to specify crash consistency points in their code, without needing to orchestrate durability explicitly. When rendering data crash consistent, our design incurs a overhead of 25%\approx 25\% and 21%\approx 21\% for parallel workloads and FileBench, respectively, compared to a system without crash consistency. Compared to NOVA-Fortis, our design provides a speedup of 1.67×\approx 1.67\times and 3×\approx 3\times for the two set of benchmarks, respectively.

Keywords

Cite

@article{arxiv.2204.03289,
  title  = {Persistent Memory Objects: Fast and Easy Crash Consistency for Persistent Memory},
  author = {Derrick Greenspan and Naveed Ul Mustafa and Zoran Kolega and Mark Heinrich and Yan Solihin},
  journal= {arXiv preprint arXiv:2204.03289},
  year   = {2022}
}

Comments

12 pages, 15 figures