Abstract
Software vulnerabilities are bugs in a program that an attacker can exploit to make the program deviate from its specification. An attacker exploits a vulnerability by crafting input that causes the program to behave incorrectly. Such an input is called an exploit. This article deals with diagnosing exploits, i.e., given an exploit, the task is to return the vulnerability that allowed it. We show that existing software diagnosis algorithms are ill-suited for this problem, and introduce two novel techniques for adapting them to this problem. This includes manipulating an automated testing tool to generate additional inputs that are similar to the given exploit, and tracing below the desired granularity level to improve diagnostic accuracy. Experimental evaluation on real exploits from four open-source projects shows that our algorithm significantly reduces diagnostic efforts.
Original language | American English |
---|---|
Article number | 8970609 |
Pages (from-to) | 7-15 |
Number of pages | 9 |
Journal | IEEE Intelligent Systems |
Volume | 35 |
Issue number | 6 |
DOIs | |
State | Published - 1 Nov 2020 |
All Science Journal Classification (ASJC) codes
- Computer Networks and Communications
- Artificial Intelligence