Remove support for 'standalone' rseq registration

Depend on libc to handle the allocation and registration of the rseq
area for the whole process.

Librseq can still be built and run with a libc that lacks the rseq
symbols as it doesn't link on them directly but it will not handle the
registration even if the syscall is available.

User visible changes:

  * Removes per-thread registration API, with libc the registration is
    either enabled for all threads or none.

Change-Id: Ib0cb9aa8ccc8c8786ed0fdd2a50cebe23e4fb1b1
Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
9 files changed
tree: a05337ccced5c6be82fe280419be929526e1f2a4
  1. doc/
  2. include/
  3. LICENSES/
  4. m4/
  5. src/
  6. tests/
  7. .gitignore
  8. .gitreview
  9. bootstrap
  10. configure.ac
  11. LICENSE
  12. Makefile.am
  13. README.md
README.md

Library for Restartable Sequences

by Mathieu Desnoyers

Required and optional dependencies

The following dependencies are optional:

  • libnuma To build without this dependency run ./configure with --disable-numa
  • libseccomp

Building

Prerequisites

This source tree is based on the Autotools suite from GNU to simplify portability. Here are some things you should have on your system in order to compile the Git repository tree:

  • GNU Autotools (Automake >= 1.12, Autoconf >= 2.69, Autoheader >= 2.69; make sure your system-wide automake points to a recent version!)
  • GNU Libtool >= 2.2
  • GNU Make
  • pkg-config
  • Linux kernel headers from kernel >= 4.18 to build on x86, arm, ppc, and mips and from kernel >= 4.19 to build on s390.

Building steps

If you get the tree from the Git repository, you will need to run

./bootstrap

in its root. It calls all the GNU tools needed to prepare the tree configuration.

To build and install, do:

./configure
make
sudo make install
sudo ldconfig

Note: the configure script sets /usr/local as the default prefix for files it installs. However, this path is not part of most distributions' default library path, which will cause builds depending on librseq to fail unless -L/usr/local/lib is added to LDFLAGS. You may provide a custom prefix to configure by using the --prefix switch (e.g., --prefix=/usr).

Building against a local version of the kernel headers

cd /path/to/kernel/sources
make headers_install
cd /path/to/librseq
CPPFLAGS=-I/path/to/kernel/sources/usr/include ./configure
make
sudo make install
sudo ldconfig

Running the test suite

To run the test suite after a successful build:

make check

The default list of tests to run can be overriden by the TESTS variable:

make check TESTS="run_unregistered_test.tap"