Hi!

I've started an --enable-checking=valgrind bootstrap during the weekend,
but only on Sunday afternoon and thus killed it on Monday morning, so it
didn't get very far, but still reported a problem where the build tools
had uninitialized memory use in copy_rtx:
    case CLOBBER:
      /* Share clobbers of hard registers (like cc0), but do not share
       * pseudo reg
         clobbers or clobbers of hard registers that originated as pseudos.
         This is needed to allow safe register renaming.  */
      if (REG_P (XEXP (orig, 0)) && REGNO (XEXP (orig, 0)) < 
FIRST_PSEUDO_REGISTER
          && ORIGINAL_REGNO (XEXP (orig, 0)) == REGNO (XEXP (orig, 0)))
        return orig;
- ORIGINAL_REGNO was uninitialized.  The problem is that read_rtx_code uses
rtx_alloc, which clears only the first int in the structure (header), and
then ignores the fields with 0 format character.  For ORIGINAL_REGNO, we
want to set it to REGNO, for others IMHO it is best to just clear those
fields.

Fixed thusly, bootstrapped/regtested on x86_64-linux and i686-linux, ok for
trunk?

2014-01-28  Jakub Jelinek  <ja...@redhat.com>

        PR other/58712
        * read-rtl.c (read_rtx_code): Clear all of RTX_CODE_SIZE (code).
        For REGs set ORIGINAL_REGNO.

--- gcc/read-rtl.c.jj   2014-01-03 11:40:57.000000000 +0100
+++ gcc/read-rtl.c      2014-01-27 10:01:44.154527266 +0100
@@ -1131,6 +1131,7 @@ read_rtx_code (const char *code_name)
   /* If we end up with an insn expression then we free this space below.  */
   return_rtx = rtx_alloc (code);
   format_ptr = GET_RTX_FORMAT (code);
+  memset (return_rtx, 0, RTX_CODE_SIZE (code));
   PUT_CODE (return_rtx, code);
 
   if (iterator)
@@ -1154,6 +1155,8 @@ read_rtx_code (const char *code_name)
        /* 0 means a field for internal use only.
           Don't expect it to be present in the input.  */
       case '0':
+       if (code == REG)
+         ORIGINAL_REGNO (return_rtx) = REGNO (return_rtx);
        break;
 
       case 'e':

        Jakub

Reply via email to