Affiliation:
1. École Polytechnique Fédérale de Lausanne (EPFL), Switzerland
Abstract
This article presents S2E, a platform for analyzing the properties and behavior of software systems, along with its use in developing tools for comprehensive performance profiling, reverse engineering of proprietary software, and automated testing of kernel-mode and user-mode binaries. Conceptually, S2E is an automated path explorer with modular path analyzers: the explorer uses a symbolic execution engine to drive the target system down all execution paths of interest, while analyzers measure and/or check properties of each such path. S2E users can either combine existing analyzers to build custom analysis tools, or they can directly use S2E’s APIs.S2E’s strength is the ability to scale to large systems, such as a full Windows stack, using two new ideas:selective symbolic execution, a way to automatically minimize the amount of code that has to be executed symbolically given a target analysis, andexecution consistency models, a way to make principled performance/accuracy trade-offs during analysis. These techniques give S2E three key abilities: to simultaneously analyze entire families of execution paths instead of just one execution at a time; to perform the analyses in-vivo within a real software stack---user programs, libraries, kernel, drivers, etc.---instead of using abstract models of these layers; and to operate directly on binaries, thus being able to analyze even proprietary software.
Publisher
Association for Computing Machinery (ACM)
Cited by
131 articles.
订阅此论文施引文献
订阅此论文施引文献,注册后可以免费订阅5篇论文的施引文献,订阅后可以查看论文全部施引文献
1. Monitor-based Testing of Network Protocol Implementations Using Symbolic Execution;Proceedings of the 19th International Conference on Availability, Reliability and Security;2024-07-30
2. Natural Symbolic Execution-Based Testing for Big Data Analytics;Proceedings of the ACM on Software Engineering;2024-07-12
3. Automated test data generation and stubbing method for C/C++ embedded projects;Automated Software Engineering;2024-06-10
4. Marco: A Stochastic Asynchronous Concolic Explorer;Proceedings of the IEEE/ACM 46th International Conference on Software Engineering;2024-02-06
5. HyperPUT: generating synthetic faulty programs to challenge bug-finding tools;Empirical Software Engineering;2024-01-15