assembly - Gnu 汇编器 (GAS) 中的 CFI 指令有何用途?

标签 assembly callstack gnu-assembler stack-unwinding debug-information

每行后面似乎都有一个 .CFI 指令,而且还有各种各样的指令,例如.cfi_startproc.cfi_endproc等。more here .

    .file   "temp.c"
    .text
.globl main
    .type   main, @function
main:
.LFB0:
    .cfi_startproc
    pushq   %rbp
    .cfi_def_cfa_offset 16
    movq    %rsp, %rbp
    .cfi_offset 6, -16
    .cfi_def_cfa_register 6
    movl    $0, %eax
    leave
    ret
    .cfi_endproc
.LFE0:
    .size   main, .-main
.globl func
    .type   func, @function
func:
.LFB1:
    .cfi_startproc
    pushq   %rbp
    .cfi_def_cfa_offset 16
    movq    %rsp, %rbp
    .cfi_offset 6, -16
    .cfi_def_cfa_register 6
    movl    %edi, -4(%rbp)
    movl    %esi, %eax
    movb    %al, -8(%rbp)
    leave
    ret
    .cfi_endproc
.LFE1:
    .size   func, .-func
    .ident  "GCC: (Ubuntu 4.4.1-4ubuntu9) 4.4.1"
    .section    .note.GNU-stack,"",@progbits

我不明白这些的目的。

最佳答案

要禁用这些,请使用 gcc 选项

-fno-asynchronous-unwind-tables
<小时/> 可能还需要

-fno-dwarf2-cfi-asm

关于assembly - Gnu 汇编器 (GAS) 中的 CFI 指令有何用途?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2529185/

相关文章:

assembly - 8086锁销和ASM LOCK前缀如何工作

gcc - 是什么导致 "x.asm:(.text+0xd): undefined reference to ` y'”?

c++ - 如何解读visual studio的callstack?

multithreading - 如何在 Visual Studio 中所有线程的调用堆栈中转储或搜索

我们能否始终针对崩溃问题获得正确(或完整)的堆栈转储

assembly - GAS ASM PIE x86-64 使用 LEA 指令访问变量

assembly - 使用 3Dh 导致中断只返回 "Acces Denied"

linux - 如何正确地将缓冲区指针传递给 x86_64 程序集中的 Linux 系统调用?

assembly - 如何让 GNU 汇编器使用斜杠/作为注释?

assembly - GNU GAS 汇编中是否有代表当前地址的符号?