Fix bug where storing into const string gives core dump, from Kamil Iskra.
authorJim Wilson <wilson@cygnus.com>
Mon, 4 May 1998 19:16:35 +0000 (19:16 +0000)
committerJim Wilson <wilson@gcc.gnu.org>
Mon, 4 May 1998 19:16:35 +0000 (12:16 -0700)
* expr.c (expand_expr, case INDIRECT_REF): Don't optimize string
reference if this is a store.

From-SVN: r19531

gcc/ChangeLog
gcc/expr.c

index 7038dbf6303df26aec7adce2abd13504b115f7fc..2c7d23c06a31b8718a6e5616cd57e56cacdf2921 100644 (file)
@@ -1,3 +1,8 @@
+Mon May  4 19:15:29 1998  Jim Wilson  <wilson@cygnus.com>
+
+       * expr.c (expand_expr, case INDIRECT_REF): Don't optimize string
+       reference if this is a store.
+
 Mon May  4 17:25:17 1998  Richard Henderson  <rth@cygnus.com>
 
        * sparc.c (output_move_quad): Fix typo in mov_by_64 argument.
index c094a0f0f02496457507c632a15860d319106d7b..8b8e5133b6a52e0983480d92578091c99aaafd1d 100644 (file)
@@ -5484,13 +5484,15 @@ expand_expr (exp, target, tmode, modifier)
        tree string = string_constant (exp1, &index);
        int i;
  
+       /* Try to optimize reads from const strings.  */
        if (string
            && TREE_CODE (string) == STRING_CST
            && TREE_CODE (index) == INTEGER_CST
            && !TREE_INT_CST_HIGH (index)
            && (i = TREE_INT_CST_LOW (index)) < TREE_STRING_LENGTH (string)
            && GET_MODE_CLASS (mode) == MODE_INT
-           && GET_MODE_SIZE (mode) == 1)
+           && GET_MODE_SIZE (mode) == 1
+           && modifier != EXPAND_MEMORY_USE_WO)
          return GEN_INT (TREE_STRING_POINTER (string)[i]);
 
        op0 = expand_expr (exp1, NULL_RTX, VOIDmode, EXPAND_SUM);