This is a reference implementation of the ITT API dynamic part that performs tracing data from ITT API function calls to log files.
To use this solution, build the collector as a shared library and point the full library path to the INTEL_LIBITTNOTIFY64 or INTEL_LIBITTNOTIFY32 environment variable.
Use CMake from the repository root, enabling the ITT_API_REFERENCE_COLLECTOR option:
cmake -B <build_dir> -DITT_API_REFERENCE_COLLECTOR=ON cmake --build <build_dir>
The shared library is placed in the bin/ subdirectory of the CMake build directory. Alternatively, use the provided buildall.py script:
python buildall.py --refcol
The shared library is placed in the bin/ subdirectory of the CMake build directory:
| Platform | Library name |
|---|---|
| Linux | libittnotify_refcol.so |
| Windows | libittnotify_refcol.dll |
On Linux
export INTEL_LIBITTNOTIFY64=<build_dir>/bin/libittnotify_refcol.so
On FreeBSD
setenv INTEL_LIBITTNOTIFY64 <build_dir>/bin/libittnotify_refcol.so
On Windows
set INTEL_LIBITTNOTIFY64=<build_dir>\bin\libittnotify_refcol.dll
By default, log files are saved in the system temporary directory. To change the location, use the INTEL_LIBITTNOTIFY_LOG_DIR environment variable:
On Linux
export INTEL_LIBITTNOTIFY_LOG_DIR=<log_dir>
On FreeBSD
setenv INTEL_LIBITTNOTIFY_LOG_DIR <log_dir>
On Windows
set INTEL_LIBITTNOTIFY_LOG_DIR=<log_dir>
This implementation adds logging of some of the ITT API function calls. Adding logging of other ITT API function calls is welcome. The solution provides 4 functions with different log levels that take printf format for logging:
LOG_FUNC_CALL_INFO(const char *msg_format, ...); LOG_FUNC_CALL_WARN(const char *msg_format, ...); LOG_FUNC_CALL_ERROR(const char *msg_format, ...); LOG_FUNC_CALL_FATAL(const char *msg_format, ...);