Blame SOURCES/gcc48-rh1655148.patch

56d343
diff --git a/gcc/cfgexpand.c b/gcc/cfgexpand.c
56d343
index 6dfbb4642..9f30b2749 100644
56d343
--- a/gcc/cfgexpand.c
56d343
+++ b/gcc/cfgexpand.c
56d343
@@ -316,6 +316,15 @@ stack_var_conflict_p (size_t x, size_t y)
56d343
   struct stack_var *b = &stack_vars[y];
56d343
   if (x == y)
56d343
     return false;
56d343
+  /* GCC 4.8 does not calculate the control flow for setjmp correctly
56d343
+     (BZ 56982).  This might lead to merging stack variable slots
56d343
+     which in fact are live at the same time.  The following check
56d343
+     considers all variables being live across setjmp invocations
56d343
+     (these must be marked volatile) to conflict with all other stack
56d343
+     variables.  */
56d343
+  if (cfun->calls_setjmp
56d343
+      && (TREE_THIS_VOLATILE (a->decl) || TREE_THIS_VOLATILE (b->decl)))
56d343
+    return true;
56d343
   /* Partitions containing an SSA name result from gimple registers
56d343
      with things like unsupported modes.  They are top-level and
56d343
      hence conflict with everything else.  */