Electronic Proceedings in Theoretical Computer Science (Feb 2010)

Type Inference for Deadlock Detection in a Multithreaded Polymorphic Typed Assembly Language

  • Vasco T. Vasconcelos,
  • Francisco Martins,
  • Tiago Cogumbreiro

DOI
https://doi.org/10.4204/EPTCS.17.8
Journal volume & issue
Vol. 17, no. Proc. PLACES 2009
pp. 95 – 109

Abstract

Read online

We previously developed a polymorphic type system and a type checker for a multithreaded lock-based polymorphic typed assembly language (MIL) that ensures that well-typed programs do not encounter race conditions. This paper extends such work by taking into consideration deadlocks. The extended type system verifies that locks are acquired in the proper order. Towards this end we require a language with annotations that specify the locking order. Rather than asking the programmer (or the compiler's backend) to specifically annotate each newly introduced lock, we present an algorithm to infer the annotations. The result is a type checker whose input language is non-decorated as before, but that further checks that programs are exempt from deadlocks.