spu.c (asm_file_start): Only reset flag_var_tracking if branch-hint optimization...
authorUlrich Weigand <uweigand@de.ibm.com>
Mon, 3 Jan 2011 23:14:18 +0000 (23:14 +0000)
committerUlrich Weigand <uweigand@gcc.gnu.org>
Mon, 3 Jan 2011 23:14:18 +0000 (23:14 +0000)
* config/spu/spu.c (asm_file_start): Only reset flag_var_tracking
if branch-hint optimization will be performed.

From-SVN: r168444

gcc/ChangeLog
gcc/config/spu/spu.c

index 3c26a9aa66bbe092588e94141af083666e4a00f2..261affd6d90801b88321c0d8e614ca7dbf9cff57 100644 (file)
@@ -1,3 +1,8 @@
+2011-01-03  Ulrich Weigand  <Ulrich.Weigand@de.ibm.com>
+
+       * config/spu/spu.c (asm_file_start): Only reset flag_var_tracking
+       if branch-hint optimization will be performed.
+
 2011-01-03  Jakub Jelinek  <jakub@redhat.com>
 
        PR tree-optimization/47148
index 045fc8794ed281d651eec059b2241454b62738d5..db17570248a589a6b6370794f75812ed66d72767 100644 (file)
@@ -7014,9 +7014,17 @@ static void
 asm_file_start (void)
 {
   /* Variable tracking should be run after all optimizations which
-     change order of insns.  It also needs a valid CFG. */
-  spu_flag_var_tracking = flag_var_tracking;
-  flag_var_tracking = 0;
+     change order of insns.  It also needs a valid CFG.  Therefore,
+     *if* we make nontrivial changes in machine-dependent reorg,
+     run variable tracking after those.  However, if we do not run
+     our machine-dependent reorg pass, we must still run the normal
+     variable tracking pass (or else we will ICE in final since
+     debug insns have not been removed).  */
+  if (TARGET_BRANCH_HINTS && optimize)
+    {
+      spu_flag_var_tracking = flag_var_tracking;
+      flag_var_tracking = 0;
+    }
 
   default_file_start ();
 }