Я использую gperftools v2.3rc и хотел бы использовать улучшенную функцию профилирования потоков. В примечаниях к выпуску указано частично:
теперь реализован новый режим профилирования процессора в Linux. Он устанавливает отдельные таймеры профилирования для отдельных потоков. … [Это] включено, если оба librt.f загружен и установлена переменная окружения CPUPROFILE_PER_THREAD_TIMERS. …
Мое приложение C ++ связано с librt.so (-lrt — библиотека расширений реального времени POSIX.1b), но я раньше не слышал о библиотеке с суффиксом .f. Что означает .f, где я могу найти эту библиотеку и как загрузить ее в свое приложение?
Я подозреваю, что временный артрит вызван отсутствием кофе (это опечатка). Что подразумевается под librt.so. С середины src/profile-handler.cc
:
// We use weak alias to timer_create to avoid runtime dependency on
// -lrt and in turn -lpthread.
//
// At runtime we detect if timer_create is available and if so we
// can enable linux-sigev-thread mode of profiling
и далее в коде:
#if HAVE_LINUX_SIGEV_THREAD_ID
if (getenv("CPUPROFILE_PER_THREAD_TIMERS")) {
if (timer_create && pthread_once) { // <-- note this bit here.
timer_sharing_ = TIMERS_SEPARATE;
CreateThreadTimerKey(&thread_timer_key);
per_thread_timer_enabled_ = true;
} else {
RAW_LOG(INFO,
"Not enabling linux-per-thread-timers mode due to lack of timer_create."" Preload or link to librt.so for this to work");
}
}
#endif
Он проверяет, установлен ли envvar и загружен либрт. Это про librt.so.