Brief announcement: a generic construction for nonblocking dual containers

J Izraelevitz, ML Scott - Proceedings of the 2014 ACM symposium on …, 2014 - dl.acm.org
Proceedings of the 2014 ACM symposium on Principles of distributed computing, 2014dl.acm.org
A dual container has the property that when it is empty, the remove method will insert an
explicit reservation (antidata) into the container, rather than returning an error flag. This
convention gives the container explicit control over the order in which pending requests will
be satisfied once data becomes available. The dual pattern also allows the method's caller
to spin on a thread-local flag, avoiding memory contention. In this paper we introduce a new
nonblocking construction that allows any nonblocking container for data to be paired with …
A dual container has the property that when it is empty, the remove method will insert an explicit reservation (antidata) into the container, rather than returning an error flag. This convention gives the container explicit control over the order in which pending requests will be satisfied once data becomes available. The dual pattern also allows the method's caller to spin on a thread-local flag, avoiding memory contention. In this paper we introduce a new nonblocking construction that allows any nonblocking container for data to be paired with almost any nonblocking container for antidata. This construction provides a composite ordering discipline - e.g., it can satisfy pending pops from a stack in FIFO order, or satisfy pending dequeues in order of thread priority.
ACM Digital Library