aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Guenther <rguenther@suse.de>2006-05-27 15:57:36 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2006-05-27 15:57:36 +0000
commit9e030af961640cc58c425da99fe98397549d5086 (patch)
tree5a69262c3b046bdf7d18dfb4631164564a727268
parentf7b985802814f02cfe92e7187dcf17a40c046d27 (diff)
downloadgcc-9e030af961640cc58c425da99fe98397549d5086.zip
gcc-9e030af961640cc58c425da99fe98397549d5086.tar.gz
gcc-9e030af961640cc58c425da99fe98397549d5086.tar.bz2
re PR middle-end/27773 (ICE: in find_lattice_value, at tree-complex.c:133)
2006-05-27 Richard Guenther <rguenther@suse.de> PR middle-end/27773 * fold-const.c (fold_plusminus_mult_expr): Use fold_convert to produce a constant of value 1 of generic type. * gcc.dg/torture/pr27773.c: New testcase. From-SVN: r114158
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/fold-const.c10
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/torture/pr27773.c6
4 files changed, 19 insertions, 8 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 4c73ad8..021e01b 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2006-05-27 Richard Guenther <rguenther@suse.de>
+
+ PR middle-end/27773
+ * fold-const.c (fold_plusminus_mult_expr): Use fold_convert
+ to produce a constant of value 1 of generic type.
+
2006-05-27 Dirk Mueller <dmueller@suse.de>
* cgraphunit.c (decide_is_function_needed): Fix wrong
diff --git a/gcc/fold-const.c b/gcc/fold-const.c
index a5e57b1..7ef0fa1 100644
--- a/gcc/fold-const.c
+++ b/gcc/fold-const.c
@@ -6702,10 +6702,7 @@ fold_plusminus_mult_expr (enum tree_code code, tree type, tree arg0, tree arg1)
else
{
arg00 = arg0;
- if (!FLOAT_TYPE_P (type))
- arg01 = build_int_cst (type, 1);
- else
- arg01 = build_real (type, dconst1);
+ arg01 = fold_convert (type, integer_one_node);
}
if (TREE_CODE (arg1) == MULT_EXPR)
{
@@ -6715,10 +6712,7 @@ fold_plusminus_mult_expr (enum tree_code code, tree type, tree arg0, tree arg1)
else
{
arg10 = arg1;
- if (!FLOAT_TYPE_P (type))
- arg11 = build_int_cst (type, 1);
- else
- arg11 = build_real (type, dconst1);
+ arg11 = fold_convert (type, integer_one_node);
}
same = NULL_TREE;
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index d25ea70..786b6ca 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2006-05-27 Richard Guenther <rguenther@suse.de>
+
+ PR middle-end/27773
+ * gcc.dg/torture/pr27773.c: New testcase.
+
2006-05-27 Dirk Mueller <dmueller@suse.de>
* gcc.dg/pr24561.c: Rename to..
diff --git a/gcc/testsuite/gcc.dg/torture/pr27773.c b/gcc/testsuite/gcc.dg/torture/pr27773.c
new file mode 100644
index 0000000..e30e540
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/torture/pr27773.c
@@ -0,0 +1,6 @@
+/* { dg-do compile } */
+
+_Complex float f(_Complex float a, float b)
+{
+ return a - a*b;
+}