This repository contains companion code for the following paper:
Shinhyung Yang, Seongho Jeong, Byunguk Min, Yeonsoo Kim, Bernd Burgstaller, and Johann Blieberger.
Design-space evaluation for non-blocking synchronization in Ada:
lock elision of protected objects, concurrent objects, and low-level atomics.
Journal of Systems Architecture 110:101764, Elsevier, Nov. 2020.
[pdf] (open access)
If you use this code, please cite the paper using the below BibTeX reference.
@article{shmsync,
title = {Design-space evaluation for non-blocking synchronization in {Ada}:
lock elision of protected objects, concurrent objects, and
low-level atomics},
author = {Shinhyung Yang and Seongho Jeong and Byunguk Min and Yeonsoo Kim
and Bernd Burgstaller and Johann Blieberger},
journal = "Journal of Systems Architecture",
volume = "110",
pages = "101764",
year = "2020",
issn = "1383-7621",
doi = "https://doi.org/10.1016/j.sysarc.2020.101764",
}
shm_sync is a synchronization benchmark suite for shared-memory multicore architectures. In contrast to prior work, it provides relaxations to determine the performance overhead incurred by a sequentially consistent high-level language memory model.
- Feb 10, 2020: GitHub repository created
- Nov 24, 2020: Added link to published paper
Please refer to the top-level CMakeLists.txt file for the configuration options of shm_sync. The list of prerequisites assumes a full build of both the Ada and C++ benchmarks. The shm_sync benchmarks require a Linux system with the following software packages installed (stated versions are known to work and represent the minimum for GCC and CMake).
shm_sync is a CMake-based project. To build the project, move to project root and follow the instructions below. The name of the build directory decides between debug and release builds.
To build the benchmarks in debug mode:
$ mkdir build_dbg
$ cd build_dbg
$ cmake ..
$ make
To build the benchmarks in release mode:
$ mkdir build_rel
$ cd build_rel
$ cmake ..
$ make
To use Likwid for running benchmarks:
$ cmake -DLIKWID_ROOT=/opt/likwid/4.3.4 ..
The benchmark suite supports 16-byte (double-word) atomic load, atomic store, and compare-and-swap. Benchmarks using 16-byte atomic operations tend to be considerbly slower than their 8-byte counterparts. In our experiments, this was e.g., noticeable with the AdaLockFree benchmark.
To build with 16-byte atomic operations enabled:
$ cmake -DBUILD_DWATOMIC=ON ..
In scripts/run
:
$ python3 ./run.py TATASLock
# Run with detailed benchmark settings (settings.py)
$ python3 ./run.py TATASLock --threads 28 --executions 100 --iterations 10M
To run benchmark with scaling run from (1..t) threads:
$ python3 ./run.py TATASLock --threads 28 --executions 100 --iterations 10M -r
To run benchmark with scaling run from (1..t) threads and to view overview only:
$ python3 ./run.py TATASLock --threads 28 --executions 100 --iterations 10M -r -o
To run lock benchmark with busy loop lasting for 30 nsec inside critical section (-u) and busy loop lasting for 50 nsec outside critical section (-y):
$ python3 ./run.py TATASLock --threads 28 --executions 100 --iterations 10M -r -o -u 30 -y 50
Benchmark profiling data files are stored under the data folder in the following subdirectory scheme:
[PROJECT_ROOT]/data/[datetime]/[benchmark_name]/[binary_name]
For example:
shm_sync_latest/data/April30_2019_10:15:22/TASLock
To get statistics and R-plots measuring ExecutionTime and Throughput, go to
scripts/run
and run Drawing.py:
$ python3 ./Drawing.py ../../data/[datetime]/[benchmark_name] -t [number_of_threads] -i [number_of_iterations]
For example, to plot given sample_ArrayLock.txt:
$ python3 ./Drawing.py sample_ArrayLock.txt -t 28 -i 10000000
To plot given sample_ArrayLock.txt and sample_CLHQueueLock.txt separately with single operation:
$ python3 ./Drawing.py sample_ArrayLock.txt sample_CLHQueueLock.txt -t 28 14 -i 10000000 10000
Result Plot
To plot given sample_ArrayLock.txt and sample_TATASLock.txt into a single figure, use "-c" flag. But their [number_of_threads] for -t and [number_of_iterations] for -i should be same.
$ python3 ./Drawing.py sample_ArrayLock.txt sample_TATASLock.txt -t 28 14 -i 10000000 -c
Result plot
If cmake cannot locate the Boost library, add the library's root path to the cmake command line:
# version and path of Boost may vary
$ cmake -DBOOST_ROOT=/opt/boost/1.69.0 ..
Please email Bernd Burgstaller at [email protected] and include [shm_sync] in the subject line.
Shinhyung Yang
Seongho Jeong
Byunguk Min
Yeonsoo Kim
Bernd Burgstaller
Johann Blieberger
The shm_sync benchmarks are open source software distributed under the license agreement found in LICENSE.txt.
This work was supported by the Austrian Science Fund (FWF) project I 1035N23, and by the Next-Generation Information Computing Development Program through the National Research Foundation of Korea (NRF), funded by the Ministry of Science, ICT & Future Planning under grant NRF-2015-M3C4A-7065522.