Publication | Closed Access
Automated atomicity-violation fixing
135
Citations
38
References
2011
Year
Software MaintenanceEngineeringVerificationComputer ArchitectureSoftware EngineeringAtomicity-violation FixingSoftware AnalysisFormal VerificationParallel ComputingRuntime VerificationConcurrent ProgrammingComputer EngineeringSoftware ReadabilityComputer ScienceStatic Program AnalysisAutomated RepairSoftware DesignSoftware DevelopmentProgram AnalysisSoftware TestingConcurrency TheoryFormal MethodsParallel ProgrammingFault InjectionSystem SoftwareSoftware Bugs
Fixing software bugs has always been an important and time-consuming process in software development. Fixing concurrency bugs has become especially critical in the multicore era. However, fixing concurrency bugs is challenging, in part due to non-deterministic failures and tricky parallel reasoning. Beyond correctly fixing the original problem in the software, a good patch should also avoid introducing new bugs, degrading performance unnecessarily, or damaging software readability. Existing tools cannot automate the whole fixing process and provide good-quality patches. We present AFix, a tool that automates the whole process of fixing one common type of concurrency bug: single-variable atomicity violations. AFix starts from the bug reports of existing bug-detection tools. It augments these with static analysis to construct a suitable patch for each bug report. It further tries to combine the patches of multiple bugs for better performance and code readability. Finally, AFix's run-time component provides testing customized for each patch. Our evaluation shows that patches automatically generated by AFix correctly eliminate six out of eight real-world bugs and significantly decrease the failure probability in the other two cases. AFix patches never introduce new bugs and usually have similar performance to manually-designed patches.
| Year | Citations | |
|---|---|---|
Page 1
Page 1