diff options
author | Olivier Hainque <hainque@act-europe.fr> | 2003-04-19 00:11:57 +0200 |
---|---|---|
committer | Richard Kenner <kenner@gcc.gnu.org> | 2003-04-18 18:11:57 -0400 |
commit | e59baa1f83fd053979c637f12f89cdf04d1d5ed5 (patch) | |
tree | 6969ca4ed91ad3bb2b2cec1840cf3c2ba1608f4b /gcc/integrate.c | |
parent | 8dcea3f35aa46a95aef9b4841b686744214f5690 (diff) | |
download | gcc-e59baa1f83fd053979c637f12f89cdf04d1d5ed5.tar.gz |
integrate.c (expand_inline_function): Ensure non-const actuals don't end up const in the caller's flow after...
* integrate.c (expand_inline_function): Ensure non-const actuals
don't end up const in the caller's flow after conversion to possibly
const formal type.
From-SVN: r65794
Diffstat (limited to 'gcc/integrate.c')
-rw-r--r-- | gcc/integrate.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/gcc/integrate.c b/gcc/integrate.c index 7a1865881c6..60fa2acd13a 100644 --- a/gcc/integrate.c +++ b/gcc/integrate.c @@ -810,6 +810,14 @@ expand_inline_function (fndecl, parms, target, ignore, type, else arg_vals[i] = 0; + /* If the formal type was const but the actual was not, we might + end up here with an rtx wrongly tagged unchanging in the caller's + context. Fix that. */ + if (arg_vals[i] != 0 + && (GET_CODE (arg_vals[i]) == REG || GET_CODE (arg_vals[i]) == MEM) + && ! TREE_READONLY (TREE_VALUE (actual))) + RTX_UNCHANGING_P (arg_vals[i]) = 0; + if (arg_vals[i] != 0 && (! TREE_READONLY (formal) /* If the parameter is not read-only, copy our argument through |