Blame SOURCES/gcc48-rh1555397.patch

5ed81e
2017-06-28  Andreas Krebbel  <krebbel@linux.vnet.ibm.com>
5ed81e
5ed81e
	* config/s390/predicates.md: Use s390_rel_address_ok_p.
5ed81e
	* config/s390/s390-protos.h: Add prototype of
5ed81e
	s390_rel_address_ok_p.
5ed81e
	* config/s390/s390.c (s390_got_symbol): New function.
5ed81e
	(s390_rel_address_ok_p): New function.
5ed81e
	(legitimize_pic_address): Use s390_rel_address_ok_p.
5ed81e
	(s390_load_got): Use s390_got_symbol.
5ed81e
	(s390_option_override): Issue error if
5ed81e
	-mno-pic-data-is-text-relative is used without -fpic/-fPIC.
5ed81e
	* config/s390/s390.h (TARGET_DEFAULT_PIC_DATA_IS_TEXT_RELATIVE):
5ed81e
	New macro.
5ed81e
	* config/s390/s390.opt: New option mpic-data-is-text-relative.
5ed81e
5ed81e
--- gcc/config/s390/predicates.md	2013-08-14 07:55:12.000000000 -0400
5ed81e
+++ gcc/config/s390/predicates.md	2018-04-09 21:36:49.428209951 -0400
5ed81e
@@ -116,7 +116,7 @@
5ed81e
   if (GET_CODE (op) == SYMBOL_REF)
5ed81e
     return (!SYMBOL_REF_ALIGN1_P (op)
5ed81e
 	    && SYMBOL_REF_TLS_MODEL (op) == 0
5ed81e
-	    && (!flag_pic || SYMBOL_REF_LOCAL_P (op)));
5ed81e
+	    && s390_rel_address_ok_p (op));
5ed81e
 
5ed81e
   /* Everything else must have a CONST, so strip it.  */
5ed81e
   if (GET_CODE (op) != CONST)
5ed81e
@@ -141,7 +141,7 @@
5ed81e
   if (GET_CODE (op) == SYMBOL_REF)
5ed81e
     return ((SYMBOL_REF_FLAGS (op) & SYMBOL_FLAG_ALIGN1) == 0
5ed81e
 	    && SYMBOL_REF_TLS_MODEL (op) == 0
5ed81e
-	    && (!flag_pic || SYMBOL_REF_LOCAL_P (op)));
5ed81e
+	    && s390_rel_address_ok_p (op));
5ed81e
 
5ed81e
   /* Now we must have a @GOTENT offset or @PLT stub
5ed81e
      or an @INDNTPOFF TLS offset.  */
5ed81e
--- gcc/config/s390/s390.c	2015-06-18 10:33:04.000000000 -0400
5ed81e
+++ gcc/config/s390/s390.c	2018-04-09 21:32:43.489851529 -0400
5ed81e
@@ -491,6 +491,23 @@ s390_label_align (rtx label)
5ed81e
   return align_labels_log;
5ed81e
 }
5ed81e
 
5ed81e
+static GTY(()) rtx got_symbol;
5ed81e
+
5ed81e
+/* Return the GOT table symbol.  The symbol will be created when the
5ed81e
+   function is invoked for the first time.  */
5ed81e
+
5ed81e
+static rtx
5ed81e
+s390_got_symbol (void)
5ed81e
+{
5ed81e
+  if (!got_symbol)
5ed81e
+    {
5ed81e
+      got_symbol = gen_rtx_SYMBOL_REF (Pmode, "_GLOBAL_OFFSET_TABLE_");
5ed81e
+      SYMBOL_REF_FLAGS (got_symbol) = SYMBOL_FLAG_LOCAL;
5ed81e
+    }
5ed81e
+
5ed81e
+  return got_symbol;
5ed81e
+}
5ed81e
+
5ed81e
 static enum machine_mode
5ed81e
 s390_libgcc_cmp_return_mode (void)
