Worst-Case Input Generation for Concurrent Programs under Non-Monotone Resource Metrics
Long Pham, Jan Hoffmann
TL;DR
This work addresses generating inputs that trigger the worst-case memory usage in concurrent programs, a problem complicated by non-monotone resource metrics and scheduling. It introduces resource-annotated session types and session skeletons to guide symbolic execution, enabling sound evaluation of high-water-mark costs and transfer of potential across processes. The authors prove soundness and relative completeness of the approach and validate it with a web server case study, showing how independent versus scheduled sessions impact memory peaks. The framework enables detecting memory-related vulnerabilities to DoS-like scenarios in concurrent systems and provides a foundation for future enhancements in handling interdependence between input/output across channels.
Abstract
Worst-case input generation aims to automatically generate inputs that exhibit the worst-case performance of programs. It has several applications, and can, for example, detect vulnerabilities to denial-of-service (DoS) attacks. However, it is non-trivial to generate worst-case inputs for concurrent programs, particularly for resources like memory where the peak cost depends on how processes are scheduled. This article presents the first sound worst-case input generation algorithm for concurrent programs under non-monotone resource metrics like memory. The key insight is to leverage resource-annotated session types and symbolic execution. Session types describe communication protocols on channels in process calculi. Equipped with resource annotations, resource-annotated session types not only encode cost bounds but also indicate how many resources can be reused and transferred between processes. This information is critical for identifying a worst-case execution path during symbolic execution. The algorithm is sound: if it returns any input, it is guaranteed to be a valid worst-case input. The algorithm is also relatively complete: as long as resource-annotated session types are sufficiently expressive and the background theory for SMT solving is decidable, a worst-case input is guaranteed to be returned. A simple case study of a web server's memory usage demonstrates the utility of the worst-case input generation algorithm.
