OSDN Git Service

Check that result of string folding is of integral type.
authorhjl <hjl@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 10 Sep 2010 14:44:20 +0000 (14:44 +0000)
committerhjl <hjl@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 10 Sep 2010 14:44:20 +0000 (14:44 +0000)
gcc/

2010-09-10  H.J. Lu  <hongjiu.lu@intel.com>

PR middle-end/45634
* tree-ssa-ccp.c (fold_const_aggregate_ref): Check that result
of string folding is of integral type.

gcc/testsuite/

2010-09-10  H.J. Lu  <hongjiu.lu@intel.com>

PR middle-end/45634
* gfortran.fortran-torture/compile/pr45634.f90: New.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@164183 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/gfortran.fortran-torture/compile/pr45634.f90 [new file with mode: 0644]
gcc/tree-ssa-ccp.c

index 5f62d06..bda4cda 100644 (file)
@@ -1,3 +1,9 @@
+2010-09-10  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR middle-end/45634
+       * tree-ssa-ccp.c (fold_const_aggregate_ref): Check that result
+       of string folding is of integral type.
+
 2010-09-10  Ryan Mansfield  <rmansfield@qnx.com>
 
        * doc/invoke.texi (-x): Fix typo.
index 7f4f87b..9815d18 100644 (file)
@@ -1,3 +1,8 @@
+2010-09-10  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR middle-end/45634
+       * gfortran.fortran-torture/compile/pr45634.f90: New.
+
 2010-09-10  Nicola Pero  <nicola.pero@meta-innovation.com>
 
        * objc.dg/fobjc-exceptions.m: New test.
diff --git a/gcc/testsuite/gfortran.fortran-torture/compile/pr45634.f90 b/gcc/testsuite/gfortran.fortran-torture/compile/pr45634.f90
new file mode 100644 (file)
index 0000000..ab0c33a
--- /dev/null
@@ -0,0 +1,5 @@
+      SUBROUTINE RCRDRD (VTYP)
+      CHARACTER(4), INTENT(OUT) :: VTYP 
+      CHARACTER(1), SAVE :: DBL = "D" 
+      VTYP = DBL
+      END
index 60e2b55..33d5cc7 100644 (file)
@@ -1537,8 +1537,9 @@ fold_const_aggregate_ref (tree t)
       /* Fold read from constant string.  */
       if (TREE_CODE (ctor) == STRING_CST)
        {
-         if ((TYPE_MODE (TREE_TYPE (t))
-              == TYPE_MODE (TREE_TYPE (TREE_TYPE (ctor))))
+         if (INTEGRAL_TYPE_P (TREE_TYPE (t))
+             && (TYPE_MODE (TREE_TYPE (t))
+                 == TYPE_MODE (TREE_TYPE (TREE_TYPE (ctor))))
              && (GET_MODE_CLASS (TYPE_MODE (TREE_TYPE (TREE_TYPE (ctor))))
                  == MODE_INT)
              && GET_MODE_SIZE (TYPE_MODE (TREE_TYPE (TREE_TYPE (ctor)))) == 1