Mirror of the gdb mailing list
 help / color / mirror / Atom feed
* Re: 64bit pointer
@ 2009-09-03 13:27 freindlyuser
  0 siblings, 0 replies; 5+ messages in thread
From: freindlyuser @ 2009-09-03 13:27 UTC (permalink / raw)
  To: Jan Kratochvil; +Cc: gdb

-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1

On Thu, 03 Sep 2009 12:33:25 +0000 Jan Kratochvil
<jan.kratochvil@redhat.com> wrote:
>On Thu, 03 Sep 2009 14:21:41 +0200, freindlyuser@hushmail.com
>wrote:
>> (gdb) x/s *($rdi+0x8)
>> 0x4210a9b7:      <Address 0x4210a9b7 out of bounds>
>
>This syntax is not much recommended, it means the same as:
>
>(gdb) x/s *(int *) ($rdi+0x8)
>0x4210a9b7:      <Address 0x4210a9b7 out of bounds>
>
>On 64bit arch sizeof (int) == 4 but sizeof (void *) == 8 so you
>will not fetch
>the whole address.
>
>
>> (gdb) x/x $rdi+0x8
>> 0x3a9b4210b7a4: 0x00003a9b4210a9b7
>> (gdb) x/s 0x00003a9b4210a9b7
>> 0x3a9b4210a9b7:  "The string it points to"
>
>Therefore you want one indirection there.
>
>> Should this be happening?
>
>Yes.  Until GDB forbids dereferencing numeric arguments as `int *'
>which IMHO
>is more confusing than convenient.  [Would a patch be approved?]
>
>
>> Is there a work around where I can read the data in
>> 0x00003a9b4210a9b7 without having to manually copy and paste
>(ie:
>> in the commands that are executed on a breakpoint).
>
>This way it should work:
>
>(gdb) x/s *(void **) ($rdi+0x8)
>OR
>(gdb) p *(char **) ($rdi+0x8)
>
>
>Regards,
>Jan

The work around works perfectly.

Thank you.
-----BEGIN PGP SIGNATURE-----
Charset: UTF8
Version: Hush 3.0
Note: This signature can be verified at https://www.hushtools.com/verify

wpwEAQMCAAYFAkqfxDYACgkQWX1/rrecYT2g+gP+J6na4+MXovA7SJRD1oYPKqbZ9Pu1
Ik4vBR5BFt6RLV0zrYXsAnEq1xOXnac1q3r9XNUA0R1jmKtEFYvJjH44KpdzwIwBBRSS
7M7qeaHZZhDEgfJOFUgWS5KUJgjwRo4Rm2lGLNgmaftQVBrgE5HUQxVicwtdwIO9qyhU
i/n0Oas=
=+lL9
-----END PGP SIGNATURE-----


^ permalink raw reply	[flat|nested] 5+ messages in thread
* 64bit pointer
@ 2009-09-03 12:21 freindlyuser
  2009-09-03 12:33 ` Jan Kratochvil
  2009-09-03 13:01 ` Andreas Schwab
  0 siblings, 2 replies; 5+ messages in thread
From: freindlyuser @ 2009-09-03 12:21 UTC (permalink / raw)
  To: gdb

-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1

I didn't know if this was a bug or if I was just doing something
wrong. Basically when I try to use * to get the value pointed to by
something it gives me 32 bits of the pointer which is actually a
64bit address.


(gdb) x/s *($rdi+0x8)
0x4210a9b7:      <Address 0x4210a9b7 out of bounds>
(gdb) x/x $rdi+0x8
0x3a9b4210b7a4: 0x00003a9b4210a9b7
(gdb) x/s 0x00003a9b4210a9b7
0x3a9b4210a9b7:  "The string it points to"

In the above I wanted to read the string pointed to by the pointer
at $rdi+0x8

Should this be happening?
Should I be using a different command or something different to the
asterisk?
Is there a work around where I can read the data in
0x00003a9b4210a9b7 without having to manually copy and paste (ie:
in the commands that are executed on a breakpoint).

Thank you.
-----BEGIN PGP SIGNATURE-----
Charset: UTF8
Version: Hush 3.0
Note: This signature can be verified at https://www.hushtools.com/verify

wpwEAQMCAAYFAkqftNQACgkQWX1/rrecYT2pBgP/RVbdltSzvOihdHAKfpweEjXQ7U1T
f2xyz8uRhyPZQ2n1w2nA/IyU79LyB3sIUcoZ+CkxX0VPh34W8Kw00XfWYq85C3dSW9vm
ibLw6AIE5CVcvz39wX/68s4qEYS/BdpetltS3sEeKswV7ylCjNajtFwu2h5WIxsVhdop
kkXuBfA=
=l5hi
-----END PGP SIGNATURE-----


^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2009-09-04 15:47 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2009-09-03 13:27 64bit pointer freindlyuser
  -- strict thread matches above, loose matches on Subject: below --
2009-09-03 12:21 freindlyuser
2009-09-03 12:33 ` Jan Kratochvil
2009-09-04 15:47   ` Tom Tromey
2009-09-03 13:01 ` Andreas Schwab

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox