Binary Ninja¶
Open Source¶
Vector 35 is grateful for the following open source packages that are used in Binary Ninja directly or indirectly:
- Documentation
- breathe-rtd-theme (breathe-rtd-theme license - MIT)
- breathe (breathe license - BSD)
- doxygen (doxygen license - GPLv2)
- mkdocs-material (mkdocs-material License - BSD)
- mkdocs (mkdocs license - BSD)
- sphinx (sphinx license - BSD and others)
The previous tools are used in the generation of our documentation, but are not distributed themselves and are merely listed here in acknowledgement for the value they provide.
-
UI
- dejavusanscode (dejavusanscode license - multiple open licenses)
- opensans (opensans license - Apache 2.0)
- qt (qt license - LGPLv3 / note, please see our qt build instructions below)
- sourcecodepro (sourcecodepro license - SIL open font license)
-
Core
- discount (discount license - BSD)
- libgit2 (libgit2 license - GPLv2 with linking exception)
- libmspack (libmspack license - LGPL, v2)
- llvm (llvm license - BSD-style)
- lzf (lzf license - BSD)
- jemalloc (jemalloc license - BSD)
- sqlite (sqlite license - public domain)
- zlib (zlib license - zlib license)
-
Other
- yasm (yasm license - 2-clause BSD) used for assembling x86 and x64
- xed (xed license - Apache License 2.0) used for disassembling x86, x64, and x16
- capstone (capstone license - 3-clause BSD) used in the PPC architecture module as an example of how to wrap an external disassembler
-
Upvector update library
- tomcrypt (tomcrypt license - public domain)
Building Qt¶
Binary Ninja uses Qt 5.12 under an LGPLv3 license which requires that we host the original sources used to build Qt for our application along with instructions on how that source may be re-built and can replace the version of Qt shipped with Binary Ninja.
Please note that we offer no support for running Binary Ninja with modified Qt libraries.
- Follow the installation requirements on the Building Qt 5 from Git page.
- Download the Qt 5.12.0 tarball from binary.ninja. (Note this is an unmodified 5.12 identical to that available from Qt's source control, but must be hosted locally according to the Qt 5.12 terms.)
- Next, build QT using the aforementioned instructions.
- On OS X, you will need to disable the code-signing signature since it would otherwise prevent changes to binaries or shared libraries. We recommend a tool such as unsign.
- Finally, replace the built libraries:
- On OS X, replace the
QtCore.framework
,QtDBus.framework
,QtGui.framework
,QtNetwork.framework
,QtPrintSupport.framework
,QtWidgets.framework
folders inside of/Applications/Binary Ninja.app/Contents/Frameworks
- On Windows, replace the
Qt5core.dll
,Qt5Gui.dll
,Qt5Network.dll
, andQt5Widgets.dll
files inC:\Program Files\Vector35\BinaryNinja\
- On Linux, replace the
libQt5Core.so.5
,libQt5DBus.so.5
,libQt5Gui.so.5
,libQt5Network.so.5
,libQt5Widgets.so.5
,libQt5XcbQpa.so.5
files wherever Binary Ninja was extracted
- On OS X, replace the