我需要print addresses of all local variables in C,为此我正在尝试使用GDB脚本。
我正在使用下面的gdb脚本首先我在main上设置了一个断点,一旦遇到这个断点,我在下一行设置了一个断点,然后在程序的每一行单步执行。
甚至可以使用next代替step执行到下一行但我需要使用step进入函数,因为next不会这样做。

b main
 commands 1
     while 1
        info locals      //some code needed to print addresses
        b
        step
     end
 end

run

但是,命令“step”也会进入库函数有没有一种方法可以有条件地运行“step”命令,使其不进入库函数当我的GCC Plugin返回程序时,我将有一个程序中使用的函数和变量的列表我是否可以使用if语句,该语句仅在遇到用户定义的函数时执行步骤,否则使用next语句?
commands 1
    while 1
       info locals
       b
       if   //function name belongs to a predefined set
         step
       else
         next
       end
    end
end

我想了解更多关于GDB脚本语言的信息,但是我找不到足够的资料我还需要知道我们是否可以声明数组、字符串并对它们执行比较和其他操作。

最佳答案

我会有一个在程序中使用的函数和变量的列表
它由我的GCC插件返回。
由于您有一个已声明的函数名列表,因此在脚本的开头,在列表中的每个函数上添加断点,现在运行它,在每次中断后运行逻辑以打印地址,然后继续。
例如:
掠夺:

void fn1()
{
  int j = 0;
  printf("I am in fn 1");
}

void fn2()
{
  int k = 0;
  printf("I am in fn 2");
}

int main()
{
  int i = 0;
  fn1();
  printf("I am in main");
  fn2();
}

gdb成绩单:
(gdb) b main
Breakpoint 1 at 0x400575: file surya.c, line 15.
(gdb) b fn1
Breakpoint 2 at 0x400535: file surya.c, line 3.
(gdb) b fn2
Breakpoint 3 at 0x400555: file surya.c, line 9.
(gdb) r
Starting program: /home/mohit/test/a.out
warning: the debug information found in "/lib64/ld-2.19.so" does not match "/lib64/ld-linux-x86-64.so.2" (CRC mismatch).


Breakpoint 1, main () at surya.c:15
15    int i = 0;
(gdb) p &i
$1 = (int *) 0x7fffffffdf7c
(gdb) c
Continuing.

Breakpoint 2, fn1 () at surya.c:3
3     int j = 0;
(gdb) p &j
$2 = (int *) 0x7fffffffdf5c
(gdb) c
Continuing.

Breakpoint 3, fn2 () at surya.c:9
9     int k = 0;
(gdb) p &k
$3 = (int *) 0x7fffffffdf5c
(gdb)

关于c - 编写GDB脚本以收集数据,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/30910750/

10-15 22:03