Skip to content

Latest commit

 

History

History
66 lines (47 loc) · 2.04 KB

README.md

File metadata and controls

66 lines (47 loc) · 2.04 KB

Scalable and Practical Locking with Shuffling

Paper

Overview

ShflLocks are a family of locking protocols that implement use shuffling mechanism to implement several policies, such as NUMA-awareness, or blocking. We implement three locking protocols: NUMA-aware spinlock, NUMA-aware blocking mutex, and NUMA-aware blocking rwlock.

ShflLock for the kernel(klocks) is provided under the terms of GNU General Public License v2, and the user library(ulocks) is released under the terms of MIT license. Please see the LICENSE files in each directory.

ShflLocks in kerenelspace

To test locks in the kernelspace, use a patch in the klocks folder. The patch is written on top of linux v4.19

  • Please checkout the Linux v4.19-rc4 version of the Linux kernel
  $ git clone --branch v4.19-rc4 https://github.com/torvalds/linux
  $ cd linux
  • Use monkey patching to apply these patches for running Linux with different versions.
  $ patch -p1 < <path-to-path>

ShflLocks in userspace

We extend the Litl framework (ulocks) and use the LD_PRELOAD for usersapce benchmarks.

Supported algorithms

Name Ref Waiting Policy Supported Name in the Paper [LOC] Notes and acknowledgments
AQS [NUMA-MCS] original (spin) non-block shfllock ShflLock paper
AQS-WO-NODE [NUMA-MCS] spin non-block shfllock wo node ShflLock paper
AQM [NUMA-MUT] spin_then_park blocking shfllock ShflLock paper
AQM-WO-NODE [NUMA-MUT] spin_then_park blocking shfllock wo node ShflLock paper

How to run

Compile the Litl framework as follows:

make -C ulocks

If you want to use non-blocking ShflLock, do the following:

./libaqs_spinlock.sh my_program

You can find more details in ulocks/README.md.

Contact