aboutsummaryrefslogtreecommitdiff
path: root/gcc/integrate.c
diff options
context:
space:
mode:
authorRoger Sayle <roger@eyesopen.com>2003-01-25 17:42:39 +0000
committerRoger Sayle <sayle@gcc.gnu.org>2003-01-25 17:42:39 +0000
commit07d9b20d818e83c12fee88ea4c41f3788ccee94b (patch)
treeb21f72610d0ef15b8f89e3f3117d170b5ca05f55 /gcc/integrate.c
parent415591122da665db1059faae87fb2d8c8097ffb6 (diff)
downloadgcc-07d9b20d818e83c12fee88ea4c41f3788ccee94b.zip
gcc-07d9b20d818e83c12fee88ea4c41f3788ccee94b.tar.gz
gcc-07d9b20d818e83c12fee88ea4c41f3788ccee94b.tar.bz2
function.h (struct function): New field calls_constant_p.
* function.h (struct function): New field calls_constant_p. (current_function_calls_constant_p): New macro for above. * function.c (prepare_function_start): Initialize calls_eh_return and calls_constant_p. * builtins.c (expand_builtin_constant_p): Set calls_constant_p. * toplev.c (rest_of_compilation): Only call purge_builtin_constant_p when the current_function_calls_constant_p. * integrate.c (expand_inline_function): Set calls_constant_p if the function being inlined has calls_constant_p set. From-SVN: r61786
Diffstat (limited to 'gcc/integrate.c')
-rw-r--r--gcc/integrate.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/gcc/integrate.c b/gcc/integrate.c
index 6eef6503..8ab4280 100644
--- a/gcc/integrate.c
+++ b/gcc/integrate.c
@@ -899,6 +899,11 @@ expand_inline_function (fndecl, parms, target, ignore, type,
if (inl_f->needs_context)
static_chain_value = lookup_static_chain (fndecl);
+ /* If the inlined function calls __builtin_constant_p, then we'll
+ need to call purge_builtin_constant_p on this function. */
+ if (inl_f->calls_constant_p)
+ current_function_calls_constant_p = 1;
+
if (GET_CODE (parm_insns) == NOTE
&& NOTE_LINE_NUMBER (parm_insns) > 0)
{