Vulnerability Analysis for X86 Executables Using Genetic Algorithm and Fuzzing

Guang-Hong Liu,Gang Wu,Zheng Tao,Jian-Mei Shuai,Zhuo-Chun Tang
DOI: https://doi.org/10.1109/ICCIT.2008.9
2008-01-01
Abstract:Fuzzing was successfully used to discover security bugs in popular programs, though released without source code. It becomes a major tool in security analysis, but needs large input space, ineffective. This paper presents a new method for the identification of vulnerabilities in executable program called GAFuzzing (Genetic Algorithm Fuzzing), which combines static and dynamic analysis to extend random Fuzzing. First, it uses static analysis to obtain the structural behavior, interface and interest region of code, then formally describes test requirement. Second, it uses genetic algorithm to intelligently direct test data generation and improve the testing objective. Unlike many software testing tools, our implementation analyzes the executables without source code directly. Our evaluation shows that GAFuzzing is superior to random Fuzzing for vulnerabilty analysis.
What problem does this paper attempt to address?