1 / 18

Eraser: A dynamic data race detector for multithreaded programs

Eraser: A dynamic data race detector for multithreaded programs. S. Savage, M. Burrows, G. Nelson, P. Sobalvarro, and T. Anderson TOCS Nov. 97. Overview. Dynamic data race detection tool – testing paradigm instead of static analysis.

nita
Download Presentation

Eraser: A dynamic data race detector for multithreaded programs

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Eraser: A dynamic data race detector for multithreaded programs S. Savage, M. Burrows, G. Nelson, P. Sobalvarro, and T. Anderson TOCS Nov. 97

  2. Overview • Dynamic data race detection tool – testing paradigm instead of static analysis. • Checks that each shared memory access follows a consistent locking discipline • Data race – when 2 concurrent threads access a shared variable and at least one is a write and the threads use no explicit synchronization to prevent simultaneous access. • Effect will depend on interleaving

  3. Previous work If 2 threads access a shared variable and the accesses are not ordered by happens-before then potential race. lock(mutex) v = v+1; unlock(mutex) Previous Approaches:Lamport’s Happened-Before lock(mutex) v = v+1; unlock(mutex)

  4. Drawbacks of Happened-Before • Difficult to implement efficiently – need per-thread information about access ordering to all shared memory locations. • Highly dependent on scheduler – needs large number of test cases.

  5. Previous work If 2 threads access a shared variable and the accesses are not ordered by happens-before then potential race. Depends on scheduler y=y+1; lock(mutex) v = v+1; unlock(mutex) lock(mutex) v = v+1; unlock(mutex) y=y+1;

  6. Previous work If 2 threads access a shared variable and the accesses are not ordered by happens-before then potential race. Depends on scheduler y=y+1; lock(mutex) v = v+1; unlock(mutex) lock(mutex) v = v+1; unlock(mutex) y=y+1;

  7. Idea in Eraser • Checks that locking discipline is observed. • That the same lock(s) is held whenever the shared data object is accessed. • Infer which locks protect which data items

  8. C(v) – candidate locks for v locks-held(t) – set of locks held by thread t Lock refinement for each v, init C(v) to set of all locks On each access to v by thread t: C(v) = C(v) 3 locks-held(t) If C(v) = {} issue warning Lockset Algorithm

  9. lock(mu1) v=v+1 unlock(mu1) lock(mu2) v=v+1 unlock(mu2) locks-held C(v) {} {mu1, mu2} {mu1} {mu1} {} {mu2} {} {} Example

  10. Initialization without locks Read-shared data(written only during init,read-only afterwards) Reader-writer locking(multiple readers) Don’t start until see a second thread Report only after it becomes write shared Change algorithm to reflect lock types On read of v by t: C(v) = C(v) 3 locks-held(t) On write of v by t: C(v) = C(v) 3 write-locks-held(t) More Sophistication • False Alarms still possible

  11. Per-Location State virgin C(v) updated, races reported wr, 1st thread Sharedmodified wr, new thread exclusive rd, wr, 1st thread wr rd, new thread shared C(v) updated, no race reporting

  12. Implementation • Binary rewriting used • Add instrumentation to call Eraser runtime • Each load and store updates C(v) • Each Acquire and Release call updates locks-held(t) • Calls to storage allocator initializes C(v) • Storage explosion handled by table lookup and use of indexes to represent sets • Shadow word holds index number • Slowdown by factor of 10 to 30x • Will change interleavings

  13. Shadow Memory and Lockset Indexes

  14. Memory reuse Private locks Benign races if (some_condition) { LOCK m DO if (some_condition) {stuff} END } EraseReuse – resets shadow word to virgin state Lock annotations EraserIgnoreOn()EraserIgnoreOff() Common False Alarms - Annotations

  15. Races inside OS • Using interrupt system to provide mutual exclusion – this implicitly locks everything affected (by interrupt level specified) • Explicitly associate a lock with interrupt level – disabling interrupt is like acquiring that lock • Signal and wait kind of synchronization • V to signal for P which waits -- semaphore not “held” by thread.

  16. An OK Race in AltaVista

  17. Bad Race in Vesta

  18. Core Loop of Lock-Coupling // ptr->lock.Acquire(); has been done before loop while (next != null & key > next->data) {next->lock.Acquire(); ptr->lock.Release(); ptr=next; next=ptr->next; } 4 6 null 2 8 ptr next

More Related