Python bindings for pin.
- Finish current sub groups
Split into multiple files and master pin's makefile schema- Continue expanding Pin Python's functionality
- Read Pythons reference counting information and implement into our Pin tool.
- Unit tests! Every change has the potential to break other functionality in unexpected ways :{
Copy the entire directory into ~/pin/source/tools
Type make
When make completes run ../../../pin -t obj-intel64/Python_Pin.so -- /bin/ls and ensure the output is correct
Enjoy!
Protip: while [ 1 == 1 ]; do inotifywait -e close_write *.cpp *.h; make; done
Leave running in another tmux pane. Whenever any file is modified, the pintool is automatically recompiled. Run touch *.cpp *.h
and everything will be recompiled.
Most of pin's functionality is exposed via the pin
module, internal to the pintool. Its implementation is very similar to the way gdb handles python extensions.
To run a specific python script, for example the strace script:
../../../pin -t obj-intel64/Python_Pin.so -m examples/strace.py -- /bin/ls
-
Modifying the Makefile is a huge pain. It needs to be made easier for distribution.This means everything has to be in the single, huge cpp file for now. And it has to be named MyPinTool.cpp.
-
Some Python modules are compiled as shared objects without symbols. These modules can't be loaded from within the python pin tool. (solution is to either not use those modules, or have a custom build of python alongside the pintool)