objdump输出 - 列代表什么?

时间:2011-08-01 04:23:14

标签: assembly objdump

我在目标文件上运行objdump -r并得到以下输出。每个列代表什么?我可能错过了它,但文档没有指定。

simple.o:     file format elf64-x86-64


Disassembly of section .text:
0000000000000000 <main>:
   0:   55                      push   %rbp
   1:   48 89 e5                mov    %rsp,%rbp
   4:   48 83 ec 30             sub    $0x30,%rsp
   8:   64 48 8b 04 25 28 00    mov    %fs:0x28,%rax
   f:   00 00 
  11:   48 89 45 f8             mov    %rax,-0x8(%rbp)
  15:   31 c0                   xor    %eax,%eax
  17:   c7 45 d8 00 00 00 00    movl   $0x0,-0x28(%rbp)
  1e:   eb 64                   jmp    84 <main+0x84>
  20:   8b 45 d8                mov    -0x28(%rbp),%eax
  23:   89 c7                   mov    %eax,%edi
  25:   e8 00 00 00 00          callq  2a <main+0x2a>
                        26: R_X86_64_PC32       foo-0x4
  2a:   89 45 dc                mov    %eax,-0x24(%rbp)
  2d:   8b 55 dc                mov    -0x24(%rbp),%edx
  30:   48 8d 45 e0             lea    -0x20(%rbp),%rax

2 个答案:

答案 0 :(得分:8)

不是自我解释:

偏移,机器代码,相应的汇编代码

答案 1 :(得分:0)

正如 Peter Cordes 所坚持的那样,在不同的操作系统上存在细微差别。

链接:https://stackoverflow.com/a/67618638/575842