]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commit - gdb/ada-lang.c
[Ada/funcalls] do not coerce fat pointers on the stack
authorJoel Brobecker <brobecker@gnat.com>
Mon, 4 Oct 2010 22:32:31 +0000 (22:32 +0000)
committerJoel Brobecker <brobecker@gnat.com>
Mon, 4 Oct 2010 22:32:31 +0000 (22:32 +0000)
commit40bc484cc36df02f9fe0177a129cef7ab82b8ec3
treea8d2e4caf8bd5b6772fec41c4604cb4dca485481
parentf17618eaf3b901702ad17e3168019a0047a4dda4
[Ada/funcalls] do not coerce fat pointers on the stack

When one of the parameter values in a subprogram calls is an array
whose value does not come from inferior memory, the debugger first
copies the array value in inferior memory.  Up to now, the memory
used to hold that copy was taken from the stack (just below the SP),
but this is causing problems on SPARC v9.

So the immediate fix is to follow what C does with arrays and strings,
which is allocate memory on the heap.

gdb/ChangeLog:

        * ada-lang.c: #include "value.h".
        (ensure_lval): Delete advance declaration.  Remove gdbarch and sp
        arguments.  Implement using value_allocate_space_in_inferior
        instead of allocating memory from the stack.
        (make_array_descriptor): Remove gdbarch and sp parameters.  Update
        calls to ensure_lval.
        (ada_convert_actual): Remove gdbarch and sp parameters.  Update
        calls to make_array_descriptor and ensure_lval.
        * ada-lang.h (ada_convert_actual): Update declaration.
        * infcall.c (value_arg_coerce): Update call to ada_convert_actual.
gdb/ChangeLog
gdb/ada-lang.c
gdb/ada-lang.h
gdb/infcall.c