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

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.