我在Trace32
中使用过C代码,我想在Trace32
中读取C宏的值。怎么做?宏值是否会存储在某个寄存器中?
例如:
#define DEST_ADD = 0xE432;
address = htonl(DEST_ADD);
如何阅读DEST_ADD
中的宏Trace32
的值?
答案 0 :(得分:3)
宏通常由预处理器替换为其内容。因此编译器不再“看到”宏名称,因此无法在ELF文件中为其创建调试信息。因此,任何调试器都无法知道宏的名称。
但是,某些编译器支持为预处理器宏生成调试信息。例如。如果您将GCC与调试级别3(gcc -g3
)一起使用,编译器会在ELF文件中创建一个名为“.debug_macro”的部分。
如果您的ELF包含“.debug_macro”部分,则必须通过使用选项“/ MACRO”告诉TRACE32在加载ELF时考虑此部分。所以你加载你的ELF,例如
Data.LOAD.Elf * /MACRO
然后,您可以在sYmbol.List.MACRO
窗口中查看所有预处理器宏,或在Var.WATCH
窗口中使用其中任何一个宏,或使用Var.VALUE()
功能访问它们或使用{打印它们{1}}命令。 E.g:
Var.PRINT
答案 1 :(得分:1)
C预处理器会将代码中的宏替换为它们的值,因此宏很可能不会在生成的目标文件中存在。但是,您只需打印变量的值:
Var.PRINT <variable>
您可能还想查看此内容:How to check if a macro exists in an object file in C?