aboutsummaryrefslogtreecommitdiff
path: root/gdb/ppc-sysv-tdep.c
diff options
context:
space:
mode:
authorMark Kettenis <kettenis@gnu.org>2008-02-02 00:07:57 +0000
committerMark Kettenis <kettenis@gnu.org>2008-02-02 00:07:57 +0000
commitf964a7562a92762d94cc8c1f6177db2989dcac15 (patch)
tree639e168efa617e66ef110cb69a3cf3903ebf9955 /gdb/ppc-sysv-tdep.c
parent3709d2edc8ba3858bac040e2b82b0fa9ee5b4adf (diff)
downloadbinutils-f964a7562a92762d94cc8c1f6177db2989dcac15.zip
binutils-f964a7562a92762d94cc8c1f6177db2989dcac15.tar.gz
binutils-f964a7562a92762d94cc8c1f6177db2989dcac15.tar.bz2
Luis Machado <luisgpm@br.ibm.com>
Thiago Jung Bauermann <bauerman@br.ibm.com> * ppc-sysv-tdep.c (ppc_sysv_abi_push_dummy_call): Pass floats that don't fit into registerson the stack the way GCC does.
Diffstat (limited to 'gdb/ppc-sysv-tdep.c')
-rw-r--r--gdb/ppc-sysv-tdep.c22
1 files changed, 13 insertions, 9 deletions
diff --git a/gdb/ppc-sysv-tdep.c b/gdb/ppc-sysv-tdep.c
index 7a87743..eea2287 100644
--- a/gdb/ppc-sysv-tdep.c
+++ b/gdb/ppc-sysv-tdep.c
@@ -129,17 +129,21 @@ ppc_sysv_abi_push_dummy_call (struct gdbarch *gdbarch, struct value *function,
}
else
{
- /* SysV ABI converts floats to doubles before
- writing them to an 8 byte aligned stack location. */
- argoffset = align_up (argoffset, 8);
+ /* The SysV ABI tells us to convert floats to
+ doubles before writing them to an 8 byte aligned
+ stack location. Unfortunately GCC does not do
+ that, and stores floats into 4 byte aligned
+ locations without converting them to doubles.
+ Since there is no know compiler that actually
+ follows the ABI here, we implement the GCC
+ convention. */
+
+ /* Align to 4 bytes or 8 bytes depending on the type of
+ the argument (float or double). */
+ argoffset = align_up (argoffset, len);
if (write_pass)
- {
- char memval[8];
- convert_typed_floating (val, type, memval,
- builtin_type_ieee_double);
write_memory (sp + argoffset, val, len);
- }
- argoffset += 8;
+ argoffset += len;
}
}
else if (TYPE_CODE (type) == TYPE_CODE_FLT