GithubHelp home page GithubHelp logo

avatarone / news2e Goto Github PK

View Code? Open in Web Editor NEW
9.0 9.0 1.0 51.14 MB

Update of S2E (https://githhub.com/dslab-epfl/s2e) to a new version of Qemu

License: Other

Makefile 15.17% Lua 0.24% C 34.31% C++ 48.37% Python 1.92%

news2e's Introduction

WARNING: This repository contains work-in-progress code for a version of S2E with a current Qemu version. The code might compile and link, but is for sure not functional. Lots of stuff is still missing, other stuff is stubbed. Use only as a study target.

S2E is a platform for writing tools that analyze the properties and behavior of software systems. So far, S2E has been used to develop a comprehensive performance profiler, a reverse engineering tool for proprietary software, and a bug finding tool for both kernel-mode and user-mode binaries. Building these tools on top of S2E took less than 770 LOC and 40 person-hours each.

S2E’s novelty consists of its ability to scale to large real systems, such as a full Windows stack. S2E is based on two new ideas:

  1. Selective symbolic execution, a way to automatically minimize the amount of code that has to be executed symbolically given a target analysis; and

  2. Relaxed execution consistency models, a way to make principled performance/accuracy trade-offs in complex analyses.

These techniques give S2E three key abilities:

  1. to simultaneously analyze entire families of execution paths, instead of just one execution at a time;

  2. 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.

Conceptually, S2E is an automated path explorer with modular path analyzers: the explorer drives the target system down all execution paths of interest, while analyzers check properties of each such path (e.g., to look for bugs) or simply collect information (e.g., count page faults). Desired paths can be specified in multiple ways, and S2E users can either combine existing analyzers to build a custom analysis tool, or write new analyzers using the S2E API.

S2E helps make analyses based on symbolic execution practical for large software that runs in real environments, without requiring explicit modeling of these environments.

S2E is built upon the KLEE symbolic execution engine and the QEMU virtual machine emulator.

Documentation

Setup instruction and user documentation can be found in the /docs folder, both in RST and HTML format.

news2e's People

Contributors

blueswirl avatar kraxel avatar jan-kiszka avatar bonzini avatar avikivity avatar kevmw avatar pm215 avatar aurel32 avatar rth7680 avatar agraf avatar mstsirkin avatar edgarigl avatar markmc avatar afaerber avatar stweil avatar dondiego avatar dgibson avatar kvaneesh avatar jwrdegoede avatar jcmvbkbc avatar mwalle avatar matosatti avatar lucab avatar mdroth avatar i-garrison avatar iksaif avatar hpoussin avatar awilliam avatar zaddach avatar contrem avatar

Stargazers

 avatar Zhang avatar Mohamed Saher avatar 星博's Github avatar Lays avatar Simon Bourne avatar  avatar  avatar Minh-Triet Pham Tran avatar

Watchers

 avatar Minh-Triet Pham Tran avatar  avatar James Cloos avatar  avatar emdel avatar  avatar Dario Nisi avatar Davide Balzarotti avatar

Forkers

amesianx

news2e's Issues

Test S2E with Z3

Currently S2E is build with STP and Minisat. Other configurations for SAT solvers would be nice to try and benchmark, i.e., Z3, or STP with Cryptominisat. This requires some changes to S2E's build system (Makefile).

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.