Computer >> 컴퓨터 >  >> 프로그램 작성 >> C++

gcc의 C/C++ 소스에서 어셈블러 출력을 얻는 방법은 무엇입니까?

<시간/>

여기에서는 gcc를 사용하여 C 또는 C++ 코드에서 어셈블러 출력을 생성하는 방법을 볼 것입니다.

gcc는 실행하는 동안 소스 코드에서 모든 중간 출력을 가져오는 훌륭한 기능을 제공합니다. 어셈블러 출력을 얻으려면 gcc에 '-S' 옵션을 사용할 수 있습니다. 이 옵션은 컴파일 후 어셈블러로 보내기 전의 출력을 보여줍니다. 이 명령의 구문은 다음과 같습니다.

gcc –S program.cpp

이제 출력이 어떻게 생겼는지 봅시다. 여기서는 간단한 프로그램을 사용하고 있습니다. 이 프로그램에서 두 개의 숫자가 변수 x와 y에 저장되고 그 합계를 다른 변수에 저장한 다음 결과를 인쇄합니다.

예시

#include <iostream>
using namespace std;
main() {
   int x, y, sum;
   x = 50;
   y = 60;
   sum = x + y;
   cout << "Sum is: " << sum << endl;
}

출력

   .file "test_cpp.cpp"
   .text
   .section .rodata
   .type _ZStL19piecewise_construct, @object
   .size _ZStL19piecewise_construct, 1
_ZStL19piecewise_construct:
   .zero 1
   .local _ZStL8__ioinit
   .comm _ZStL8__ioinit,1,1
.LC0:
   .string "Sum is: "
   .text
   .globl main
   .type main, @function
main:
.LFB1493:
.cfi_startproc
pushq %rbp
   .cfi_def_cfa_offset 16
   .cfi_offset 6, -16
   movq %rsp, %rbp
   .cfi_def_cfa_register 6
   subq $16, %rsp
   movl $50, -12(%rbp)
   movl $60, -8(%rbp)
   movl -12(%rbp), %edx
   movl -8(%rbp), %eax
   addl %edx, %eax
   movl %eax, -4(%rbp)
   leaq .LC0(%rip), %rsi
   leaq _ZSt4cout(%rip), %rdi
   call _ZStlsISt11char_traitsIcEERSt13basic_ostreamIcT_ES5_PKc@PLT
   movq %rax, %rdx
   movl -4(%rbp), %eax
   movl %eax, %esi
   movq %rdx, %rdi
   call _ZNSolsEi@PLT
   movq %rax, %rdx
   movq
_ZSt4endlIcSt11char_traitsIcEERSt13basic_ostreamIT_T0_ES6_@GOTPCREL(%rip),
   %rax
   movq %rax, %rsi
   movq %rdx, %rdi
   call _ZNSolsEPFRSoS_E@PLT
   movl $0, %eax
   leave
   .cfi_def_cfa 7, 8
   ret
   .cfi_endproc
.LFE1493:
   .size main, .-main
   .type _Z41__static_initialization_and_destruction_0ii, @function
_Z41__static_initialization_and_destruction_0ii:
.LFB1982:
   .cfi_startproc
   pushq %rbp
   .cfi_def_cfa_offset 16
   .cfi_offset 6, -16
   movq %rsp, %rbp
   .cfi_def_cfa_register 6
   subq $16, %rsp
   movl %edi, -4(%rbp)
   movl %esi, -8(%rbp)
   cmpl $1, -4(%rbp)
   jne .L5
   cmpl $65535, -8(%rbp)
   jne .L5
   leaq _ZStL8__ioinit(%rip), %rdi
   call _ZNSt8ios_base4InitC1Ev@PLT
   leaq __dso_handle(%rip), %rdx
   leaq _ZStL8__ioinit(%rip), %rsi
   movq _ZNSt8ios_base4InitD1Ev@GOTPCREL(%rip), %rax
   movq %rax, %rdi
   call __cxa_atexit@PLT
.L5:
   nop
leave
   .cfi_def_cfa 7, 8
   ret
   .cfi_endproc
.LFE1982:
   .size _Z41__static_initialization_and_destruction_0ii,
.-_Z41__static_initialization_and_destruction_0ii
.type _GLOBAL__sub_I_main, @function
_GLOBAL__sub_I_main:
.LFB1983:
   .cfi_startproc
   pushq %rbp
   .cfi_def_cfa_offset 16
   .cfi_offset 6, -16
   movq %rsp, %rbp
   .cfi_def_cfa_register 6
   movl $65535, %esi
   movl $1, %edi
   call _Z41__static_initialization_and_destruction_0ii
   popq %rbp
   .cfi_def_cfa 7, 8
   ret
   .cfi_endproc
.LFE1983:
   .size _GLOBAL__sub_I_main, .-_GLOBAL__sub_I_main
   .section .init_array,"aw"
   .align 8
   .quad _GLOBAL__sub_I_main
   .hidden __dso_handle
   .ident "GCC: (Ubuntu 7.3.0-16ubuntu3) 7.3.0"
   .section .note.GNU-stack,"",@progbits