Supporting lock-based multiprocessor resource sharing protocols in real-time programming languages

Research output: Contribution to journalArticlepeer-review

Abstract

Lock-based resource sharing protocols for single processor systems are well understood and supported in programming languages such as Ada and the Real-Time Specification for Java, and in Real-Time Operating Systems, such as those that conform to the Real-Time POSIX standard. In contrast, multiprocessor resource sharing protocols are still in their infancy with no agreed best practices, and yet current real-time programming languages and operating systems claim to be suitable for multiprocessor applications. This paper reviews the currently available multiprocessor resource allocation policies and analyzes their applicability to the main industry standard real-time programming languages. It then proposes a framework that allows programmers to define and implement their own locking policy. A prototype implementation of the framework for Ada is presented and evaluated.
Original languageEnglish
Pages (from-to)1532-0634
JournalConcurrency and Computation: Practice and Experience
DOIs
Publication statusPublished - 20 Jun 2012

Keywords

  • real-time programming, lock-based synchronization, multiprocessor

Cite this