Static Analysis of File-Processing Programs using File Format Specifications

Raveendra Kumar Medicherla,Raghavan Komondoor,S. Narendran
DOI: https://doi.org/10.48550/arXiv.1501.04730
2015-04-03
Abstract:Programs that process data that reside in files are widely used in varied domains, such as banking, healthcare, and web-traffic analysis. Precise static analysis of these programs in the context of software verification and transformation tasks is a challenging problem. Our key insight is that static analysis of file-processing programs can be made more useful if knowledge of the input file formats of these programs is made available to the analysis. We propose a generic framework that is able to perform any given underlying abstract interpretation on the program, while restricting the attention of the analysis to program paths that are potentially feasible when the program's input conforms to the given file format specification. We describe an implementation of our approach, and present empirical results using real and realistic programs that show how our approach enables novel verification and transformation tasks, and also improves the precision of standard analysis problems.
Programming Languages
What problem does this paper attempt to address?