c - 返回地址 GDB : . exe 与 .elf 不同?

标签 c windows cmd gdb elf

我正在使用 GDB 在我的 C 代码中返回一个local 静态变量的地址(在本例中为 pressureResult2),这对于 ARM 输出工作正常:.elf 文件。

但是,如果我使用 Windows 的构建配置,创建一个 .exe,则无法找到我要求的变量。

我用什么来返回变量的地址:

sensorOffset::pressureResult2

代码:

static void sensorOffset (uint8_t axle)
{
  static int16_t pressureResult2 = 400;
  int16_t pressureResult = 0;
  if (axle == AXLE_FRONT)
  {
   /* Always copy the actual value first to the value with offset */
   CtisMach.front.tPressureSensorOffset = CtisMach.front.tPressureAct;
   .... and so on

有人知道这个问题吗? Windows 可执行文件的命令是否不同?还是我只是做错了什么?

要找出最明显的:

你能读取全局静态吗?

是的,没问题

GDB 是否注意到有关调试符号的任何信息?

不,出现了通常的“从 file.exe 读取符号 .. 完成”。

它可以与 .elf 一起使用吗?

是的,确实如此。

回复评论:

代码编译如下:

 cflags := \
    -O0 \
    -g3 \
    -Wall \
    -c \
    -MD \
    -fmessage-length=0 \
    -fpermissive \
    -I/mingw/include \
    -I/usr/include \
    -I/local/include \
    -D WINDOWS \
    $(CONFIGFLAGS) \
    $(INCLUDES)

 lnkflags := \
     -Wl,--enable-stdcall-fixup \
     -static-libgcc \
     -static-libstdc++ \
     $(CONFIGFLAGS) \
    $(EXT_LIBDIR)

 od_flags := \
    --dwarf

因为我已经提到它不会提示调试变量符号我也可以阅读全局静态这似乎不是问题,或者我错了吗?它应该提示没有 -g 就没有调试符号,对吗? 编辑:Andreas 重现了这种情况,但我似乎仍然无法修复它。

对变量做任何有用的事情:

static int16_t pressureResult2 = 0;

if (pressureResult2 < 100)
{
  pressureResult2++;
}
else
{
  pressureResult2 = 0;
} 

注意:这只是一个示例,代码中的所有局部静态变量都存在相同的问题(太大而无法在 SO 上转储)。

GDB 对“信息变量”的响应,我的变量“pressureResult2”位于非调试符号类别中,这可能是问题所在吗?

GDB response on "Info variables"

在没有 -g 的情况下,查看 -g 标志是否真的在做某事:

p& randomvar
$1 = (<data variable, no debug info> *) 0x4eade2 <randomvar>

用-g

p& randomvar    
$1 = (uint16_t *) 0x4eade2 <randomvar>

所以它肯定是活跃的,但它仍然不可能返回局部静态。 到目前为止唯一值得注意的事情是如何将我正在寻找的变量分类为非调试符号

编译 Andreas 的代码片段可以工作,包括返回变量的地址,但是我自己的代码,不多。

最佳答案

很可能,您需要将 -g 标志添加到编译器调用以添加调试信息,删除优化标志,例如 -O2。给定以下 .c 源文件,在 MS Windows 上使用 cygwin 环境:

#include <stdio.h>

static int globalstatic = 512;

static void sensorOffset (uint8_t axle) {
  static int16_t pressureResult2 = 400;

  pressureResult2++;
  printf("%d %d\n", globalstatic, pressureResult2);
}

int main() {
   int i = 0;
   for (i = 0;  i < 10;  i++) {
       sensorOffset(42);
   }
   return 0;
}

当使用 -O2 编译为 .exe 文件时,您的观察是可重现的 - gdb 识别全局静态变量,但不识别本地变量(即使 -g 已指定):

C:> gcc -g -O2 -Wall -pedantic -o static static.c

C:> gdb static.exe
(gdb) break main
(gdb) run
Breakpoint 1, main () at static.c:14
14      int main() {    Breakpoint 1, 0x0000000100401128 in main ()
(gdb) print globalstatic
$1 = 512
(gdb) print sensorOffset::pressureResult2
No symbol "sensorOffset" in current context.

当删除 -O2 标志时,gdb 确实识别局部静态变量:

C:> gcc -g -Wall -pedantic -o static static.c

C:> gdb static.exe
(gdb) break main
(gdb) run
Breakpoint 1, main () at static.c:12
12         int i = 0;
(gdb) print sensorOffset::pressureResult2
$1 = 400

关于c - 返回地址 GDB : . exe 与 .elf 不同?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33102550/

相关文章:

c - 如何递归计算 "x"元素之前所有元素的总和?

java - 从 java 应用程序中获取用户名 (windows)

batch-file - 如何使用命令提示符删除除一个文件夹及其内容之外的所有文件夹?

c - 如何按字母顺序对字符串中的单词进行排序

c - 线程矩阵乘法 : Why is it not faster?

C 代码在 Windows 中崩溃,但在 Linux 中不会

c# - 在 PC 中使用网络摄像头作为环境光传感器

powershell - 无法将Batch变量设置为命令输出

ios - CMD - 获取 iPhone 的 MAC 地址

c++ - 使用 clang llvm 检查变量是否在任意源位置具有范围