Skip to content

Unicorn CPU emulator framework (ARM, AArch64, M68K, Mips, Sparc, PowerPC, RiscV, S390x, TriCore, X86)

License

GPL-2.0, Unknown licenses found

Licenses found

GPL-2.0
COPYING
Unknown
COPYING.LGPL2
Notifications You must be signed in to change notification settings

unicorn-engine/unicorn

This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

4021a20 · Mar 4, 2025
Feb 17, 2025
Feb 18, 2025
Dec 21, 2024
Feb 13, 2025
Oct 13, 2024
Feb 18, 2025
Jun 16, 2023
Mar 4, 2025
Feb 11, 2024
Mar 4, 2025
Oct 29, 2021
Oct 17, 2024
Jan 18, 2022
Aug 21, 2015
Mar 4, 2025
Aug 21, 2015
Dec 16, 2017
Dec 27, 2016
Jul 11, 2023
Feb 17, 2025
Feb 13, 2025
Dec 30, 2024
Oct 31, 2022
Oct 6, 2021
Aug 8, 2024
Feb 17, 2025
Nov 1, 2021
Nov 7, 2021
Feb 12, 2022
Feb 11, 2025
Feb 21, 2025

Repository files navigation

Unicorn Engine

pypi downloads Fuzzing Status

Unicorn is a lightweight, multi-platform, multi-architecture CPU emulator framework, based on QEMU.

Unicorn offers some unparalleled features:

  • Multi-architecture: ARM, ARM64 (ARMv8), M68K, MIPS, PowerPC, RISCV, SPARC, S390X, TriCore and X86 (16, 32, 64-bit)
  • Clean/simple/lightweight/intuitive architecture-neutral API
  • Implemented in pure C language, with bindings for Crystal, Clojure, Visual Basic, Perl, Rust, Ruby, Python, Java, .NET, Go, Delphi/Free Pascal, Haskell, Pharo, Lua and Zig.
  • Native support for Windows & *nix (with Mac OSX, Linux, Android, *BSD & Solaris confirmed)
  • High performance via Just-In-Time compilation
  • Support for fine-grained instrumentation at various levels
  • Thread-safety by design
  • Distributed under free software license GPLv2

Further information is available at http://www.unicorn-engine.org

License

This project is released under the GPL license.

Compilation & Docs

See docs/COMPILE.md file for how to compile and install Unicorn.

More documentation is available in docs/README.md.

For common questions, read docs/FAQ.md before raising an issue.

Contact

Contact us via mailing list, email or twitter for any questions.

Contribute

If you want to contribute, please pick up something from our Github issues.

We also maintain a list of more challenged problems in milestones for our regular release.

Please send pull request to our dev branch.

CREDITS.TXT records important contributors of our project.