This repository is a code coverage tool that utilizes Pin, a Dynamic Binary Instrumentation (DBI) engine published by Intel. It operates as a Pin plugin.
- GNU/Linux
First, clone this repository.
git clone [email protected]:simotin13/CodeCoverage.git
Pin tool itself is required to run the code. You can download the Pin tool from the Intel Pin website.
Scripts for downloading, building, and running examples are included in this repository.
Please start by running 00_setup.sh.
cd CodeCoverage/
./00_setup.sh
In 00_setup.sh
, Pin 3.27 is downloaded and extracted to the same directory as this repository. Then, the source code in this repository is built.
To use the latest version of the pin, download it from the site as needed.
After downloading and building, please run 01_run_example.sh.
In 01_run_example.sh
, a C program included in examples/c_function_call is executed as a coverage measurement target for this coverage tool.
After running, the coverage measurement results are output as an HTML file in the report
folder.
To build this tool, please execute:
make PIN_ROOT=../pin-3.27-98718-gbeaa5d51e-gcc-linux
The convention when building Pin tools is to specify the directory path of the PIN tool with PIN_ROOT.
To run this tool, execute the following command:
../pin-3.27-98718-gbeaa5d51e-gcc-linux/pin -t ./obj-intel64/CodeCoverage.so -- <target_module_path> <target_args...>
where <target_module_path> and <target_args...> are the path and any arguments for the target module you want to measure code coverage for.
This coverage tool uses DWARF debugging information to obtain line number information.
Pin 3.27 supports DWARF4 as debugging information. When building the application for which you want to measure coverage, please build it with the -g
and -gdwarf-4
options.
例).
gcc -g -gdwarf-4 main.c