OSDN Git Service

2010-03-18 Paolo Carlini <paolo.carlini@oracle.com>
[pf3gnuchains/gcc-fork.git] / gcc / df-problems.c
index 5aad97a..e0ec167 100644 (file)
@@ -1,7 +1,7 @@
 /* Standard problems for dataflow support routines.
    Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007,
    2008, 2009 Free Software Foundation, Inc.
-   Originally contributed by Michael P. Hayes 
+   Originally contributed by Michael P. Hayes
              (m.hayes@elec.canterbury.ac.nz, mhayes@redhat.com)
    Major rewrite contributed by Danny Berlin (dberlin@dberlin.org)
              and Kenneth Zadeck (zadeck@naturalbridge.com).
@@ -47,7 +47,7 @@ along with GCC; see the file COPYING3.  If not see
 
 /* Note that turning REG_DEAD_DEBUGGING on will cause
    gcc.c-torture/unsorted/dump-noaddr.c to fail because it prints
-   addresses in the dumps.  */  
+   addresses in the dumps.  */
 #if 0
 #define REG_DEAD_DEBUGGING
 #endif
@@ -73,7 +73,7 @@ df_get_live_out (basic_block bb)
 
   if (df_live)
     return DF_LIVE_OUT (bb);
-  else 
+  else
     return DF_LR_OUT (bb);
 }
 
@@ -89,7 +89,7 @@ df_get_live_in (basic_block bb)
 
   if (df_live)
     return DF_LIVE_IN (bb);
-  else 
+  else
     return DF_LR_IN (bb);
 }
 
@@ -136,7 +136,7 @@ df_chain_dump (struct df_link *link, FILE *file)
 
 /* Print some basic block info as part of df_dump.  */
 
-void 
+void
 df_print_bb_index (basic_block bb, FILE *file)
 {
   edge e;
@@ -147,13 +147,13 @@ df_print_bb_index (basic_block bb, FILE *file)
     {
       basic_block pred = e->src;
       fprintf (file, "%d%s ", pred->index, e->flags & EDGE_EH ? "(EH)" : "");
-    } 
+    }
   fprintf (file, ")->[%d]->( ", bb->index);
   FOR_EACH_EDGE (e, ei, bb->succs)
     {
       basic_block succ = e->dest;
       fprintf (file, "%d%s ", succ->index, e->flags & EDGE_EH ? "(EH)" : "");
-    } 
+    }
   fprintf (file, ")\n");
 }
 
@@ -168,12 +168,12 @@ df_print_bb_index (basic_block bb, FILE *file)
    ----------------------------------------------------------------------------*/
 
 /* This problem plays a large number of games for the sake of
-   efficiency.  
-   
+   efficiency.
+
    1) The order of the bits in the bitvectors.  After the scanning
    phase, all of the defs are sorted.  All of the defs for the reg 0
    are first, followed by all defs for reg 1 and so on.
-   
+
    2) There are two kill sets, one if the number of defs is less or
    equal to DF_SPARSE_THRESHOLD and another if the number of defs is
    greater.
@@ -195,8 +195,8 @@ df_print_bb_index (basic_block bb, FILE *file)
 struct df_rd_problem_data
 {
   /* The set of defs to regs invalidated by call.  */
-  bitmap sparse_invalidated_by_call;  
-  /* The set of defs to regs invalidate by call for rd.  */  
+  bitmap sparse_invalidated_by_call;
+  /* The set of defs to regs invalidate by call for rd.  */
   bitmap dense_invalidated_by_call;
   /* An obstack for the bitmaps we need for this problem.  */
   bitmap_obstack rd_bitmaps;
@@ -205,7 +205,7 @@ struct df_rd_problem_data
 /* Set basic block info.  */
 
 static void
