Montage: A Neural Network Language Model-Guided JavaScript Engine Fuzzer

Authors: 

Suyoung Lee, HyungSeok Han, Sang Kil Cha, and Sooel Son, KAIST

Abstract: 

JavaScript (JS) engine vulnerabilities pose significant security threats affecting billions of web browsers. While fuzzing is a prevalent technique for finding such vulnerabilities, there have been few studies that leverage the recent advances in neural network language models (NNLMs). In this paper, we present Montage, the first NNLM-guided fuzzer for finding JS engine vulnerabilities. The key aspect of our technique is to transform a JS abstract syntax tree (AST) into a sequence of AST subtrees that can directly train prevailing NNLMs. We demonstrate that Montage is capable of generating valid JS tests, and show that it outperforms previous studies in terms of finding vulnerabilities. Montage found 37 real-world bugs, including three CVEs, in the latest JS engines, demonstrating its efficacy in finding JS engine bugs.

Open Access Media

USENIX is committed to Open Access to the research presented at our events. Papers and proceedings are freely available to everyone once the event begins. Any video, audio, and/or slides that are posted after the event are also free and open to everyone. Support USENIX and our commitment to Open Access.

BibTeX
@inproceedings {247670,
author = {Suyoung Lee and HyungSeok Han and Sang Kil Cha and Sooel Son},
title = {Montage: A Neural Network Language {Model-Guided} {JavaScript} Engine Fuzzer},
booktitle = {29th USENIX Security Symposium (USENIX Security 20)},
year = {2020},
isbn = {978-1-939133-17-5},
pages = {2613--2630},
url = {https://www.usenix.org/conference/usenixsecurity20/presentation/lee-suyoung},
publisher = {USENIX Association},
month = aug
}

Presentation Video