Explaining intermittent concurrent bugs by minimizing scheduling noise

4Citations
Citations of this article
6Readers
Mendeley users who have this article in their library.
Get full text

Abstract

A noise maker is a tool for testing multi-threaded programs. It seeds shared memory accesses and synchronization events (concurrent events) with conditional context switches and timeouts during runtime, in order to increase the likelihood that a concurrent bug manifests itself. However, an instrumented program with many seeded events may not be useful for debugging; events have been seeded all over the source code and provide almost no information regarding the bug. We argue that for many bug patterns only a few relevant context switches are critical for the bug. Based on the observation that bugs involve only a small set of critical events, we develop a randomized algorithm to reduce the scheduling noise and discover these events related to the bug. To evaluate the effectiveness of our approach, we experiment with debugging of industrial code, known open source code software, and programs representing known concurrent bugs. Our results demonstrate that this simple technique is in many cases very powerful, and significantly helps the user locating and understanding concurrent bugs. © Springer-Verlag Berlin Heidelberg 2007.

Cite

CITATION STYLE

APA

Eytani, Y., & Latvala, T. (2007). Explaining intermittent concurrent bugs by minimizing scheduling noise. In Lecture Notes in Computer Science (including subseries Lecture Notes in Artificial Intelligence and Lecture Notes in Bioinformatics) (Vol. 4383 LNCS, pp. 183–197). Springer Verlag. https://doi.org/10.1007/978-3-540-70889-6_14

Register to see more suggestions

Mendeley helps you to discover research relevant for your work.

Already have an account?

Save time finding and organizing research with Mendeley

Sign up for free