IEEE Access (Jan 2018)

PTfuzz: Guided Fuzzing With Processor Trace Feedback

  • Gen Zhang,
  • Xu Zhou,
  • Yingqi Luo,
  • Xugang Wu,
  • Erxue Min

DOI
https://doi.org/10.1109/ACCESS.2018.2851237
Journal volume & issue
Vol. 6
pp. 37302 – 37313

Abstract

Read online

Greybox fuzzing, such as american fuzzy lop (AFL), is very efficient in finding software vulnerability, which makes it the state-of-the-art fuzzing technology. Greybox fuzzing leverages the branch information collected during program running as feedback to guide choosing seeds. Current greybox fuzzing generally uses two kinds of methods to collect branch information: compile-time instrumentation (AFL) and emulation [AFL extended with QEMU emulation (QAFL)]. Compile-time instrumentation is efficient, but it does not support binary programs. Meanwhile, emulation supports binary programs, but its efficiency is very low. In this paper, we propose a greybox fuzzing approach named PTfuzz, which leverages hardware mechanism (Intel Processor Trace) to collect branch information. Our approach supports binary programs, just like the emulation method, while it gains a comparable performance with the compile-time instrumentation method. Our experiments show that PTfuzz can fuzz the original binary programs without any modification, and we gain a 3× performance improvement compared to QAFL.

Keywords