5ed81e
 {
5ed81e
@@ -1863,6 +1880,9 @@ s390_option_override (void)
5ed81e
   if (flag_prefetch_loop_arrays < 0 && HAVE_prefetch && optimize >= 3)
5ed81e
     flag_prefetch_loop_arrays = 1;
5ed81e
 
5ed81e
+  if (!s390_pic_data_is_text_relative && !flag_pic)
5ed81e
+    error ("-mno-pic-data-is-text-relative cannot be used without -fpic/-fPIC");
5ed81e
+
5ed81e
   /* Use the alternative scheduling-pressure algorithm by default.  */
5ed81e
   maybe_set_param_value (PARAM_SCHED_PRESSURE_ALGORITHM, 2,
5ed81e
                          global_options.x_param_values,
5ed81e
@@ -3557,6 +3577,26 @@ s390_load_address (rtx dst, rtx src)
5ed81e
     emit_insn (gen_force_la_31 (dst, src));
5ed81e
 }
5ed81e
 
5ed81e
+/* Return true if it ok to use SYMBOL_REF in a relative address.  */
5ed81e
+
5ed81e
+bool
5ed81e
+s390_rel_address_ok_p (rtx symbol_ref)
5ed81e
+{
5ed81e
+  tree decl;
5ed81e
+
5ed81e
+  if (symbol_ref == s390_got_symbol () || CONSTANT_POOL_ADDRESS_P (symbol_ref))
5ed81e
+    return true;
5ed81e
+
5ed81e
+  decl = SYMBOL_REF_DECL (symbol_ref);
5ed81e
+
5ed81e
+  if (!flag_pic || SYMBOL_REF_LOCAL_P (symbol_ref))
5ed81e
+    return (s390_pic_data_is_text_relative
5ed81e
+	    || (decl
5ed81e
+		&& TREE_CODE (decl) == FUNCTION_DECL));
5ed81e
+
5ed81e
+  return false;
5ed81e
+}
5ed81e
+
5ed81e
 /* Return a legitimate reference for ORIG (an address) using the
5ed81e
    register REG.  If REG is 0, a new pseudo is generated.
5ed81e
 
5ed81e
@@ -3594,7 +3634,7 @@ legitimize_pic_address (rtx orig, rtx re
5ed81e
     }
5ed81e
 
5ed81e
   if ((GET_CODE (addr) == LABEL_REF
5ed81e
-       || (GET_CODE (addr) == SYMBOL_REF && SYMBOL_REF_LOCAL_P (addr))
5ed81e
+       || (GET_CODE (addr) == SYMBOL_REF && s390_rel_address_ok_p (addr))
5ed81e
        || (GET_CODE (addr) == UNSPEC &&
5ed81e
 	   (XINT (addr, 1) == UNSPEC_GOTENT
5ed81e
 	    || (TARGET_CPU_ZARCH && XINT (addr, 1) == UNSPEC_PLT))))
5ed81e
@@ -8545,7 +8585,6 @@ restore_gprs (rtx base, int offset, int
5ed81e
 
5ed81e
 /* Return insn sequence to load the GOT register.  */
5ed81e
 
5ed81e
-static GTY(()) rtx got_symbol;
5ed81e
 rtx
5ed81e
 s390_load_got (void)
5ed81e
 {
5ed81e
@@ -8557,23 +8596,17 @@ s390_load_got (void)
5ed81e
      aren't usable.  */
5ed81e
   rtx got_rtx = gen_rtx_REG (Pmode, 12);
5ed81e
 
5ed81e
-  if (!got_symbol)
5ed81e
-    {
5ed81e
-      got_symbol = gen_rtx_SYMBOL_REF (Pmode, "_GLOBAL_OFFSET_TABLE_");
5ed81e
-      SYMBOL_REF_FLAGS (got_symbol) = SYMBOL_FLAG_LOCAL;
5ed81e
-    }
5ed81e
-
5ed81e
   start_sequence ();
5ed81e
 
5ed81e
   if (TARGET_CPU_ZARCH)
5ed81e
     {
5ed81e
-      emit_move_insn (got_rtx, got_symbol);
5ed81e
+      emit_move_insn (got_rtx, s390_got_symbol ());
5ed81e
     }
5ed81e
   else
5ed81e
     {
5ed81e
       rtx offset;
5ed81e
 
5ed81e
-      offset = gen_rtx_UNSPEC (Pmode, gen_rtvec (1, got_symbol),
5ed81e
+      offset = gen_rtx_UNSPEC (Pmode, gen_rtvec (1, s390_got_symbol ()),
5ed81e
 			       UNSPEC_LTREL_OFFSET);
5ed81e
       offset = gen_rtx_CONST (Pmode, offset);
5ed81e
       offset = force_const_mem (Pmode, offset);
5ed81e
--- gcc/config/s390/s390.h	2014-01-14 10:37:03.000000000 -0500
5ed81e
+++ gcc/config/s390/s390.h	2018-04-09 21:21:28.076858052 -0400
5ed81e
@@ -814,6 +814,10 @@ do {									\
5ed81e
 
5ed81e
 #define LEGITIMATE_PIC_OPERAND_P(X)  legitimate_pic_operand_p (X)
5ed81e
 
5ed81e
+#ifndef TARGET_DEFAULT_PIC_DATA_IS_TEXT_RELATIVE
5ed81e
+#define TARGET_DEFAULT_PIC_DATA_IS_TEXT_RELATIVE 1
5ed81e
+#endif
5ed81e
+
5ed81e
 
5ed81e
 /* Assembler file format.  */
5ed81e
 
5ed81e
--- gcc/config/s390/s390.opt	2015-06-18 10:33:05.000000000 -0400
5ed81e
+++ gcc/config/s390/s390.opt	2018-04-09 21:28:18.842465842 -0400
5ed81e
@@ -158,6 +158,10 @@ mzarch
5ed81e
 Target Report RejectNegative Negative(mesa) Mask(ZARCH)
5ed81e
 z/Architecture
5ed81e
 
5ed81e
+mpic-data-is-text-relative
5ed81e
+Target Report Var(s390_pic_data_is_text_relative) Init(TARGET_DEFAULT_PIC_DATA_IS_TEXT_RELATIVE)
5ed81e
+Assume data segments are relative to text segment.
5ed81e
+
5ed81e
 mbranch-cost=
5ed81e
 Target Report Joined RejectNegative UInteger Var(s390_branch_cost) Init(1)
5ed81e
 Set the branch costs for conditional branch instructions.  Reasonable
5ed81e
--- gcc/config/s390/s390-protos.h	2014-01-14 10:37:04.000000000 -0500
5ed81e
+++ gcc/config/s390/s390-protos.h	2018-04-09 21:21:28.072858046 -0400
5ed81e
@@ -52,6 +52,7 @@ extern bool s390_contiguous_bitmask_p (u
5ed81e
 extern bool s390_split_ok_p (rtx, rtx, enum machine_mode, int);
5ed81e
 extern bool s390_overlap_p (rtx, rtx, HOST_WIDE_INT);
5ed81e
 extern bool s390_offset_p (rtx, rtx, rtx);
5ed81e
+extern bool s390_rel_address_ok_p (rtx);
5ed81e
 extern int tls_symbolic_operand (rtx);
5ed81e
 
5ed81e
 extern bool s390_match_ccmode (rtx, enum machine_mode);
5ed81e
--- gcc/testsuite/gcc.target/s390/nodatarel-1.c	1969-12-31 19:00:00.000000000 -0500
5ed81e
+++ gcc/testsuite/gcc.target/s390/nodatarel-1.c	2018-04-09 21:21:28.077858053 -0400
5ed81e
@@ -0,0 +1,83 @@
5ed81e
+/* Test -mno-pic-data-is-text-relative option.  No relative addressing
5ed81e
+   of elements in .data and .bss are allowed with that option.  */
5ed81e
+
5ed81e
+/* { dg-do compile } */
5ed81e
+/* { dg-options "-O3 -fno-optimize-sibling-calls -fpic -mno-pic-data-is-text-relative -march=z10 -mtune=z9-109 -mzarch" } */
5ed81e
+
5ed81e
+static int a = 3;
5ed81e
+
5ed81e
+/* With -mno-pic-data-is-text-relative these must be addressed via
5ed81e
+   GOT.  */
5ed81e
+
5ed81e
+int __attribute__((noinline,noclone))
5ed81e
+foo ()
5ed81e
+{
5ed81e
+  return a;
5ed81e
+}
5ed81e
+
5ed81e
+static int __attribute__((noinline,noclone))
5ed81e
+foostatic (void)
5ed81e
+{
5ed81e
+  return a;
5ed81e
+}
5ed81e
+
5ed81e
+/* Just to make a potentially modified.  */
5ed81e
+
5ed81e
+void
5ed81e
+bar (int b)
5ed81e
+{
5ed81e
+  a = b;
5ed81e
+}
5ed81e
+
5ed81e
+/* { dg-final { scan-assembler-times "a@GOTENT" 3 } } */
5ed81e
+
5ed81e
+/* The exrl target is a label_ref which should not be affected at
5ed81e
+   all.  */
5ed81e
+
5ed81e
+void
5ed81e
+mymemcpy (char *dst, char *src, long size)
5ed81e
+{
5ed81e
+  __builtin_memcpy (dst, src, size);
5ed81e
+}
5ed81e
+
5ed81e
+/* { dg-final { scan-assembler "exrl" } } */
5ed81e
+
5ed81e
+
5ed81e
+/* PLT slots can still be addressed relatively.  */
5ed81e
+
5ed81e
+int
5ed81e
+callfoo ()
5ed81e
+{
5ed81e
+  return foo ();
5ed81e
+}
5ed81e
+
5ed81e
+/* { dg-final { scan-assembler-times "foo@PLT" 1 } } */
5ed81e
+
5ed81e
+
5ed81e
+/* GOT entries can still be addressed relatively.  */
5ed81e
+
5ed81e
+void *
5ed81e
+fooptr ()
5ed81e
+{
5ed81e
+  return &foo;
5ed81e
+}
5ed81e
+
5ed81e
+/* { dg-final { scan-assembler-times "foo@GOTENT" 1 } } */
5ed81e
+
5ed81e
+
5ed81e
+/* A static function can be addressed relatively.  */
5ed81e
+
5ed81e
+int
5ed81e
+callfoostatic ()
5ed81e
+{
5ed81e
+  return foostatic ();
5ed81e
+}
5ed81e
+
5ed81e
+void *
5ed81e
+foostaticptr ()
5ed81e
+{
5ed81e
+  return &foostatic;
5ed81e
+}
5ed81e
+
5ed81e
+
5ed81e
+/* { dg-final { scan-assembler-not "foostatic@" } } */