首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Objdump反汇编与源代码不匹配

Objdump反汇编与源代码不匹配
EN

Stack Overflow用户
提问于 2017-10-17 22:39:06
回答 1查看 722关注 0票数 2

我正在研究链接到libgomp的OpenMP程序的执行流程。它使用#pragma omp parallel for。我已经知道,除其他外,这个构造变成了对GOMP_parallel函数的调用,其实现方式如下:

代码语言:javascript
复制
void
GOMP_parallel (void (*fn) (void *), void *data, 
               unsigned num_threads, unsigned int flags)
{
   num_threads = gomp_resolve_num_threads (num_threads, 0);
   gomp_team_start (fn, data, num_threads, flags, gomp_new_team (num_threads));
   fn (data);
   ialias_call (GOMP_parallel_end) ();
}

在libgomp上执行objdump -d时,GOMP_parallel显示为:

代码语言:javascript
复制
000000000000bc80 <GOMP_parallel@@GOMP_4.0>:
bc80:   41 55                   push   %r13
bc82:   41 54                   push   %r12
bc84:   41 89 cd                mov    %ecx,%r13d
bc87:   55                      push   %rbp
bc88:   53                      push   %rbx
bc89:   48 89 f5                mov    %rsi,%rbp
bc8c:   48 89 fb                mov    %rdi,%rbx
bc8f:   31 f6                   xor    %esi,%esi
bc91:   89 d7                   mov    %edx,%edi
bc93:   48 83 ec 08             sub    $0x8,%rsp
bc97:   e8 d4 fd ff ff          callq  ba70 <GOMP_ordered_end@@GOMP_1.0+0x70>
bc9c:   41 89 c4                mov    %eax,%r12d
bc9f:   89 c7                   mov    %eax,%edi
bca1:   e8 ca 37 00 00          callq  f470 <omp_in_final@@OMP_3.1+0x2c0>
bca6:   44 89 e9                mov    %r13d,%ecx
bca9:   44 89 e2                mov    %r12d,%edx
bcac:   48 89 ee                mov    %rbp,%rsi
bcaf:   48 89 df                mov    %rbx,%rdi
bcb2:   49 89 c0                mov    %rax,%r8
bcb5:   e8 16 39 00 00          callq  f5d0 <omp_in_final@@OMP_3.1+0x420>
bcba:   48 89 ef                mov    %rbp,%rdi
bcbd:   ff d3                   callq  *%rbx
bcbf:   48 83 c4 08             add    $0x8,%rsp
bcc3:   5b                      pop    %rbx
bcc4:   5d                      pop    %rbp
bcc5:   41 5c                   pop    %r12
bcc7:   41 5d                   pop    %r13
bcc9:   e9 32 ff ff ff          jmpq   bc00 <GOMP_parallel_end@@GOMP_1.0>
bcce:   66 90                   xchg   %ax,%ax

首先,例如,在GOMP_ordered_end的源代码中没有对GOMP_parallel的任何调用。第二,这一职能包括:

代码语言:javascript
复制
void
GOMP_ordered_end (void)
{
}

根据objdump输出,此函数从ba00开始,在bbbd结束。它怎么会在一个空函数中有这么多代码呢?顺便说一句,libgomp的源代码中有评论说,只有在使用有序结构时(顾名思义),它才会出现,这不是我的测试的情况。

最后,我主要关心的是:为什么源代码与反汇编有如此大的不同?例如,为什么在程序集中没有提到gomp_team_start

该系统具有gcc版本5.4.0

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-10-18 08:57:02

根据objdump输出,此函数从ba00开始,在bbbd结束。它怎么会在一个空函数中有这么多代码呢?

函数本身很小,但是GCC只是使用一些额外的字节来对齐下一个函数,并存储一些静态数据(可能是这个文件中的其他函数使用的)。这里是我在本地ordered.o中看到的

代码语言:javascript
复制
00000000000003b0 <GOMP_ordered_end>:
 3b0:   f3 c3                   repz retq
 3b2:   66 66 66 66 66 2e 0f    data32 data32 data32 data32 nopw %cs:0x0(%rax,%rax,1)
 3b9:   1f 84 00 00 00 00 00

首先,例如,在GOMP_ordered_end的源代码中没有对GOMP_parallel的任何调用。

不要因装配代码中的GOMP_ordered_end@@GOMP_1.0+0x70标记而分心。它只表示调用了一些本地库函数( objdump没有找到任何符号信息),该函数恰好位于GOMP_ordered_end之后的112个字节。这很可能是gomp_resolve_num_threads

例如,为什么在程序集中没有提到gomp_team_start?

嗯,这个看起来很像:

代码语言:javascript
复制
bcb5:   e8 16 39 00 00          callq  f5d0 <omp_in_final@@OMP_3.1+0x420>
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46804270

复制
相关文章

相似问题

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