跳到主要导航 跳到搜索 跳到主要内容

Testing Error Handling Code With Software Fault Injection and Error-Coverage-Guided Fuzzing

  • Jia Ju Bai*
  • , Zi Xuan Fu
  • , Kai Tao Xie
  • , Zu Ming Jiang
  • *此作品的通讯作者
  • Beihang University
  • Tsinghua University
  • Alibaba Group Holding Ltd.
  • Swiss Federal Institute of Technology Zurich

科研成果: 期刊稿件文章同行评审

摘要

Real-world programs require error handling code to handle various kinds of possible errors. However, these errors just infrequently occur due to special conditions, so error handling code is difficult to test. Coverage-guided fuzzing and software fault injection (SFI) are two common techniques that can test error handling code, but they still have major limitations. Specifically, existing fuzzing approaches generate program inputs guided by code coverage, but many occasional errors (such as insufficient memory) are unrelated to inputs, and code coverage cannot effectively reflect the execution contexts of these errors; existing SFI approaches often inject single or random faults, without exploring fault space or using program feedback. In this paper, we propose a new fuzzing framework named EH-Fuzz, to effectively test error handling code. EH-Fuzz uses a context-sensitive SFI-based fuzzing approach to explore fault space and perform fault injection, guided by a new metric named error coverage. We evaluate EH-Fuzz on 9 user-level programs and 6 kernel-level modules, and find 45 new real bugs, 31 of which have been confirmed and fixed. We compare EH-Fuzz to existing fuzzing approaches (including AFL, AFL++, Syzkaller, FIZZER and FIFUZZ), and EH-Fuzz finds many real bugs missed by these approaches with higher testing coverage.

源语言英语
页(从-至)1724-1739
页数16
期刊IEEE Transactions on Dependable and Secure Computing
21
4
DOI
出版状态已出版 - 2024

指纹

探究 'Testing Error Handling Code With Software Fault Injection and Error-Coverage-Guided Fuzzing' 的科研主题。它们共同构成独一无二的指纹。

引用此