Non-termination Proving at Scale

被引:0
|
作者
Raad, Azalea [1 ,2 ]
Vanegue, Julien [1 ,2 ]
O'Hearn, Peter [3 ]
机构
[1] Imperial Coll London, London, ON, Canada
[2] Bloomberg, New York, NY 10022 USA
[3] UCL, London, England
来源
基金
英国工程与自然科学研究理事会;
关键词
Divergence; non-termination; under-approximation; incorrectness logic;
D O I
10.1145/3689720
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
Program termination is a classic non-safety property whose falsification cannot in general be witnessed by a finite trace. This makes testing for non-termination challenging, and also a natural target for symbolic proof. Several works in the literature apply non-termination proving to small, self-contained benchmarks, but it has not been developed for large, real-world projects; as such, despite its allure, non-termination proving has had limited practical impact. We develop a compositional theory for non-termination proving, paving the way for its scalable application to large codebases. Discovering non-termination is an under-approximate problem, and we present UNTER, a sound and complete under-approximate logic for proving non-termination. We then extend UNTER with separation logic and develop UNTERSL for heap-manipulating programs, yielding a compositional proof method amenable to automation via under-approximation and bi-abduction. We extend the Pulse analyser from Meta and develop Pulse(infinity), an automated, compositional prover for non-termination based on UNTERSL. We have run Pulse(infinity) on large codebases and libraries, each comprising hundreds of thousands of lines of code, including OpenSSL, libxml2, libxpm and CryptoPP; we discovered several previously-unknown non-termination bugs and have reported them to developers of these libraries.
引用
收藏
页数:29
相关论文
共 50 条