Eunomia: Enabling User-Specified Fine-Grained Search in Symbolically Executing WebAssembly Binaries

dc.contributor.authorHe, Ningyuen
dc.contributor.authorZhao, Zhehaoen
dc.contributor.authorWang, Jikaien
dc.contributor.authorHu, Yubinen
dc.contributor.authorGuo, Shengjianen
dc.contributor.authorWang, Haoyuen
dc.contributor.authorLiang, Guangtaien
dc.contributor.authorLi, Dingen
dc.contributor.authorChen, Xiangqunen
dc.contributor.authorGuo, Yaoen
dc.date.accessioned2023-08-02T17:46:13Zen
dc.date.available2023-08-02T17:46:13Zen
dc.date.issued2023-07-12en
dc.date.updated2023-08-01T07:58:02Zen
dc.description.abstractAlthough existing techniques have proposed automated approaches to alleviate the path explosion problem of symbolic execution, users still need to optimize symbolic execution by applying various searching strategies carefully. As existing approaches mainly support only coarse-grained global searching strategies, they cannot efficiently traverse through complex code structures. In this paper, we propose Eunomia, a symbolic execution technique that supports fine-grained search with local domain knowledge. Eunomia uses Aes, a DSL that lets users specify local searching strategies for different parts of the program. Eunomia also isolates the context of variables for different local searching strategies, avoiding conflicts. We implement Eunomia for WebAssembly, which can analyze applications written in various languages. Eunomia is the first symbolic execution engine that supports the full features of WebAssembly. We evaluate Eunomia with a microbenchmark suite and six real-world applications. Our evaluation shows that Eunomia improves bug detection by up to three orders of magnitude. We also conduct a user study that shows the benefits of using Aes. Moreover, Eunomia verifies six known bugs and detects two new zero-day bugs in Collections-C.en
dc.description.versionPublished versionen
dc.format.mimetypeapplication/pdfen
dc.identifier.doihttps://doi.org/10.1145/3597926.3598064en
dc.identifier.urihttp://hdl.handle.net/10919/115961en
dc.language.isoenen
dc.publisherACMen
dc.rightsIn Copyrighten
dc.rights.holderThe author(s)en
dc.rights.urihttp://rightsstatements.org/vocab/InC/1.0/en
dc.titleEunomia: Enabling User-Specified Fine-Grained Search in Symbolically Executing WebAssembly Binariesen
dc.typeArticle - Refereeden
dc.type.dcmitypeTexten

Files

Original bundle
Now showing 1 - 1 of 1
Loading...
Thumbnail Image
Name:
3597926.3598064.pdf
Size:
953.7 KB
Format:
Adobe Portable Document Format
Description:
Published version
License bundle
Now showing 1 - 1 of 1
Name:
license.txt
Size:
0 B
Format:
Item-specific license agreed upon to submission
Description: