Libfork: portable continuation-stealing with stackless coroutines
Conor John Williams, James Elliott
TL;DR
This work addresses the challenge of achieving fully-strict fork-join parallelism with bounded memory in shared-memory systems without compiler modifications. It introduces Libfork, a portable C++20 stackless-coroutines-based library that maps fork-join operations to continuation-stealing tasks using segmented stacks and NUMA-aware, lock-free schedulers. Theoretical bounds are derived for memory and time scaling, and extensive benchmarks show Libfork delivering substantial speedups (up to $7.5\times$ vs TBB and $24\times$ vs OpenMP) while using far less memory, across classical SFJ tests and UTS benchmarks. The results motivate the practical value of coroutine-based continuation stealing and set the stage for further optimizations, including HALO-like heap-elision and improved resource management.
Abstract
Fully-strict fork-join parallelism is a powerful model for shared-memory programming due to its optimal time scaling and strong bounds on memory scaling. The latter is rarely achieved due to the difficulty of implementing continuation stealing in traditional High Performance Computing (HPC) languages -- where it is often impossible without modifying the compiler or resorting to non-portable techniques. We demonstrate how stackless coroutines (a new feature in C++20) can enable fully-portable continuation stealing and present libfork a lock-free fine-grained parallelism library, combining coroutines with user-space, geometric segmented-stacks. We show our approach is able to achieve optimal time/memory scaling, both theoretically and empirically, across a variety of benchmarks. Compared to openMP (libomp), libfork is on average 7.2x faster and consumes 10x less memory. Similarly, compared to Intel's TBB, libfork is on average 2.7x faster and consumes 6.2x less memory. Additionally, we introduce non-uniform memory access (NUMA) optimizations for schedulers that demonstrate performance matching busy-waiting schedulers.
