layout | title | permalink |
---|---|---|
page |
Documentation |
/docs/ |
Find details on the design & implementation of Unicorn in this BlackHat USA 2015 slides.
There are several methods to compile and install Unicorn.
Find the source in Download section and follow the instructions to build and install the core of Unicorn.
This section explains how to install Unicorn on *nix platforms from some software repositories.
Homebrew users can install the core of Unicorn with:
{% highlight bash %} $ brew install unicorn {% endhighlight %}
Note that Homebrew installs libraries into its own directory, so you need to tell applications where to find them, for example with:
{% highlight bash %} $ export DYLD_LIBRARY_PATH=/usr/local/opt/unicorn/lib/:$DYLD_LIBRARY_PATH {% endhighlight %}
Unicorn has been packaged for pkgsrc, thus available for NetBSD, FreeBSD, Bitrig and OpenBSD.
Installation from binary pre-built packages with:
{% highlight bash %} $ pkgin install unicorn {% endhighlight %}
Installation from sources with:
{% highlight bash %} $ cd /usr/pkgsrc/emulators/unicorn && make install {% endhighlight %}
The easiest way to install Python binding is via pip, where packages for all the Operating Systems, including Windows, are provided. Simply run the below command from prompt (you need sudo on Linux, MacOS for root access).
{% highlight bash %} pip install unicorn {% endhighlight %}
If you want to install from source, note that Python binding depends on the core, so make sure to install the core before you can use this binding.
On *nix platforms, do: {% highlight bash %} $ cd bindings/python $ sudo make install {% endhighlight %}
On Windows, do: {% highlight bash %} cd bindings/python python setup.py install {% endhighlight %}
For Windows, after above steps, you need to copy all the DLL files from the Windows core engine in the Download section into directory C:\location_to_python\Lib\site-packages\unicorn.
At the moment precompiled binaries for Windows & Java are available in our Download section.
-
If you only want to write your tool in Python, all you need is the Python installer, which includes full Unicorn module. The Windows core engine is not necessary because it is already embedded inside the Python module.
For all the bindings, firstly you still need to install the Windows core engine, which includes the static/dynamic libraries and also the headers (*.h) for C programming.
-
Java binding is available in JAR package.
After installation, find in tutorials below how to write your tools based on Unicorn using your favorite programming languages.
-
Unicorn: next generation CPU emulator framework: Blackhat USA 2015 slides (PDF).
-
Beyond QEMU: A quick technical comparison of Unicorn and QEMU.
-
Micro-Unicorn-Engine-API-Documentation in Chinese: This API Documentation details some Unicorn's data types, APIs, and related code implementations (currently available in Chinese only).