Neural reverse engineering of stripped binaries using augmented control flow graphs


연구 분야: Analysis



학회: Proceedings of the ACM on Programming Languages, Volume 4, Issue OOPSLA


초록

We address the problem of reverse engineering of stripped executables, which contain no debug information. This is a challenging problem because of the low amount of syntactic information available in stripped executables, and the diverse assembly code patterns arising from compiler optimizations. We present a novel approach for predicting procedure names in stripped executables. Our approach combines static analysis with neural models. The main idea is to use static analysis to obtain augmented representations of call sites; encode the structure of these call sites using the control-flow graph (CFG) and finally, generate a target name while attending to these call sites. We use our representation to drive graph-based, LSTM-based and Transformer-based architectures. Our evaluation shows that our models produce predictions that are difficult and time consuming for humans, while improving on existing methods by 28% and by 100% over state-of-the-art neural textual models that do not use any static analysis. Code and data for this evaluation are available at https://github.com/tech-srl/Nero.


Author Profile
Yaniv David

Technion Israel

Israel
Author Profile
Uri Alon

Technion Israel

Israel
Author Profile
Eran Yahav

Technion Israel

Israel

📄 논문 정보

발행 연도 2020년
인용수 54
출판 국가 Israel
사이트 ACM
좋아요 수 0

연관 논문 목록 (172건)