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.

СМОТРИТЕ ТАКЖЕ

gprof(1), sprof(1), setitimer(2), sigaction(2), signal(2)

2017-09-15 Linux