From 0b3f98d3508f6b8ed8a9fe14e3c3727ac2ea0d69 Mon Sep 17 00:00:00 2001 From: Andrew Cagney Date: Mon, 19 Mar 2001 20:08:16 +0000 Subject: * valops.c (hand_function_call): Simplify computation of the address of the pushed argument. --- gdb/ChangeLog | 6 ++++++ gdb/valops.c | 17 +++++------------ 2 files changed, 11 insertions(+), 12 deletions(-) diff --git a/gdb/ChangeLog b/gdb/ChangeLog index c0f110f..4490a2a 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,9 @@ +2001-03-19 Andrew Cagney + + From Mon Nov 20 13:59:29 2000 Andrew Cagney : + * valops.c (hand_function_call): Simplify computation of the + address of the pushed argument. + 2001-03-17 Andrew Cagney * p-exp.y (parse_number): Avoid shift overflow when ``long''. diff --git a/gdb/valops.c b/gdb/valops.c index d417cdc..0ab0ae6 100644 --- a/gdb/valops.c +++ b/gdb/valops.c @@ -1530,26 +1530,19 @@ You must use a pointer to function type variable. Command ignored.", arg_name); { /* stack grows downward */ sp -= aligned_len; + /* ... so the address of the thing we push is the + stack pointer after we push it. */ + addr = sp; } else { /* The stack grows up, so the address of the thing we push is the stack pointer before we push it. */ addr = sp; - } - /* Push the structure. */ - write_memory (sp, VALUE_CONTENTS_ALL (args[i]), len); - if (INNER_THAN (1, 2)) - { - /* The stack grows down, so the address of the thing - we push is the stack pointer after we push it. */ - addr = sp; - } - else - { - /* stack grows upward */ sp += aligned_len; } + /* Push the structure. */ + write_memory (addr, VALUE_CONTENTS_ALL (args[i]), len); /* The value we're going to pass is the address of the thing we just pushed. */ /*args[i] = value_from_longest (lookup_pointer_type (value_type), -- cgit v1.1