Verification of Erlang programs using abstract interpretation and model checking

被引:18
|
作者
Huch, F [1 ]
机构
[1] Rhein Westfal TH Aachen, Lehrstuhl Informat 2, D-52056 Aachen, Germany
关键词
abstract interpretation; verification; model checking; Erlang; distributed system;
D O I
10.1145/317765.317908
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
We present an approach for the verification of Erlang programs using abstract interpretation and model checking. In general model checking for temporal logics like LTL and Erlang programs is undecidable. Therefore we define a framework for abstract interpretations for a core fragment of Erlang. In this framework it is guaranteed, that the abstract operational semantics preserves all paths of the standard operational semantics. We consider properties that have to hold on all paths of a system, like properties in LTL. If these properties can be proved for the abstract operational semantics, they also hold for the Erlang program. They can be proved with model checking if the abstract operational semantics is a finite transition system. Therefore we introduce a example abstract interpretation, which has this property. We have implemented this approach as a prototype and were able to prove properties like mutual exclusion or the absence of deadlocks and lifelocks for some Erlang programs.
引用
收藏
页码:261 / 272
页数:12
相关论文
共 50 条