У меня проблемы с профилированием моего кода C ++ на Jetson TX2.Само профилирование работает, но я не получаю имена функций, а вместо этого говорит, что часть неизвестна.Я установил pprof с go, и он работает на моем Raspberry Pi, зо я думаю, id сделал правильные шаги.Например, разница между моим Jetson и моим Pi:
Результат, который я получаю на Jetson:
LD_PRELOAD="/usr/lib/libprofiler.so.0" CPUPROFILE=./tmp/profile.log ./testProg
Worker threads activated: 1
Done
PROFILE: interrupts/evictions/bytes = 3792/1650/150928
pprof --functions --text ./testProg ./tmp/profile.log
Some binary filenames not available. Symbolization may be incomplete.
Try setting PPROF_BINARY_PATH to the search path for local binaries.
File: testProg
Type: cpu
Showing nodes accounting for 37.15s, 97.97% of 37.92s total
Dropped 38 nodes (cum <= 0.19s)
flat flat% sum% cum cum%
16s 42.19% 42.19% 16s 42.19% inflateBackEnd
5.88s 15.51% 57.70% 5.88s 15.51% cv::(anonymous namespace)::medianBlur_SortNet
3.92s 10.34% 68.04% 3.92s 10.34% png_get_uint_16
2.86s 7.54% 75.58% 2.86s 7.54% inflate
1.89s 4.98% 80.56% 1.89s 4.98% adler32
1.15s 3.03% 83.60% 1.15s 3.03% memcpy
1.13s 2.98% 86.58% 1.13s 2.98% png_set_invert_mono
0.93s 2.45% 89.03% 0.93s 2.45% crc32
0.68s 1.79% 90.82% 0.68s 1.79% carotene_o4t::bgr2gray
0.62s 1.64% 92.46% 0.62s 1.64% sched_yield
0.48s 1.27% 93.72% 0.48s 1.27% [[vdso]]
0.48s 1.27% 94.99% 0.48s 1.27% cv::ThresholdRunner::operator()
0.47s 1.24% 96.23% 0.47s 1.24% inflateMark
0.37s 0.98% 97.20% 0.37s 0.98% read
0.29s 0.76% 97.97% 0.29s 0.76% cvFindNextContour
0 0% 97.97% 37.92s 100%
На Pi я получаю:
LD_PRELOAD="/usr/lib/libprofiler.so.0" CPUPROFILE=./tmp/profile.log ./testProg
Worker threads activated: 1
Done
PROFILE: interrupts/evictions/bytes = 16223/283/24060
pprof --functions --text ./testProg ./tmp/profile.log
File: testProg
Type: cpu
Showing nodes accounting for 159.98s, 98.61% of 162.23s total
Dropped 97 nodes (cum <= 0.81s)
flat flat% sum% cum cum%
75.63s 46.62% 46.62% 75.63s 46.62% cv::medianBlur_8u_Om
37.26s 22.97% 69.59% 37.26s 22.97% inflateBackEnd
11.58s 7.14% 76.72% 11.58s 7.14% png_set_read_user_transform_fn
6.45s 3.98% 80.70% 6.45s 3.98% memcmp
5.45s 3.36% 84.06% 5.45s 3.36% inflate
4.46s 2.75% 86.81% 4.46s 2.75% adler32
3.91s 2.41% 89.22% 3.91s 2.41% png_set_invert_mono
3.86s 2.38% 91.60% 3.87s 2.39% cvFindNextContour
2.97s 1.83% 93.43% 2.97s 1.83% cv::CvtColorLoop_Invoker::operator()
2s 1.23% 94.66% 2s 1.23% read
1.90s 1.17% 95.83% 1.90s 1.17% cv::ThresholdRunner::operator()
1.80s 1.11% 96.94% 1.80s 1.11% crc32
1.25s 0.77% 97.71% 1.25s 0.77% munmap
1.22s 0.75% 98.47% 1.22s 0.75% inflateMark
0.10s 0.062% 98.53% 5.40s 3.33% tbb::empty_task::~empty_task
0.03s 0.018% 98.55% 2.04s 1.26% __GI__IO_file_xsgetn
0.02s 0.012% 98.56% 3.14s 1.94% rml::internal::thread_monitor::detach_thread
0.02s 0.012% 98.57% 4.91s 3.03% tbb::interface7::internal::start_for::execute
0.01s 0.0062% 98.58% 2.05s 1.26% _GI__IO_fread
0.01s 0.0062% 98.58% 4.18s 2.58% cv::findContours
0.01s 0.0062% 98.59% 2.33s 1.44% cv::parallel_for
0.01s 0.0062% 98.59% 4.24s 2.61% imgprocessing::blobfind
0.01s 0.0062% 98.60% 2.31s 1.42% tbb::interface7::internal::delegated_function::operator()
0.01s 0.0062% 98.61% 2.32s 1.43% tbb::interface7::internal::task_arena_base::internal_execute
0.01s 0.0062% 98.61% 3.12s 1.92% tbb::task_scheduler_init::initialize
0 0% 98.61% 1.30s 0.8% _IO_new_file_underflow
0 0% 98.61% 82.20s 50.67% __libc_start_main
0 0% 98.61% 1.72s 1.06% cv::cvtColor
0 0% 98.61% 1.72s 1.06% cv::cvtColorBGR2Gray
0 0% 98.61% 1.71s 1.05% cv::hal::cvtBGRtoGray
0 0% 98.61% 75.65s 46.63% cv::medianBlur
0 0% 98.61% 76.06s 46.88% imgprocessing::filter_img (inline)
0 0% 98.61% 82.20s 50.67% imgprocessing::process
0 0% 98.61% 82.20s 50.67% main
0 0% 98.61% 2.30s 1.42% tbb::interface7::internal::start_for::run
Как вы можете видеть, профилирование функций OpenCV, которые я использовал, работает нормально, но мой собственный код называется неизвестным.
У меня включен флаг -g при компиляции.Я использую следующую строку для профилирования моего кода (makefile)
LD_PRELOAD="/usr/lib/libprofiler.so.0" CPUPROFILE=./tmp/profile.log ./$(PROG)
pprof --functions --text ./$(PROG) ./tmp/profile.log
... Когда я использую google-pprof вместо pprof, я не получаю неизвестные, а только адреса (например, 0x0000007f7a090498).Я пытался решить ошибку, но безуспешно.Я много пробовал и думаю, что это что-то со связью адресов с именами функций.Когда я пробую addr2line, я получаю:
addr2line -e testProg 0x7f7a090498
??:0
Я надеюсь, что кто-то может мне помочь.