summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoraoliva <aoliva@138bc75d-0d04-0410-961f-82ee72b054a4>2007-10-06 11:47:51 +0000
committeraoliva <aoliva@138bc75d-0d04-0410-961f-82ee72b054a4>2007-10-06 11:47:51 +0000
commit6cd85af4dabbe9d599c752ff4687dfa7d8deb0dc (patch)
tree97386aa2a17f337dd3026d0bf370e0be78a9f48d
parentfd71b5424ba66b6910b10d0360eba73ceffe9f86 (diff)
downloadppe42-gcc-6cd85af4dabbe9d599c752ff4687dfa7d8deb0dc.tar.gz
ppe42-gcc-6cd85af4dabbe9d599c752ff4687dfa7d8deb0dc.zip
gcc/ChangeLog:
PR tree-optimization/33655 * tree-sra.c (bitfield_overlaps_p): Handle array and complex elements. gcc/testsuite/ChangeLog: PR tree-optimization/33655 * gcc.dg/torture/pr33655.c: New. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@129052 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/torture/pr33655.c14
-rw-r--r--gcc/tree-sra.c5
4 files changed, 30 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index db4e33e8873..4534268ebd6 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,11 @@
2007-10-06 Alexandre Oliva <aoliva@redhat.com>
+ PR tree-optimization/33655
+ * tree-sra.c (bitfield_overlaps_p): Handle array and complex
+ elements.
+
+2007-10-06 Alexandre Oliva <aoliva@redhat.com>
+
PR tree-optimization/33572
* tree-cfg.c (verify_stmts): Check for missing PHI defs.
* tree-inline.c (update_ssa_across_eh_edges): Renamed to...
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 5ce628947e5..70326245c70 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,10 @@
2007-10-06 Alexandre Oliva <aoliva@redhat.com>
+ PR tree-optimization/33655
+ * gcc.dg/torture/pr33655.c: New.
+
+2007-10-06 Alexandre Oliva <aoliva@redhat.com>
+
PR tree-optimization/33572
* g++.dg/torture/pr33572.C: New.
diff --git a/gcc/testsuite/gcc.dg/torture/pr33655.c b/gcc/testsuite/gcc.dg/torture/pr33655.c
new file mode 100644
index 00000000000..2f9da65aec4
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/torture/pr33655.c
@@ -0,0 +1,14 @@
+/* { dg-do compile } */
+typedef struct {
+ unsigned long attr;
+ int chars[2];
+} cchar_t;
+typedef struct _win_st {
+ cchar_t _bkgrnd;
+} WINDOW;
+void render_char(WINDOW *win, cchar_t ch)
+{
+ if ((ch).chars[0] == L' '
+ && (ch).chars[1] == L'\0')
+ win->_bkgrnd = ch;
+}
diff --git a/gcc/tree-sra.c b/gcc/tree-sra.c
index ff7a52c1a76..764f70b0631 100644
--- a/gcc/tree-sra.c
+++ b/gcc/tree-sra.c
@@ -2897,6 +2897,11 @@ bitfield_overlaps_p (tree blen, tree bpos, struct sra_elt *fld,
flen = fold_convert (bitsizetype, TREE_OPERAND (fld->element, 1));
fpos = fold_convert (bitsizetype, TREE_OPERAND (fld->element, 2));
}
+ else if (TREE_CODE (fld->element) == INTEGER_CST)
+ {
+ flen = fold_convert (bitsizetype, TYPE_SIZE (fld->type));
+ fpos = size_binop (MULT_EXPR, flen, fld->element);
+ }
else
gcc_unreachable ();
OpenPOWER on IntegriCloud