Minimize Your Critical Path with Combine-and-Exchange Locks
By: Simon König, Lukas Epple, Christian Becker
Potential Business Impact:
Makes computer programs run much faster.
Coroutines are experiencing a renaissance as many modern programming languages support the use of cooperative multitasking for highly parallel or asynchronous applications. One of the greatest advantages of this is that concurrency and synchronization is manged entirely in the userspace, omitting heavy-weight system calls. However, we find that state-of-the-art userspace synchronization primitives approach synchronization in the userspace from the perspective of kernel-level scheduling. This introduces unnecessary delays on the critical path of the application, limiting throughput. In this paper, we re-think synchronization for tasks that are scheduled entirely in the userspace (e.g., coroutines, fibers, etc.). We develop Combine-and-Exchange Scheduling (CES), a novel scheduling approach that ensures contended critical sections stay on the same thread of execution while parallelizable work is evenly spread across the remaining threads. We show that our approach can be applied to many existing languages and libraries, resulting in 3-fold performance improvements in application benchmarks as well as 8-fold performance improvements in microbenchmarks.
Similar Papers
Basic Lock Algorithms in Lightweight Thread Environments
Distributed, Parallel, and Cluster Computing
Makes computer programs run faster and smoother.
Concurrency Testing in the Linux Kernel via eBPF
Operating Systems
Finds hidden computer bugs faster and easier.
Resolving Conflicts with Grace: Dynamically Concurrent Universality
Distributed, Parallel, and Cluster Computing
Lets computers work together faster without getting stuck.