diff options
author | ebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4> | 2014-10-03 10:28:50 +0000 |
---|---|---|
committer | ebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4> | 2014-10-03 10:28:50 +0000 |
commit | 24fa98f436e4a43c0580163002fdbf47d5afe63e (patch) | |
tree | c0f876e4d6ea20b37981e650091d325e3c79507f /gcc/convert.c | |
parent | a08f4f98a2fd74c3c81fdbf4a568e7093b1d661a (diff) | |
download | gcc-24fa98f436e4a43c0580163002fdbf47d5afe63e.tar.gz |
* convert.c (convert_to_integer): Do not introduce useless conversions
between integral types.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@215843 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/convert.c')
-rw-r--r-- | gcc/convert.c | 29 |
1 files changed, 24 insertions, 5 deletions
diff --git a/gcc/convert.c b/gcc/convert.c index 3834351aad5..9ef27f6347f 100644 --- a/gcc/convert.c +++ b/gcc/convert.c @@ -746,8 +746,9 @@ convert_to_integer (tree type, tree expr) /* Can't do arithmetic in enumeral types so use an integer type that will hold the values. */ if (TREE_CODE (typex) == ENUMERAL_TYPE) - typex = lang_hooks.types.type_for_size - (TYPE_PRECISION (typex), TYPE_UNSIGNED (typex)); + typex + = lang_hooks.types.type_for_size (TYPE_PRECISION (typex), + TYPE_UNSIGNED (typex)); /* But now perhaps TYPEX is as wide as INPREC. In that case, do nothing special here. @@ -788,9 +789,15 @@ convert_to_integer (tree type, tree expr) && (ex_form == PLUS_EXPR || ex_form == MINUS_EXPR || ex_form == MULT_EXPR))) - typex = unsigned_type_for (typex); + { + if (!TYPE_UNSIGNED (typex)) + typex = unsigned_type_for (typex); + } else - typex = signed_type_for (typex); + { + if (TYPE_UNSIGNED (typex)) + typex = signed_type_for (typex); + } return convert (type, fold_build2 (ex_form, typex, convert (typex, arg0), @@ -805,7 +812,19 @@ convert_to_integer (tree type, tree expr) /* This is not correct for ABS_EXPR, since we must test the sign before truncation. */ { - tree typex = unsigned_type_for (type); + /* Do the arithmetic in type TYPEX, + then convert result to TYPE. */ + tree typex = type; + + /* Can't do arithmetic in enumeral types + so use an integer type that will hold the values. */ + if (TREE_CODE (typex) == ENUMERAL_TYPE) + typex + = lang_hooks.types.type_for_size (TYPE_PRECISION (typex), + TYPE_UNSIGNED (typex)); + + if (!TYPE_UNSIGNED (typex)) + typex = unsigned_type_for (typex); return convert (type, fold_build1 (ex_form, typex, convert (typex, |