我正在尝试从我拥有的地址值创建一个 SB 值,但我遇到了 SBAddress 构造函数的问题。当我这样做时:
target = lldb.debugger.GetSelectedTarget()
pointer = target.FindFirstType('node_t').GetPointerType()
root = target.CreateValueFromAddress('root', lldb.SBAddress(0x100004058, target), pointer)
然后我跑了
root.GetValue()
我得到类似0x0000000100004041
我在这里对 SBAddress 的构造函数有什么问题吗?
你必须小心什么指向什么才能做到这一点。 0x100004058是要从中生成类型的指针的值,还是该指针的位置? 我怀疑是前者...
地址处的内存是指针的值,保存着类型为"node_t"的对象。 因此,当您想用该内存制作SBValue时,您想要的类型是"node_t"而不是"node_t *"。
但是,如果指针的位置0x100004058,则创建一个值作为指向该地址处node_t的指针是正确的。
因此,例如,停在这里:
* thread #1: tid = 0x4ae2e3, function: take_void , stop reason = breakpoint 1.1
frame #0: 0x0000000100000f33 pointers`take_void at pointers.c:12
9 void
10 take_void(void *input)
11 {
-> 12 printf("Got pointer: %p.n", input);
13 }
14
15 int
呼叫自:
15 int
16 main()
17 {
18 struct Foo my_foo = {111, 222};
19 take_void (&my_foo);
20 return 0;
21 }
然后:
(lldb) fr v -L
0x00007fff5fbff658: (void *) input = 0x00007fff5fbff670
第一个地址是输入的位置,因此:
(lldb) script
>>> ptr_type = lldb.target.FindFirstType('Foo').GetPointerType()
>>> root = lldb.target.CreateValueFromAddress("root", lldb.SBAddress(0x00007fff5fbff658, lldb.target), ptr_type)
>>> root.GetValue()
'0x00007fff5fbff670'
这是你所期望的。 和:
>>> root = lldb.target.CreateValueFromAddress("root", lldb.SBAddress(0x00007fff5fbff670, lldb.target), type)
>>> root.GetValue()
没错,因为结构没有价值。 和:
>>> root.GetChildAtIndex(0).GetValue()
'111'
>>> root.GetChildAtIndex(1).GetValue()
'222'
这些是我放在字段中的值,所以这是正确的。 和:
>>> root = lldb.target.CreateValueFromAddress("root", lldb.SBAddress(0x00007fff5fbff670, lldb.target), ptr_type)
>>> root.GetValue()
'0x000000de0000006f'
(这可能是你犯的错误)也是有道理的,因为0xde是 222,0x6f是 111,而我在一个小端系统上......
我正在使用SBValue
自己的CreateValueFromAddress
方法。它没有很好地记录,但我已经弄清楚了参数,它们比目标的参数更简单。这样使用它(不需要特殊的地址函数,只需普通+运算符):
offset_in_bytes = base_address + some_offset
some_other_sbvalue.CreateValueFromAddress("name-of-new-value", offset_in_bytes, value_type)