Summary In this article, we present mutable locks, a synchronization construct with the same semantic of traditional locks (such as spin locks or sleep locks), but with a self-tuned optimized trade-off between responsiveness and CPU-time usage during threads' wait phases. Mutable locks tackle the need for efficient synchronization supports in the era of multicore machines, where the run-time performance should be optimized while reducing resource usage. This goal should be achieved with no intervention by the programmers. Our proposal is intended for exploitation in generic concurrent applications, where scarce or no knowledge is available about the underlying software/hardware stack and the workload. This is an adverse scenario for static choices between spinning and sleeping, which is tackled by our mutable locks thanks to their hybrid waiting phase and self-tuning capabilities.
2020, CONCURRENCY AND COMPUTATION, Pages -
Mutable locks: Combining the best of spin and sleep locks (01a Articolo in rivista)
Marotta Romolo, Tiriticco Davide, Di Sanzo Pierangelo, Pellegrini Alessandro, Ciciani Bruno, Quaglia Francesco