Graph explorer

Datalog Disassembly

Disassembly is fundamental to binary analysis and rewriting. We present a novel disassembly technique that takes a stripped binary and produces reassembleable assembly code. The resulting assembly code has accurate symbolic information, providing cross-references for analysis and to enable adjustment of code and data pointers to accommodate rewriting. Our technique features multiple static analyses and heuristics in a combined Datalog implementation. We argue that Datalog's inference process is particularly well suited for disassembly and the required analyses. Our implementation and experiments support this claim. We have implemented our approach into an open-source tool called Ddisasm. In extensive experiments in which we rewrite thousands of x64 binaries we find Ddisasm is both faster and more accurate than the current state-of-the-art binary reassembling tool, Ramblr.

4 nodes3 linksoverview previewDatalog Disassembly
4 nodes3 links
Datalog Disassembly4 visible / 4 total nodes / 4 links
Co-authorshipAuthorshipAuthorshipTopic signalWDatalog Disassemblypreprint / 2020AAntonio Flores-MontoyaResearcherAEric SchulteResearcherTProgramming Languages1239 works
PaperSignal 103 links

Datalog Disassembly

preprint / 2020

Open