#include <stdio.h>
int main()
{
printf("a=%d; b=%d; c=%d", 1, 2, 3);
return 0;
};
我使用
gcc -g 3arg.cpp
进行编译。用objdump -d -M intel a.out
拆卸。在输出中仅存在一个名为_init
的函数,它的分解方式如下: /> 为什么最后一次拆卸不同?它甚至不是以不同的方式分解相同的数据(如在遇到断点时将
gdb
输出与objdump
命令gdb
的输出进行比较时所看到的)。如果它是不同的x/10b $rip
函数:如何在
_init
输出和objdump
中的第一个反汇编中看到一个断点? 1是在gdb
,然后在其他功能处停止了?#1 楼
要到达您的_init
函数,只需继续执行即可。这将再次在预期的位置停止。 gdb -q test.out
Reading symbols from test.out...done.
(gdb) b _init
Breakpoint 1 at 0x4003e0
(gdb) run
Starting program: /home/[censored]/stk/test.out
Breakpoint 1, _init (argc=1, argv=0x7fffffffe008, envp=0x7fffffffe018) at ../csu/init-first.c:52
52 ../csu/init-first.c: No such file or directory.
(gdb) bt
#0 _init (argc=1, argv=0x7fffffffe008, envp=0x7fffffffe018) at ../csu/init-first.c:52
#1 0x00007ffff7dea0fd in call_init (l=0x7ffff7ff74c0, argc=argc@entry=1, argv=argv@entry=0x7fffffffe008, env=env@entry=0x7fffffffe018) at dl-init.c:64
#2 0x00007ffff7dea223 in call_init (env=<optimized out>, argv=<optimized out>, argc=<optimized out>, l=<optimized out>) at dl-init.c:36
#3 _dl_init (main_map=0x7ffff7ffe1c8, argc=1, argv=0x7fffffffe008, env=0x7fffffffe018) at dl-init.c:126
#4 0x00007ffff7ddb30a in _dl_start_user () from /lib64/ld-linux-x86-64.so.2
#5 0x0000000000000001 in ?? ()
#6 0x00007fffffffe364 in ?? ()
#7 0x0000000000000000 in ?? ()
(gdb) c
Continuing.
Breakpoint 1, 0x00000000004003e0 in _init ()
(gdb) bt
#0 0x00000000004003e0 in _init ()
#1 0x0000000000400593 in __libc_csu_init ()
#2 0x00007ffff7a36e55 in __libc_start_main (main=0x40052d <main>, argc=1, argv=0x7fffffffe008, init=0x400560 <__libc_csu_init>, fini=<optimized out>, rtld_fini=<optimized out>, stack_end=0x7fffffffdff8)
at libc-start.c:246
#3 0x0000000000400469 in _start ()
(gdb) info shared
From To Syms Read Shared Object Library
0x00007ffff7ddaae0 0x00007ffff7df54e0 Yes /lib64/ld-linux-x86-64.so.2
0x00007ffff7a344a0 0x00007ffff7b79583 Yes /lib/x86_64-linux-gnu/libc.so.6
(gdb) x/10i $pc
=> 0x4003e0 <_init>: sub b *address
x8,%rsp
0x4003e4 <_init+4>: mov 0x200c0d(%rip),%rax # 0x600ff8
0x4003eb <_init+11>: test %rax,%rax
0x4003ee <_init+14>: je 0x4003f5 <_init+21>
0x4003f0 <_init+16>: callq 0x400430 <__gmon_start__@plt>
0x4003f5 <_init+21>: add (gdb) break test.c:call1
x8,%rsp
0x4003f9 <_init+25>: retq
(gdb) info breakpoints
Num Type Disp Enb Address What
1 breakpoint keep y <MULTIPLE>
breakpoint already hit 2 times
1.1 y 0x00000000004003e0 <_init>
1.2 y 0x00007ffff7a36c20 in _init at ../csu/init-first.c:52
根据有关共享库的信息,它第一次在
libc.so
的地址区域中停止,看起来也有_init
函数,这也导致gdb
也在那里设置此断点(请参见清单末尾的断点定义)。如果要在特定地址中设置断点,则可以使用
q4312078q
表示法。如果要在特定源文件中的特定功能上设置断点,则可以使用类似
q4312078q
在此处更深入地讨论同一件事。 >
祝你好运。