diff options
author | Joel Brobecker <brobecker@gnat.com> | 2013-05-13 10:27:35 +0000 |
---|---|---|
committer | Joel Brobecker <brobecker@gnat.com> | 2013-05-13 10:27:35 +0000 |
commit | 36d1c68c70a09d38d76faa82263d16269139033c (patch) | |
tree | c49ae87ce7a151cf9e1ffaa7e04fc94ce73995cb /gdb/ChangeLog | |
parent | 8414efeff8a66b8471e7a372fafffb9624cb499f (diff) | |
download | gdb-36d1c68c70a09d38d76faa82263d16269139033c.zip gdb-36d1c68c70a09d38d76faa82263d16269139033c.tar.gz gdb-36d1c68c70a09d38d76faa82263d16269139033c.tar.bz2 |
Float parameter passing in funcall on ppc-aix & ppc-lynx178.
Given the following code:
float global_float = 0.0;
void
set_float (float f)
{
global_float = f;
}
GDB incorrectly calls set_float if the set_float function is marked
as prototyped:
(gdb) call set_float (5.0)
(gdb) print global_float
$1 = 2048
What happens, when the function is marked as prototyped, is that
GDB finds that the argument is a float, casts the value given in
the expression to a float, and then gives that float to ppc-aix/
ppc-lynx178's push_dummy_call gdbarch routine. The latter then blindly
copies it as is in the first floating-point register, instead of
making sure that it has the proper format first.
gdb/ChangeLog:
* rs6000-aix-tdep.c (rs6000_push_dummy_call): Convert
floating point registers to register type before storing
value.
* rs6000-lynx178-tdep.c (rs6000_lynx178_push_dummy_call):
Likewise.
Diffstat (limited to 'gdb/ChangeLog')
-rw-r--r-- | gdb/ChangeLog | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 84159e1..e3c2c4b 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,11 @@ +2013-05-13 Joel Brobecker <brobecker@adacore.com> + + * rs6000-aix-tdep.c (rs6000_push_dummy_call): Convert + floating point registers to register type before storing + value. + * rs6000-lynx178-tdep.c (rs6000_lynx178_push_dummy_call): + Likewise. + 2013-05-10 Joel Brobecker <brobecker@adacore.com> Tom Tromey <tromey@redhat.com> |