Blame SOURCES/gcc48-rh1535655-4.patch

56d343
commit 94695137d1ea3c094dd37ab5b73d66b09639f3f4
56d343
Author: hjl <hjl@138bc75d-0d04-0410-961f-82ee72b054a4>
56d343
Date:   Tue Jan 16 11:17:49 2018 +0000
56d343
56d343
    HJ patch #3
56d343
56d343
diff --git a/gcc/config/i386/constraints.md b/gcc/config/i386/constraints.md
56d343
index d567fd7..43faabb 100644
56d343
--- a/gcc/config/i386/constraints.md
56d343
+++ b/gcc/config/i386/constraints.md
56d343
@@ -135,7 +135,8 @@
56d343
 
56d343
 (define_constraint "w"
56d343
   "@internal Call memory operand."
56d343
-  (and (not (match_test "TARGET_X32"))
56d343
+  (and (not (match_test "ix86_indirect_branch_register"))
56d343
+       (not (match_test "TARGET_X32"))
56d343
        (match_operand 0 "memory_operand")))
56d343
 
56d343
 ;; Integer constant constraints.
56d343
diff --git a/gcc/config/i386/i386.md b/gcc/config/i386/i386.md
56d343
index ef16cf5..228f8f6 100644
56d343
--- a/gcc/config/i386/i386.md
56d343
+++ b/gcc/config/i386/i386.md
56d343
@@ -11274,7 +11274,7 @@
56d343
   [(set (pc) (match_operand 0 "indirect_branch_operand"))]
56d343
   ""
56d343
 {
56d343
-  if (TARGET_X32)
56d343
+  if (TARGET_X32 || ix86_indirect_branch_register)
56d343
     operands[0] = convert_memory_address (word_mode, operands[0]);
56d343
   cfun->machine->has_local_indirect_jump = true;
56d343
 })
56d343
@@ -11327,7 +11327,7 @@
56d343
 					 OPTAB_DIRECT);
56d343
     }
56d343
 
56d343
-  if (TARGET_X32)
56d343
+  if (TARGET_X32 || ix86_indirect_branch_register)
56d343
     operands[0] = convert_memory_address (word_mode, operands[0]);
56d343
   cfun->machine->has_local_indirect_jump = true;
56d343
 })
56d343
@@ -11514,7 +11514,7 @@
56d343
 })
56d343
 
