[lldb-dev] What's the difference between GetLocation, AddressOf and GetLoadAddress

Ziming Song s.ziming at hotmail.com
Mon Mar 30 19:59:47 PDT 2015


Every time the process stops, I use SBFrame::GetVariables to get to variable list and display them in the "variable" window. Since variable within different scope may have same name, I want to use the address of the variable to check if they are same. For example, when the process first stop, I got a variable "a" at address 0x123. While on the next stop, I got a variable "a" at address 0x456, so I know these two "a" are different variables.
If variable can also be in register, how can I know if two variables got from two stop are the same. Is there a way to get the identity of variables?
PS: I know there's a function SBValue::GetID, but that seems to return different result on different stop.> Subject: Re: [lldb-dev] What's the difference between GetLocation, AddressOf and GetLoadAddress
> From: gclayton at apple.com
> Date: Mon, 30 Mar 2015 13:03:14 -0700
> CC: lldb-dev at cs.uiuc.edu
> To: s.ziming at hotmail.com
> 
> If your variables are both pointers, then you just get the value as unsigned:
> 
> SBValue value1 = ...;
> SBValue value2 = ...;
> if (value1.GetType().IsPointerType() && value2.GetType().IsPointerType())
> {
>     if (value1.GetValueAsUnsigned() == value2.GetValueAsUnsigned())
>     {
>         // Pointers are the same
>     }
> }
> 
> 
> 
> > On Mar 30, 2015, at 11:50 AM, Ziming Song <s.ziming at hotmail.com> wrote:
> > 
> > I want to know if two pointer point to the same variable, so I want to get the location of each variable and the value of the pointer.
> > In the API doc, I found three functions that seem to do the work, they are:
> > 
> > - SBValue::GetLocation -> const char*
> > - SBValue::AddressOf -> SBValue
> > - SBValue::GetLoadLocation -> addr_t (uint64_t)
> > 
> Why do you want the location? A pointer will often be in a register like "rax". And if a pointer is on the stack, why do you want the address of the pointer (which is what SBValue::GetLocation() would tell you)?
> 
> So: SBValue::GetLocation() will tell you where a variable is stored. It might be something like "rax" when it is in a register. Or some address when it is on the stack, heap or .data section. But this is the location of the value itself (address of the pointer). 
> 
> SBValue::AddressOf() will return a new SBValue that represents the address of the value itself. If your variable is in a register, this will be invalid. If you already have a pointer like a "Foo *", then calling AddressOf will return you a value that is a "Foo **".
> 
> If you want to know if something is loaded in memory and not in a register, you can call SBValue::GetLoadLocation() which will only return a valid address _if_ the value is actually in memory. If you have a pointer that is in "rax" you will get back LLDB_INVALID_ADDRESS.
> 
> So to sum up: if you have a SBValue that represents a pointer, you can ask the value for its value as unsigned using SBValue::GetValueAsUnsigned() since that will be the pointer value itself. You don't want the location (the address of) the value. The SBValue::AddressOf() can be used on a variable that is actually an instance of "Foo". So if you have a variable whose type is "Foo", and a pointer to a "Foo":
> 
> SBValue foo1 = get_instance_of_foo();
> SBValue foo2 = get_pointer_to_foo();
> 
> You can still check if these point to the same instance if you wanted to:
> 
> lldb::addr_t foo1_load_location = LLDB_INVALID_ADDRESS;
> lldb::addr_t foo2_load_location = LLDB_INVALID_ADDRESS;
> if (foo1.GetType().IsPointerType())
>     foo1_load_location = foo1.GetValueAsUnsigned();
> else
>     foo1_load_location = foo1.GetLoadLocation();
> 
> if (foo2.GetType().IsPointerType())
>     foo2_load_location = foo2.GetValueAsUnsigned();
> else
>     foo2_load_location = foo2.GetLoadLocation();
> 
> if (foo1_load_location == foo2_load_location && foo2_load_location != LLDB_INVALID_ADDRESS)
> {
>     // Two SBValue represent the same value in memory
> }
> 
> Again you really need to understand what you are asking of the value.
> 
> 
> Greg Clayton
> 
 		 	   		  
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/lldb-dev/attachments/20150331/52af4e50/attachment.html>


More information about the lldb-dev mailing list