首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Clang的ASM输出与GCC的ASM输出

Clang的ASM输出与GCC的ASM输出
EN

Stack Overflow用户
提问于 2012-11-17 20:58:43
回答 2查看 5.2K关注 0票数 0

(我对汇编语言几乎一无所知)。

我正在尝试学习this教程。

问题是,他的编译器和我的测试设置( Linux 32位上的gcc)产生的结果完全不同,而且比我的主设置(OSX64位上的clang)产生的输出要少得多。

以下是我对int main() {}的输出

32位Linux平台上的gcc

代码语言:javascript
复制
$ cat blank.c
int main() {}
$ gcc -S blank.c              
$ cat blank.s
    .file   "blank.c"
    .text
    .globl  main
    .type   main, @function
main:
.LFB0:
    .cfi_startproc
    pushl   %ebp
    .cfi_def_cfa_offset 8
    .cfi_offset 5, -8
    movl    %esp, %ebp
    .cfi_def_cfa_register 5
    popl    %ebp
    .cfi_def_cfa 4, 4
    .cfi_restore 5
    ret
    .cfi_endproc
.LFE0:
    .size   main, .-main
    .ident  "GCC: (Ubuntu/Linaro 4.6.3-1ubuntu5) 4.6.3"
    .section    .note.GNU-stack,"",@progbits

在Mac OSX 64位上点击

代码语言:javascript
复制
$ cat blank.c
int main() {}
$ clang -S blank.c
$ cat blank.s
    .section    __TEXT,__text,regular,pure_instructions
    .globl  _main
    .align  4, 0x90
_main:                                  ## @main
Leh_func_begin0:
## BB#0:
    pushq   %rbp
Ltmp0:
    movq    %rsp, %rbp
Ltmp1:
    movl    $0, %eax
    popq    %rbp
    ret
Leh_func_end0:

    .section    __TEXT,__eh_frame,coalesced,no_toc+strip_static_syms+live_support
EH_frame0:
Lsection_eh_frame0:
Leh_frame_common0:
Lset0 = Leh_frame_common_end0-Leh_frame_common_begin0 ## Length of Common Information Entry
    .long   Lset0
Leh_frame_common_begin0:
    .long   0                       ## CIE Identifier Tag
    .byte   1                       ## DW_CIE_VERSION
    .asciz   "zR"                   ## CIE Augmentation
    .byte   1                       ## CIE Code Alignment Factor
    .byte   120                     ## CIE Data Alignment Factor
    .byte   16                      ## CIE Return Address Column
    .byte   1                       ## Augmentation Size
    .byte   16                      ## FDE Encoding = pcrel
    .byte   12                      ## DW_CFA_def_cfa
    .byte   7                       ## Register
    .byte   8                       ## Offset
    .byte   144                     ## DW_CFA_offset + Reg (16)
    .byte   1                       ## Offset
    .align  3
Leh_frame_common_end0:
    .globl  _main.eh
_main.eh:
Lset1 = Leh_frame_end0-Leh_frame_begin0 ## Length of Frame Information Entry
    .long   Lset1
Leh_frame_begin0:
Lset2 = Leh_frame_begin0-Leh_frame_common0 ## FDE CIE offset
    .long   Lset2
Ltmp2:                                  ## FDE initial location
Ltmp3 = Leh_func_begin0-Ltmp2
    .quad   Ltmp3
Lset3 = Leh_func_end0-Leh_func_begin0   ## FDE address range
    .quad   Lset3
    .byte   0                       ## Augmentation size
    .byte   4                       ## DW_CFA_advance_loc4
Lset4 = Ltmp0-Leh_func_begin0
    .long   Lset4
    .byte   14                      ## DW_CFA_def_cfa_offset
    .byte   16                      ## Offset
    .byte   134                     ## DW_CFA_offset + Reg (6)
    .byte   2                       ## Offset
    .byte   4                       ## DW_CFA_advance_loc4
Lset5 = Ltmp1-Ltmp0
    .long   Lset5
    .byte   13                      ## DW_CFA_def_cfa_register
    .byte   6                       ## Register
    .align  3
Leh_frame_end0:


.subsections_via_symbols

是否可以在我的Mac上生成类似的汇编输出,以便我可以按照教程进行操作?或者这是特定于平台的汇编代码?如果是,我可以使用clang上的哪些标志来生成较少的冗长/样板(?)代码?

EN

回答 2

Stack Overflow用户

发布于 2012-11-17 23:25:03

确保您指示clang在MacOSX64位上使用clang -m32生成32位代码,并且您基本上不必担心其他差异。

gcc输出中的.cfi_XXX指令和clang输出中.section __TEXT,__eh_frame之后的行都用于生成用于展开堆栈的.eh_frame部分。有关详情,请参阅:http://blog.mozilla.org/respindola/2011/05/12/cfi-directives/

票数 6
EN

Stack Overflow用户

发布于 2012-11-17 23:21:35

gcc -fno-asynchronous-unwind-tables编译你的程序。或者忽略各种.cfi_XYZ指令。对于clang,请不要注意__eh_frame部分。请记住,两个不同的编译器生成相同的代码是相当不常见的,即使是来自相同的源代码。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13430797

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档