From ddc923b52d28df9ed6e5d50138593a31da3e519a Mon Sep 17 00:00:00 2001 From: Marek Polacek Date: Tue, 3 Dec 2013 12:11:36 +0000 Subject: [PATCH] re PR middle-end/56344 (ICE for program with very large structs returned by value) PR middle-end/56344 * calls.c (expand_call): Disallow passing huge arguments by value. From-SVN: r205628 --- gcc/ChangeLog | 6 ++++++ gcc/calls.c | 9 +++++++++ 2 files changed, 15 insertions(+) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index de5799c1a36..944e28cbbc4 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2013-12-03 Marek Polacek + + PR middle-end/56344 + * calls.c (expand_call): Disallow passing huge arguments + by value. + 2013-12-03 Jakub Jelinek PR tree-optimization/59362 diff --git a/gcc/calls.c b/gcc/calls.c index 7d6327f28ef..3963bc29754 100644 --- a/gcc/calls.c +++ b/gcc/calls.c @@ -3045,6 +3045,15 @@ expand_call (tree exp, rtx target, int ignore) { rtx before_arg = get_last_insn (); + /* We don't allow passing huge (> 2^30 B) arguments + by value. It would cause an overflow later on. */ + if (adjusted_args_size.constant + >= (1 << (HOST_BITS_PER_INT - 2))) + { + sorry ("passing too large argument on stack"); + continue; + } + if (store_one_arg (&args[i], argblock, flags, adjusted_args_size.var != 0, reg_parm_stack_space)