We present a framework for statically detecting deadlocks in a concurrent object-oriented language with asynchronous method calls and cooperative scheduling of method activations. Since this language features recursion and dynamic resource creation, deadlock detection is extremely complex and state-of-the-art solutions either give imprecise answers or do not scale. In order to augment precision and scalability, we propose a modular framework that allows several techniques to be combined. The basic component of the framework is a front-end inference algorithm that extracts abstract behavioral descriptions of methods, called contracts, which retain resource dependency information. This component is integrated with a number of possible different back-ends that analyze contracts and derive deadlock information. As a proof-of-concept, we discuss two such back-ends: (1) an evaluator that computes a fixpoint semantics and (2) an evaluator using abstract model checking.

Giachino, E., Laneve, C., Lienhardt, M. (2016). A framework for deadlock detection in core ABS. SOFTWARE AND SYSTEMS MODELING, 15(4), 1013-1048 [10.1007/s10270-014-0444-y].

A framework for deadlock detection in core ABS

GIACHINO, ELENA
;
LANEVE, COSIMO;LIENHARDT, MICHAEL
2016

Abstract

We present a framework for statically detecting deadlocks in a concurrent object-oriented language with asynchronous method calls and cooperative scheduling of method activations. Since this language features recursion and dynamic resource creation, deadlock detection is extremely complex and state-of-the-art solutions either give imprecise answers or do not scale. In order to augment precision and scalability, we propose a modular framework that allows several techniques to be combined. The basic component of the framework is a front-end inference algorithm that extracts abstract behavioral descriptions of methods, called contracts, which retain resource dependency information. This component is integrated with a number of possible different back-ends that analyze contracts and derive deadlock information. As a proof-of-concept, we discuss two such back-ends: (1) an evaluator that computes a fixpoint semantics and (2) an evaluator using abstract model checking.
2016
Giachino, E., Laneve, C., Lienhardt, M. (2016). A framework for deadlock detection in core ABS. SOFTWARE AND SYSTEMS MODELING, 15(4), 1013-1048 [10.1007/s10270-014-0444-y].
Giachino, Elena; Laneve, Cosimo; Lienhardt, Michael
File in questo prodotto:
File Dimensione Formato  
Giachino2016_Article_AFrameworkForDeadlockDetection.pdf

accesso riservato

Tipo: Versione (PDF) editoriale
Licenza: Licenza per accesso riservato
Dimensione 2.2 MB
Formato Adobe PDF
2.2 MB Adobe PDF   Visualizza/Apri   Contatta l'autore
SoSyM-Giachino-Laneve-Lienhardt.pdf

accesso aperto

Tipo: Postprint
Licenza: Licenza per accesso libero gratuito
Dimensione 803.97 kB
Formato Adobe PDF
803.97 kB Adobe PDF Visualizza/Apri

I documenti in IRIS sono protetti da copyright e tutti i diritti sono riservati, salvo diversa indicazione.

Utilizza questo identificativo per citare o creare un link a questo documento: https://hdl.handle.net/11585/588172
Citazioni
  • ???jsp.display-item.citation.pmc??? ND
  • Scopus 38
  • ???jsp.display-item.citation.isi??? 19
social impact