From 03a569a38c07e2094cd76fd1e951a3e52c7568fa Mon Sep 17 00:00:00 2001 From: Kazu Hirata Date: Mon, 28 Aug 2006 17:18:29 +0000 Subject: [PATCH] re PR middle-end/26632 (spurious warning: value computed is not used) gcc/ PR middle-end/26632 * convert.c (convert_to_integer): Set TREE_NO_WARNING to 1 on an implicit conversion. gcc/testsuite/ PR middle-end/26632 * gcc.dg/pr26632.c: New. From-SVN: r116510 --- gcc/ChangeLog | 6 ++++++ gcc/convert.c | 9 ++++++++- gcc/testsuite/ChangeLog | 5 +++++ 3 files changed, 19 insertions(+), 1 deletion(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 745c642..733fa47 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2006-08-28 Kazu Hirata + + PR middle-end/26632 + * convert.c (convert_to_integer): Set TREE_NO_WARNING to 1 on + an implicit conversion. + 2006-08-28 Prafulla Thakare * config/h8300/h8300.c (TARGET_DEFAULT_TARGET_FLAGS): New. diff --git a/gcc/convert.c b/gcc/convert.c index 2757195..118889f 100644 --- a/gcc/convert.c +++ b/gcc/convert.c @@ -487,6 +487,7 @@ convert_to_integer (tree type, tree expr) else if (outprec >= inprec) { enum tree_code code; + tree tem; /* If the precision of the EXPR's type is K bits and the destination mode has more bits, and the sign is changing, @@ -504,7 +505,13 @@ convert_to_integer (tree type, tree expr) else code = NOP_EXPR; - return fold_build1 (code, type, expr); + tem = fold_unary (code, type, expr); + if (tem) + return tem; + + tem = build1 (code, type, expr); + TREE_NO_WARNING (tem) = 1; + return tem; } /* If TYPE is an enumeral type or a type with a precision less diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 65900a7..767f94e 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2006-08-28 Kazu Hirata + + PR middle-end/26632 + * gcc.dg/pr26632.c: New. + 2006-08-27 Jerry DeLisle PR libgfortran/28354 -- 2.7.4