From 9fb117e8310076cd8e4803e35eaa6d3b09a45d79 Mon Sep 17 00:00:00 2001 From: Hans-Peter Nilsson Date: Mon, 11 Feb 2019 09:03:51 +0000 Subject: [PATCH] function.c (assign_parm_setup_block): Use the stored size... * function.c (assign_parm_setup_block): Use the stored size, not the passed size, when allocating stack-space, also for a parameter with alignment larger than MAX_SUPPORTED_STACK_ALIGNMENT. From-SVN: r268763 --- gcc/ChangeLog | 7 +++++++ gcc/function.c | 2 +- 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 9e938f753b0..a4cc46a5fc8 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2019-02-11 Hans-Peter Nilsson + + * function.c (assign_parm_setup_block): Use the stored + size, not the passed size, when allocating stack-space, + also for a parameter with alignment larger than + MAX_SUPPORTED_STACK_ALIGNMENT. + 2019-02-11 Martin Liska PR ipa/89009 diff --git a/gcc/function.c b/gcc/function.c index 1525d8bc29a..dc035707c20 100644 --- a/gcc/function.c +++ b/gcc/function.c @@ -2915,7 +2915,7 @@ assign_parm_setup_block (struct assign_parm_data_all *all, SET_DECL_ALIGN (parm, MAX (DECL_ALIGN (parm), BITS_PER_WORD)); if (DECL_ALIGN (parm) > MAX_SUPPORTED_STACK_ALIGNMENT) { - rtx allocsize = gen_int_mode (size, Pmode); + rtx allocsize = gen_int_mode (size_stored, Pmode); get_dynamic_stack_size (&allocsize, 0, DECL_ALIGN (parm), NULL); stack_parm = assign_stack_local (BLKmode, UINTVAL (allocsize), MAX_SUPPORTED_STACK_ALIGNMENT); -- 2.30.2