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

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.