XRCU is a library that provides efficient lock-less synchronization for read-mostly tasks and structures.

Luciano Lo Giudice a98f1f7caa Simplify access to hash table vector 3 lat temu
docs f806512122 Fix doc and make 'ctz' inline in non-gcc builds 4 lat temu
tests f8171d4b0a Harden tests 4 lat temu
.gitignore b36a901ab3 Ignore test binary 5 lat temu
Changes 0954bec884 Add version 5 lat temu
LICENSE b3e6bf1eac Update README and add LICENSE 6 lat temu
Makefile 195c70bfb0 Support the mingw toolchain 4 lat temu
README.md b809c18cc8 Fix typo 3 lat temu
VERSION 0954bec884 Add version 5 lat temu
configure 43b1edd822 Clean up configure script 5 lat temu
hash_table.cpp 7c46983d3f Fix several typos 4 lat temu
hash_table.hpp a98f1f7caa Simplify access to hash table vector 3 lat temu
lwlock.cpp 7c46983d3f Fix several typos 4 lat temu
lwlock.hpp 7c46983d3f Fix several typos 4 lat temu
optional.hpp 7c46983d3f Fix several typos 4 lat temu
queue.cpp 7c46983d3f Fix several typos 4 lat temu
queue.hpp a38b91c34e Fix data race in queue::pop 3 lat temu
skip_list.cpp 22b8f72937 Move common code outside template class 3 lat temu
skip_list.hpp 30cd316b15 Remove redundant fields and functions 3 lat temu
stack.cpp 7c46983d3f Fix several typos 4 lat temu
stack.hpp 7c46983d3f Fix several typos 4 lat temu
utils.cpp 7c46983d3f Fix several typos 4 lat temu
utils.hpp 7c46983d3f Fix several typos 4 lat temu
version.hpp 0954bec884 Add version 5 lat temu
xatomic.hpp 7c46983d3f Fix several typos 4 lat temu
xrcu.cpp 7c46983d3f Fix several typos 4 lat temu
xrcu.hpp f806512122 Fix doc and make 'ctz' inline in non-gcc builds 4 lat temu

README.md

XRCU

This library implements efficient lockless synchronization for read-mostly tasks. In addition, it provides several data lockless data structures that make use of said synchronization, with an API that closely resembles the one used in C++'s STL. These data structures include: stacks, queues (multiple producer, multiple consumer), skip lists and hash tables.

Installation

As with most GNU packages, xrcu follows a very simple convention:

./configure
make
make install

Usage

Even though the data structures are generic and thus implemented almost completely in single headers, there's still the need to link with this library (-lxrcu) to pull the runtime.

Documentation

See docs/xrcu.html for a full overview of the design and its API.

Authors

Luciano Lo Giudice

Agustina Arzille

License

Licensed under the GPLv3.