Modeling concurrency in parallel debugging
- 1 February 1990
- journal article
- Published by Association for Computing Machinery (ACM) in ACM SIGPLAN Notices
- Vol. 25 (3) , 11-20
- https://doi.org/10.1145/99164.99166
Abstract
We propose a debugging language, Data Path Expressions (DPEs), for modeling the behavior of parallel programs. The debugging paradigm is for the programmer to describe the expected program behavior and for the debugger to compare the actual program behavior during execution to detect program errors. We classify DPEs into five subclasses according to syntactic criteria, and characterize their semantics in terms of a hierarchy of extended Petri Net models. The characterization demonstrates the power of DPEs for modeling parallelism. We present predecessor automata as a mechanism for implementing the third subclass of DPEs, which expresses bounded parallelism. Predecessor automata extend finite state automata to provide efficient event recognizers for parallel debugging. We briefly describe the application of DPEs to race conditions, deadlock and starvation.This publication has 9 references indexed in Scilit:
- The specification of process synchronization by path expressionsPublished by Springer Nature ,2005
- Data path debugging: data-oriented debugging for a concurrent programming languageACM SIGPLAN Notices, 1988
- Debugging heterogeneous distributed systems using event-based models of behaviorACM SIGPLAN Notices, 1988
- Machine-independent virtual memory management for paged uniprocessor and multiprocessor architecturesPublished by Association for Computing Machinery (ACM) ,1987
- A Calculus of Communicating SystemsLecture Notes in Computer Science, 1980
- UNIX Time-Sharing System: Language Development ToolsBell System Technical Journal, 1978
- Time, clocks, and the ordering of events in a distributed systemCommunications of the ACM, 1978
- System DeadlocksACM Computing Surveys, 1971
- Semantics of context-free languagesTheory of Computing Systems, 1968