私はしばらくの間、C でステートメントを書き、"gcc -S" でコンパイルし、出力を調べることで、GNU アセンブリを独学で学んできました。これは、x86 (および -m32 でコンパイル) では問題なく動作しますが、私の AMD64 ボックスでは、次のコードの場合 (例として):
int main()
{
return 0;
}
GCCは私に与えます:
.file "test.c" 。文章 .globl メイン .type メイン、@関数 主要: .LFB2: pushq %rbp .LCFI0: movq %rsp, %rbp .LCFI1: 移動 $0, %eax 離れる 戻る .LFE2: .サイズメイン、.-メイン .section .eh_frame,"a",@progbits .Lframe1: .long .LECIE1-.LSCIE1 .LSCIE1: .long 0x0 .byte 0x1 .string "zR" .uleb128 0x1 .sleb128 -8 .byte 0x10 .uleb128 0x1 .byte 0x3 .byte 0xc .uleb128 0x7 .uleb128 0x8 .byte 0x90 .uleb128 0x1 .align 8 .LECIE1: .LSFDE1: .long .LEFDE1-.LASFDE1 .LASFDE1: .long .LASFDE1-.Lframe1 .long .LFB2 .long .LFE2-.LFB2 .uleb128 0x0 .byte 0x4 .long .LCFI0-.LFB2 .byte 0xe .uleb128 0x10 .byte 0x86 .uleb128 0x2 .byte 0x4 .long .LCFI1-.LCFI0 .byte 0xd .uleb128 0x6 .align 8 .LEFDE1: .ident "GCC: (Ubuntu 4.3.3-5ubuntu4) 4.3.3" .section .note.GNU-stack,"",@progbits
と比べて:
.file "test.c" 。文章 .globl メイン .type メイン、@関数 主要: リール 4(%esp)、%ecx andl $-16, %esp pushl -4(%ecx) pushl %ebp movl %esp, %ebp pushl %ecx 移動 $0, %eax popl %ecx popl %ebp leal -4(%ecx), %esp 戻る .サイズメイン、.-メイン .ident "GCC: (Ubuntu 4.3.3-5ubuntu4) 4.3.3" .section .note.GNU-stack,"",@progbits
x86 で。
綿毛なしでx86_64出力アセンブリでGCC -Sを作成する方法はありますか?