DocumentCode :
2076451
Title :
Slicing and dicing bugs in concurrent programs
Author :
Rungta, Neha ; Mercer, Eric
Author_Institution :
NASA Ames Res. Center, Moffett Field, CA, USA
Volume :
2
fYear :
2010
fDate :
2-8 May 2010
Firstpage :
195
Lastpage :
198
Abstract :
A lack of scalable verification tools for concurrent programs has not allowed concurrent software development to keep abreast with hardware trends in multi-core technologies. The growing complexity of modern concurrent systems necessitates the use of abstractions in order to verify all the expected behaviors of the system. Current abstraction refinement techniques are restricted to verifying mostly sequential and simpler concurrent programs. In this work, we present a novel incremental underapproximation technique that uses program slicing. Based on a reachability property, an initial backward slice for a single thread is generated. The information in the program slice is coupled with a concrete execution to drive the lone thread; generating an underapproximation of the program behavior space. If the target location is reached in the underapproximation, then we have an actual concrete trace. Otherwise, the initial single-thread slice is refined to include another thread that affects the reachability of the target location. In this case, the concrete execution only considers the two threads in the slice and preemption points between the threads only occur at locations in the slice. This refinement process is repeated until the target location is reached or is shown to be unreachable. Initial results indicate that the incremental technique can potentially allow the discovery of errors in larger systems using fewer resources and produce a better reduction in systems that are correct.
Keywords :
computational complexity; concurrent engineering; incremental compilers; program debugging; program slicing; program verification; reachability analysis; abstraction refinement technique; bugs dicing; bugs slicing; concurrent program; concurrent software development; incremental underapproximation technique; multicore technology; program slicing; reachability property; verification tool; Concrete; Java; Limiting; Runtime environment; Software; Testing; USA Councils; abstraction-refinement; concurrency; underapproximation;
fLanguage :
English
Publisher :
ieee
Conference_Titel :
Software Engineering, 2010 ACM/IEEE 32nd International Conference on
Conference_Location :
Cape Town
ISSN :
0270-5257
Print_ISBN :
978-1-60558-719-6
Type :
conf
DOI :
10.1145/1810295.1810328
Filename :
6062158
Link To Document :
بازگشت