-df_rd_set_bb_info (unsigned int index, 
+df_rd_set_bb_info (unsigned int index,
                   struct df_rd_bb_info *bb_info)
 {
   gcc_assert (df_rd);
@@ -217,7 +217,7 @@ df_rd_set_bb_info (unsigned int index,
 /* Free basic block info.  */
 
 static void
-df_rd_free_bb_info (basic_block bb ATTRIBUTE_UNUSED, 
+df_rd_free_bb_info (basic_block bb ATTRIBUTE_UNUSED,
                    void *vbb_info)
 {
   struct df_rd_bb_info *bb_info = (struct df_rd_bb_info *) vbb_info;
@@ -236,7 +236,7 @@ df_rd_free_bb_info (basic_block bb ATTRIBUTE_UNUSED,
 /* Allocate or reset bitmaps for DF_RD blocks. The solution bits are
    not touched unless the block is new.  */
 
-static void 
+static void
 df_rd_alloc (bitmap all_blocks)
 {
   unsigned int bb_index;
@@ -244,7 +244,7 @@ df_rd_alloc (bitmap all_blocks)
   struct df_rd_problem_data *problem_data;
 
   if (!df_rd->block_pool)
-    df_rd->block_pool = create_alloc_pool ("df_rd_block pool", 
+    df_rd->block_pool = create_alloc_pool ("df_rd_block pool",
                                           sizeof (struct df_rd_bb_info), 50);
 
   if (df_rd->problem_data)
@@ -253,7 +253,7 @@ df_rd_alloc (bitmap all_blocks)
       bitmap_clear (problem_data->sparse_invalidated_by_call);
       bitmap_clear (problem_data->dense_invalidated_by_call);
     }
-  else 
+  else
     {
       problem_data = XNEW (struct df_rd_problem_data);
       df_rd->problem_data = problem_data;
@@ -275,13 +275,13 @@ df_rd_alloc (bitmap all_blocks)
     {
       struct df_rd_bb_info *bb_info = df_rd_get_bb_info (bb_index);
       if (bb_info)
-       { 
+       {
          bitmap_clear (bb_info->kill);
          bitmap_clear (bb_info->sparse_kill);
          bitmap_clear (bb_info->gen);
        }
       else
-       { 
+       {
          bb_info = (struct df_rd_bb_info *) pool_alloc (df_rd->block_pool);
          df_rd_set_bb_info (bb_index, bb_info);
          bb_info->kill = BITMAP_ALLOC (&problem_data->rd_bitmaps);
@@ -310,8 +310,8 @@ df_rd_simulate_artificial_defs_at_top (basic_block bb, bitmap local_rd)
        {
          unsigned int dregno = DF_REF_REGNO (def);
          if (!(DF_REF_FLAGS (def) & (DF_REF_PARTIAL | DF_REF_CONDITIONAL)))
-           bitmap_clear_range (local_rd, 
-                               DF_DEFS_BEGIN (dregno), 
+           bitmap_clear_range (local_rd,
+                               DF_DEFS_BEGIN (dregno),
                                DF_DEFS_COUNT (dregno));
          bitmap_set_bit (local_rd, DF_REF_ID (def));
        }
@@ -336,10 +336,10 @@ df_rd_simulate_one_insn (basic_block bb ATTRIBUTE_UNUSED, rtx insn,
           || (dregno >= FIRST_PSEUDO_REGISTER))
         {
           if (!(DF_REF_FLAGS (def) & (DF_REF_PARTIAL | DF_REF_CONDITIONAL)))
-           bitmap_clear_range (local_rd, 
-                               DF_DEFS_BEGIN (dregno), 
+           bitmap_clear_range (local_rd,
+                               DF_DEFS_BEGIN (dregno),
                                DF_DEFS_COUNT (dregno));
-         if (!(DF_REF_FLAGS (def) 
+         if (!(DF_REF_FLAGS (def)
                & (DF_REF_MUST_CLOBBER | DF_REF_MAY_CLOBBER)))
            bitmap_set_bit (local_rd, DF_REF_ID (def));
        }
@@ -352,7 +352,7 @@ df_rd_simulate_one_insn (basic_block bb ATTRIBUTE_UNUSED, rtx insn,
    of kill sets.   */
 
 static void
-df_rd_bb_local_compute_process_def (struct df_rd_bb_info *bb_info, 
+df_rd_bb_local_compute_process_def (struct df_rd_bb_info *bb_info,
                                    df_ref *def_rec,
                                    int top_flag)
 {
@@ -364,12 +364,12 @@ df_rd_bb_local_compute_process_def (struct df_rd_bb_info *bb_info,
          unsigned int regno = DF_REF_REGNO (def);
          unsigned int begin = DF_DEFS_BEGIN (regno);
          unsigned int n_defs = DF_DEFS_COUNT (regno);
-         
+
          if ((!(df->changeable_flags & DF_NO_HARD_REGS))
              || (regno >= FIRST_PSEUDO_REGISTER))
            {
              /* Only the last def(s) for a regno in the block has any
-                effect.  */ 
+                effect.  */
              if (!bitmap_bit_p (seen_in_block, regno))
                {
                  /* The first def for regno in insn gets to knock out the
@@ -377,7 +377,7 @@ df_rd_bb_local_compute_process_def (struct df_rd_bb_info *bb_info,
                  if ((!bitmap_bit_p (seen_in_insn, regno))
                      /* If the def is to only part of the reg, it does
                         not kill the other defs that reach here.  */
-                     && (!(DF_REF_FLAGS (def) & 
+                     && (!(DF_REF_FLAGS (def) &
                            (DF_REF_PARTIAL | DF_REF_CONDITIONAL | DF_REF_MAY_CLOBBER))))
                    {
                      if (n_defs > DF_SPARSE_THRESHOLD)
@@ -391,11 +391,11 @@ df_rd_bb_local_compute_process_def (struct df_rd_bb_info *bb_info,
                          bitmap_clear_range (bb_info->gen, begin, n_defs);
                        }
                    }
-                 
+
                  bitmap_set_bit (seen_in_insn, regno);
                  /* All defs for regno in the instruction may be put into
                     the gen set.  */
-                 if (!(DF_REF_FLAGS (def) 
+                 if (!(DF_REF_FLAGS (def)
                        & (DF_REF_MUST_CLOBBER | DF_REF_MAY_CLOBBER)))
                    bitmap_set_bit (bb_info->gen, DF_REF_ID (def));
                }
@@ -419,7 +419,7 @@ df_rd_bb_local_compute (unsigned int bb_index)
 
   /* Artificials are only hard regs.  */
   if (!(df->changeable_flags & DF_NO_HARD_REGS))
-    df_rd_bb_local_compute_process_def (bb_info, 
+    df_rd_bb_local_compute_process_def (bb_info,
                                        df_get_artificial_defs (bb_index),
                                        0);
 
@@ -430,7 +430,7 @@ df_rd_bb_local_compute (unsigned int bb_index)
       if (!INSN_P (insn))
        continue;
 
-      df_rd_bb_local_compute_process_def (bb_info, 
+      df_rd_bb_local_compute_process_def (bb_info,
                                          DF_INSN_UID_DEFS (uid), 0);
 
       /* This complex dance with the two bitmaps is required because
@@ -447,7 +447,7 @@ df_rd_bb_local_compute (unsigned int bb_index)
      are going backwards through the block and these are logically at
      the start.  */
   if (!(df->changeable_flags & DF_NO_HARD_REGS))
-    df_rd_bb_local_compute_process_def (bb_info, 
+    df_rd_bb_local_compute_process_def (bb_info,
                                        df_get_artificial_defs (bb_index),
                                        DF_REF_AT_TOP);
 }
@@ -475,15 +475,15 @@ df_rd_local_compute (bitmap all_blocks)
     {
       df_rd_bb_local_compute (bb_index);
     }
-  
+
   /* Set up the knockout bit vectors to be applied across EH_EDGES.  */
   EXECUTE_IF_SET_IN_BITMAP (regs_invalidated_by_call_regset, 0, regno, bi)
     {
       if (DF_DEFS_COUNT (regno) > DF_SPARSE_THRESHOLD)
        bitmap_set_bit (sparse_invalidated, regno);
       else
-       bitmap_set_range (dense_invalidated, 
-                         DF_DEFS_BEGIN (regno), 
+       bitmap_set_range (dense_invalidated,
+                         DF_DEFS_BEGIN (regno),
                          DF_DEFS_COUNT (regno));
     }
 
@@ -494,7 +494,7 @@ df_rd_local_compute (bitmap all_blocks)
 
 /* Initialize the solution bit vectors for problem.  */
 
-static void 
+static void
 df_rd_init_solution (bitmap all_blocks)
 {
   unsigned int bb_index;
@@ -503,7 +503,7 @@ df_rd_init_solution (bitmap all_blocks)
   EXECUTE_IF_SET_IN_BITMAP (all_blocks, 0, bb_index, bi)
     {
       struct df_rd_bb_info *bb_info = df_rd_get_bb_info (bb_index);
-      
+
       bitmap_copy (bb_info->out, bb_info->gen);
       bitmap_clear (bb_info->in);
     }
@@ -517,7 +517,7 @@ df_rd_confluence_n (edge e)
   bitmap op1 = df_rd_get_bb_info (e->dest->index)->in;
   bitmap op2 = df_rd_get_bb_info (e->src->index)->out;
 
-  if (e->flags & EDGE_FAKE) 
+  if (e->flags & EDGE_FAKE)
     return;
 
   if (e->flags & EDGE_EH)
@@ -535,8 +535,8 @@ df_rd_confluence_n (edge e)
 
       EXECUTE_IF_SET_IN_BITMAP (sparse_invalidated, 0, regno, bi)
        {
-         bitmap_clear_range (tmp, 
-                             DF_DEFS_BEGIN (regno), 
+         bitmap_clear_range (tmp,
+                             DF_DEFS_BEGIN (regno),
                              DF_DEFS_COUNT (regno));
        }
       bitmap_ior_into (op1, tmp);
@@ -563,7 +563,7 @@ df_rd_transfer_function (int bb_index)
 
   if (bitmap_empty_p (sparse_kill))
     return  bitmap_ior_and_compl (out, gen, in, kill);
-  else 
+  else
     {
       struct df_rd_problem_data *problem_data;
       bool changed = false;
@@ -577,8 +577,8 @@ df_rd_transfer_function (int bb_index)
       bitmap_copy (tmp, in);
       EXECUTE_IF_SET_IN_BITMAP (sparse_kill, 0, regno, bi)
        {
-         bitmap_clear_range (tmp, 
-                             DF_DEFS_BEGIN (regno), 
+         bitmap_clear_range (tmp,
+                             DF_DEFS_BEGIN (regno),
                              DF_DEFS_COUNT (regno));
        }
       bitmap_and_compl_into (tmp, kill);
@@ -589,7 +589,7 @@ df_rd_transfer_function (int bb_index)
          BITMAP_FREE (out);
          bb_info->out = tmp;
        }
-      else 
+      else
          BITMAP_FREE (tmp);
       return changed;
     }
@@ -608,7 +608,7 @@ df_rd_free (void)
     {
       free_alloc_pool (df_rd->block_pool);
       bitmap_obstack_release (&problem_data->rd_bitmaps);
-      
+
       df_rd->block_info_size = 0;
       free (df_rd->block_info);
       free (df_rd->problem_data);
@@ -626,8 +626,8 @@ df_rd_start_dump (FILE *file)
     = (struct df_rd_problem_data *) df_rd->problem_data;
   unsigned int m = DF_REG_SIZE(df);
   unsigned int regno;
-  
-  if (!df_rd->block_info) 
+
+  if (!df_rd->block_info)
     return;
 
   fprintf (file, ";; Reaching defs:\n\n");
@@ -639,8 +639,8 @@ df_rd_start_dump (FILE *file)
 
   for (regno = 0; regno < m; regno++)
     if (DF_DEFS_COUNT (regno))
-      fprintf (file, "%d[%d,%d] ", regno, 
-              DF_DEFS_BEGIN (regno), 
+      fprintf (file, "%d[%d,%d] ", regno,
+              DF_DEFS_BEGIN (regno),
               DF_DEFS_COUNT (regno));
   fprintf (file, "\n");
 
@@ -655,7 +655,7 @@ df_rd_top_dump (basic_block bb, FILE *file)
   struct df_rd_bb_info *bb_info = df_rd_get_bb_info (bb->index);
   if (!bb_info || !bb_info->in)
     return;
-  
+
   fprintf (file, ";; rd  in  \t(%d)\n", (int) bitmap_count_bits (bb_info->in));
   dump_bitmap (file, bb_info->in);
   fprintf (file, ";; rd  gen \t(%d)\n", (int) bitmap_count_bits (bb_info->gen));
@@ -673,7 +673,7 @@ df_rd_bottom_dump (basic_block bb, FILE *file)
   struct df_rd_bb_info *bb_info = df_rd_get_bb_info (bb->index);
   if (!bb_info || !bb_info->out)
     return;
-  
+
   fprintf (file, ";; rd  out \t(%d)\n", (int) bitmap_count_bits (bb_info->out));
   dump_bitmap (file, bb_info->out);
 }
@@ -690,8 +690,8 @@ static struct df_problem problem_RD =
   df_rd_local_compute,        /* Local compute function.  */
   df_rd_init_solution,        /* Init the solution specific data.  */
   df_worklist_dataflow,       /* Worklist solver.  */
-  NULL,                       /* Confluence operator 0.  */ 
-  df_rd_confluence_n,         /* Confluence operator n.  */ 
+  NULL,                       /* Confluence operator 0.  */
+  df_rd_confluence_n,         /* Confluence operator n.  */
   df_rd_transfer_function,    /* Transfer function.  */
   NULL,                       /* Finalize function.  */
   df_rd_free,                 /* Free all of the problem information.  */
@@ -702,7 +702,7 @@ static struct df_problem problem_RD =
   NULL,                       /* Incremental solution verify start.  */
   NULL,                       /* Incremental solution verify end.  */
   NULL,                       /* Dependent problem.  */
-  TV_DF_RD,                   /* Timing variable.  */ 
+  TV_DF_RD,                   /* Timing variable.  */
   true                        /* Reset blocks on dropping out of blocks_to_analyze.  */
 };
 
@@ -739,7 +739,7 @@ struct df_lr_problem_data
 /* Set basic block info.  */
 
 static void
-df_lr_set_bb_info (unsigned int index, 
+df_lr_set_bb_info (unsigned int index,
                   struct df_lr_bb_info *bb_info)
 {
   gcc_assert (df_lr);
@@ -747,11 +747,11 @@ df_lr_set_bb_info (unsigned int index,
   df_lr->block_info[index] = bb_info;
 }
 
+
 /* Free basic block info.  */
 
 static void
-df_lr_free_bb_info (basic_block bb ATTRIBUTE_UNUSED, 
+df_lr_free_bb_info (basic_block bb ATTRIBUTE_UNUSED,
                    void *vbb_info)
 {
   struct df_lr_bb_info *bb_info = (struct df_lr_bb_info *) vbb_info;
@@ -769,14 +769,14 @@ df_lr_free_bb_info (basic_block bb ATTRIBUTE_UNUSED,
 /* Allocate or reset bitmaps for DF_LR blocks. The solution bits are
    not touched unless the block is new.  */
 
-static void 
+static void
 df_lr_alloc (bitmap all_blocks ATTRIBUTE_UNUSED)
 {
   unsigned int bb_index;
   bitmap_iterator bi;
 
   if (!df_lr->block_pool)
-    df_lr->block_pool = create_alloc_pool ("df_lr_block pool", 
+    df_lr->block_pool = create_alloc_pool ("df_lr_block pool",
                                           sizeof (struct df_lr_bb_info), 50);
 
   df_grow_bb_info (df_lr);
@@ -785,12 +785,12 @@ df_lr_alloc (bitmap all_blocks ATTRIBUTE_UNUSED)
     {
       struct df_lr_bb_info *bb_info = df_lr_get_bb_info (bb_index);
       if (bb_info)
-       { 
+       {
          bitmap_clear (bb_info->def);
          bitmap_clear (bb_info->use);
        }
       else
-       { 
+       {
          bb_info = (struct df_lr_bb_info *) pool_alloc (df_lr->block_pool);
          df_lr_set_bb_info (bb_index, bb_info);
          bb_info->use = BITMAP_ALLOC (NULL);
@@ -806,7 +806,7 @@ df_lr_alloc (bitmap all_blocks ATTRIBUTE_UNUSED)
 
 /* Reset the global solution for recalculation.  */
 
-static void 
+static void
 df_lr_reset (bitmap all_blocks)
 {
   unsigned int bb_index;
@@ -859,7 +859,7 @@ df_lr_bb_local_compute (unsigned int bb_index)
       unsigned int uid = INSN_UID (insn);
 
       if (!NONDEBUG_INSN_P (insn))
-       continue;       
+       continue;
 
       for (def_rec = DF_INSN_UID_DEFS (uid); *def_rec; def_rec++)
        {
@@ -895,7 +895,7 @@ df_lr_bb_local_compute (unsigned int bb_index)
          bitmap_clear_bit (bb_info->use, dregno);
        }
     }
-  
+
 #ifdef EH_USES
   /* Process the uses that are live into an exception handler.  */
   for (use_rec = df_get_artificial_uses (bb_index); *use_rec; use_rec++)
@@ -923,12 +923,12 @@ df_lr_local_compute (bitmap all_blocks ATTRIBUTE_UNUSED)
 {
   unsigned int bb_index;
   bitmap_iterator bi;
-    
+
   bitmap_clear (df->hardware_regs_used);
-  
+
   /* The all-important stack pointer must always be live.  */
   bitmap_set_bit (df->hardware_regs_used, STACK_POINTER_REGNUM);
-  
+
   /* Before reload, there are a few registers that must be forced
      live everywhere -- which might not already be the case for
      blocks within infinite loops.  */
@@ -937,21 +937,21 @@ df_lr_local_compute (bitmap all_blocks ATTRIBUTE_UNUSED)
       /* Any reference to any pseudo before reload is a potential
         reference of the frame pointer.  */
       bitmap_set_bit (df->hardware_regs_used, FRAME_POINTER_REGNUM);
-      
+
 #if FRAME_POINTER_REGNUM != ARG_POINTER_REGNUM
       /* Pseudos with argument area equivalences may require
         reloading via the argument pointer.  */
       if (fixed_regs[ARG_POINTER_REGNUM])
        bitmap_set_bit (df->hardware_regs_used, ARG_POINTER_REGNUM);
 #endif
-      
+
       /* Any constant, or pseudo with constant equivalences, may
         require reloading from memory using the pic register.  */
       if ((unsigned) PIC_OFFSET_TABLE_REGNUM != INVALID_REGNUM
          && fixed_regs[PIC_OFFSET_TABLE_REGNUM])
        bitmap_set_bit (df->hardware_regs_used, PIC_OFFSET_TABLE_REGNUM);
     }
-  
+
   EXECUTE_IF_SET_IN_BITMAP (df_lr->out_of_date_transfer_functions, 0, bb_index, bi)
     {
       if (bb_index == EXIT_BLOCK)
@@ -971,7 +971,7 @@ df_lr_local_compute (bitmap all_blocks ATTRIBUTE_UNUSED)
 
 /* Initialize the solution vectors.  */
 
-static void 
+static void
 df_lr_init (bitmap all_blocks)
 {
   unsigned int bb_index;
@@ -995,7 +995,7 @@ df_lr_confluence_0 (basic_block bb)
   bitmap op1 = df_lr_get_bb_info (bb->index)->out;
   if (bb != EXIT_BLOCK_PTR)
     bitmap_copy (op1, df->hardware_regs_used);
-} 
+}
 
 
 /* Confluence function that ignores fake edges.  */
@@ -1005,7 +1005,7 @@ df_lr_confluence_n (edge e)
 {
   bitmap op1 = df_lr_get_bb_info (e->src->index)->out;
   bitmap op2 = df_lr_get_bb_info (e->dest->index)->in;
+
   /* Call-clobbered registers die across exception and call edges.  */
   /* ??? Abnormal call edges ignored for the moment, as this gets
      confused by sibling call edges, which crashes reg-stack.  */
@@ -1015,7 +1015,7 @@ df_lr_confluence_n (edge e)
     bitmap_ior_into (op1, op2);
 
   bitmap_ior_into (op1, df->hardware_regs_used);
-} 
+}
 
 
 /* Transfer function.  */
@@ -1087,7 +1087,7 @@ df_lr_free (void)
            }
        }
       free_alloc_pool (df_lr->block_pool);
-      
+
       df_lr->block_info_size = 0;
       free (df_lr->block_info);
     }
@@ -1106,7 +1106,7 @@ df_lr_top_dump (basic_block bb, FILE *file)
   struct df_lr_problem_data *problem_data;
   if (!bb_info || !bb_info->in)
     return;
-      
+
   fprintf (file, ";; lr  in  \t");
   df_print_regset (file, bb_info->in);
   if (df_lr->problem_data)
@@ -1119,7 +1119,7 @@ df_lr_top_dump (basic_block bb, FILE *file)
   df_print_regset (file, bb_info->use);
   fprintf (file, ";; lr  def \t");
   df_print_regset (file, bb_info->def);
-}  
+}
 
 
 /* Debugging info at bottom of bb.  */
@@ -1131,7 +1131,7 @@ df_lr_bottom_dump (basic_block bb, FILE *file)
   struct df_lr_problem_data *problem_data;
   if (!bb_info || !bb_info->out)
     return;
-  
+
   fprintf (file, ";; lr  out \t");
   df_print_regset (file, bb_info->out);
   if (df_lr->problem_data)
@@ -1140,7 +1140,7 @@ df_lr_bottom_dump (basic_block bb, FILE *file)
       fprintf (file, ";;  old out  \t");
       df_print_regset (file, problem_data->out[bb->index]);
     }
-}  
+}
 
 
 /* Build the datastructure to verify that the solution to the dataflow
@@ -1157,7 +1157,7 @@ df_lr_verify_solution_start (void)
       return;
     }
 
-  /* Set it true so that the solution is recomputed.  */ 
+  /* Set it true so that the solution is recomputed.  */
   df_lr->solutions_dirty = true;
 
   problem_data = XNEW (struct df_lr_problem_data);
@@ -1231,8 +1231,8 @@ static struct df_problem problem_LR =
   df_lr_local_compute,        /* Local compute function.  */
   df_lr_init,                 /* Init the solution specific data.  */
   df_worklist_dataflow,       /* Worklist solver.  */
-  df_lr_confluence_0,         /* Confluence operator 0.  */ 
-  df_lr_confluence_n,         /* Confluence operator n.  */ 
+  df_lr_confluence_0,         /* Confluence operator 0.  */
+  df_lr_confluence_n,         /* Confluence operator n.  */
   df_lr_transfer_function,    /* Transfer function.  */
   df_lr_finalize,             /* Finalize function.  */
   df_lr_free,                 /* Free all of the problem information.  */
@@ -1243,7 +1243,7 @@ static struct df_problem problem_LR =
   df_lr_verify_solution_start,/* Incremental solution verify start.  */
   df_lr_verify_solution_end,  /* Incremental solution verify end.  */
   NULL,                       /* Dependent problem.  */
-  TV_DF_LR,                   /* Timing variable.  */ 
+  TV_DF_LR,                   /* Timing variable.  */
   false                       /* Reset blocks on dropping out of blocks_to_analyze.  */
 };
 
@@ -1294,7 +1294,7 @@ df_lr_verify_transfer_functions (void)
          /* Make a copy of the transfer functions and then compute
             new ones to see if the transfer functions have
             changed.  */
-         if (!bitmap_bit_p (df_lr->out_of_date_transfer_functions, 
+         if (!bitmap_bit_p (df_lr->out_of_date_transfer_functions,
                             bb->index))
            {
              bitmap_copy (saved_def, bb_info->def);
@@ -1312,7 +1312,7 @@ df_lr_verify_transfer_functions (void)
          /* If we do not have basic block info, the block must be in
             the list of dirty blocks or else some one has added a
             block behind our backs. */
-         gcc_assert (bitmap_bit_p (df_lr->out_of_date_transfer_functions, 
+         gcc_assert (bitmap_bit_p (df_lr->out_of_date_transfer_functions,
                                    bb->index));
        }
       /* Make sure no one created a block without following
@@ -1321,8 +1321,8 @@ df_lr_verify_transfer_functions (void)
     }
 
   /* Make sure there are no dirty bits in blocks that have been deleted.  */
-  gcc_assert (!bitmap_intersect_compl_p (df_lr->out_of_date_transfer_functions, 
-                                        all_blocks)); 
+  gcc_assert (!bitmap_intersect_compl_p (df_lr->out_of_date_transfer_functions,
+                                        all_blocks));
 
   BITMAP_FREE (saved_def);
   BITMAP_FREE (saved_use);
@@ -1349,7 +1349,7 @@ df_lr_verify_transfer_functions (void)
 
    Then, the in and out sets for the LIVE problem itself are computed.
    These are the logical AND of the IN and OUT sets from the LR problem
-   and the must-initialized problem. 
+   and the must-initialized problem.
 ----------------------------------------------------------------------------*/
 
 /* Private data used to verify the solution for this problem.  */
@@ -1367,7 +1367,7 @@ static bitmap df_live_scratch;
 /* Set basic block info.  */
 
 static void
-df_live_set_bb_info (unsigned int index, 
+df_live_set_bb_info (unsigned int index,
                   struct df_live_bb_info *bb_info)
 {
   gcc_assert (df_live);
@@ -1379,7 +1379,7 @@ df_live_set_bb_info (unsigned int index,
 /* Free basic block info.  */
 
 static void
-df_live_free_bb_info (basic_block bb ATTRIBUTE_UNUSED, 
+df_live_free_bb_info (basic_block bb ATTRIBUTE_UNUSED,
                    void *vbb_info)
 {
   struct df_live_bb_info *bb_info = (struct df_live_bb_info *) vbb_info;
@@ -1397,14 +1397,14 @@ df_live_free_bb_info (basic_block bb ATTRIBUTE_UNUSED,
 /* Allocate or reset bitmaps for DF_LIVE blocks. The solution bits are
    not touched unless the block is new.  */
 
-static void 
+static void
 df_live_alloc (bitmap all_blocks ATTRIBUTE_UNUSED)
 {
   unsigned int bb_index;
   bitmap_iterator bi;
 
   if (!df_live->block_pool)
-    df_live->block_pool = create_alloc_pool ("df_live_block pool", 
+    df_live->block_pool = create_alloc_pool ("df_live_block pool",
                                           sizeof (struct df_live_bb_info), 100);
   if (!df_live_scratch)
     df_live_scratch = BITMAP_ALLOC (NULL);
@@ -1415,12 +1415,12 @@ df_live_alloc (bitmap all_blocks ATTRIBUTE_UNUSED)
     {
       struct df_live_bb_info *bb_info = df_live_get_bb_info (bb_index);
       if (bb_info)
-       { 
+       {
          bitmap_clear (bb_info->kill);
          bitmap_clear (bb_info->gen);
        }
       else
-       { 
+       {
          bb_info = (struct df_live_bb_info *) pool_alloc (df_live->block_pool);
          df_live_set_bb_info (bb_index, bb_info);
          bb_info->kill = BITMAP_ALLOC (NULL);
@@ -1435,7 +1435,7 @@ df_live_alloc (bitmap all_blocks ATTRIBUTE_UNUSED)
 
 /* Reset the global solution for recalculation.  */
 
-static void 
+static void
 df_live_reset (bitmap all_blocks)
 {
   unsigned int bb_index;
@@ -1517,7 +1517,7 @@ df_live_local_compute (bitmap all_blocks ATTRIBUTE_UNUSED)
 
   df_grow_insn_info ();
 
-  EXECUTE_IF_SET_IN_BITMAP (df_live->out_of_date_transfer_functions, 
+  EXECUTE_IF_SET_IN_BITMAP (df_live->out_of_date_transfer_functions,
                            0, bb_index, bi)
     {
       df_live_bb_local_compute (bb_index);
@@ -1529,7 +1529,7 @@ df_live_local_compute (bitmap all_blocks ATTRIBUTE_UNUSED)
 
 /* Initialize the solution vectors.  */
 
-static void 
+static void
 df_live_init (bitmap all_blocks)
 {
   unsigned int bb_index;
@@ -1554,12 +1554,12 @@ df_live_confluence_n (edge e)
 {
   bitmap op1 = df_live_get_bb_info (e->dest->index)->in;
   bitmap op2 = df_live_get_bb_info (e->src->index)->out;
-  if (e->flags & EDGE_FAKE) 
+
+  if (e->flags & EDGE_FAKE)
     return;
 
   bitmap_ior_into (op1, op2);
-} 
+}
 
 
 /* Transfer function for the forwards must-initialized problem.  */
@@ -1574,10 +1574,9 @@ df_live_transfer_function (int bb_index)
   bitmap gen = bb_info->gen;
   bitmap kill = bb_info->kill;
 
-  /* We need to use a scratch set here so that the value returned from
-     this function invocation properly reflects if the sets changed in
-     a significant way; i.e. not just because the lr set was anded
-     in.  */
+  /* We need to use a scratch set here so that the value returned from this
+     function invocation properly reflects whether the sets changed in a
+     significant way; i.e. not just because the lr set was anded in.  */
   bitmap_and (df_live_scratch, gen, bb_lr_info->out);
   /* No register may reach a location where it is not used.  Thus
      we trim the rr result to the places where it is used.  */
@@ -1602,13 +1601,13 @@ df_live_finalize (bitmap all_blocks)
        {
          struct df_lr_bb_info *bb_lr_info = df_lr_get_bb_info (bb_index);
          struct df_live_bb_info *bb_live_info = df_live_get_bb_info (bb_index);
-  
+
          /* No register may reach a location where it is not used.  Thus
             we trim the rr result to the places where it is used.  */
          bitmap_and_into (bb_live_info->in, bb_lr_info->in);
          bitmap_and_into (bb_live_info->out, bb_lr_info->out);
        }
-      
+
       df_live->solutions_dirty = false;
     }
 }
@@ -1622,7 +1621,7 @@ df_live_free (void)
   if (df_live->block_info)
     {
       unsigned int i;
-      
+
       for (i = 0; i < df_live->block_info_size; i++)
        {
          struct df_live_bb_info *bb_info = df_live_get_bb_info (i);
@@ -1634,7 +1633,7 @@ df_live_free (void)
              BITMAP_FREE (bb_info->out);
            }
        }
-      
+
       free_alloc_pool (df_live->block_pool);
       df_live->block_info_size = 0;
       free (df_live->block_info);
@@ -1657,7 +1656,7 @@ df_live_top_dump (basic_block bb, FILE *file)
 
   if (!bb_info || !bb_info->in)
     return;
-      
+
   fprintf (file, ";; live  in  \t");
   df_print_regset (file, bb_info->in);
   if (df_live->problem_data)
@@ -1683,7 +1682,7 @@ df_live_bottom_dump (basic_block bb, FILE *file)
 
   if (!bb_info || !bb_info->out)
     return;
-      
+
   fprintf (file, ";; live  out \t");
   df_print_regset (file, bb_info->out);
   if (df_live->problem_data)
@@ -1709,7 +1708,7 @@ df_live_verify_solution_start (void)
       return;
     }
 
-  /* Set it true so that the solution is recomputed.  */ 
+  /* Set it true so that the solution is recomputed.  */
   df_live->solutions_dirty = true;
 
   problem_data = XNEW (struct df_live_problem_data);
@@ -1778,8 +1777,8 @@ static struct df_problem problem_LIVE =
   df_live_local_compute,        /* Local compute function.  */
   df_live_init,                 /* Init the solution specific data.  */
   df_worklist_dataflow,         /* Worklist solver.  */
-  NULL,                         /* Confluence operator 0.  */ 
-  df_live_confluence_n,         /* Confluence operator n.  */ 
+  NULL,                         /* Confluence operator 0.  */
+  df_live_confluence_n,         /* Confluence operator n.  */
   df_live_transfer_function,    /* Transfer function.  */
   df_live_finalize,             /* Finalize function.  */
   df_live_free,                 /* Free all of the problem information.  */
@@ -1817,7 +1816,7 @@ df_live_set_all_dirty (void)
 {
   basic_block bb;
   FOR_ALL_BB (bb)
-    bitmap_set_bit (df_live->out_of_date_transfer_functions, 
+    bitmap_set_bit (df_live->out_of_date_transfer_functions,
                    bb->index);
 }
 
@@ -1852,7 +1851,7 @@ df_live_verify_transfer_functions (void)
          /* Make a copy of the transfer functions and then compute
             new ones to see if the transfer functions have
             changed.  */
-         if (!bitmap_bit_p (df_live->out_of_date_transfer_functions, 
+         if (!bitmap_bit_p (df_live->out_of_date_transfer_functions,
                             bb->index))
            {
              bitmap_copy (saved_gen, bb_info->gen);
@@ -1870,7 +1869,7 @@ df_live_verify_transfer_functions (void)
          /* If we do not have basic block info, the block must be in
             the list of dirty blocks or else some one has added a
             block behind our backs. */
-         gcc_assert (bitmap_bit_p (df_live->out_of_date_transfer_functions, 
+         gcc_assert (bitmap_bit_p (df_live->out_of_date_transfer_functions,
                                    bb->index));
        }
       /* Make sure no one created a block without following
@@ -1879,8 +1878,8 @@ df_live_verify_transfer_functions (void)
     }
 
   /* Make sure there are no dirty bits in blocks that have been deleted.  */
-  gcc_assert (!bitmap_intersect_compl_p (df_live->out_of_date_transfer_functions, 
-                                        all_blocks)); 
+  gcc_assert (!bitmap_intersect_compl_p (df_live->out_of_date_transfer_functions,
+                                        all_blocks));
   BITMAP_FREE (saved_gen);
   BITMAP_FREE (saved_kill);
   BITMAP_FREE (all_blocks);
@@ -1906,7 +1905,7 @@ df_chain_create (df_ref src, df_ref dst)
 {
   struct df_link *head = DF_REF_CHAIN (src);
   struct df_link *link = (struct df_link *) pool_alloc (df_chain->block_pool);
-  
+
   DF_REF_CHAIN (src) = link;
   link->next = head;
   link->ref = dst;
@@ -1915,7 +1914,7 @@ df_chain_create (df_ref src, df_ref dst)
 
 
 /* Delete any du or ud chains that start at REF and point to
-   TARGET.  */ 
+   TARGET.  */
 static void
 df_chain_unlink_1 (df_ref ref, df_ref target)
 {
@@ -1958,10 +1957,10 @@ df_chain_unlink (df_ref ref)
 
 
 /* Copy the du or ud chain starting at FROM_REF and attach it to
-   TO_REF.  */ 
+   TO_REF.  */
 
-void 
-df_chain_copy (df_ref to_ref, 
+void
+df_chain_copy (df_ref to_ref,
               struct df_link *from_ref)
 {
   while (from_ref)
@@ -1980,7 +1979,7 @@ df_chain_remove_problem (void)
   bitmap_iterator bi;
   unsigned int bb_index;
 
-  /* Wholesale destruction of the old chains.  */ 
+  /* Wholesale destruction of the old chains.  */
   if (df_chain->block_pool)
     free_alloc_pool (df_chain->block_pool);
 
@@ -1997,11 +1996,11 @@ df_chain_remove_problem (void)
       if (df_chain_problem_p (DF_UD_CHAIN))
        for (use_rec = df_get_artificial_uses (bb->index); *use_rec; use_rec++)
          DF_REF_CHAIN (*use_rec) = NULL;
-      
+
       FOR_BB_INSNS (bb, insn)
        {
          unsigned int uid = INSN_UID (insn);
-         
+
          if (INSN_P (insn))
            {
              if (df_chain_problem_p (DF_DU_CHAIN))
@@ -2036,11 +2035,11 @@ df_chain_fully_remove_problem (void)
 
 /* Create def-use or use-def chains.  */
 
-static void  
+static void
 df_chain_alloc (bitmap all_blocks ATTRIBUTE_UNUSED)
 {
   df_chain_remove_problem ();
-  df_chain->block_pool = create_alloc_pool ("df_chain_block pool", 
+  df_chain->block_pool = create_alloc_pool ("df_chain_block pool",
                                         sizeof (struct df_link), 50);
   df_chain->optional_p = true;
 }
@@ -2064,7 +2063,7 @@ df_chain_create_bb_process_use (bitmap local_rd,
 {
   bitmap_iterator bi;
   unsigned int def_index;
-  
+
   while (*use_rec)
     {
       df_ref use = *use_rec;
@@ -2080,13 +2079,13 @@ df_chain_create_bb_process_use (bitmap local_rd,
                {
                  unsigned int first_index = DF_DEFS_BEGIN (uregno);
                  unsigned int last_index = first_index + count - 1;
-                 
+
                  EXECUTE_IF_SET_IN_BITMAP (local_rd, first_index, def_index, bi)
                    {
                      df_ref def;
-                     if (def_index > last_index) 
+                     if (def_index > last_index)
                        break;
-                     
+
                      def = DF_DEFS_GET (def_index);
                      if (df_chain_problem_p (DF_DU_CHAIN))
                        df_chain_create (def, use);
@@ -2121,16 +2120,16 @@ df_chain_create_bb (unsigned int bb_index)
 #ifdef EH_USES
   /* Create the chains for the artificial uses from the EH_USES at the
      beginning of the block.  */
-  
+
   /* Artificials are only hard regs.  */
   if (!(df->changeable_flags & DF_NO_HARD_REGS))
     df_chain_create_bb_process_use (cpy,
-                                   df_get_artificial_uses (bb->index), 
+                                   df_get_artificial_uses (bb->index),
                                    DF_REF_AT_TOP);
 #endif
 
   df_rd_simulate_artificial_defs_at_top (bb, cpy);
-  
+
   /* Process the regular instructions next.  */
   FOR_BB_INSNS (bb, insn)
     if (INSN_P (insn))
@@ -2151,7 +2150,7 @@ df_chain_create_bb (unsigned int bb_index)
      at the end of the block.  */
   if (!(df->changeable_flags & DF_NO_HARD_REGS))
     df_chain_create_bb_process_use (cpy,
-                                   df_get_artificial_uses (bb->index), 
+                                   df_get_artificial_uses (bb->index),
                                    0);
 
   BITMAP_FREE (cpy);
@@ -2165,7 +2164,7 @@ df_chain_finalize (bitmap all_blocks)
 {
   unsigned int bb_index;
   bitmap_iterator bi;
-  
+
   EXECUTE_IF_SET_IN_BITMAP (all_blocks, 0, bb_index, bi)
     {
       df_chain_create_bb (bb_index);
@@ -2195,7 +2194,7 @@ df_chain_top_dump (basic_block bb, FILE *file)
       df_ref *def_rec = df_get_artificial_defs (bb->index);
       if (*def_rec)
        {
-         
+
          fprintf (file, ";;  DU chains for artificial defs\n");
          while (*def_rec)
            {
@@ -2205,7 +2204,7 @@ df_chain_top_dump (basic_block bb, FILE *file)
              fprintf (file, "\n");
              def_rec++;
            }
-       }      
+       }
 
       FOR_BB_INSNS (bb, insn)
        {
@@ -2215,9 +2214,9 @@ df_chain_top_dump (basic_block bb, FILE *file)
              def_rec = DF_INSN_INFO_DEFS (insn_info);
              if (*def_rec)
                {
-                 fprintf (file, ";;   DU chains for insn luid %d uid %d\n", 
+                 fprintf (file, ";;   DU chains for insn luid %d uid %d\n",
                           DF_INSN_INFO_LUID (insn_info), INSN_UID (insn));
-                 
+
                  while (*def_rec)
                    {
                      df_ref def = *def_rec;
@@ -2254,7 +2253,7 @@ df_chain_bottom_dump (basic_block bb, FILE *file)
              fprintf (file, "\n");
              use_rec++;
            }
-       }      
+       }
 
       FOR_BB_INSNS (bb, insn)
        {
@@ -2265,9 +2264,9 @@ df_chain_bottom_dump (basic_block bb, FILE *file)
              use_rec = DF_INSN_INFO_USES (insn_info);
              if (*use_rec || *eq_use_rec)
                {
-                 fprintf (file, ";;   UD chains for insn luid %d uid %d\n", 
+                 fprintf (file, ";;   UD chains for insn luid %d uid %d\n",
                           DF_INSN_INFO_LUID (insn_info), INSN_UID (insn));
-                 
+
                  while (*use_rec)
                    {
                      df_ref use = *use_rec;
@@ -2303,8 +2302,8 @@ static struct df_problem problem_CHAIN =
   NULL,                       /* Local compute function.  */
   NULL,                       /* Init the solution specific data.  */
   NULL,                       /* Iterative solver.  */
-  NULL,                       /* Confluence operator 0.  */ 
-  NULL,                       /* Confluence operator n.  */ 
+  NULL,                       /* Confluence operator 0.  */
+  NULL,                       /* Confluence operator n.  */
   NULL,                       /* Transfer function.  */
   df_chain_finalize,          /* Finalize function.  */
   df_chain_free,              /* Free all of the problem information.  */
@@ -2377,8 +2376,8 @@ struct df_byte_lr_problem_data
   bitmap needs_expansion;
 
   /* The start position and len for each regno in the various bit
-     vectors.  */ 
-  unsigned int* regno_start;  
+     vectors.  */
+  unsigned int* regno_start;
   unsigned int* regno_len;
   /* An obstack for the bitmaps we need for this problem.  */
   bitmap_obstack byte_lr_bitmaps;
@@ -2387,10 +2386,10 @@ struct df_byte_lr_problem_data
 
 /* Get the starting location for REGNO in the df_byte_lr bitmaps.  */
 
-int 
+int
 df_byte_lr_get_regno_start (unsigned int regno)
 {
-  struct df_byte_lr_problem_data *problem_data 
+  struct df_byte_lr_problem_data *problem_data
     = (struct df_byte_lr_problem_data *)df_byte_lr->problem_data;;
   return problem_data->regno_start[regno];
 }
@@ -2398,10 +2397,10 @@ df_byte_lr_get_regno_start (unsigned int regno)
 
 /* Get the len for REGNO in the df_byte_lr bitmaps.  */
 
-int 
+int
 df_byte_lr_get_regno_len (unsigned int regno)
-{  
-  struct df_byte_lr_problem_data *problem_data 
+{
+  struct df_byte_lr_problem_data *problem_data
     = (struct df_byte_lr_problem_data *)df_byte_lr->problem_data;;
   return problem_data->regno_len[regno];
 }
@@ -2410,7 +2409,7 @@ df_byte_lr_get_regno_len (unsigned int regno)
 /* Set basic block info.  */
 
 static void
-df_byte_lr_set_bb_info (unsigned int index, 
+df_byte_lr_set_bb_info (unsigned int index,
                        struct df_byte_lr_bb_info *bb_info)
 {
   gcc_assert (df_byte_lr);
@@ -2418,11 +2417,11 @@ df_byte_lr_set_bb_info (unsigned int index,
   df_byte_lr->block_info[index] = bb_info;
 }
 
+
 /* Free basic block info.  */
 
 static void
-df_byte_lr_free_bb_info (basic_block bb ATTRIBUTE_UNUSED, 
+df_byte_lr_free_bb_info (basic_block bb ATTRIBUTE_UNUSED,
                         void *vbb_info)
 {
   struct df_byte_lr_bb_info *bb_info = (struct df_byte_lr_bb_info *) vbb_info;
@@ -2443,14 +2442,14 @@ df_byte_lr_free_bb_info (basic_block bb ATTRIBUTE_UNUSED,
 static void
 df_byte_lr_check_regs (df_ref *ref_rec)
 {
-  struct df_byte_lr_problem_data *problem_data 
+  struct df_byte_lr_problem_data *problem_data
     = (struct df_byte_lr_problem_data *)df_byte_lr->problem_data;
 
   for (; *ref_rec; ref_rec++)
     {
       df_ref ref = *ref_rec;
-      if (DF_REF_FLAGS_IS_SET (ref, DF_REF_SIGN_EXTRACT 
-                              | DF_REF_ZERO_EXTRACT 
+      if (DF_REF_FLAGS_IS_SET (ref, DF_REF_SIGN_EXTRACT
+                              | DF_REF_ZERO_EXTRACT
                               | DF_REF_STRICT_LOW_PART)
          || GET_CODE (DF_REF_REG (ref)) == SUBREG)
        bitmap_set_bit (problem_data->needs_expansion, DF_REF_REGNO (ref));
@@ -2458,13 +2457,13 @@ df_byte_lr_check_regs (df_ref *ref_rec)
 }
 
 
-/* Expand bitmap SRC which is indexed by regno to DEST which is indexed by 
+/* Expand bitmap SRC which is indexed by regno to DEST which is indexed by
    regno_start and regno_len.  */
 
 static void
 df_byte_lr_expand_bitmap (bitmap dest, bitmap src)
 {
-  struct df_byte_lr_problem_data *problem_data 
+  struct df_byte_lr_problem_data *problem_data
     = (struct df_byte_lr_problem_data *)df_byte_lr->problem_data;
   bitmap_iterator bi;
   unsigned int i;
@@ -2472,7 +2471,7 @@ df_byte_lr_expand_bitmap (bitmap dest, bitmap src)
   bitmap_clear (dest);
   EXECUTE_IF_SET_IN_BITMAP (src, 0, i, bi)
     {
-      bitmap_set_range (dest, problem_data->regno_start[i], 
+      bitmap_set_range (dest, problem_data->regno_start[i],
                        problem_data->regno_len[i]);
     }
 }
@@ -2481,7 +2480,7 @@ df_byte_lr_expand_bitmap (bitmap dest, bitmap src)
 /* Allocate or reset bitmaps for DF_BYTE_LR blocks. The solution bits are
    not touched unless the block is new.  */
 
-static void 
+static void
 df_byte_lr_alloc (bitmap all_blocks ATTRIBUTE_UNUSED)
 {
   unsigned int bb_index;
@@ -2496,7 +2495,7 @@ df_byte_lr_alloc (bitmap all_blocks ATTRIBUTE_UNUSED)
   df_byte_lr->problem_data = problem_data;
 
   if (!df_byte_lr->block_pool)
-    df_byte_lr->block_pool = create_alloc_pool ("df_byte_lr_block pool", 
+    df_byte_lr->block_pool = create_alloc_pool ("df_byte_lr_block pool",
                                           sizeof (struct df_byte_lr_bb_info), 50);
 
   df_grow_bb_info (df_byte_lr);
@@ -2513,7 +2512,7 @@ df_byte_lr_alloc (bitmap all_blocks ATTRIBUTE_UNUSED)
   problem_data->hardware_regs_used = BITMAP_ALLOC (&problem_data->byte_lr_bitmaps);
   problem_data->invalidated_by_call = BITMAP_ALLOC (&problem_data->byte_lr_bitmaps);
   problem_data->needs_expansion = BITMAP_ALLOC (&problem_data->byte_lr_bitmaps);
-  
+
   /* Discover which regno's use subregs, extracts or
      strict_low_parts.  */
   FOR_EACH_BB (bb)
@@ -2533,7 +2532,7 @@ df_byte_lr_alloc (bitmap all_blocks ATTRIBUTE_UNUSED)
 
   bitmap_set_bit (df_byte_lr->out_of_date_transfer_functions, ENTRY_BLOCK);
   bitmap_set_bit (df_byte_lr->out_of_date_transfer_functions, EXIT_BLOCK);
-  
+
   /* Allocate the slots for each regno.  */
   for (regno = 0; regno < max_reg; regno++)
     {
@@ -2541,28 +2540,28 @@ df_byte_lr_alloc (bitmap all_blocks ATTRIBUTE_UNUSED)
       problem_data->regno_start[regno] = index;
       if (bitmap_bit_p (problem_data->needs_expansion, regno))
        len = GET_MODE_SIZE (GET_MODE (regno_reg_rtx[regno]));
-      else 
+      else
        len = 1;
-      
+
       problem_data->regno_len[regno] = len;
       index += len;
     }
 
-  df_byte_lr_expand_bitmap (problem_data->hardware_regs_used, 
+  df_byte_lr_expand_bitmap (problem_data->hardware_regs_used,
                            df->hardware_regs_used);
-  df_byte_lr_expand_bitmap (problem_data->invalidated_by_call, 
+  df_byte_lr_expand_bitmap (problem_data->invalidated_by_call,
                            regs_invalidated_by_call_regset);
 
   EXECUTE_IF_SET_IN_BITMAP (df_byte_lr->out_of_date_transfer_functions, 0, bb_index, bi)
     {
       struct df_byte_lr_bb_info *bb_info = df_byte_lr_get_bb_info (bb_index);
       if (bb_info)
-       { 
+       {
          bitmap_clear (bb_info->def);
          bitmap_clear (bb_info->use);
        }
       else
-       { 
+       {
          bb_info = (struct df_byte_lr_bb_info *) pool_alloc (df_byte_lr->block_pool);
          df_byte_lr_set_bb_info (bb_index, bb_info);
          bb_info->use = BITMAP_ALLOC (&problem_data->byte_lr_bitmaps);
@@ -2571,14 +2570,14 @@ df_byte_lr_alloc (bitmap all_blocks ATTRIBUTE_UNUSED)
          bb_info->out = BITMAP_ALLOC (&problem_data->byte_lr_bitmaps);
        }
     }
-  
+
   df_byte_lr->optional_p = true;
 }
 
 
 /* Reset the global solution for recalculation.  */
 
-static void 
+static void
 df_byte_lr_reset (bitmap all_blocks)
 {
   unsigned int bb_index;
@@ -2599,7 +2598,7 @@ df_byte_lr_reset (bitmap all_blocks)
 static void
 df_byte_lr_bb_local_compute (unsigned int bb_index)
 {
-  struct df_byte_lr_problem_data *problem_data 
+  struct df_byte_lr_problem_data *problem_data
     = (struct df_byte_lr_problem_data *)df_byte_lr->problem_data;
   basic_block bb = BASIC_BLOCK (bb_index);
   struct df_byte_lr_bb_info *bb_info = df_byte_lr_get_bb_info (bb_index);
@@ -2640,7 +2639,7 @@ df_byte_lr_bb_local_compute (unsigned int bb_index)
       unsigned int uid = INSN_UID (insn);
 
       if (!INSN_P (insn))
-       continue;       
+       continue;
 
       for (def_rec = DF_INSN_UID_DEFS (uid); *def_rec; def_rec++)
        {
@@ -2701,7 +2700,7 @@ df_byte_lr_bb_local_compute (unsigned int bb_index)
          bitmap_clear_range (bb_info->use, start, len);
        }
     }
-  
+
 #ifdef EH_USES
   /* Process the uses that are live into an exception handler.  */
   for (use_rec = df_get_artificial_uses (bb_index); *use_rec; use_rec++)
@@ -2747,7 +2746,7 @@ df_byte_lr_local_compute (bitmap all_blocks ATTRIBUTE_UNUSED)
 
 /* Initialize the solution vectors.  */
 
-static void 
+static void
 df_byte_lr_init (bitmap all_blocks)
 {
   unsigned int bb_index;
@@ -2768,12 +2767,12 @@ df_byte_lr_init (bitmap all_blocks)
 static void
 df_byte_lr_confluence_0 (basic_block bb)
 {
-  struct df_byte_lr_problem_data *problem_data 
+  struct df_byte_lr_problem_data *problem_data
     = (struct df_byte_lr_problem_data *)df_byte_lr->problem_data;
   bitmap op1 = df_byte_lr_get_bb_info (bb->index)->out;
   if (bb != EXIT_BLOCK_PTR)
     bitmap_copy (op1, problem_data->hardware_regs_used);
-} 
+}
 
 
 /* Confluence function that ignores fake edges.  */
@@ -2781,11 +2780,11 @@ df_byte_lr_confluence_0 (basic_block bb)
 static void
 df_byte_lr_confluence_n (edge e)
 {
-  struct df_byte_lr_problem_data *problem_data 
+  struct df_byte_lr_problem_data *problem_data
     = (struct df_byte_lr_problem_data *)df_byte_lr->problem_data;
   bitmap op1 = df_byte_lr_get_bb_info (e->src->index)->out;
   bitmap op2 = df_byte_lr_get_bb_info (e->dest->index)->in;
+
   /* Call-clobbered registers die across exception and call edges.  */
   /* ??? Abnormal call edges ignored for the moment, as this gets
      confused by sibling call edges, which crashes reg-stack.  */
@@ -2795,7 +2794,7 @@ df_byte_lr_confluence_n (edge e)
     bitmap_ior_into (op1, op2);
 
   bitmap_ior_into (op1, problem_data->hardware_regs_used);
-} 
+}
 
 
 /* Transfer function.  */
@@ -2846,14 +2845,14 @@ df_byte_lr_top_dump (basic_block bb, FILE *file)
   struct df_byte_lr_bb_info *bb_info = df_byte_lr_get_bb_info (bb->index);
   if (!bb_info || !bb_info->in)
     return;
-      
+
   fprintf (file, ";; blr  in  \t");
   df_print_byte_regset (file, bb_info->in);
   fprintf (file, ";; blr  use \t");
   df_print_byte_regset (file, bb_info->use);
   fprintf (file, ";; blr  def \t");
   df_print_byte_regset (file, bb_info->def);
-}  
+}
 
 
 /* Debugging info at bottom of bb.  */
@@ -2864,10 +2863,10 @@ df_byte_lr_bottom_dump (basic_block bb, FILE *file)
   struct df_byte_lr_bb_info *bb_info = df_byte_lr_get_bb_info (bb->index);
   if (!bb_info || !bb_info->out)
     return;
-  
+
   fprintf (file, ";; blr  out \t");
   df_print_byte_regset (file, bb_info->out);
-}  
+}
 
 
 /* All of the information associated with every instance of the problem.  */
@@ -2882,8 +2881,8 @@ static struct df_problem problem_BYTE_LR =
   df_byte_lr_local_compute,        /* Local compute function.  */
   df_byte_lr_init,                 /* Init the solution specific data.  */
   df_worklist_dataflow,            /* Worklist solver.  */
-  df_byte_lr_confluence_0,         /* Confluence operator 0.  */ 
-  df_byte_lr_confluence_n,         /* Confluence operator n.  */ 
+  df_byte_lr_confluence_0,         /* Confluence operator 0.  */
+  df_byte_lr_confluence_n,         /* Confluence operator n.  */
   df_byte_lr_transfer_function,    /* Transfer function.  */
   NULL,                            /* Finalize function.  */
   df_byte_lr_free,                 /* Free all of the problem information.  */
@@ -2894,7 +2893,7 @@ static struct df_problem problem_BYTE_LR =
   NULL,                            /* Incremental solution verify start.  */
   NULL,                            /* Incremental solution verify end.  */
   NULL,                            /* Dependent problem.  */
-  TV_DF_BYTE_LR,                   /* Timing variable.  */ 
+  TV_DF_BYTE_LR,                   /* Timing variable.  */
   false                            /* Reset blocks on dropping out of blocks_to_analyze.  */
 };
 
@@ -2918,7 +2917,7 @@ df_byte_lr_add_problem (void)
 void
 df_byte_lr_simulate_defs (rtx insn, bitmap live)
 {
-  struct df_byte_lr_problem_data *problem_data 
+  struct df_byte_lr_problem_data *problem_data
     = (struct df_byte_lr_problem_data *)df_byte_lr->problem_data;
   df_ref *def_rec;
   unsigned int uid = INSN_UID (insn);
@@ -2946,15 +2945,15 @@ df_byte_lr_simulate_defs (rtx insn, bitmap live)
            bitmap_clear_range (live, start, len);
        }
     }
-}  
+}
 
 
 /* Simulate the effects of the uses of INSN on LIVE.  */
 
-void 
+void
 df_byte_lr_simulate_uses (rtx insn, bitmap live)
 {
-  struct df_byte_lr_problem_data *problem_data 
+  struct df_byte_lr_problem_data *problem_data
     = (struct df_byte_lr_problem_data *)df_byte_lr->problem_data;
   df_ref *use_rec;
   unsigned int uid = INSN_UID (insn);
@@ -2967,13 +2966,13 @@ df_byte_lr_simulate_uses (rtx insn, bitmap live)
       unsigned int len = problem_data->regno_len[uregno];
       unsigned int sb;
       unsigned int lb;
-      
+
       if (!df_compute_accessed_bytes (use, DF_MM_MAY, &sb, &lb))
        {
          start += sb;
          len = lb - sb;
        }
-      
+
       /* Add use to set of uses in this BB.  */
       if (len)
        bitmap_set_range (live, start, len);
@@ -2984,17 +2983,17 @@ df_byte_lr_simulate_uses (rtx insn, bitmap live)
 /* Apply the artificial uses and defs at the top of BB in a forwards
    direction.  */
 
-void 
+void
 df_byte_lr_simulate_artificial_refs_at_top (basic_block bb, bitmap live)
 {
-  struct df_byte_lr_problem_data *problem_data 
+  struct df_byte_lr_problem_data *problem_data
     = (struct df_byte_lr_problem_data *)df_byte_lr->problem_data;
   df_ref *def_rec;
 #ifdef EH_USES
   df_ref *use_rec;
 #endif
   int bb_index = bb->index;
-  
+
 #ifdef EH_USES
   for (use_rec = df_get_artificial_uses (bb_index); *use_rec; use_rec++)
     {
@@ -3013,7 +3012,7 @@ df_byte_lr_simulate_artificial_refs_at_top (basic_block bb, bitmap live)
     {
       df_ref def = *def_rec;
       if (DF_REF_FLAGS (def) & DF_REF_AT_TOP)
-       {      
+       {
          unsigned int dregno = DF_REF_REGNO (def);
          unsigned int start = problem_data->regno_start[dregno];
          unsigned int len = problem_data->regno_len[dregno];
@@ -3026,15 +3025,15 @@ df_byte_lr_simulate_artificial_refs_at_top (basic_block bb, bitmap live)
 /* Apply the artificial uses and defs at the end of BB in a backwards
    direction.  */
 
-void 
+void
 df_byte_lr_simulate_artificial_refs_at_end (basic_block bb, bitmap live)
 {
-  struct df_byte_lr_problem_data *problem_data 
+  struct df_byte_lr_problem_data *problem_data
     = (struct df_byte_lr_problem_data *)df_byte_lr->problem_data;
   df_ref *def_rec;
   df_ref *use_rec;
   int bb_index = bb->index;
-  
+
   for (def_rec = df_get_artificial_defs (bb_index); *def_rec; def_rec++)
     {
       df_ref def = *def_rec;
@@ -3066,14 +3065,14 @@ df_byte_lr_simulate_artificial_refs_at_end (basic_block bb, bitmap live)
    This problem computes REG_DEAD and REG_UNUSED notes.
    ----------------------------------------------------------------------------*/
 
-static void 
+static void
 df_note_alloc (bitmap all_blocks ATTRIBUTE_UNUSED)
 {
   df_note->optional_p = true;
 }
 
 #ifdef REG_DEAD_DEBUGGING
-static void 
+static void
 df_print_note (const char *prefix, rtx insn, rtx note)
 {
   if (dump_file)
@@ -3091,14 +3090,14 @@ df_print_note (const char *prefix, rtx insn, rtx note)
    just leave the notes alone. */
 
 #ifdef STACK_REGS
-static inline bool 
+static inline bool
 df_ignore_stack_reg (int regno)
 {
   return regstack_completed
     && IN_RANGE (regno, FIRST_STACK_REG, LAST_STACK_REG);
 }
 #else
-static inline bool 
+static inline bool
 df_ignore_stack_reg (int regno ATTRIBUTE_UNUSED)
 {
   return false;
@@ -3122,7 +3121,7 @@ df_kill_notes (rtx insn, rtx *old_dead_notes, rtx *old_unused_notes)
       switch (REG_NOTE_KIND (link))
        {
        case REG_DEAD:
-         /* After reg-stack, we need to ignore any unused notes 
+         /* After reg-stack, we need to ignore any unused notes
             for the stack registers.  */
          if (df_ignore_stack_reg (REGNO (XEXP (link, 0))))
            {
@@ -3142,7 +3141,7 @@ df_kill_notes (rtx insn, rtx *old_dead_notes, rtx *old_unused_notes)
          break;
 
        case REG_UNUSED:
-         /* After reg-stack, we need to ignore any unused notes 
+         /* After reg-stack, we need to ignore any unused notes
             for the stack registers.  */
          if (df_ignore_stack_reg (REGNO (XEXP (link, 0))))
            {
@@ -3160,7 +3159,7 @@ df_kill_notes (rtx insn, rtx *old_dead_notes, rtx *old_unused_notes)
              *pprev = link = next;
            }
          break;
-         
+
        default:
          pprev = &XEXP (link, 1);
          link = *pprev;
@@ -3200,7 +3199,7 @@ df_set_note (enum reg_note note_type, rtx insn, rtx old, rtx reg)
        prev = curr;
        curr = XEXP (curr, 1);
       }
-  
+
   /* Did not find the note.  */
   add_reg_note (insn, note_type, reg);
   return old;
@@ -3241,14 +3240,14 @@ df_whole_mw_reg_unused_p (struct df_mw_hardreg *mws,
 
 static rtx
 df_set_unused_notes_for_mw (rtx insn, rtx old, struct df_mw_hardreg *mws,
-                           bitmap live, bitmap do_not_gen, 
+                           bitmap live, bitmap do_not_gen,
                            bitmap artificial_uses)
 {
   unsigned int r;
-  
+
 #ifdef REG_DEAD_DEBUGGING
   if (dump_file)
-    fprintf (dump_file, "mw_set_unused looking at mws[%d..%d]\n", 
+    fprintf (dump_file, "mw_set_unused looking at mws[%d..%d]\n",
             mws->start_regno, mws->end_regno);
 #endif
 
@@ -3322,11 +3321,11 @@ df_set_dead_notes_for_mw (rtx insn, rtx old, struct df_mw_hardreg *mws,
   bool is_debug = *added_notes_p;
 
   *added_notes_p = false;
-  
+
 #ifdef REG_DEAD_DEBUGGING
   if (dump_file)
     {
-      fprintf (dump_file, "mw_set_dead looking at mws[%d..%d]\n  do_not_gen =", 
+      fprintf (dump_file, "mw_set_dead looking at mws[%d..%d]\n  do_not_gen =",
               mws->start_regno, mws->end_regno);
       df_print_regset (dump_file, do_not_gen);
       fprintf (dump_file, "  live =");
@@ -3375,11 +3374,11 @@ df_set_dead_notes_for_mw (rtx insn, rtx old, struct df_mw_hardreg *mws,
    LIVE.  Do not generate notes for registers in ARTIFICIAL_USES.  */
 
 static rtx
-df_create_unused_note (rtx insn, rtx old, df_ref def, 
+df_create_unused_note (rtx insn, rtx old, df_ref def,
                       bitmap live, bitmap artificial_uses)
 {
   unsigned int dregno = DF_REF_REGNO (def);
-  
+
 #ifdef REG_DEAD_DEBUGGING
   if (dump_file)
     {
@@ -3393,14 +3392,14 @@ df_create_unused_note (rtx insn, rtx old, df_ref def,
        || bitmap_bit_p (artificial_uses, dregno)
        || df_ignore_stack_reg (dregno)))
     {
-      rtx reg = (DF_REF_LOC (def)) 
+      rtx reg = (DF_REF_LOC (def))
                 ? *DF_REF_REAL_LOC (def): DF_REF_REG (def);
       old = df_set_note (REG_UNUSED, insn, old, reg);
 #ifdef REG_DEAD_DEBUGGING
       df_print_note ("adding 3: ", insn, REG_NOTES (insn));
 #endif
     }
-  
+
   return old;
 }
 
@@ -3410,7 +3409,7 @@ df_create_unused_note (rtx insn, rtx old, df_ref def,
    BB.  The three bitvectors are scratch regs used here.  */
 
 static void
-df_note_bb_compute (unsigned int bb_index, 
+df_note_bb_compute (unsigned int bb_index,
                    bitmap live, bitmap do_not_gen, bitmap artificial_uses)
 {
   basic_block bb = BASIC_BLOCK (bb_index);
@@ -3450,13 +3449,13 @@ df_note_bb_compute (unsigned int bb_index,
        {
          unsigned int regno = DF_REF_REGNO (use);
          bitmap_set_bit (live, regno);
-         
+
          /* Notes are not generated for any of the artificial registers
             at the bottom of the block.  */
          bitmap_set_bit (artificial_uses, regno);
        }
     }
-  
+
 #ifdef REG_DEAD_DEBUGGING
   if (dump_file)
     {
@@ -3472,7 +3471,7 @@ df_note_bb_compute (unsigned int bb_index,
       rtx old_dead_notes;
       rtx old_unused_notes;
       int debug_insn;
+
       if (!INSN_P (insn))
        continue;
 
@@ -3496,12 +3495,12 @@ df_note_bb_compute (unsigned int bb_index,
          mws_rec = DF_INSN_UID_MWS (uid);
          while (*mws_rec)
            {
-             struct df_mw_hardreg *mws = *mws_rec; 
-             if ((DF_MWS_REG_DEF_P (mws)) 
+             struct df_mw_hardreg *mws = *mws_rec;
+             if ((DF_MWS_REG_DEF_P (mws))
                  && !df_ignore_stack_reg (mws->start_regno))
-               old_unused_notes 
-                 = df_set_unused_notes_for_mw (insn, old_unused_notes, 
-                                               mws, live, do_not_gen, 
+               old_unused_notes
+                 = df_set_unused_notes_for_mw (insn, old_unused_notes,
+                                               mws, live, do_not_gen,
                                                artificial_uses);
              mws_rec++;
            }
@@ -3515,7 +3514,7 @@ df_note_bb_compute (unsigned int bb_index,
              if (!DF_REF_FLAGS_IS_SET (def, DF_REF_MUST_CLOBBER | DF_REF_MAY_CLOBBER))
                {
                  old_unused_notes
-                   = df_create_unused_note (insn, old_unused_notes, 
+                   = df_create_unused_note (insn, old_unused_notes,
                                             def, live, artificial_uses);
                  bitmap_set_bit (do_not_gen, dregno);
                }
@@ -3530,11 +3529,11 @@ df_note_bb_compute (unsigned int bb_index,
          mws_rec = DF_INSN_UID_MWS (uid);
          while (*mws_rec)
            {
-             struct df_mw_hardreg *mws = *mws_rec; 
+             struct df_mw_hardreg *mws = *mws_rec;
              if (DF_MWS_REG_DEF_P (mws))
                old_unused_notes
-                 = df_set_unused_notes_for_mw (insn, old_unused_notes, 
-                                               mws, live, do_not_gen, 
+                 = df_set_unused_notes_for_mw (insn, old_unused_notes,
+                                               mws, live, do_not_gen,
                                                artificial_uses);
              mws_rec++;
            }
@@ -3544,7 +3543,7 @@ df_note_bb_compute (unsigned int bb_index,
              df_ref def = *def_rec;
              unsigned int dregno = DF_REF_REGNO (def);
              old_unused_notes
-               = df_create_unused_note (insn, old_unused_notes, 
+               = df_create_unused_note (insn, old_unused_notes,
                                         def, live, artificial_uses);
 
              if (!DF_REF_FLAGS_IS_SET (def, DF_REF_MUST_CLOBBER | DF_REF_MAY_CLOBBER))
@@ -3554,13 +3553,13 @@ df_note_bb_compute (unsigned int bb_index,
                bitmap_clear_bit (live, dregno);
            }
        }
-      
+
       /* Process the uses.  */
       mws_rec = DF_INSN_UID_MWS (uid);
       while (*mws_rec)
        {
-         struct df_mw_hardreg *mws = *mws_rec; 
-         if ((DF_MWS_REG_DEF_P (mws))  
+         struct df_mw_hardreg *mws = *mws_rec;
+         if ((DF_MWS_REG_DEF_P (mws))
              && !df_ignore_stack_reg (mws->start_regno))
            {
              bool really_add_notes = debug_insn != 0;
@@ -3603,7 +3602,7 @@ df_note_bb_compute (unsigned int bb_index,
                   && (!(DF_REF_FLAGS (use) & DF_REF_READ_WRITE))
                   && (!df_ignore_stack_reg (uregno)))
                {
-                 rtx reg = (DF_REF_LOC (use)) 
+                 rtx reg = (DF_REF_LOC (use))
                             ? *DF_REF_REAL_LOC (use) : DF_REF_REG (use);
                  old_dead_notes = df_set_note (REG_DEAD, insn, old_dead_notes, reg);
 
@@ -3687,8 +3686,8 @@ static struct df_problem problem_NOTE =
   df_note_compute,            /* Local compute function.  */
   NULL,                       /* Init the solution specific data.  */
   NULL,                       /* Iterative solver.  */
-  NULL,                       /* Confluence operator 0.  */ 
-  NULL,                       /* Confluence operator n.  */ 
+  NULL,                       /* Confluence operator 0.  */
+  NULL,                       /* Confluence operator n.  */
   NULL,                       /* Transfer function.  */
   NULL,                       /* Finalize function.  */
   df_note_free,               /* Free all of the problem information.  */
@@ -3718,7 +3717,7 @@ df_note_add_problem (void)
 
 \f
 /*----------------------------------------------------------------------------
-   Functions for simulating the effects of single insns.  
+   Functions for simulating the effects of single insns.
 
    You can either simulate in the forwards direction, starting from
    the top of a block or the backwards direction from the end of the
@@ -3772,12 +3771,12 @@ df_simulate_defs (rtx insn, bitmap live)
       if (!(DF_REF_FLAGS (def) & (DF_REF_PARTIAL | DF_REF_CONDITIONAL)))
        bitmap_clear_bit (live, dregno);
     }
-}  
+}
 
 
 /* Simulate the effects of the uses of INSN on LIVE.  */
 
-void 
+void
 df_simulate_uses (rtx insn, bitmap live)
 {
   df_ref *use_rec;
@@ -3824,13 +3823,13 @@ df_simulate_fixup_sets (basic_block bb, bitmap live)
 /* Apply the artificial uses and defs at the end of BB in a backwards
    direction.  */
 
-void 
+void
 df_simulate_initialize_backwards (basic_block bb, bitmap live)
 {
   df_ref *def_rec;
   df_ref *use_rec;
   int bb_index = bb->index;
-  
+
   for (def_rec = df_get_artificial_defs (bb_index); *def_rec; def_rec++)
     {
       df_ref def = *def_rec;
@@ -3849,12 +3848,12 @@ df_simulate_initialize_backwards (basic_block bb, bitmap live)
 
 /* Simulate the backwards effects of INSN on the bitmap LIVE.  */
 
-void 
+void
 df_simulate_one_insn_backwards (basic_block bb, rtx insn, bitmap live)
 {
   if (!NONDEBUG_INSN_P (insn))
-    return;    
-  
+    return;
+
   df_simulate_defs (insn, live);
   df_simulate_uses (insn, live);
   df_simulate_fixup_sets (bb, live);
@@ -3864,7 +3863,7 @@ df_simulate_one_insn_backwards (basic_block bb, rtx insn, bitmap live)
 /* Apply the artificial uses and defs at the top of BB in a backwards
    direction.  */
 
-void 
+void
 df_simulate_finalize_backwards (basic_block bb, bitmap live)
 {
   df_ref *def_rec;
@@ -3872,7 +3871,7 @@ df_simulate_finalize_backwards (basic_block bb, bitmap live)
   df_ref *use_rec;
 #endif
   int bb_index = bb->index;
-  
+
   for (def_rec = df_get_artificial_defs (bb_index); *def_rec; def_rec++)
     {
       df_ref def = *def_rec;
@@ -3892,7 +3891,7 @@ df_simulate_finalize_backwards (basic_block bb, bitmap live)
 /*----------------------------------------------------------------------------
    The following three functions are used only for FORWARDS scanning:
    i.e. they process the defs and the REG_DEAD and REG_UNUSED notes.
-   Thus it is important to add the DF_NOTES problem to the stack of 
+   Thus it is important to add the DF_NOTES problem to the stack of
    problems computed before using these functions.
 
    df_simulate_initialize_forwards should be called first with a
@@ -3909,12 +3908,12 @@ df_simulate_finalize_backwards (basic_block bb, bitmap live)
    unless (as is the case for fwprop) they are correct when liveness
    bitmaps are *under*estimated.  */
 
-void 
+void
 df_simulate_initialize_forwards (basic_block bb, bitmap live)
 {
   df_ref *def_rec;
   int bb_index = bb->index;
-  
+
   for (def_rec = df_get_artificial_defs (bb_index); *def_rec; def_rec++)
     {
       df_ref def = *def_rec;
@@ -3925,14 +3924,14 @@ df_simulate_initialize_forwards (basic_block bb, bitmap live)
 
 /* Simulate the forwards effects of INSN on the bitmap LIVE.  */
 
-void 
+void
 df_simulate_one_insn_forwards (basic_block bb, rtx insn, bitmap live)
 {
   rtx link;
   if (! INSN_P (insn))
-    return;    
+    return;
 
-  /* Make sure that DF_NOTE really is an active df problem.  */ 
+  /* Make sure that DF_NOTE really is an active df problem.  */
   gcc_assert (df_note);
 
   /* Note that this is the opposite as how the problem is defined, because
@@ -3958,7 +3957,7 @@ df_simulate_one_insn_forwards (basic_block bb, rtx insn, bitmap live)
                while (--n >= 0)
                  bitmap_clear_bit (live, regno + n);
              }
-           else 
+           else
              bitmap_clear_bit (live, regno);
          }
          break;
@@ -3975,8 +3974,8 @@ df_simulate_one_insn_forwards (basic_block bb, rtx insn, bitmap live)
    MULTIPLE DEFINITIONS
 
    Find the locations in the function reached by multiple definition sites
-   for a pseudo.  In and out bitvectors are built for each basic
-   block.
+   for a live pseudo.  In and out bitvectors are built for each basic
+   block.  They are restricted for efficiency to live registers.
 
    The gen and kill sets for the problem are obvious.  Together they
    include all defined registers in a basic block; the gen set includes
@@ -4015,13 +4014,17 @@ df_simulate_one_insn_forwards (basic_block bb, rtx insn, bitmap live)
     init-set of BB3 includes r10 and r12, but not r11.  Note that we do
     not need to iterate the dominance frontier, because we do not insert
     anything like PHI functions there!  Instead, dataflow will take care of
-    propagating the information to BB3's successors. 
+    propagating the information to BB3's successors.
    ---------------------------------------------------------------------------*/
 
+/* Scratch var used by transfer functions.  This is used to do md analysis
+   only for live registers.  */
+static bitmap df_md_scratch;
+
 /* Set basic block info.  */
 
 static void
-df_md_set_bb_info (unsigned int index, 
+df_md_set_bb_info (unsigned int index,
                    struct df_md_bb_info *bb_info)
 {
   gcc_assert (df_md);
@@ -4031,7 +4034,7 @@ df_md_set_bb_info (unsigned int index,
 
 
 static void
-df_md_free_bb_info (basic_block bb ATTRIBUTE_UNUSED, 
+df_md_free_bb_info (basic_block bb ATTRIBUTE_UNUSED,
                     void *vbb_info)
 {
   struct df_md_bb_info *bb_info = (struct df_md_bb_info *) vbb_info;
@@ -4050,23 +4053,24 @@ df_md_free_bb_info (basic_block bb ATTRIBUTE_UNUSED,
 /* Allocate or reset bitmaps for DF_MD. The solution bits are
    not touched unless the block is new.  */
 
-static void 
+static void
 df_md_alloc (bitmap all_blocks)
 {
   unsigned int bb_index;
   bitmap_iterator bi;
 
   if (!df_md->block_pool)
-    df_md->block_pool = create_alloc_pool ("df_md_block pool", 
+    df_md->block_pool = create_alloc_pool ("df_md_block pool",
                                            sizeof (struct df_md_bb_info), 50);
 
   df_grow_bb_info (df_md);
+  df_md_scratch = BITMAP_ALLOC (NULL);
 
   EXECUTE_IF_SET_IN_BITMAP (all_blocks, 0, bb_index, bi)
     {
       struct df_md_bb_info *bb_info = df_md_get_bb_info (bb_index);
       if (bb_info)
-        { 
+        {
           bitmap_clear (bb_info->init);
           bitmap_clear (bb_info->gen);
           bitmap_clear (bb_info->kill);
@@ -4074,7 +4078,7 @@ df_md_alloc (bitmap all_blocks)
           bitmap_clear (bb_info->out);
         }
       else
-        { 
+        {
           bb_info = (struct df_md_bb_info *) pool_alloc (df_md->block_pool);
           df_md_set_bb_info (bb_index, bb_info);
           bb_info->init = BITMAP_ALLOC (NULL);
@@ -4139,7 +4143,7 @@ df_md_simulate_one_insn (basic_block bb ATTRIBUTE_UNUSED, rtx insn,
 }
 
 static void
-df_md_bb_local_compute_process_def (struct df_md_bb_info *bb_info, 
+df_md_bb_local_compute_process_def (struct df_md_bb_info *bb_info,
                                     df_ref *def_rec,
                                     int top_flag)
 {
@@ -4186,7 +4190,7 @@ df_md_bb_local_compute (unsigned int bb_index)
 
   /* Artificials are only hard regs.  */
   if (!(df->changeable_flags & DF_NO_HARD_REGS))
-    df_md_bb_local_compute_process_def (bb_info, 
+    df_md_bb_local_compute_process_def (bb_info,
                                         df_get_artificial_defs (bb_index),
                                         DF_REF_AT_TOP);
 
@@ -4200,7 +4204,7 @@ df_md_bb_local_compute (unsigned int bb_index)
     }
 
   if (!(df->changeable_flags & DF_NO_HARD_REGS))
-    df_md_bb_local_compute_process_def (bb_info, 
+    df_md_bb_local_compute_process_def (bb_info,
                                         df_get_artificial_defs (bb_index),
                                         0);
 }
@@ -4221,7 +4225,7 @@ df_md_local_compute (bitmap all_blocks)
     {
       df_md_bb_local_compute (bb_index);
     }
-  
+
   BITMAP_FREE (seen_in_insn);
 
   frontiers = XNEWVEC (bitmap, last_basic_block);
@@ -4236,8 +4240,10 @@ df_md_local_compute (bitmap all_blocks)
       bitmap kill = df_md_get_bb_info (bb_index)->kill;
       EXECUTE_IF_SET_IN_BITMAP (frontiers[bb_index], 0, df_bb_index, bi2)
        {
+         basic_block bb = BASIC_BLOCK (df_bb_index);
          if (bitmap_bit_p (all_blocks, df_bb_index))
-           bitmap_ior_into (df_md_get_bb_info (df_bb_index)->init, kill);
+           bitmap_ior_and_into (df_md_get_bb_info (df_bb_index)->init, kill,
+                                df_get_live_in (bb));
        }
     }
 
@@ -4249,7 +4255,7 @@ df_md_local_compute (bitmap all_blocks)
 
 /* Reset the global solution for recalculation.  */
 
-static void 
+static void
 df_md_reset (bitmap all_blocks)
 {
   unsigned int bb_index;
@@ -4267,18 +4273,28 @@ df_md_reset (bitmap all_blocks)
 static bool
 df_md_transfer_function (int bb_index)
 {
+  basic_block bb = BASIC_BLOCK (bb_index);
   struct df_md_bb_info *bb_info = df_md_get_bb_info (bb_index);
   bitmap in = bb_info->in;
   bitmap out = bb_info->out;
   bitmap gen = bb_info->gen;
   bitmap kill = bb_info->kill;
 
-  return bitmap_ior_and_compl (out, gen, in, kill);
+  /* We need to use a scratch set here so that the value returned from this
+     function invocation properly reflects whether the sets changed in a
+     significant way; i.e. not just because the live set was anded in.  */
+  bitmap_and (df_md_scratch, gen, df_get_live_out (bb));
+
+  /* Multiple definitions of a register are not relevant if it is not
+     live.  Thus we trim the result to the places where it is live.  */
+  bitmap_and_into (in, df_get_live_in (bb));
+
+  return bitmap_ior_and_compl (out, df_md_scratch, in, kill);
 }
 
 /* Initialize the solution bit vectors for problem.  */
 
-static void 
+static void
 df_md_init (bitmap all_blocks)
 {
   unsigned int bb_index;
@@ -4287,7 +4303,7 @@ df_md_init (bitmap all_blocks)
   EXECUTE_IF_SET_IN_BITMAP (all_blocks, 0, bb_index, bi)
     {
       struct df_md_bb_info *bb_info = df_md_get_bb_info (bb_index);
-      
+
       bitmap_copy (bb_info->in, bb_info->init);
       df_md_transfer_function (bb_index);
     }
@@ -4298,7 +4314,7 @@ df_md_confluence_0 (basic_block bb)
 {
   struct df_md_bb_info *bb_info = df_md_get_bb_info (bb->index);
   bitmap_copy (bb_info->in, bb_info->init);
-} 
+}
 
 /* In of target gets or of out of source.  */
 
@@ -4308,7 +4324,7 @@ df_md_confluence_n (edge e)
   bitmap op1 = df_md_get_bb_info (e->dest->index)->in;
   bitmap op2 = df_md_get_bb_info (e->src->index)->out;
 
-  if (e->flags & EDGE_FAKE) 
+  if (e->flags & EDGE_FAKE)
     return;
 
   if (e->flags & EDGE_EH)
@@ -4336,6 +4352,7 @@ df_md_free (void)
        }
     }
 
+  BITMAP_FREE (df_md_scratch);
   free_alloc_pool (df_md->block_pool);
 
   df_md->block_info_size = 0;
@@ -4352,7 +4369,7 @@ df_md_top_dump (basic_block bb, FILE *file)
   struct df_md_bb_info *bb_info = df_md_get_bb_info (bb->index);
   if (!bb_info || !bb_info->in)
     return;
-      
+
   fprintf (file, ";; md  in  \t");
   df_print_regset (file, bb_info->in);
   fprintf (file, ";; md  init  \t");
@@ -4371,10 +4388,10 @@ df_md_bottom_dump (basic_block bb, FILE *file)
   struct df_md_bb_info *bb_info = df_md_get_bb_info (bb->index);
   if (!bb_info || !bb_info->out)
     return;
-  
+
   fprintf (file, ";; md  out \t");
   df_print_regset (file, bb_info->out);
-}  
+}
 
 static struct df_problem problem_MD =
 {
@@ -4386,8 +4403,8 @@ static struct df_problem problem_MD =
   df_md_local_compute,        /* Local compute function.  */
   df_md_init,                 /* Init the solution specific data.  */
   df_worklist_dataflow,       /* Worklist solver.  */
-  df_md_confluence_0,         /* Confluence operator 0.  */ 
-  df_md_confluence_n,         /* Confluence operator n.  */ 
+  df_md_confluence_0,         /* Confluence operator 0.  */
+  df_md_confluence_n,         /* Confluence operator n.  */
   df_md_transfer_function,    /* Transfer function.  */
   NULL,                       /* Finalize function.  */
   df_md_free,                 /* Free all of the problem information.  */
@@ -4398,7 +4415,7 @@ static struct df_problem problem_MD =
   NULL,                              /* Incremental solution verify start.  */
   NULL,                              /* Incremental solution verify end.  */
   NULL,                       /* Dependent problem.  */
-  TV_DF_MD,                   /* Timing variable.  */ 
+  TV_DF_MD,                   /* Timing variable.  */
   false                       /* Reset blocks on dropping out of blocks_to_analyze.  */
 };