A Marriage of Pointer- and Epoch-Based Reclamation

Cited 0 time in webofscience Cited 0 time in scopus
  • Hit : 110
  • Download : 0
All pointer-based nonblocking concurrent data structures should deal with the problem of \emph{safe memory reclamation}: before reclaiming a memory block, a thread should ensure no other threads hold a local pointer to the block that may later be dereferenced. Various safe memory reclamation schemes have been proposed in the literature, but none of them satisfy the following desired properties at the same time: $(i)$ \emph{robust}: a non-cooperative thread does not prevent the other threads from reclaiming an unbounded number of blocks; $(ii)$ \emph{fast}: it does not incur significant time overhead; $(iii)$ \emph{compact}: it does not incur significant space overhead; $(iv)$ \emph{self-contained}: it neither relies on special hardware/OS supports nor intrusively affects execution environments; and $(v)$ \emph{widely applicable}: it supports many data structures. We introduce PEBR, which we believe is the first scheme that satisfies all the properties above. PEBR is inspired by Snowflake's hybrid design of pointer- and epoch-based reclamation schemes (PBR and EBR, resp.) that is mostly robust, fast, and compact but neither self-contained nor widely applicable. To achieve self-containedness, we design algorithms using only the standard C/C++ concurrency features and process-wide memory fence. To achieve wide applicability, we characterize PEBR's requirement for safe reclamation that is satisfied by a variety of data structures, including Harris's and Harris-Herlihy-Shavit's lists that are not supported by PBR. We experimentally evaluate whether PEBR is fast and robust using microbenchmarks, for which PEBR performs comparably to the state-of-the-art schemes.
Association for Computing Machinery
Issue Date

ACM SIGPLAN conference on Programming Languages Design and Implementation

Appears in Collection
CS-Conference Papers(학술회의논문)
Files in This Item
There are no files associated with this item.


  • mendeley


rss_1.0 rss_2.0 atom_1.0