断点有两个地址?

时间:2016-09-06 19:58:05

标签: debugging assembly gdb breakpoints

我最近设置了一个断点,其初始地址为:

(gdb) b viewscreen_movieplayerst::create(char, viewscreenst*)
Breakpoint 1 at 0x804beec

,第二个(通常的地址)是:

   (gdb) run

   Breakpoint 1, 0xf7b46630 
   in viewscreen_movieplayerst::create(char,viewscreenst*)()
   from/path/libs/libgraphics.so

这是因为可执行文件被剥离了吗?或者执行可执行文件并在执行后更改地址?

另外,主要是:

(gdb) b main 
Breakpoint 1 at 0x804bdec

这似乎与地址非常接近,所以我将其包括在内。

修改

What does the concept of relocation mean?

So most of the binary is composed of reloc table?

1 个答案:

答案 0 :(得分:4)

也许您在Unix上看到来自共享库函数的Procedure Linkage Table(PLT)地址?

编译器构建了一个蹦床'间接引用共享库依赖项的地址。这是一个复杂的主题,有一篇详细的文章here

这是一个简单的例子。

lib.cpp

#include <iostream>


int foo()
{
  return 0;
}

junk.cpp

#include<iostream>

int foo();
int main(int argc, char* argv[])
{
  int k = foo();
  return 0;
}

编译

/tmp$ g++ -fPIC -g -std=c++11 -shared -o libtest_library.so lib.cpp
/tmp$ g++  -g -std=c++11  -o tramp junk.cpp -L . -l test_library

gdb tramp

Reading symbols from tramp...done.
(gdb) p foo
$1 = (<text from jump slot in .got.plt, no debug info>) 0x4006d6 <foo()@plt+6>
(gdb) b foo
Breakpoint 1 at 0x4006d0
(gdb) d 1
(gdb) r
Starting program: /tmp/tramp 
lib:  0x602010
[Inferior 1 (process 12804) exited normally]
(gdb) b foo
Breakpoint 2 at 0x4006d0 (2 locations)
(gdb) info break
Num     Type           Disp Enb Address            What
2       breakpoint     keep y   <MULTIPLE>         
2.1                         y     0x00000000004006d0 <foo()@plt>
2.2                         y     0x00002aaaaacd0a99 in foo() at lib.cpp:6

正如你可以看到符号“foo&#39;有两个地址和两个断点。一个是PLT,另一个是共享库中的符号位置。

如注释所述,模板实例化和编译器优化还可以为一个符号或源代码行创建多个地址。