summaryrefslogtreecommitdiff
path: root/gcc/calls.c
diff options
context:
space:
mode:
authorlaw <law@138bc75d-0d04-0410-961f-82ee72b054a4>1999-01-07 11:29:38 +0000
committerlaw <law@138bc75d-0d04-0410-961f-82ee72b054a4>1999-01-07 11:29:38 +0000
commit6d801f270762f4d2e8db9004448ab931020e717d (patch)
tree7c5f130f91ec25adc7b64b5a91dd19084554401c /gcc/calls.c
parent11e995449695fe53ec710529707d534605cc5136 (diff)
downloadgcc-6d801f270762f4d2e8db9004448ab931020e717d.tar.gz
* calls.c (store_unaligned_arguments_into_pseudos): Use xmalloc to
allocate memory that will live beyond this function. (expand_call): Free it here. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@24561 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/calls.c')
-rw-r--r--gcc/calls.c16
1 files changed, 13 insertions, 3 deletions
diff --git a/gcc/calls.c b/gcc/calls.c
index b1807584d92..b41158e1356 100644
--- a/gcc/calls.c
+++ b/gcc/calls.c
@@ -753,7 +753,12 @@ restore_fixed_argument_area (save_area, argblock, high_to_save, low_to_save)
/* If any elements in ARGS refer to parameters that are to be passed in
registers, but not in memory, and whose alignment does not permit a
direct copy into registers. Copy the values into a group of pseudos
- which we will later copy into the appropriate hard registers. */
+ which we will later copy into the appropriate hard registers.
+
+ Pseudos for each unaligned argument will be stored into the array
+ args[argnum].aligned_regs. The caller is responsible for deallocating
+ the aligned_regs array if it is nonzero. */
+
static void
store_unaligned_arguments_into_pseudos (args, num_actuals)
struct arg_data *args;
@@ -774,8 +779,8 @@ store_unaligned_arguments_into_pseudos (args, num_actuals)
= args[i].partial ? args[i].partial
: (bytes + (UNITS_PER_WORD - 1)) / UNITS_PER_WORD;
- args[i].aligned_regs = (rtx *) alloca (sizeof (rtx)
- * args[i].n_aligned_regs);
+ args[i].aligned_regs = (rtx *) xmalloc (sizeof (rtx)
+ * args[i].n_aligned_regs);
/* Structures smaller than a word are aligned to the least
significant byte (to the right). On a BYTES_BIG_ENDIAN machine,
@@ -2298,6 +2303,11 @@ expand_call (exp, target, ignore)
pop_temp_slots ();
+ /* Free up storage we no longer need. */
+ for (i = 0; i < num_actuals; ++i)
+ if (args[i].aligned_regs)
+ free (args[i].aligned_regs);
+
return target;
}