Publication | Closed Access
A randomized dynamic program analysis technique for detecting real deadlocks
190
Citations
26
References
2009
Year
Unknown Venue
EngineeringVerificationSoftware EngineeringConcurrent SystemSoftware AnalysisFormal VerificationHardware SecurityPotential DeadlocksSystems EngineeringStatic CheckingParallel ComputingRuntime VerificationConcurrent ProgrammingComputer EngineeringComputer ScienceStatic Program AnalysisReal DeadlocksProgram AnalysisSoftware TestingConcurrency TheoryFormal MethodsParallel ProgrammingUnknown Real Deadlocks
We present a novel dynamic analysis technique that finds real deadlocks in multi-threaded programs. Our technique runs in two stages. In the first stage, we use an imprecise dynamic analysis technique to find potential deadlocks in a multi-threaded program by observing an execution of the program. In the second stage, we control a random thread scheduler to create the potential deadlocks with high probability. Unlike other dynamic analysis techniques, our approach has the advantage that it does not give any false warnings. We have implemented the technique in a prototype tool for Java, and have experimented on a number of large multi-threaded Java programs. We report a number of previously known and unknown real deadlocks that were found in these benchmarks.
| Year | Citations | |
|---|---|---|
Page 1
Page 1