By Osnat Levi,
Published:06/13/2012 Last Updated:06/13/2012
Please post to the Pinheads Newsgroup. Provide as much information as possible so that we can reproduce the bug. What is the command line? What is the system you are running on. On Linux* do:
cat /etc/*release*
What is the full name of the kit that you are using? Problems that can be reproduced using the sample tools in the kit are the easiest for us to reproduce.
First, you can find out what each signal means by typing: man 7 signal. Next, you can debug the problem using GDB as described in the user manual
IPOINT_AFTER for RTN is implemented by instrumenting the ret instruction. Pin finds the ret by scanning the body of the function. Sometimes a procedure doesn’t return, but instead jumps to another procedure which does the exit. To reliably instrument after a function has exited, you can replace the function with a wrapper function and put the before/after actions in the wrapper function.
Yes, Pin provides an interface that allows PinTools to create and manage their own threads. For example, the PIN_SpawnInternalThread() function can be used to create a new tool's internal thread in the current process. See the Pin Thread API section in the Pin's manual for detailed descriptions of this and other threading functions provided by Pin.
Note PinTools can NOT link against the pthreads library nor can they use pthreads functions on Linux. The reason for this is that using pthreads in the tool would interfere with the pthreads library linked into the application (e.g. they both try to take over the same signal handlers). Similarly, PinTools should not use Win32 threading API (e.g. CreateThread()) on Windows because this does not allow distinguishing between threads created by the application and the tool's internal threads.
Yes.
Yes.
Yes.
Pin is able to instrument all code, including threads and signals. It provides precise exception state in handlers; a handler cannot detect that the program is instrumented by looking at the context of the interrupted thread.
Pin allocates memory in the address space of the application, and that may cause application code, shared libraries and dynamically allocated data to move.
Note Recent Linux kernels intentionally move the location of stack and dynamically allocated data from run to run, even if you are not using pin. On RedHat-based systems you can workaround this by running Pin as follows:
$ setarch i386 pin -t pintool -- app
setarch i386 tells the kernel to disable Address Space Layout Randomization.
Pin will run on all Intel® 64 Architectures. An IA-32 processor needs the following features:
Pentium III processors do not have SSE2. Pentium IV processors can run Pin. You can check the capabilities of your processor on Linux with the following command:
cat /proc/cpuinfo
Pin has not been tested on systems with non-Intel processors. Therefore, incompatible or proprietary instructions in non-Intel processors may cause Pin to function incorrectly. Any attempt to instrument code not supported by Intel processors may lead to failures.
Pin has been validated on the below platforms:
Yes. You will have to build the 32-bit version of the tool. See the user manual.
In your SPEC config file (one of the files in $SPEC/config), add the following two lines:
submit=/my/path/to/pin/Bin/pin -t /my/pin/tool -- $command use_submit_for_speed=yes
Now SPEC will automatically run Pin with whatever benchmarks it runs. Note that you need the full path name for your pin and pintool binaries.
The instrumentation engine is not open source, but the example tools are open source. They have a BSD-style license, and can be redistributed in any form, as long as you keep the copyright notice.
Chi-Keung Luk, Robert Cohn, Robert Muth, Harish Patil, Artur Klauser, Geoff Lowney, Steven Wallace, Vijay Janapa Reddi, Kim Hazelwood. "Pin: Building Customized Program Analysis Tools with Dynamic Instrumentation," Programming Language Design and Implementation (PLDI), Chicago, IL, June 2005, pp. 190-200.
Pin - A Dynamic Binary Instrumentation Tool
Pin - A Binary Instrumentation Tool - Downloads
pinheads@groups.io
Pin - A Binary Instrumentation Tool - Papers
Intel® X86 Encoder Decoder Software Library
Intel® Software Development Emulator
Pin - A Binary Instrumentation Tool - PinPoints
Program Record/Replay Toolkit
DrDebug: Deterministic Replay based Debugging with Pin
Performance varies by use, configuration and other factors. Learn more at www.Intel.com/PerformanceIndex.