objdump为使用和不使用-fPIC生成的目标文件提供相同的输出

时间:2018-04-01 19:35:01

标签: c++ gcc position-independent-code

我有两个文件,a.h和a.cpp:

// a.h
extern "C" void a();

// a.cpp
#include "a.h"
#include <stdio.h>

void a()
{
    printf("a\n");
}

我使用和不使用-fPIC编译了这个,然后objdump编辑了这两个。 奇怪的是,我得到了两个文件的相同输出。对于a(),我在两种情况下都会得到这个:

callq 15 <a+0x15>

我还尝试使用-no-pie编译目标文件,但仍然没有运气。

2 个答案:

答案 0 :(得分:1)

默认情况下,objdump不执行重定位处理。请改为objdump --reloc

在您的情况下,编译器和汇编器会生成R_X86_64_PLT32重定位。这是一个与职位无关的搬迁。您的编译器似乎默认生成PIE二进制文件。 -no-pie是链接器标志,您需要使用-fno-pie来更改编译器输出。 (在这种特殊情况下,无关紧要,因为在链接编辑器运行后,最终结果将是相同的。)

答案 1 :(得分:1)

以详细模式(-v)编译代码(或任何内容),检查输出, 你会发现:

Configured with:  ... --enable-default-pie ...

,因为GCC 6,意味着工具链是为了编译PIC代码和链接而构建的 默认情况下是PIE可执行文件。

要坚持非PIC编译,请运行例如

g++ -Wall -c -fno-PIC -o anopic.o a.cpp

要坚持PIC编译,请运行例如

g++ -Wall -c -fPIC -o apic.o a.cpp

然后运行:

$ objdump -d anopic.o 

anopic.o:     file format elf64-x86-64


Disassembly of section .text:

0000000000000000 <a>:
   0:   55                      push   %rbp
   1:   48 89 e5                mov    %rsp,%rbp
   4:   bf 00 00 00 00          mov    $0x0,%edi
   9:   e8 00 00 00 00          callq  e <a+0xe>
   e:   90                      nop
   f:   5d                      pop    %rbp
  10:   c3                      retq     

$ objdump -d apic.o 

apic.o:     file format elf64-x86-64


Disassembly of section .text:

0000000000000000 <a>:
   0:   55                      push   %rbp
   1:   48 89 e5                mov    %rsp,%rbp
   4:   48 8d 3d 00 00 00 00    lea    0x0(%rip),%rdi        # b <a+0xb>
   b:   e8 00 00 00 00          callq  10 <a+0x10>
  10:   90                      nop
  11:   5d                      pop    %rbp
  12:   c3                      retq

你会发现差异。

您可以通过以下方式将重定位与程序集交错:

$ objdump --reloc -d anopic.o 

anopic.o:     file format elf64-x86-64


Disassembly of section .text:

0000000000000000 <a>:
   0:   55                      push   %rbp
   1:   48 89 e5                mov    %rsp,%rbp
   4:   bf 00 00 00 00          mov    $0x0,%edi
            5: R_X86_64_32  .rodata
   9:   e8 00 00 00 00          callq  e <a+0xe>
            a: R_X86_64_PC32    puts-0x4
   e:   90                      nop
   f:   5d                      pop    %rbp
  10:   c3                      retq

$ objdump --reloc -d apic.o 

apic.o:     file format elf64-x86-64


Disassembly of section .text:

0000000000000000 <a>:
   0:   55                      push   %rbp
   1:   48 89 e5                mov    %rsp,%rbp
   4:   48 8d 3d 00 00 00 00    lea    0x0(%rip),%rdi        # b <a+0xb>
            7: R_X86_64_PC32    .rodata-0x4
   b:   e8 00 00 00 00          callq  10 <a+0x10>
            c: R_X86_64_PLT32   puts-0x4
  10:   90                      nop
  11:   5d                      pop    %rbp
  12:   c3                      retq