簡體   English   中英

帶有 --call-stack fp 的 perf 記錄無法展開主函數

[英]perf record with --call-stack fp fails to unwind main function

我有一個讓 CPU 保持忙碌的 C++ 測試程序:

#include <cstdint>
#include <iostream>

// Linear-feedback shift register
uint64_t lfsr1(uint64_t max_ix)
{
    uint64_t start_state = 0xACE1u;  /* Any nonzero start state will work. */
    uint64_t lfsr = start_state;
    uint64_t bit;                    /* Must be 16-bit to allow bit<<15 later in the code */

    for (uint64_t ix = 0; ix < max_ix; ++ix)
    {   /* taps: 16 14 13 11; feedback polynomial: x^16 + x^14 + x^13 + x^11 + 1 */
        bit = ((lfsr >> 0) ^ (lfsr >> 1) ^ (lfsr >> 3) ^ (lfsr >> 4)) & 1 /* & 1u */;
        lfsr = (lfsr >> 1) | (bit << 15);
    }
    return lfsr;
}

int main() {
    std::cout << lfsr1(1717986914ull) << "\n";
}

我用g++ -g -O3 -fno-omit-frame-pointer cpu.cpp -o cpu.bin編譯它,然后用perf record -F 100 --call-graph fp -- ./cpu.bin和 a第二次用dwarf而不是fp

fpperf script輸出中,我可以看到

cpu.bin 23435 1535437.021156:   42706947 cycles: 
            5617daf4b7a1 main+0x31 (…/cpu.bin)
            7f9a95088bf7 __libc_start_main+0xe7 (/lib/x86_64-linux-gnu/libc-2.27.so)
         3fe258d4c544155 [unknown] ([unknown])

而對於dwarf ,它是

cpu.bin 23443 1535441.101859:   42952079 cycles: 
            55a3b4ffd7a1 lfsr1+0x31 (inlined)
            55a3b4ffd7a1 main+0x31 (…/cpu.bin)
            7f00bcc8ebf6 __libc_start_main+0xe6 (/lib/x86_64-linux-gnu/libc-2.27.so)
            55a3b4ffd829 _start+0x29 (…/cpu.bin)

似乎fp__libc_start_main關閉了一個字節,這導致它錯過了最后一個展開步驟。 如何解決這個問題?

就像彼得在他的評論中所說的那樣,當使用帶有幀指針的 glibc 版本時,問題會自行解決。 在 Ubuntu 20.04 上,有一個帶有這樣的 glibc 的包。

sudo apt install libc6-prof
# To use this library:
env LD_LIBRARY_PATH=/lib/libc6-prof/x86_64-linux-gnu perf record …

然后, [unknown]按預期解析為_start

來源: https : //bugs.launchpad.net/ubuntu/+source/glibc/+bug/1908307

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM