Blame SOURCES/gcc48-rh1469697-10.patch

4dd737
commit c22c3dee4bbf4a99b234307c63e4845052a15890
4dd737
Author: law <law@138bc75d-0d04-0410-961f-82ee72b054a4>
4dd737
Date:   Thu Sep 21 22:03:59 2017 +0000
4dd737
4dd737
            * config/i386/i386.c (ix86_adjust_stack_and_probe_stack_clash):
4dd737
            Fix dump output if the only stack space is for pushed registers.
4dd737
    
4dd737
            * lib/target-supports.exp
4dd737
            (check_effective_target_frame_pointer_for_non_leaf): Add
4dd737
            case for x86 Solaris.
4dd737
    
4dd737
    git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@253082 138bc75d-0d04-0410-961f-82ee72b054a4
4dd737
4dd737
diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c
4dd737
index a9072f58f50..d8a225195ae 100644
4dd737
--- a/gcc/config/i386/i386.c
4dd737
+++ b/gcc/config/i386/i386.c
4dd737
@@ -9856,7 +9856,16 @@ ix86_adjust_stack_and_probe_stack_clash (const HOST_WIDE_INT size)
4dd737
      no probes are needed.  */
4dd737
   if (!size)
4dd737
     {
4dd737
-      dump_stack_clash_frame_info (NO_PROBE_NO_FRAME, false);
4dd737
+      struct ix86_frame frame;
4dd737
+      ix86_compute_frame_layout (&frame);
4dd737
+
4dd737
+      /* However, the allocation of space via pushes for register
4dd737
+	 saves could be viewed as allocating space, but without the
4dd737
+	 need to probe.  */
4dd737
+      if (frame.nregs || frame.nsseregs || frame_pointer_needed)
4dd737
+        dump_stack_clash_frame_info (NO_PROBE_SMALL_FRAME, true);
4dd737
+      else
4dd737
+	dump_stack_clash_frame_info (NO_PROBE_NO_FRAME, false);
4dd737
       return;
4dd737
     }
4dd737
 
4dd737
diff --git a/gcc/testsuite/lib/target-supports.exp b/gcc/testsuite/lib/target-supports.exp
4dd737
index f24c5c6e0ac..7c126e4122b 100644
4dd737
--- a/gcc/testsuite/lib/target-supports.exp
4dd737
+++ b/gcc/testsuite/lib/target-supports.exp
4dd737
@@ -5439,6 +5439,12 @@ proc check_effective_target_frame_pointer_for_non_leaf { } {
4dd737
   if { [istarget aarch*-*-*] } {
4dd737
 	return 1
4dd737
   }
4dd737
+
4dd737
+  # Solaris/x86 defaults to -fno-omit-frame-pointer.
4dd737
+  if { [istarget i?86-*-solaris*] || [istarget x86_64-*-solaris*] } {
4dd737
+    return 1
4dd737
+  }
4dd737
+
4dd737
   return 0
4dd737
 }
4dd737