PROFIL(3) | Руководство программиста Linux | PROFIL(3) |
profil - профилирование времени работы
#include <unistd.h>
int profil(unsigned short *buf, size_t bufsiz, size_t offset, unsigned int scale);
Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):
profil():
Начиная с glibc 2.21: _DEFAULT_SOURCE В glibc 2.19 и 2.20: _DEFAULT_SOURCE || (_XOPEN_SOURCE && _XOPEN_SOURCE < 500) По glibc 2.19 включительно: _BSD_SOURCE || (_XOPEN_SOURCE && _XOPEN_SOURCE < 500)
Эта функция позволяет выяснить какие области вашей программы работают больше всего. В аргументе buf указывается bufsiz байт ядра. Каждые 10 виртуальных миллисекунд проверяется пользовательский программный счётчик (PC): из него вычитается offset, умножается на scale и делится на 65536. Если полученное значение меньше bufsiz, то в buf увеличивается соответствующая запись. Если buf равно NULL, профилирование выключено.
Всегда возвращается ноль.
Описание терминов данного раздела смотрите в attributes(7).
Интерфейс | Атрибут | Значение |
profil() | Безвредность в нитях | MT-Unsafe |
Подобно вызову в SVr4 (но не POSIX.1).
Функцию profil() нельзя использовать на программе, которая также использует таймеры интервалов ITIMER_PROF (смотрите setitimer(2)).
При профилировании настоящим ядром получаются более точные результаты. В libc 4.4 есть заплата к ядру, добавляющая системный вызов profil.
2017-09-15 | Linux |