From: Andrew Cagney Date: Mon, 19 Mar 2001 20:08:16 +0000 (+0000) Subject: * valops.c (hand_function_call): Simplify computation of the X-Git-Tag: dberlin-typesystem-branchpoint~1001 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=0b3f98d3508f6b8ed8a9fe14e3c3727ac2ea0d69;p=thirdparty%2Fbinutils-gdb.git * valops.c (hand_function_call): Simplify computation of the address of the pushed argument. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index c0f110fa227..4490a2afce7 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 d417cdc2a06..0ab0ae6e916 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),