Control Data Collection
export INTEL_LIBITTNOTIFY64=libtcc_collector.so <additional environment variables to control data collection>
Description / Examples
Use a shared memory ring buffer instead of a local buffer to enable streaming of all measurement results to a separate application. Can be true or false. Default: false.
When the shared memory mode is enabled, the second (monitoring) application can attach to the shared buffer and process the measurement results.
Define the buffers that will hold the measurements generated from your instrumented real-time application. If your application has multiple measurement instances, you can define a buffer for each instance. One buffer will be created per instance.
Full format description:
For each measurement instance in your application, specify:
File where measurements are logged after the program finishes. If the specified file does not exist, it will be created. If a file with the same name already exists, its contents will be overwritten. If the measurement library cannot open the specified file, nothing will be stored.
NOTE:Use either implicit output (TCC_MEASUREMENTS_DUMP_FILE) or explicit output (“print” described in Post-process Analysis of Measurements). If you use both, you will get an empty dump file.
Time unit that will be used to store the results. If the measurement library cannot parse
TCC_MEASUREMENTS_TIME_UNIT, clk will be used. Options:
/* Extract the deadline settings from the environment variable */ uint64_t deadline, deadline_raw; TCC_TIME_UNIT unit = tcc_measurement_get_time_unit_from_env(); deadline_raw = tcc_measurement_get_deadline_from_env(measurement_name); deadline = tcc_measurement_convert_time_units_to_clock(deadline_raw, unit); tcc_status = tcc_measurement_set_deadline(tcc_measurement_ptr, deadline, notify_deadline);
Examples of Controlling the Collector Behavior
- Example 1: One ring buffer in local memoryThe measurement library collector will create a local ring buffer for the measurement instance “Input.” The buffer can hold 1000 measurements. The collector will store the measurement results for the “Input” measurement instance in the buffer during application run. After the application is finished, the results will vanish.The following diagram demonstrates the data flow of this scenario:INTEL_LIBITTNOTIFY64=libtcc_collector.so TCC_MEASUREMENTS_BUFFERS=Input:1000 ./myapp
- Example 2: Two ring buffers in local memory, store results to dump file on application finishThe measurement library collector will create a local ring buffer for each measurement instance: “Input” and “Compute.” Each buffer can hold 1000 measurements. The collector will store the measurement results in the buffers during application run. After the application is finished, the last 1000 results of each measurement instance will be stored in the dump.txt file. The format is explained in Post-process Analysis of Measurements. The data will be stored in CPU clock cycles.The following diagram demonstrates the data flow of this scenario:INTEL_LIBITTNOTIFY64=libtcc_collector.so TCC_MEASUREMENTS_DUMP_FILE=dump.txt TCC_MEASUREMENTS_BUFFERS=Input:1000,Compute:1000 ./myapp
- Example 3: Two ring buffers in shared memory, store results to dump file on application finish, measurements from shared buffers are read by monitoring applicationThe measurement library collector will create a shared memory ring buffer for each measurement instance: “Input” and “Compute.” Each buffer can hold 10 measurements. The collector will store the measurement results in the buffers during application run. After the application is finished, the last 10 results of each measurement instance will be stored in the dump.txt file. The shared memory always keeps data in CPU clock cycles (raw measurements) while the output file (dump.txt) uses the specified time units. The deadline value does not influence collector behavior. You can decide how to use the value in your code.The monitoring application connects to the shared buffers and reads measurements from the shared buffers. You can decide how the monitoring application processes the values. For details about monitoring applications, see Monitor Measurements from a Monitoring Application.The following diagram demonstrates the data flow of this scenario:INTEL_LIBITTNOTIFY64=libtcc_collector.so TCC_USE_SHARED_MEMORY=true TCC_MEASUREMENTS_TIME_UNIT=us TCC_MEASUREMENTS_DUMP_FILE=dump.txt TCC_MEASUREMENTS_BUFFERS=Input:10:10,Compute:10:100 ./myapp