Linux
2017-09-15
man-pages-ru
Russian man pages from the Linux Documentation Project
manpages-dev
Manual pages about using GNU/Linux for development
man-pages
Linux kernel and C library user-space interface documentation
ИМЯ
profil - профилирование времени работы
ОБЗОР
#include <unistd.h>Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):
int profil(unsigned short *buf, size_t bufsiz, size_t offset, unsigned int scale);
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.