2011-10-14 14:24:38 +00:00
|
|
|
------------------------------------------------------
|
|
|
|
IDAPython - Python plugin for Interactive Disassembler
|
|
|
|
------------------------------------------------------
|
2010-06-28 12:36:40 +00:00
|
|
|
Building From Source
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
REQUIREMENTS
|
|
|
|
------------
|
|
|
|
|
|
|
|
[Tested versions are in brackets]
|
|
|
|
|
2010-11-10 13:58:08 +00:00
|
|
|
|
|
|
|
- IDA and IDA SDK [> 5.6]
|
2010-06-28 12:36:40 +00:00
|
|
|
http://www.hex-rays.com/idapro/
|
|
|
|
|
2010-11-10 13:58:08 +00:00
|
|
|
- Python [2.5.1, 2.6.1, 2.7]
|
2010-06-28 12:36:40 +00:00
|
|
|
http://www.python.org/
|
|
|
|
|
2010-11-10 13:58:08 +00:00
|
|
|
- Simplified Wrapper Interface Generator (SWIG) [2.0]
|
2010-06-28 12:36:40 +00:00
|
|
|
http://www.swig.org/
|
|
|
|
|
|
|
|
- Unix utilities (GNU patch on Windows):
|
|
|
|
http://www.research.att.com/sw/tools/uwin/ or
|
|
|
|
http://unxutils.sourceforge.net/ or
|
|
|
|
http://www.cygwin.com/
|
|
|
|
|
|
|
|
- GCC on Linux and Mac OS X [4.0.1, 4.1.3]
|
|
|
|
Comes with your distribution
|
|
|
|
|
|
|
|
- Microsoft Visual C on Windows [Microsoft Visual C++ 2008 Express Edition]
|
|
|
|
http://msdn.microsoft.com/vstudio/express/visualc/
|
|
|
|
|
|
|
|
|
|
|
|
BUILDING
|
|
|
|
--------
|
|
|
|
|
|
|
|
Make sure all the needed tools (compiler, swig) are on the PATH.
|
|
|
|
|
2011-10-14 14:24:38 +00:00
|
|
|
1. Unpack the IDAPython source and IDA SDK into the following
|
2010-06-28 12:36:40 +00:00
|
|
|
directory structure:
|
|
|
|
|
2011-10-14 14:24:38 +00:00
|
|
|
swigsdk-versions/x.y/ - A supported version of the IDA SDK
|
2010-06-28 12:36:40 +00:00
|
|
|
idapython/ - IDAPython source code
|
|
|
|
|
2013-07-03 01:40:54 +00:00
|
|
|
Note: To build with Hex-Rays decompiler support, please copy hexrays.hpp from
|
|
|
|
the decompiler SDK folder into IDA's include folder (in the SDK).
|
|
|
|
|
2010-11-10 13:58:08 +00:00
|
|
|
2. On Mac OS X copy libida.dylib from the IDA install directory to
|
2011-06-10 15:21:21 +00:00
|
|
|
swigsdk-versions/x.y/lib/x86_mac_gcc_32/
|
2010-06-28 12:36:40 +00:00
|
|
|
and libida64.dylib to
|
2011-06-10 15:21:21 +00:00
|
|
|
swigsdk-versions/x.y/lib/x86_mac_gcc_64/
|
2010-06-28 12:36:40 +00:00
|
|
|
|
2010-11-10 13:58:08 +00:00
|
|
|
3. Build the plugin
|
2010-06-28 12:36:40 +00:00
|
|
|
|
|
|
|
python build.py
|
|
|
|
|
|
|
|
It is possible to build the plugin for different Python versions by
|
|
|
|
running build.py with the corresponding Python binary.
|
|
|
|
|
|
|
|
Run 'build.py --help' for more information.
|
|
|
|
|
2010-11-10 13:58:08 +00:00
|
|
|
4. Install the components as described in README.txt
|
2010-06-28 12:36:40 +00:00
|
|
|
|
|
|
|
See build.py for build details and possible tweaks.
|
2010-11-10 13:58:08 +00:00
|
|
|
|
|
|
|
On 64 bits distributions, you may need to compile Python to generate a 32bit
|
|
|
|
version of the interpreter:
|
|
|
|
|
|
|
|
1. tar xvf Python-2.6.6.tar.bz2
|
|
|
|
2. cd Python-2.6.6
|
|
|
|
3. CC="gcc -m32" CXX="c++ -m32" ./configure --prefix=/path/to/py32 --enable-shared
|
|
|
|
4. make
|
|
|
|
5. make install
|
|
|
|
6. cd /path/to/py32/lib
|
|
|
|
7. ln -s libpython2.6.so.1.0 libpython2.6.so.1
|
|
|
|
8. PYTHONHOME=/path/to/py32 LD_LIBRARY_PATH=/path/to/py32/lib idaq
|