From: Dominik Vogt Date: Fri, 18 Nov 2016 14:44:54 +0000 (+0000) Subject: Re-apply: Drop excess size used for run time allocated stack variables. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=d79318594936bb80dc5a0b82c70346249c49e5b0;p=gcc.git Re-apply: Drop excess size used for run time allocated stack variables. The patch got reverted after hitting PR77359 which turned out to be a rs6000 backend problem. Reapplying after the PR got fixed. gcc/ChangeLog: 2016-11-18 Dominik Vogt Re-apply after PR bootstrap/77359 is fixed: 2016-08-23 Dominik Vogt * explow.c (get_dynamic_stack_size): Take known alignment of stack pointer + STACK_DYNAMIC_OFFSET into account when calculating the size needed. --This line, and those below, will be ignored-- M gcc/ChangeLog M gcc/explow.c From-SVN: r242590 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 95506d39c0f..b3f2b7327f7 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,12 @@ +2016-11-18 Dominik Vogt + + Re-apply after PR bootstrap/77359 is fixed: + 2016-08-23 Dominik Vogt + + * explow.c (get_dynamic_stack_size): Take known alignment of stack + pointer + STACK_DYNAMIC_OFFSET into account when calculating the + size needed. + 2016-11-18 Dominik Vogt PR bootstrap/77359 diff --git a/gcc/explow.c b/gcc/explow.c index 75af333c1c3..6758cca87e7 100644 --- a/gcc/explow.c +++ b/gcc/explow.c @@ -1233,9 +1233,15 @@ get_dynamic_stack_size (rtx *psize, unsigned size_align, example), so we must preventively align the value. We leave space in SIZE for the hole that might result from the alignment operation. */ - extra = (required_align - BITS_PER_UNIT) / BITS_PER_UNIT; - size = plus_constant (Pmode, size, extra); - size = force_operand (size, NULL_RTX); + unsigned known_align = REGNO_POINTER_ALIGN (VIRTUAL_STACK_DYNAMIC_REGNUM); + if (known_align == 0) + known_align = BITS_PER_UNIT; + if (required_align > known_align) + { + extra = (required_align - known_align) / BITS_PER_UNIT; + size = plus_constant (Pmode, size, extra); + size = force_operand (size, NULL_RTX); + } if (flag_stack_usage_info && pstack_usage_size) *pstack_usage_size += extra;