56d343
 (define_insn "*call_pop"
56d343
-  [(call (mem:QI (match_operand:SI 0 "call_insn_operand" "lzm"))
56d343
+  [(call (mem:QI (match_operand:SI 0 "call_insn_operand" "lwz"))
56d343
 	 (match_operand 1))
56d343
    (set (reg:SI SP_REG)
56d343
 	(plus:SI (reg:SI SP_REG)
56d343
@@ -11612,7 +11612,7 @@
56d343
 
56d343
 (define_insn "*call_value_pop"
56d343
   [(set (match_operand 0)
56d343
-	(call (mem:QI (match_operand:SI 1 "call_insn_operand" "lzm"))
56d343
+	(call (mem:QI (match_operand:SI 1 "call_insn_operand" "lwz"))
56d343
 	      (match_operand 2)))
56d343
    (set (reg:SI SP_REG)
56d343
 	(plus:SI (reg:SI SP_REG)
56d343
diff --git a/gcc/config/i386/i386.opt b/gcc/config/i386/i386.opt
56d343
index 9dfa2cb..0a8ae8f 100644
56d343
--- a/gcc/config/i386/i386.opt
56d343
+++ b/gcc/config/i386/i386.opt
56d343
@@ -654,3 +654,7 @@ Enum(indirect_branch) String(thunk-inline) Value(indirect_branch_thunk_inline)
56d343
 
56d343
 EnumValue
56d343
 Enum(indirect_branch) String(thunk-extern) Value(indirect_branch_thunk_extern)
56d343
+
56d343
+mindirect-branch-register
56d343
+Target Report Var(ix86_indirect_branch_register) Init(0)
56d343
+Force indirect call and jump via register.
56d343
diff --git a/gcc/config/i386/predicates.md b/gcc/config/i386/predicates.md
56d343
index 61614e1..6c7a593 100644
56d343
--- a/gcc/config/i386/predicates.md
56d343
+++ b/gcc/config/i386/predicates.md
56d343
@@ -540,7 +540,8 @@
56d343
 ;; Test for a valid operand for indirect branch.
56d343
 (define_predicate "indirect_branch_operand"
56d343
   (ior (match_operand 0 "register_operand")
56d343
-       (and (not (match_test "TARGET_X32"))
56d343
+       (and (not (match_test "ix86_indirect_branch_register"))
56d343
+	    (not (match_test "TARGET_X32"))
56d343
 	    (match_operand 0 "memory_operand"))))
56d343
 
56d343
 ;; Test for a valid operand for a call instruction.
56d343
@@ -549,8 +550,9 @@
56d343
   (ior (match_test "constant_call_address_operand
56d343
 		     (op, mode == VOIDmode ? mode : Pmode)")
56d343
        (match_operand 0 "call_register_no_elim_operand")
56d343
-       (and (not (match_test "TARGET_X32"))
56d343
-	    (match_operand 0 "memory_operand"))))
56d343
+       (and (not (match_test "ix86_indirect_branch_register"))
56d343
+	    (and (not (match_test "TARGET_X32"))
56d343
+		 (match_operand 0 "memory_operand")))))
56d343
 
56d343
 ;; Similarly, but for tail calls, in which we cannot allow memory references.
56d343
 (define_special_predicate "sibcall_insn_operand"
56d343
diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
56d343
index 5acd23a..4a365c7 100644
56d343
--- a/gcc/doc/invoke.texi
56d343
+++ b/gcc/doc/invoke.texi
56d343
@@ -658,7 +658,8 @@ Objective-C and Objective-C++ Dialects}.
56d343
 -m32 -m64 -mx32 -mlarge-data-threshold=@var{num} @gol
56d343
 -msse2avx -mfentry -m8bit-idiv @gol
56d343
 -mavx256-split-unaligned-load -mavx256-split-unaligned-store @gol
56d343
--mindirect-branch=@var{choice} -mfunction-return==@var{choice}}
56d343
+-mindirect-branch=@var{choice} -mfunction-return==@var{choice}
56d343
+-mindirect-branch-register}
56d343
 
56d343
 @emph{i386 and x86-64 Windows Options}
56d343
 @gccoptlist{-mconsole -mcygwin -mno-cygwin -mdll @gol
56d343
@@ -14669,6 +14670,10 @@ object file.  You can control this behavior for a specific function by
56d343
 using the function attribute @code{function_return}.
56d343
 @xref{Function Attributes}.
56d343
 
56d343
+@item -mindirect-branch-register
56d343
+@opindex -mindirect-branch-register
56d343
+Force indirect call and jump via register.
56d343
+
56d343
 @end table
56d343
 
56d343
 These @samp{-m} switches are supported in addition to the above
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-1.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-1.c
56d343
index 034b4cc..321db77 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-1.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-1.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-2.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-2.c
56d343
index e0c57cb..d584516 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-2.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-2.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-3.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-3.c
56d343
index 3c0d4c3..9e24a38 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-3.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-3.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mno-indirect-branch-register -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-4.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-4.c
56d343
index 14d4ef6..127b5d9 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-4.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-4.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mno-indirect-branch-register -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-7.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-7.c
56d343
index bc6b47a..17c2d0f 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-7.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-7.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk -fno-pic" } */
56d343
 
56d343
 void func0 (void);
56d343
 void func1 (void);
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-1.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-1.c
56d343
index 7c45142..cd7e8d7 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-1.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-1.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-2.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-2.c
56d343
index 9eebc84..4dbd7a5 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-2.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-2.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-3.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-3.c
56d343
index f938db0..4aeec18 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-3.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-3.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-4.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-4.c
56d343
index 4e58599..ac0e599 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-4.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-4.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-5.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-5.c
56d343
index b8d5024..573cf1e 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-5.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-5.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-6.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-6.c
56d343
index 455adab..b2b37fc 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-6.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-6.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-7.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-7.c
56d343
index 4595b84..4a43e19 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-7.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-attr-7.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -fno-pic" } */
56d343
 
56d343
 void func0 (void);
56d343
 void func1 (void);
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-1.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-1.c
56d343
index f424181..72de88e 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-1.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-1.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk-extern -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk-extern -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-2.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-2.c
56d343
index ac54868..d4137b3 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-2.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-2.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk-extern -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk-extern -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-3.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-3.c
56d343
index 06ebf1c..d9964c2 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-3.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-3.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk-extern -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk-extern -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-4.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-4.c
56d343
index 1c8f944..d4dca4d 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-4.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-4.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk-extern -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk-extern -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-7.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-7.c
56d343
index 86e9fd1..aece938 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-7.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-extern-7.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk-extern -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk-extern -fno-pic" } */
56d343
 
56d343
 void func0 (void);
56d343
 void func1 (void);
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-1.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-1.c
56d343
index 4117a35..e3cea3f 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-1.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-1.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk-inline -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk-inline -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-2.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-2.c
56d343
index 650d55c..6222996 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-2.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-2.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk-inline -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk-inline -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-3.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-3.c
56d343
index 9540996..2eef6f3 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-3.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-3.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk-inline -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk-inline -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-4.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-4.c
56d343
index f3db6e2..e825a10 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-4.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-4.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk-inline -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk-inline -fno-pic" } */
56d343
 
56d343
 typedef void (*dispatch_t)(long offset);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-7.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-7.c
56d343
index 764a375..c67066c 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-7.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-inline-7.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk-inline -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk-inline -fno-pic" } */
56d343
 
56d343
 void func0 (void);
56d343
 void func1 (void);
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-register-1.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-register-1.c
56d343
new file mode 100644
56d343
index 0000000..7d396a3
56d343
--- /dev/null
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-register-1.c
56d343
@@ -0,0 +1,22 @@
56d343
+/* { dg-do compile } */
56d343
+/* { dg-options "-O2 -mindirect-branch=thunk -mindirect-branch-register -fno-pic" } */
56d343
+
56d343
+typedef void (*dispatch_t)(long offset);
56d343
+
56d343
+dispatch_t dispatch;
56d343
+
56d343
+void
56d343
+male_indirect_jump (long offset)
56d343
+{
56d343
+  dispatch(offset);
56d343
+}
56d343
+
56d343
+/* { dg-final { scan-assembler "jmp\[ \t\]*__x86_indirect_thunk_(r|e)ax" } } */
56d343
+/* { dg-final { scan-assembler "jmp\[ \t\]*\.LIND" } } */
56d343
+/* { dg-final { scan-assembler "call\[ \t\]*\.LIND" } } */
56d343
+/* { dg-final { scan-assembler "mov\[ \t\](%eax|%rax), \\((%esp|%rsp)\\)" } } */
56d343
+/* { dg-final { scan-assembler {\tpause} } } */
56d343
+/* { dg-final { scan-assembler-not "push(?:l|q)\[ \t\]*_?dispatch"  } } */
56d343
+/* { dg-final { scan-assembler-not "pushq\[ \t\]%rax" } } */
56d343
+/* { dg-final { scan-assembler-not "__x86_indirect_thunk\n" } } */
56d343
+/* { dg-final { scan-assembler-not "__x86_indirect_thunk_bnd\n" } } */
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-register-2.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-register-2.c
56d343
new file mode 100644
56d343
index 0000000..e7e616b
56d343
--- /dev/null
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-register-2.c
56d343
@@ -0,0 +1,20 @@
56d343
+/* { dg-do compile } */
56d343
+/* { dg-options "-O2 -mindirect-branch=thunk-inline -mindirect-branch-register -fno-pic" } */
56d343
+
56d343
+typedef void (*dispatch_t)(long offset);
56d343
+
56d343
+dispatch_t dispatch;
56d343
+
56d343
+void
56d343
+male_indirect_jump (long offset)
56d343
+{
56d343
+  dispatch(offset);
56d343
+}
56d343
+
56d343
+/* { dg-final { scan-assembler "jmp\[ \t\]*\.LIND" } } */
56d343
+/* { dg-final { scan-assembler "call\[ \t\]*\.LIND" } } */
56d343
+/* { dg-final { scan-assembler "mov\[ \t\](%eax|%rax), \\((%esp|%rsp)\\)" } } */
56d343
+/* { dg-final { scan-assembler {\tpause} } } */
56d343
+/* { dg-final { scan-assembler-not "push(?:l|q)\[ \t\]*_?dispatch"  } } */
56d343
+/* { dg-final { scan-assembler-not "pushq\[ \t\]%rax" } } */
56d343
+/* { dg-final { scan-assembler-not "__x86_indirect_thunk" } } */
56d343
diff --git a/gcc/testsuite/gcc.target/i386/indirect-thunk-register-3.c b/gcc/testsuite/gcc.target/i386/indirect-thunk-register-3.c
56d343
new file mode 100644
56d343
index 0000000..5320e92
56d343
--- /dev/null
56d343
+++ b/gcc/testsuite/gcc.target/i386/indirect-thunk-register-3.c
56d343
@@ -0,0 +1,19 @@
56d343
+/* { dg-do compile } */
56d343
+/* { dg-options "-O2 -mindirect-branch=thunk-extern -mindirect-branch-register -fno-pic" } */
56d343
+
56d343
+typedef void (*dispatch_t)(long offset);
56d343
+
56d343
+dispatch_t dispatch;
56d343
+
56d343
+void
56d343
+male_indirect_jump (long offset)
56d343
+{
56d343
+  dispatch(offset);
56d343
+}
56d343
+
56d343
+/* { dg-final { scan-assembler "jmp\[ \t\]*__x86_indirect_thunk_(r|e)ax" } } */
56d343
+/* { dg-final { scan-assembler-not "push(?:l|q)\[ \t\]*_?dispatch"  } } */
56d343
+/* { dg-final { scan-assembler-not "pushq\[ \t\]%rax" } } */
56d343
+/* { dg-final { scan-assembler-not {\t(pause|pause|nop)} } } */
56d343
+/* { dg-final { scan-assembler-not "jmp\[ \t\]*\.LIND" } } */
56d343
+/* { dg-final { scan-assembler-not "call\[ \t\]*\.LIND" } } */
56d343
diff --git a/gcc/testsuite/gcc.target/i386/ret-thunk-10.c b/gcc/testsuite/gcc.target/i386/ret-thunk-10.c
56d343
index 3a6727b..e6fea84 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/ret-thunk-10.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/ret-thunk-10.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=thunk-inline -mindirect-branch=thunk -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mno-indirect-branch-register -mfunction-return=thunk-inline -mindirect-branch=thunk -fno-pic" } */
56d343
 
56d343
 extern void (*bar) (void);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/ret-thunk-11.c b/gcc/testsuite/gcc.target/i386/ret-thunk-11.c
56d343
index b8f6818..e239ec4 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/ret-thunk-11.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/ret-thunk-11.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=thunk-extern -mindirect-branch=thunk -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mno-indirect-branch-register -mno-indirect-branch-register -mno-indirect-branch-register -mfunction-return=thunk-extern -mindirect-branch=thunk -fno-pic" } */
56d343
 
56d343
 extern void (*bar) (void);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/ret-thunk-12.c b/gcc/testsuite/gcc.target/i386/ret-thunk-12.c
56d343
index 01b0a02..fa31813 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/ret-thunk-12.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/ret-thunk-12.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mno-indirect-branch-register -mno-indirect-branch-register -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk -fno-pic" } */
56d343
 
56d343
 extern void (*bar) (void);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/ret-thunk-13.c b/gcc/testsuite/gcc.target/i386/ret-thunk-13.c
56d343
index 4b497b5..fd5b41f 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/ret-thunk-13.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/ret-thunk-13.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk-inline -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk-inline -fno-pic" } */
56d343
 
56d343
 extern void (*bar) (void);
56d343
 extern int foo (void) __attribute__ ((function_return("thunk")));
56d343
diff --git a/gcc/testsuite/gcc.target/i386/ret-thunk-14.c b/gcc/testsuite/gcc.target/i386/ret-thunk-14.c
56d343
index 4ae4c44..d606373 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/ret-thunk-14.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/ret-thunk-14.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=thunk-extern -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=thunk-extern -fno-pic" } */
56d343
 
56d343
 extern void (*bar) (void);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/ret-thunk-15.c b/gcc/testsuite/gcc.target/i386/ret-thunk-15.c
56d343
index 5b5bc76..75e45e2 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/ret-thunk-15.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/ret-thunk-15.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=keep -mindirect-branch=keep -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mno-indirect-branch-register -mno-indirect-branch-register -mno-indirect-branch-register -mfunction-return=keep -mindirect-branch=keep -fno-pic" } */
56d343
 
56d343
 extern void (*bar) (void);
56d343
 
56d343
diff --git a/gcc/testsuite/gcc.target/i386/ret-thunk-9.c b/gcc/testsuite/gcc.target/i386/ret-thunk-9.c
56d343
index fa24a1f..d1db41c 100644
56d343
--- a/gcc/testsuite/gcc.target/i386/ret-thunk-9.c
56d343
+++ b/gcc/testsuite/gcc.target/i386/ret-thunk-9.c
56d343
@@ -1,5 +1,5 @@
56d343
 /* { dg-do compile } */
56d343
-/* { dg-options "-O2 -mfunction-return=thunk -mindirect-branch=thunk -fno-pic" } */
56d343
+/* { dg-options "-O2 -mno-indirect-branch-register -mno-indirect-branch-register -mfunction-return=thunk -mindirect-branch=thunk -fno-pic" } */
56d343
 
56d343
 extern void (*bar) (void);
56d343