[PATCH 13/13] Document "no debug info debugging" improvements

Pedro Alves palves@redhat.com
Thu Jul 13 13:51:00 GMT 2017


On 07/13/2017 12:09 PM, Pedro Alves wrote:

> I woke up thinking that mapping to unprototyped is the wrong
> equivalence -- that it'd be better to assume the function is
> prototyped, since that's how most C functions are written as
> nowadays.  Also, there's no such thing as an unprototyped
> function in C++.
> 
> Assuming prototyped would allow this, for example:
> 
>     float mult (float v1, float v2) { return v1 * v2; }
> 
>     (gdb) p (float) mult (2.0f, 3.0f)
>     $1 = 6
>     (gdb) p (float) mult ((float) 2, (float) 3)
>     $2 = 6
>     (gdb) p ((float (*) (float, float)) mult) (2, 3)
>     $3 = 6
> 
>     (gdb) ptype 2.0f
>     type = float
>     (gdb) ptype 2.0
>     type = double
> 
> If the function really is unprototyped, then you'd still be
> able to call it correctly via the function pointer cast syntax:
> 
>     float mult_noproto (v1, v2)
>        float v1, v2;
>     { return v1 * v2; }
> 
>     (gdb) p ((float (*) ()) mult_noproto) (2.0f, 3.0f)
>     $1 = 6
>     (gdb) p ((float (*) ()) mult_noproto) (2.0, 3.0)
>     $2 = 6
>     (gdb) p ((float (*) ()) mult_noproto) ((float) 2, (float) 3)
>     $3 = 6
> 
> I'll give this a try, and add those as tests to gdb.base/nodebug.exp.

This worked nicely, see below.

I'll tweak the docs, and send an updated patch.

Thanks,
Pedro Alves



More information about the Gdb-patches mailing list