Blame SOURCES/binutils-x86-JCC-Errata.patch

d396ed
diff -rupN binutils-2.32/gas/config/tc-i386.c binutils.new/gas/config/tc-i386.c
d396ed
--- binutils-2.32/gas/config/tc-i386.c	2019-01-19 16:01:33.000000000 +0000
d396ed
+++ binutils.new/gas/config/tc-i386.c	2019-11-25 14:01:00.626325922 +0000
d396ed
@@ -351,6 +351,9 @@ struct _i386_insn
d396ed
     /* Has ZMM register operands.  */
d396ed
     bfd_boolean has_regzmm;
d396ed
 
d396ed
+    /* Has GOTPC relocation.  */
d396ed
+    bfd_boolean has_gotpc_reloc;
d396ed
+
d396ed
     /* RM and SIB are the modrm byte and the sib byte where the
d396ed
        addressing modes of this insn are encoded.  */
d396ed
     modrm_byte rm;
d396ed
@@ -545,6 +548,8 @@ static enum flag_code flag_code;
d396ed
 static unsigned int object_64bit;
d396ed
 static unsigned int disallow_64bit_reloc;
d396ed
 static int use_rela_relocations = 0;
d396ed
+/* __tls_get_addr/___tls_get_addr symbol for TLS.  */
d396ed
+static const char *tls_get_addr;
d396ed
 
d396ed
 #if ((defined (OBJ_MAYBE_COFF) && defined (OBJ_MAYBE_AOUT)) \
d396ed
      || defined (OBJ_ELF) || defined (OBJ_MAYBE_ELF) \
d396ed
@@ -605,6 +610,21 @@ static int omit_lock_prefix = 0;
d396ed
    "lock addl $0, (%{re}sp)".  */
d396ed
 static int avoid_fence = 0;
d396ed
 
d396ed
+/* Type of the previous instruction.  */
d396ed
+static struct
d396ed
+  {
d396ed
+    segT seg;
d396ed
+    const char *file;
d396ed
+    const char *name;
d396ed
+    unsigned int line;
d396ed
+    enum last_insn_kind
d396ed
+      {
d396ed
+	last_insn_other = 0,
d396ed
+	last_insn_directive,
d396ed
+	last_insn_prefix
d396ed
+      } kind;
d396ed
+  } last_insn;
d396ed
+
d396ed
 /* 1 if the assembler should generate relax relocations.  */
d396ed
 
d396ed
 static int generate_relax_relocations
d396ed
@@ -618,6 +638,31 @@ static enum check_kind
d396ed
   }
d396ed
 sse_check, operand_check = check_warning;
d396ed
 
d396ed
+/* Non-zero if branches should be aligned within power of 2 boundary.  */
d396ed
+static int align_branch_power = 0;
d396ed
+
d396ed
+/* Types of branches to align.  */
d396ed
+enum align_branch_kind
d396ed
+  {
d396ed
+    align_branch_none = 0,
d396ed
+    align_branch_jcc = 1 << 0,
d396ed
+    align_branch_fused = 1 << 1,
d396ed
+    align_branch_jmp = 1 << 2,
d396ed
+    align_branch_call = 1 << 3,
d396ed
+    align_branch_indirect = 1 << 4,
d396ed
+    align_branch_ret = 1 << 5
d396ed
+  };
d396ed
+
d396ed
+static unsigned int align_branch = (align_branch_jcc
d396ed
+				    | align_branch_fused
d396ed
+				    | align_branch_jmp);
d396ed
+
d396ed
+/* The maximum padding size for fused jcc.  */
d396ed
+#define MAX_FUSED_JCC_PADDING_SIZE 20
d396ed
+
d396ed
+/* The maximum number of prefixes added for an instruction.  */
d396ed
+static unsigned int align_branch_prefix_size = 5;
d396ed
+
d396ed
 /* Optimization:
d396ed
    1. Clear the REX_W bit with register operand if possible.
d396ed
    2. Above plus use 128bit vector instruction to clear the full vector
d396ed
@@ -721,12 +766,19 @@ int x86_cie_data_alignment;
d396ed
 /* Interface to relax_segment.
d396ed
    There are 3 major relax states for 386 jump insns because the
d396ed
    different types of jumps add different sizes to frags when we're
d396ed
-   figuring out what sort of jump to choose to reach a given label.  */
d396ed
+   figuring out what sort of jump to choose to reach a given label.
d396ed
+
d396ed
+   BRANCH_PADDING, BRANCH_PREFIX and FUSED_JCC_PADDING are used to align
d396ed
+   branches which are handled by md_estimate_size_before_relax() and
d396ed
+   i386_generic_table_relax_frag().  */
d396ed
 
d396ed
 /* Types.  */
d396ed
 #define UNCOND_JUMP 0
d396ed
 #define COND_JUMP 1
d396ed
 #define COND_JUMP86 2
d396ed
+#define BRANCH_PADDING 3
d396ed
+#define BRANCH_PREFIX 4
d396ed
+#define FUSED_JCC_PADDING 5
d396ed
 
d396ed
 /* Sizes.  */
d396ed
 #define CODE16	1
d396ed
@@ -1345,6 +1397,12 @@ i386_generate_nops (fragS *fragP, char *
d396ed
     case rs_fill_nop:
d396ed
     case rs_align_code:
d396ed
       break;
d396ed
+    case rs_machine_dependent:
d396ed
+      /* Allow NOP padding for jumps and calls.  */
d396ed
+      if (TYPE_FROM_RELAX_STATE (fragP->fr_subtype) == BRANCH_PADDING
d396ed
+	  || TYPE_FROM_RELAX_STATE (fragP->fr_subtype) == FUSED_JCC_PADDING)
d396ed
+	break;
d396ed
+      /* Fall through.  */
d396ed
     default:
d396ed
       return;
d396ed
     }
d396ed
@@ -1489,7 +1547,7 @@ i386_generate_nops (fragS *fragP, char *
d396ed
 	  return;
d396ed
 	}
d396ed
     }
d396ed
-  else
d396ed
+  else if (fragP->fr_type != rs_machine_dependent)
d396ed
     fragP->fr_var = count;
d396ed
 
d396ed
   if ((count / max_single_nop_size) > max_number_of_nops)
d396ed
@@ -2957,6 +3015,11 @@ md_begin (void)
d396ed
       x86_dwarf2_return_column = 8;
d396ed
       x86_cie_data_alignment = -4;
d396ed
     }
d396ed
+
d396ed
+  /* NB: FUSED_JCC_PADDING frag must have sufficient room so that it
d396ed
+     can be turned into BRANCH_PREFIX frag.  */
d396ed
+  if (align_branch_prefix_size > MAX_FUSED_JCC_PADDING_SIZE)
d396ed
+    abort ();
d396ed
 }
d396ed
 
d396ed
 void
d396ed
@@ -4386,6 +4449,17 @@ md_assemble (char *line)
d396ed
 
d396ed
   /* We are ready to output the insn.  */
d396ed
   output_insn ();
d396ed
+
d396ed
+  last_insn.seg = now_seg;
d396ed
+
d396ed
+  if (i.tm.opcode_modifier.isprefix)
d396ed
+    {
d396ed
+      last_insn.kind = last_insn_prefix;
d396ed
+      last_insn.name = i.tm.name;
d396ed
+      last_insn.file = as_where (&last_insn.line);
d396ed
+    }
d396ed
+  else
d396ed
+    last_insn.kind = last_insn_other;
d396ed
 }
d396ed
 
d396ed
 static char *
d396ed
@@ -8001,11 +8075,202 @@ x86_cleanup (void)
d396ed
 }
d396ed
 #endif
d396ed
 
d396ed
+/* Return 1 for test, and, cmp, add, sub, inc and dec which may
d396ed
+   be macro-fused with conditional jumps.  */
d396ed
+
d396ed
+static int
d396ed
+maybe_fused_with_jcc_p (void)
d396ed
+{
d396ed
+  /* No RIP address.  */
d396ed
+  if (i.base_reg && i.base_reg->reg_num == RegIP)
d396ed
+    return 0;
d396ed
+
d396ed
+  /* and, add, sub with destination register.  */
d396ed
+  if (!strcmp (i.tm.name, "and")
d396ed
+      || !strcmp (i.tm.name, "add")
d396ed
+      || !strcmp (i.tm.name, "sub"))
d396ed
+    return i.types[1].bitfield.reg;
d396ed
+
d396ed
+  /* test, cmp with any register.  */
d396ed
+  if (!strcmp (i.tm.name, "test") || !strcmp (i.tm.name, "cmp"))
d396ed
+    return (i.types[0].bitfield.reg
d396ed
+	    || i.types[1].bitfield.reg);
d396ed
+
d396ed
+  /* inc, dec with 16/32/64-bit register.   */
d396ed
+  if (!strcmp (i.tm.name, "inc") || !strcmp (i.tm.name, "dec"))
d396ed
+    return i.types[0].bitfield.reg;
d396ed
+
d396ed
+  return 0;
d396ed
+}
d396ed
+
d396ed
+/* Return 1 if a FUSED_JCC_PADDING frag should be generated.  */
d396ed
+
d396ed
+static int
d396ed
+add_fused_jcc_padding_frag_p (void)
d396ed
+{
d396ed
+  if (!align_branch_power
d396ed
+      || now_seg == absolute_section
d396ed
+      || !cpu_arch_flags.bitfield.cpui386
d396ed
+      || !(align_branch & align_branch_fused))
d396ed
+    return 0;
d396ed
+
d396ed
+  if (maybe_fused_with_jcc_p ())
d396ed
+    {
d396ed
+      if (last_insn.kind != last_insn_other
d396ed
+	  && last_insn.seg == now_seg)
d396ed
+	{
d396ed
+	  if (flag_debug)
d396ed
+	    as_warn_where (last_insn.file, last_insn.line,
d396ed
+			   _("`%s` skips -malign-branch-boundary on `%s`"),
d396ed
+			   last_insn.name, i.tm.name);
d396ed
+	  return 0;
d396ed
+	}
d396ed
+      return 1;
d396ed
+    }
d396ed
+
d396ed
+  return 0;
d396ed
+}
d396ed
+
d396ed
+/* Return 1 if a BRANCH_PREFIX frag should be generated.  */
d396ed
+
d396ed
+static int
d396ed
+add_branch_prefix_frag_p (void)
d396ed
+{
d396ed
+  if (!align_branch_power
d396ed
+      || now_seg == absolute_section
d396ed
+      || i.tm.cpu_flags.bitfield.cpupadlock
d396ed
+      || !cpu_arch_flags.bitfield.cpui386)
d396ed
+    return 0;
d396ed
+
d396ed
+  /* Don't add prefix if it is a prefix or there is no operand.  */
d396ed
+  if (!i.operands || i.tm.opcode_modifier.isprefix)
d396ed
+    return 0;
d396ed
+
d396ed
+  if (last_insn.kind != last_insn_other
d396ed
+      && last_insn.seg == now_seg)
d396ed
+    {
d396ed
+      if (flag_debug)
d396ed
+	as_warn_where (last_insn.file, last_insn.line,
d396ed
+		       _("`%s` skips -malign-branch-boundary on `%s`"),
d396ed
+		       last_insn.name, i.tm.name);
d396ed
+      return 0;
d396ed
+    }
d396ed
+
d396ed
+  return 1;
d396ed
+}
d396ed
+
d396ed
+/* Return 1 if a BRANCH_PADDING frag should be generated.  */
d396ed
+
d396ed
+static int
d396ed
+add_branch_padding_frag_p (enum align_branch_kind *branch_p)
d396ed
+{
d396ed
+  int add_padding;
d396ed
+
d396ed
+  if (!align_branch_power
d396ed
+      || now_seg == absolute_section
d396ed
+      || !cpu_arch_flags.bitfield.cpui386)
d396ed
+    return 0;
d396ed
+
d396ed
+  add_padding = 0;
d396ed
+
d396ed
+  /* Check for jcc and direct jmp.  */
d396ed
+  if (i.tm.opcode_modifier.jump)
d396ed
+    {
d396ed
+      if (i.tm.base_opcode == JUMP_PC_RELATIVE)
d396ed
+	{
d396ed
+	  *branch_p = align_branch_jmp;
d396ed
+	  add_padding = align_branch & align_branch_jmp;
d396ed
+	}
d396ed
+      else
d396ed
+	{
d396ed
+	  *branch_p = align_branch_jcc;
d396ed
+	  if ((align_branch & align_branch_jcc))
d396ed
+	    add_padding = 1;
d396ed
+	}
d396ed
+    }
d396ed
+  else if (i.tm.base_opcode == 0xc2
d396ed
+	   || i.tm.base_opcode == 0xc3
d396ed
+	   || i.tm.base_opcode == 0xca
d396ed
+	   || i.tm.base_opcode == 0xcb)
d396ed
+    {
d396ed
+      *branch_p = align_branch_ret;
d396ed
+      if ((align_branch & align_branch_ret))
d396ed
+	add_padding = 1;
d396ed
+    }
d396ed
+  else
d396ed
+    {
d396ed
+      if (i.tm.base_opcode == 0xe8)
d396ed
+	{
d396ed
+	  *branch_p = align_branch_call;
d396ed
+	  if ((align_branch & align_branch_call))
d396ed
+	    add_padding = 1;
d396ed
+	}
d396ed
+      else if (i.tm.base_opcode == 0xff
d396ed
+	       && (i.rm.reg == 2 || i.rm.reg == 4))
d396ed
+	{
d396ed
+	  *branch_p = align_branch_indirect;
d396ed
+	  if ((align_branch & align_branch_indirect))
d396ed
+	    add_padding = 1;
d396ed
+	}
d396ed
+
d396ed
+      /* Check for indirect jmp, direct and indirect calls.  */
d396ed
+      if (add_padding
d396ed
+	  && i.disp_operands
d396ed
+	  && tls_get_addr
d396ed
+	  && (i.op[0].disps->X_op == O_symbol
d396ed
+	      || (i.op[0].disps->X_op == O_subtract
d396ed
+		  && i.op[0].disps->X_op_symbol == GOT_symbol)))
d396ed
+	{
d396ed
+	  symbolS *s = i.op[0].disps->X_add_symbol;
d396ed
+	  /* No padding to call to global or undefined tls_get_addr.  */
d396ed
+	  if ((S_IS_EXTERNAL (s) || !S_IS_DEFINED (s))
d396ed
+	      && strcmp (S_GET_NAME (s), tls_get_addr) == 0)
d396ed
+	    return 0;
d396ed
+	}
d396ed
+    }
d396ed
+
d396ed
+  if (add_padding
d396ed
+      && last_insn.kind != last_insn_other
d396ed
+      && last_insn.seg == now_seg)
d396ed
+    {
d396ed
+      if (flag_debug)
d396ed
+	as_warn_where (last_insn.file, last_insn.line,
d396ed
+		       _("`%s` skips -malign-branch-boundary on `%s`"),
d396ed
+		       last_insn.name, i.tm.name);
d396ed
+      return 0;
d396ed
+    }
d396ed
+
d396ed
+  return add_padding;
d396ed
+}
d396ed
+
d396ed
+static unsigned int
d396ed
+encoding_length (const fragS *start_frag, offsetT start_off,
d396ed
+		 const char *frag_now_ptr)
d396ed
+{
d396ed
+  unsigned int len = 0;
d396ed
+
d396ed
+  if (start_frag != frag_now)
d396ed
+    {
d396ed
+      const fragS *fr = start_frag;
d396ed
+
d396ed
+      do
d396ed
+	{
d396ed
+	  len += fr->fr_fix;
d396ed
+	  fr = fr->fr_next;
d396ed
+	}
d396ed
+      while (fr && fr != frag_now);
d396ed
+    }
d396ed
+
d396ed
+  return len - start_off + (frag_now_ptr - frag_now->fr_literal);
d396ed
+}
d396ed
+
d396ed
 static void
d396ed
 output_insn (void)
d396ed
 {
d396ed
   fragS *insn_start_frag;
d396ed
   offsetT insn_start_off;
d396ed
+  fragS *fragP = NULL;
d396ed
+  enum align_branch_kind branch = align_branch_none;
d396ed
 
d396ed
 #if defined (OBJ_ELF) || defined (OBJ_MAYBE_ELF)
d396ed
   if (IS_ELF && x86_used_note)
d396ed
@@ -8100,6 +8365,30 @@ output_insn (void)
d396ed
   insn_start_frag = frag_now;
d396ed
   insn_start_off = frag_now_fix ();
d396ed
 
d396ed
+  if (add_branch_padding_frag_p (&branch))
d396ed
+    {
d396ed
+      char *p;
d396ed
+      unsigned int max_branch_padding_size = 14;
d396ed
+
d396ed
+      /* Align section to boundary.  */
d396ed
+      record_alignment (now_seg, align_branch_power);
d396ed
+
d396ed
+      /* Make room for padding.  */
d396ed
+      frag_grow (max_branch_padding_size);
d396ed
+
d396ed
+      /* Start of the padding.  */
d396ed
+      p = frag_more (0);
d396ed
+
d396ed
+      fragP = frag_now;
d396ed
+
d396ed
+      frag_var (rs_machine_dependent, max_branch_padding_size, 0,
d396ed
+		ENCODE_RELAX_STATE (BRANCH_PADDING, 0),
d396ed
+		NULL, 0, p);
d396ed
+
d396ed
+      fragP->tc_frag_data.branch_type = branch;
d396ed
+      fragP->tc_frag_data.max_bytes = max_branch_padding_size;
d396ed
+    }
d396ed
+
d396ed
   /* Output jumps.  */
d396ed
   if (i.tm.opcode_modifier.jump)
d396ed
     output_branch ();
d396ed
@@ -8141,6 +8430,44 @@ output_insn (void)
d396ed
 	  i.prefix[LOCK_PREFIX] = 0;
d396ed
 	}
d396ed
 
d396ed
+      if (branch)
d396ed
+	/* Skip if this is a branch.  */
d396ed
+	;
d396ed
+      else if (add_fused_jcc_padding_frag_p ())
d396ed
+	{
d396ed
+	  unsigned int max_fused_padding_size
d396ed
+	    = MAX_FUSED_JCC_PADDING_SIZE;
d396ed
+
d396ed
+	  /* Make room for padding.  */
d396ed
+	  frag_grow (max_fused_padding_size);
d396ed
+	  p = frag_more (0);
d396ed
+
d396ed
+	  fragP = frag_now;
d396ed
+
d396ed
+	  frag_var (rs_machine_dependent, max_fused_padding_size, 0,
d396ed
+		    ENCODE_RELAX_STATE (FUSED_JCC_PADDING, 0),
d396ed
+		    NULL, 0, p);
d396ed
+
d396ed
+	  fragP->tc_frag_data.branch_type = align_branch_fused;
d396ed
+	  fragP->tc_frag_data.max_bytes = max_fused_padding_size;
d396ed
+	}
d396ed
+      else if (add_branch_prefix_frag_p ())
d396ed
+	{
d396ed
+	  unsigned int max_prefix_size = align_branch_prefix_size;
d396ed
+
d396ed
+	  /* Make room for padding.  */
d396ed
+	  frag_grow (max_prefix_size);
d396ed
+	  p = frag_more (0);
d396ed
+
d396ed
+	  fragP = frag_now;
d396ed
+
d396ed
+	  frag_var (rs_machine_dependent, max_prefix_size, 0,
d396ed
+		    ENCODE_RELAX_STATE (BRANCH_PREFIX, 0),
d396ed
+		    NULL, 0, p);
d396ed
+
d396ed
+	  fragP->tc_frag_data.max_bytes = max_prefix_size;
d396ed
+	}
d396ed
+
d396ed
       /* Since the VEX/EVEX prefix contains the implicit prefix, we
d396ed
 	 don't need the explicit prefix.  */
d396ed
       if (!i.tm.opcode_modifier.vex && !i.tm.opcode_modifier.evex)
d396ed
@@ -8276,6 +8603,88 @@ output_insn (void)
d396ed
 
d396ed
       if (i.imm_operands)
d396ed
 	output_imm (insn_start_frag, insn_start_off);
d396ed
+
d396ed
+      /*
d396ed
+       * frag_now_fix () returning plain abs_section_offset when we're in the
d396ed
+       * absolute section, and abs_section_offset not getting updated as data
d396ed
+       * gets added to the frag breaks the logic below.
d396ed
+       */
d396ed
+      if (now_seg != absolute_section)
d396ed
+	{
d396ed
+	  j = encoding_length (insn_start_frag, insn_start_off, frag_more (0));
d396ed
+	  if (fragP)
d396ed
+	    {
d396ed
+	      /* NB: Don't add prefix with GOTPC relocation since
d396ed
+		 output_disp() above depends on the fixed encoding
d396ed
+		 length.  */
d396ed
+	      unsigned int max = i.has_gotpc_reloc ? 0 : 15 - j;
d396ed
+	      /* Prefix count on the current instruction.  */
d396ed
+	      unsigned int count = !!is_any_vex_encoding (&i.tm);
d396ed
+	      unsigned int k;
d396ed
+	      for (k = 0; k < ARRAY_SIZE (i.prefix); k++)
d396ed
+		if (i.prefix[k])
d396ed
+		  count++;
d396ed
+
d396ed
+	      /* NB: prefix count + instruction size must be <= 15.  */
d396ed
+	      if (j > 15)
d396ed
+		as_fatal (_("instruction length of %u bytes exceeds the limit of 15"),
d396ed
+			  j);
d396ed
+
d396ed
+	      if (TYPE_FROM_RELAX_STATE (fragP->fr_subtype)
d396ed
+		  == BRANCH_PREFIX)
d396ed
+		{
d396ed
+		  /* Set the maximum prefix size in BRANCH_PREFIX
d396ed
+		     frag.  */
d396ed
+		  if (fragP->tc_frag_data.max_bytes > max)
d396ed
+		    fragP->tc_frag_data.max_bytes = max;
d396ed
+		  if (fragP->tc_frag_data.max_bytes > count)
d396ed
+		    fragP->tc_frag_data.max_bytes -= count;
d396ed
+		  else
d396ed
+		    fragP->tc_frag_data.max_bytes = 0;
d396ed
+		}
d396ed
+	      else
d396ed
+		{
d396ed
+		  /* Remember the maximum prefix size in FUSED_JCC_PADDING
d396ed
+		     frag.  */
d396ed
+		  unsigned int max_prefix_size;
d396ed
+		  if (align_branch_prefix_size > max)
d396ed
+		    max_prefix_size = max;
d396ed
+		  else
d396ed
+		    max_prefix_size = align_branch_prefix_size;
d396ed
+		  if (max_prefix_size > count)
d396ed
+		    fragP->tc_frag_data.max_prefix_length
d396ed
+		      = max_prefix_size - count;
d396ed
+		}
d396ed
+
d396ed
+	      /* Use existing segment prefix if possible.  Use CS
d396ed
+		 segment prefix in 64-bit mode.  In 32-bit mode, use SS
d396ed
+		 segment prefix with ESP/EBP base register and use DS
d396ed
+		 segment prefix without ESP/EBP base register.  */
d396ed
+	      if (i.prefix[SEG_PREFIX])
d396ed
+		fragP->tc_frag_data.default_prefix = i.prefix[SEG_PREFIX];
d396ed
+	      else if (flag_code == CODE_64BIT)
d396ed
+		fragP->tc_frag_data.default_prefix = CS_PREFIX_OPCODE;
d396ed
+	      else if (i.base_reg
d396ed
+		       && (i.base_reg->reg_num == 4
d396ed
+			   || i.base_reg->reg_num == 5))
d396ed
+		fragP->tc_frag_data.default_prefix = SS_PREFIX_OPCODE;
d396ed
+	      else
d396ed
+		fragP->tc_frag_data.default_prefix = DS_PREFIX_OPCODE;
d396ed
+	    }
d396ed
+	  else if (j > 15)
d396ed
+	    as_warn (_("instruction length of %u bytes exceeds the limit of 15"),
d396ed
+		     j);
d396ed
+	}
d396ed
+    }
d396ed
+
d396ed
+  if (align_branch_power
d396ed
+      && now_seg != absolute_section
d396ed
+      && cpu_arch_flags.bitfield.cpui386)
d396ed
+    {
d396ed
+      /* Terminate each frag so that we can add prefix and check for
d396ed
+         fused jcc.  */
d396ed
+      frag_wane (frag_now);
d396ed
+      frag_new (0);
d396ed
     }
d396ed
 
d396ed
 #ifdef DEBUG386
d396ed
@@ -8402,6 +8811,7 @@ output_disp (fragS *insn_start_frag, off
d396ed
 		  if (!object_64bit)
d396ed
 		    {
d396ed
 		      reloc_type = BFD_RELOC_386_GOTPC;
d396ed
+		      i.has_gotpc_reloc = TRUE;
d396ed
 		      i.op[n].imms->X_add_number += add;
d396ed
 		    }
d396ed
 		  else if (reloc_type == BFD_RELOC_64)
d396ed
@@ -8568,6 +8978,7 @@ output_imm (fragS *insn_start_frag, offs
d396ed
 		    reloc_type = BFD_RELOC_X86_64_GOTPC32;
d396ed
 		  else if (size == 8)
d396ed
 		    reloc_type = BFD_RELOC_X86_64_GOTPC64;
d396ed
+		  i.has_gotpc_reloc = TRUE;
d396ed
 		  i.op[n].imms->X_add_number += add;
d396ed
 		}
d396ed
 	      fix_new_exp (frag_now, p - frag_now->fr_literal, size,
d396ed
@@ -10193,6 +10604,355 @@ elf_symbol_resolved_in_segment_p (symbol
d396ed
 }
d396ed
 #endif
d396ed
 
d396ed
+/* Return the next non-empty frag.  */
d396ed
+
d396ed
+static fragS *
d396ed
+i386_next_non_empty_frag (fragS *fragP)
d396ed
+{
d396ed
+  /* There may be a frag with a ".fill 0" when there is no room in
d396ed
+     the current frag for frag_grow in output_insn.  */
d396ed
+  for (fragP = fragP->fr_next;
d396ed
+       (fragP != NULL
d396ed
+	&& fragP->fr_type == rs_fill
d396ed
+	&& fragP->fr_fix == 0);
d396ed
+       fragP = fragP->fr_next)
d396ed
+    ;
d396ed
+  return fragP;
d396ed
+}
d396ed
+
d396ed
+/* Return the next jcc frag after BRANCH_PADDING.  */
d396ed
+
d396ed
+static fragS *
d396ed
+i386_next_jcc_frag (fragS *fragP)
d396ed
+{
d396ed
+  if (!fragP)
d396ed
+    return NULL;
d396ed
+
d396ed
+  if (fragP->fr_type == rs_machine_dependent
d396ed
+      && (TYPE_FROM_RELAX_STATE (fragP->fr_subtype)
d396ed
+	  == BRANCH_PADDING))
d396ed
+    {
d396ed
+      fragP = i386_next_non_empty_frag (fragP);
d396ed
+      if (fragP->fr_type != rs_machine_dependent)
d396ed
+	return NULL;
d396ed
+      if (TYPE_FROM_RELAX_STATE (fragP->fr_subtype) == COND_JUMP)
d396ed
+	return fragP;
d396ed
+    }
d396ed
+
d396ed
+  return NULL;
d396ed
+}
d396ed
+
d396ed
+/* Classify BRANCH_PADDING, BRANCH_PREFIX and FUSED_JCC_PADDING frags.  */
d396ed
+
d396ed
+static void
d396ed
+i386_classify_machine_dependent_frag (fragS *fragP)
d396ed
+{
d396ed
+  fragS *cmp_fragP;
d396ed
+  fragS *pad_fragP;
d396ed
+  fragS *branch_fragP;
d396ed
+  fragS *next_fragP;
d396ed
+  unsigned int max_prefix_length;
d396ed
+
d396ed
+  if (fragP->tc_frag_data.classified)
d396ed
+    return;
d396ed
+
d396ed
+  /* First scan for BRANCH_PADDING and FUSED_JCC_PADDING.  Convert
d396ed
+     FUSED_JCC_PADDING and merge BRANCH_PADDING.  */
d396ed
+  for (next_fragP = fragP;
d396ed
+       next_fragP != NULL;
d396ed
+       next_fragP = next_fragP->fr_next)
d396ed
+    {
d396ed
+      next_fragP->tc_frag_data.classified = 1;
d396ed
+      if (next_fragP->fr_type == rs_machine_dependent)
d396ed
+	switch (TYPE_FROM_RELAX_STATE (next_fragP->fr_subtype))
d396ed
+	  {
d396ed
+	  case BRANCH_PADDING:
d396ed
+	    /* The BRANCH_PADDING frag must be followed by a branch
d396ed
+	       frag.  */
d396ed
+	    branch_fragP = i386_next_non_empty_frag (next_fragP);
d396ed
+	    next_fragP->tc_frag_data.u.branch_fragP = branch_fragP;
d396ed
+	    break;
d396ed
+	  case FUSED_JCC_PADDING:
d396ed
+	    /* Check if this is a fused jcc:
d396ed
+	       FUSED_JCC_PADDING
d396ed
+	       CMP
d396ed
+	       BRANCH_PADDING
d396ed
+	       COND_JUMP
d396ed
+	       */
d396ed
+	    cmp_fragP = i386_next_non_empty_frag (next_fragP);
d396ed
+	    pad_fragP = i386_next_non_empty_frag (cmp_fragP);
d396ed
+	    branch_fragP = i386_next_jcc_frag (pad_fragP);
d396ed
+	    if (branch_fragP)
d396ed
+	      {
d396ed
+		/* The BRANCH_PADDING frag is merged with the
d396ed
+		   FUSED_JCC_PADDING frag.  */
d396ed
+		next_fragP->tc_frag_data.u.branch_fragP = branch_fragP;
d396ed
+		/* CMP instruction size.  */
d396ed
+		next_fragP->tc_frag_data.cmp_size = cmp_fragP->fr_fix;
d396ed
+		frag_wane (pad_fragP);
d396ed
+		/* Skip to branch_fragP.  */
d396ed
+		next_fragP = branch_fragP;
d396ed
+	      }
d396ed
+	    else if (next_fragP->tc_frag_data.max_prefix_length)
d396ed
+	      {
d396ed
+		/* Turn FUSED_JCC_PADDING into BRANCH_PREFIX if it isn't
d396ed
+		   a fused jcc.  */
d396ed
+		next_fragP->fr_subtype
d396ed
+		  = ENCODE_RELAX_STATE (BRANCH_PREFIX, 0);
d396ed
+		next_fragP->tc_frag_data.max_bytes
d396ed
+		  = next_fragP->tc_frag_data.max_prefix_length;
d396ed
+		/* This will be updated in the BRANCH_PREFIX scan.  */
d396ed
+		next_fragP->tc_frag_data.max_prefix_length = 0;
d396ed
+	      }
d396ed
+	    else
d396ed
+	      frag_wane (next_fragP);
d396ed
+	    break;
d396ed
+	  }
d396ed
+    }
d396ed
+
d396ed
+  /* Scan for BRANCH_PREFIX.  */
d396ed
+  for (; fragP != NULL; fragP = fragP->fr_next)
d396ed
+    if (fragP->fr_type == rs_machine_dependent
d396ed
+	&& (TYPE_FROM_RELAX_STATE (fragP->fr_subtype)
d396ed
+	    == BRANCH_PREFIX))
d396ed
+      {
d396ed
+	/* Count all BRANCH_PREFIX frags before BRANCH_PADDING and
d396ed
+	   COND_JUMP_PREFIX.  */
d396ed
+	max_prefix_length = 0;
d396ed
+	for (next_fragP = fragP;
d396ed
+	     next_fragP != NULL;
d396ed
+	     next_fragP = next_fragP->fr_next)
d396ed
+	  {
d396ed
+	    if (next_fragP->fr_type == rs_fill)
d396ed
+	      /* Skip rs_fill frags.  */
d396ed
+	      ;
d396ed
+	    else if (next_fragP->fr_type == rs_machine_dependent)
d396ed
+	      {
d396ed
+		if (TYPE_FROM_RELAX_STATE (next_fragP->fr_subtype)
d396ed
+		    == BRANCH_PREFIX)
d396ed
+		  {
d396ed
+		    /* Count BRANCH_PREFIX frags.  */
d396ed
+		    if (max_prefix_length >= MAX_FUSED_JCC_PADDING_SIZE)
d396ed
+		      {
d396ed
+			max_prefix_length = MAX_FUSED_JCC_PADDING_SIZE;
d396ed
+			frag_wane (next_fragP);
d396ed
+		      }
d396ed
+		    else
d396ed
+		      max_prefix_length
d396ed
+			+= next_fragP->tc_frag_data.max_bytes;
d396ed
+		  }
d396ed
+		else if ((TYPE_FROM_RELAX_STATE (next_fragP->fr_subtype)
d396ed
+			  == BRANCH_PADDING)
d396ed
+			 || (TYPE_FROM_RELAX_STATE (next_fragP->fr_subtype)
d396ed
+			     == FUSED_JCC_PADDING))
d396ed
+		  {
d396ed
+		    /* Stop at BRANCH_PADDING and FUSED_JCC_PADDING.  */
d396ed
+		    fragP->tc_frag_data.u.padding_fragP = next_fragP;
d396ed
+		    break;
d396ed
+		  }
d396ed
+		else
d396ed
+		  /* Stop for other rs_machine_dependent frags.  */
d396ed
+		  break;
d396ed
+	      }
d396ed
+	    else
d396ed
+	      /* Stop for all other frags.  */
d396ed
+	      break;
d396ed
+	  }
d396ed
+
d396ed
+	fragP->tc_frag_data.max_prefix_length = max_prefix_length;
d396ed
+
d396ed
+	/* Skip to the next frag.  */
d396ed
+	fragP = next_fragP;
d396ed
+      }
d396ed
+}
d396ed
+
d396ed
+/* Compute padding size for
d396ed
+
d396ed
+	FUSED_JCC_PADDING
d396ed
+	CMP
d396ed
+	BRANCH_PADDING
d396ed
+	COND_JUMP/UNCOND_JUMP
d396ed
+
d396ed
+   or
d396ed
+
d396ed
+	BRANCH_PADDING
d396ed
+	COND_JUMP/UNCOND_JUMP
d396ed
+ */
d396ed
+
d396ed
+static int
d396ed
+i386_branch_padding_size (fragS *fragP, offsetT address)
d396ed
+{
d396ed
+  unsigned int offset, size, padding_size;
d396ed
+  fragS *branch_fragP = fragP->tc_frag_data.u.branch_fragP;
d396ed
+
d396ed
+  /* The start address of the BRANCH_PADDING or FUSED_JCC_PADDING frag.  */
d396ed
+  if (!address)
d396ed
+    address = fragP->fr_address;
d396ed
+  address += fragP->fr_fix;
d396ed
+
d396ed
+  /* CMP instrunction size.  */
d396ed
+  size = fragP->tc_frag_data.cmp_size;
d396ed
+
d396ed
+  /* The base size of the branch frag.  */
d396ed
+  size += branch_fragP->fr_fix;
d396ed
+
d396ed
+  /* Add opcode and displacement bytes for the rs_machine_dependent
d396ed
+     branch frag.  */
d396ed
+  if (branch_fragP->fr_type == rs_machine_dependent)
d396ed
+    size += md_relax_table[branch_fragP->fr_subtype].rlx_length;
d396ed
+
d396ed
+  /* Check if branch is within boundary and doesn't end at the last
d396ed
+     byte.  */
d396ed
+  offset = address & ((1U << align_branch_power) - 1);
d396ed
+  if ((offset + size) >= (1U << align_branch_power))
d396ed
+    /* Padding needed to avoid crossing boundary.  */
d396ed
+    padding_size = (1 << align_branch_power) - offset;
d396ed
+  else
d396ed
+    /* No padding needed.  */
d396ed
+    padding_size = 0;
d396ed
+
d396ed
+  if (!fits_in_signed_byte (padding_size))
d396ed
+    abort ();
d396ed
+
d396ed
+  return padding_size;
d396ed
+}
d396ed
+
d396ed
+/* i386_generic_table_relax_frag()
d396ed
+
d396ed
+   Handle BRANCH_PADDING, BRANCH_PREFIX and FUSED_JCC_PADDING frags to
d396ed
+   grow/shrink padding to align branch frags.  Hand others to
d396ed
+   relax_frag().  */
d396ed
+
d396ed
+long
d396ed
+i386_generic_table_relax_frag (segT segment, fragS *fragP, long stretch)
d396ed
+{
d396ed
+  if (TYPE_FROM_RELAX_STATE (fragP->fr_subtype) == BRANCH_PADDING
d396ed
+      || TYPE_FROM_RELAX_STATE (fragP->fr_subtype) == FUSED_JCC_PADDING)
d396ed
+    {
d396ed
+      long padding_size = i386_branch_padding_size (fragP, 0);
d396ed
+      long grow = padding_size - fragP->tc_frag_data.length;
d396ed
+
d396ed
+      /* When the BRANCH_PREFIX frag is used, the computed address
d396ed
+         must match the actual address and there should be no padding.  */
d396ed
+      if (fragP->tc_frag_data.padding_address
d396ed
+	  && (fragP->tc_frag_data.padding_address != fragP->fr_address
d396ed
+	      || padding_size))
d396ed
+	abort ();
d396ed
+
d396ed
+      /* Update the padding size.  */
d396ed
+      if (grow)
d396ed
+	fragP->tc_frag_data.length = padding_size;
d396ed
+
d396ed
+      return grow;
d396ed
+    }
d396ed
+  else if (TYPE_FROM_RELAX_STATE (fragP->fr_subtype) == BRANCH_PREFIX)
d396ed
+    {
d396ed
+      fragS *padding_fragP, *next_fragP;
d396ed
+      long padding_size, left_size, last_size;
d396ed
+
d396ed
+      padding_fragP = fragP->tc_frag_data.u.padding_fragP;
d396ed
+      if (!padding_fragP)
d396ed
+	/* Use the padding set by the leading BRANCH_PREFIX frag.  */
d396ed
+	return (fragP->tc_frag_data.length
d396ed
+		- fragP->tc_frag_data.last_length);
d396ed
+
d396ed
+      /* Compute the relative address of the padding frag in the very
d396ed
+        first time where the BRANCH_PREFIX frag sizes are zero.  */
d396ed
+      if (!fragP->tc_frag_data.padding_address)
d396ed
+	fragP->tc_frag_data.padding_address
d396ed
+	  = padding_fragP->fr_address - (fragP->fr_address - stretch);
d396ed
+
d396ed
+      /* First update the last length from the previous interation.  */
d396ed
+      left_size = fragP->tc_frag_data.prefix_length;
d396ed
+      for (next_fragP = fragP;
d396ed
+	   next_fragP != padding_fragP;
d396ed
+	   next_fragP = next_fragP->fr_next)
d396ed
+	if (next_fragP->fr_type == rs_machine_dependent
d396ed
+	    && (TYPE_FROM_RELAX_STATE (next_fragP->fr_subtype)
d396ed
+		== BRANCH_PREFIX))
d396ed
+	  {
d396ed
+	    if (left_size)
d396ed
+	      {
d396ed
+		int max = next_fragP->tc_frag_data.max_bytes;
d396ed
+		if (max)
d396ed
+		  {
d396ed
+		    int size;
d396ed
+		    if (max > left_size)
d396ed
+		      size = left_size;
d396ed
+		    else
d396ed
+		      size = max;
d396ed
+		    left_size -= size;
d396ed
+		    next_fragP->tc_frag_data.last_length = size;
d396ed
+		  }
d396ed
+	      }
d396ed
+	    else
d396ed
+	      next_fragP->tc_frag_data.last_length = 0;
d396ed
+	  }
d396ed
+
d396ed
+      /* Check the padding size for the padding frag.  */
d396ed
+      padding_size = i386_branch_padding_size
d396ed
+	(padding_fragP, (fragP->fr_address
d396ed
+			 + fragP->tc_frag_data.padding_address));
d396ed
+
d396ed
+      last_size = fragP->tc_frag_data.prefix_length;
d396ed
+      /* Check if there is change from the last interation.  */
d396ed
+      if (padding_size == last_size)
d396ed
+	{
d396ed
+	  /* Update the expected address of the padding frag.  */
d396ed
+	  padding_fragP->tc_frag_data.padding_address
d396ed
+	    = (fragP->fr_address + padding_size
d396ed
+	       + fragP->tc_frag_data.padding_address);
d396ed
+	  return 0;
d396ed
+	}
d396ed
+
d396ed
+      if (padding_size > fragP->tc_frag_data.max_prefix_length)
d396ed
+	{
d396ed
+	  /* No padding if there is no sufficient room.  Clear the
d396ed
+	     expected address of the padding frag.  */
d396ed
+	  padding_fragP->tc_frag_data.padding_address = 0;
d396ed
+	  padding_size = 0;
d396ed
+	}
d396ed
+      else
d396ed
+	/* Store the expected address of the padding frag.  */
d396ed
+	padding_fragP->tc_frag_data.padding_address
d396ed
+	  = (fragP->fr_address + padding_size
d396ed
+	     + fragP->tc_frag_data.padding_address);
d396ed
+
d396ed
+      fragP->tc_frag_data.prefix_length = padding_size;
d396ed
+
d396ed
+      /* Update the length for the current interation.  */
d396ed
+      left_size = padding_size;
d396ed
+      for (next_fragP = fragP;
d396ed
+	   next_fragP != padding_fragP;
d396ed
+	   next_fragP = next_fragP->fr_next)
d396ed
+	if (next_fragP->fr_type == rs_machine_dependent
d396ed
+	    && (TYPE_FROM_RELAX_STATE (next_fragP->fr_subtype)
d396ed
+		== BRANCH_PREFIX))
d396ed
+	  {
d396ed
+	    if (left_size)
d396ed
+	      {
d396ed
+		int max = next_fragP->tc_frag_data.max_bytes;
d396ed
+		if (max)
d396ed
+		  {
d396ed
+		    int size;
d396ed
+		    if (max > left_size)
d396ed
+		      size = left_size;
d396ed
+		    else
d396ed
+		      size = max;
d396ed
+		    left_size -= size;
d396ed
+		    next_fragP->tc_frag_data.length = size;
d396ed
+		  }
d396ed
+	      }
d396ed
+	    else
d396ed
+	      next_fragP->tc_frag_data.length = 0;
d396ed
+	  }
d396ed
+
d396ed
+      return (fragP->tc_frag_data.length
d396ed
+	      - fragP->tc_frag_data.last_length);
d396ed
+    }
d396ed
+  return relax_frag (segment, fragP, stretch);
d396ed
+}
d396ed
+
d396ed
 /* md_estimate_size_before_relax()
d396ed
 
d396ed
    Called just before relax() for rs_machine_dependent frags.  The x86
d396ed
@@ -10209,6 +10969,14 @@ elf_symbol_resolved_in_segment_p (symbol
d396ed
 int
d396ed
 md_estimate_size_before_relax (fragS *fragP, segT segment)
d396ed
 {
d396ed
+  if (TYPE_FROM_RELAX_STATE (fragP->fr_subtype) == BRANCH_PADDING
d396ed
+      || TYPE_FROM_RELAX_STATE (fragP->fr_subtype) == BRANCH_PREFIX
d396ed
+      || TYPE_FROM_RELAX_STATE (fragP->fr_subtype) == FUSED_JCC_PADDING)
d396ed
+    {
d396ed
+      i386_classify_machine_dependent_frag (fragP);
d396ed
+      return fragP->tc_frag_data.length;
d396ed
+    }
d396ed
+
d396ed
   /* We've already got fragP->fr_subtype right;  all we have to do is
d396ed
      check for un-relaxable symbols.  On an ELF system, we can't relax
d396ed
      an externally visible symbol, because it may be overridden by a
d396ed
@@ -10342,6 +11110,106 @@ md_convert_frag (bfd *abfd ATTRIBUTE_UNU
d396ed
   unsigned int extension = 0;
d396ed
   offsetT displacement_from_opcode_start;
d396ed
 
d396ed
+  if (TYPE_FROM_RELAX_STATE (fragP->fr_subtype) == BRANCH_PADDING
d396ed
+      || TYPE_FROM_RELAX_STATE (fragP->fr_subtype) == FUSED_JCC_PADDING
d396ed
+      || TYPE_FROM_RELAX_STATE (fragP->fr_subtype) == BRANCH_PREFIX)
d396ed
+    {
d396ed
+      /* Generate nop padding.  */
d396ed
+      unsigned int size = fragP->tc_frag_data.length;
d396ed
+      if (size)
d396ed
+	{
d396ed
+	  if (size > fragP->tc_frag_data.max_bytes)
d396ed
+	    abort ();
d396ed
+
d396ed
+	  if (flag_debug)
d396ed
+	    {
d396ed
+	      const char *msg;
d396ed
+	      const char *branch = "branch";
d396ed
+	      const char *prefix = "";
d396ed
+	      fragS *padding_fragP;
d396ed
+	      if (TYPE_FROM_RELAX_STATE (fragP->fr_subtype)
d396ed
+		  == BRANCH_PREFIX)
d396ed
+		{
d396ed
+		  padding_fragP = fragP->tc_frag_data.u.padding_fragP;
d396ed
+		  switch (fragP->tc_frag_data.default_prefix)
d396ed
+		    {
d396ed
+		    default:
d396ed
+		      abort ();
d396ed
+		      break;
d396ed
+		    case CS_PREFIX_OPCODE:
d396ed
+		      prefix = " cs";
d396ed
+		      break;
d396ed
+		    case DS_PREFIX_OPCODE:
d396ed
+		      prefix = " ds";
d396ed
+		      break;
d396ed
+		    case ES_PREFIX_OPCODE:
d396ed
+		      prefix = " es";
d396ed
+		      break;
d396ed
+		    case FS_PREFIX_OPCODE:
d396ed
+		      prefix = " fs";
d396ed
+		      break;
d396ed
+		    case GS_PREFIX_OPCODE:
d396ed
+		      prefix = " gs";
d396ed
+		      break;
d396ed
+		    case SS_PREFIX_OPCODE:
d396ed
+		      prefix = " ss";
d396ed
+		      break;
d396ed
+		    }
d396ed
+		  if (padding_fragP)
d396ed
+		    msg = _("%s:%u: add %d%s at 0x%llx to align "
d396ed
+			    "%s within %d-byte boundary\n");
d396ed
+		  else
d396ed
+		    msg = _("%s:%u: add additional %d%s at 0x%llx to "
d396ed
+			    "align %s within %d-byte boundary\n");
d396ed
+		}
d396ed
+	      else
d396ed
+		{
d396ed
+		  padding_fragP = fragP;
d396ed
+		  msg = _("%s:%u: add %d%s-byte nop at 0x%llx to align "
d396ed
+			  "%s within %d-byte boundary\n");
d396ed
+		}
d396ed
+
d396ed
+	      if (padding_fragP)
d396ed
+		switch (padding_fragP->tc_frag_data.branch_type)
d396ed
+		  {
d396ed
+		  case align_branch_jcc:
d396ed
+		    branch = "jcc";
d396ed
+		    break;
d396ed
+		  case align_branch_fused:
d396ed
+		    branch = "fused jcc";
d396ed
+		    break;
d396ed
+		  case align_branch_jmp:
d396ed
+		    branch = "jmp";
d396ed
+		    break;
d396ed
+		  case align_branch_call:
d396ed
+		    branch = "call";
d396ed
+		    break;
d396ed
+		  case align_branch_indirect:
d396ed
+		    branch = "indiret branch";
d396ed
+		    break;
d396ed
+		  case align_branch_ret:
d396ed
+		    branch = "ret";
d396ed
+		    break;
d396ed
+		  default:
d396ed
+		    break;
d396ed
+		  }
d396ed
+
d396ed
+	      fprintf (stdout, msg,
d396ed
+		       fragP->fr_file, fragP->fr_line, size, prefix,
d396ed
+		       (long long) fragP->fr_address, branch,
d396ed
+		       1 << align_branch_power);
d396ed
+	    }
d396ed
+	  if (TYPE_FROM_RELAX_STATE (fragP->fr_subtype) == BRANCH_PREFIX)
d396ed
+	    memset (fragP->fr_opcode,
d396ed
+		    fragP->tc_frag_data.default_prefix, size);
d396ed
+	  else
d396ed
+	    i386_generate_nops (fragP, (char *) fragP->fr_opcode,
d396ed
+				size, 0);
d396ed
+	  fragP->fr_fix += size;
d396ed
+	}
d396ed
+      return;
d396ed
+    }
d396ed
+
d396ed
   opcode = (unsigned char *) fragP->fr_opcode;
d396ed
 
d396ed
   /* Address we want to reach in file space.  */
d396ed
@@ -10898,6 +11766,10 @@ const char *md_shortopts = "qnO::";
d396ed
 #define OPTION_MFENCE_AS_LOCK_ADD (OPTION_MD_BASE + 24)
d396ed
 #define OPTION_X86_USED_NOTE (OPTION_MD_BASE + 25)
d396ed
 #define OPTION_MVEXWIG (OPTION_MD_BASE + 26)
d396ed
+#define OPTION_MALIGN_BRANCH_BOUNDARY (OPTION_MD_BASE + 27)
d396ed
+#define OPTION_MALIGN_BRANCH_PREFIX_SIZE (OPTION_MD_BASE + 28)
d396ed
+#define OPTION_MALIGN_BRANCH (OPTION_MD_BASE + 29)
d396ed
+#define OPTION_MBRANCHES_WITH_32B_BOUNDARIES (OPTION_MD_BASE + 30)
d396ed
 
d396ed
 struct option md_longopts[] =
d396ed
 {
d396ed
@@ -10933,6 +11805,10 @@ struct option md_longopts[] =
d396ed
   {"mfence-as-lock-add", required_argument, NULL, OPTION_MFENCE_AS_LOCK_ADD},
d396ed
   {"mrelax-relocations", required_argument, NULL, OPTION_MRELAX_RELOCATIONS},
d396ed
   {"mevexrcig", required_argument, NULL, OPTION_MEVEXRCIG},
d396ed
+  {"malign-branch-boundary", required_argument, NULL, OPTION_MALIGN_BRANCH_BOUNDARY},
d396ed
+  {"malign-branch-prefix-size", required_argument, NULL, OPTION_MALIGN_BRANCH_PREFIX_SIZE},
d396ed
+  {"malign-branch", required_argument, NULL, OPTION_MALIGN_BRANCH},
d396ed
+  {"mbranches-within-32B-boundaries", no_argument, NULL, OPTION_MBRANCHES_WITH_32B_BOUNDARIES},
d396ed
   {"mamd64", no_argument, NULL, OPTION_MAMD64},
d396ed
   {"mintel64", no_argument, NULL, OPTION_MINTEL64},
d396ed
   {NULL, no_argument, NULL, 0}
d396ed
@@ -10943,7 +11819,7 @@ int
d396ed
 md_parse_option (int c, const char *arg)
d396ed
 {
d396ed
   unsigned int j;
d396ed
-  char *arch, *next, *saved;
d396ed
+  char *arch, *next, *saved, *type;
d396ed
 
d396ed
   switch (c)
d396ed
     {
d396ed
@@ -11319,6 +12195,86 @@ md_parse_option (int c, const char *arg)
d396ed
         as_fatal (_("invalid -mrelax-relocations= option: `%s'"), arg);
d396ed
       break;
d396ed
 
d396ed
+    case OPTION_MALIGN_BRANCH_BOUNDARY:
d396ed
+      {
d396ed
+	char *end;
d396ed
+	int align = strtoul (arg, &end, 0);
d396ed
+	if (*end == '\0')
d396ed
+	  {
d396ed
+	    if (align == 0)
d396ed
+	      {
d396ed
+		align_branch_power = 0;
d396ed
+		break;
d396ed
+	      }
d396ed
+	    else if (align >= 32)
d396ed
+	      {
d396ed
+		int align_power;
d396ed
+		for (align_power = 0;
d396ed
+		     (align & 1) == 0;
d396ed
+		     align >>= 1, align_power++)
d396ed
+		  continue;
d396ed
+		if (align == 1)
d396ed
+		  {
d396ed
+		    align_branch_power = align_power;
d396ed
+		    break;
d396ed
+		  }
d396ed
+	      }
d396ed
+	  }
d396ed
+	as_fatal (_("invalid -malign-branch-boundary= value: %s"), arg);
d396ed
+      }
d396ed
+      break;
d396ed
+
d396ed
+    case OPTION_MALIGN_BRANCH_PREFIX_SIZE:
d396ed
+      {
d396ed
+	char *end;
d396ed
+	int align = strtoul (arg, &end, 0);
d396ed
+	if (*end == '\0' && align >= 0 && align < 6)
d396ed
+	  {
d396ed
+	    align_branch_prefix_size = align;
d396ed
+	    break;
d396ed
+	  }
d396ed
+	as_fatal (_("invalid -malign-branch-prefix-size= value: %s"),
d396ed
+		  arg);
d396ed
+      }
d396ed
+      break;
d396ed
+
d396ed
+    case OPTION_MALIGN_BRANCH:
d396ed
+      align_branch = 0;
d396ed
+      saved = xstrdup (arg);
d396ed
+      type = saved;
d396ed
+      do
d396ed
+	{
d396ed
+	  next = strchr (type, '+');
d396ed
+	  if (next)
d396ed
+	    *next++ = '\0';
d396ed
+	  if (strcasecmp (type, "jcc") == 0)
d396ed
+	    align_branch |= align_branch_jcc;
d396ed
+	  else if (strcasecmp (type, "fused") == 0)
d396ed
+	    align_branch |= align_branch_fused;
d396ed
+	  else if (strcasecmp (type, "jmp") == 0)
d396ed
+	    align_branch |= align_branch_jmp;
d396ed
+	  else if (strcasecmp (type, "call") == 0)
d396ed
+	    align_branch |= align_branch_call;
d396ed
+	  else if (strcasecmp (type, "ret") == 0)
d396ed
+	    align_branch |= align_branch_ret;
d396ed
+	  else if (strcasecmp (type, "indirect") == 0)
d396ed
+	    align_branch |= align_branch_indirect;
d396ed
+	  else
d396ed
+	    as_fatal (_("invalid -malign-branch= option: `%s'"), arg);
d396ed
+	  type = next;
d396ed
+	}
d396ed
+      while (next != NULL);
d396ed
+      free (saved);
d396ed
+      break;
d396ed
+
d396ed
+    case OPTION_MBRANCHES_WITH_32B_BOUNDARIES:
d396ed
+      align_branch_power = 5;
d396ed
+      align_branch_prefix_size = 5;
d396ed
+      align_branch = (align_branch_jcc
d396ed
+		      | align_branch_fused
d396ed
+		      | align_branch_jmp);
d396ed
+      break;
d396ed
+
d396ed
     case OPTION_MAMD64:
d396ed
       intel64 = 0;
d396ed
       break;
d396ed
@@ -11571,6 +12527,20 @@ md_show_usage (FILE *stream)
d396ed
   fprintf (stream, _("\
d396ed
                           generate relax relocations\n"));
d396ed
   fprintf (stream, _("\
d396ed
+  -malign-branch-boundary=NUM (default: 0)\n\
d396ed
+                          align branches within NUM byte boundary\n"));
d396ed
+  fprintf (stream, _("\
d396ed
+  -malign-branch=TYPE[+TYPE...] (default: jcc+fused+jmp)\n\
d396ed
+                          TYPE is combination of jcc, fused, jmp, call, ret,\n\
d396ed
+                           indirect\n\
d396ed
+                          specify types of branches to align\n"));
d396ed
+  fprintf (stream, _("\
d396ed
+  -malign-branch-prefix-size=NUM (default: 5)\n\
d396ed
+                          align branches with NUM prefixes per instruction\n"));
d396ed
+  fprintf (stream, _("\
d396ed
+  -mbranches-within-32B-boundaries\n\
d396ed
+                          align branches within 32 byte boundary\n"));
d396ed
+  fprintf (stream, _("\
d396ed
   -mamd64                 accept only AMD64 ISA [default]\n"));
d396ed
   fprintf (stream, _("\
d396ed
   -mintel64               accept only Intel64 ISA\n"));
d396ed
@@ -11654,15 +12624,24 @@ i386_target_format (void)
d396ed
 	  {
d396ed
 	  default:
d396ed
 	    format = ELF_TARGET_FORMAT;
d396ed
+#ifndef TE_SOLARIS
d396ed
+	    tls_get_addr = "___tls_get_addr";
d396ed
+#endif
d396ed
 	    break;
d396ed
 	  case X86_64_ABI:
d396ed
 	    use_rela_relocations = 1;
d396ed
 	    object_64bit = 1;
d396ed
+#ifndef TE_SOLARIS
d396ed
+	    tls_get_addr = "__tls_get_addr";
d396ed
+#endif
d396ed
 	    format = ELF_TARGET_FORMAT64;
d396ed
 	    break;
d396ed
 	  case X86_64_X32_ABI:
d396ed
 	    use_rela_relocations = 1;
d396ed
 	    object_64bit = 1;
d396ed
+#ifndef TE_SOLARIS
d396ed
+	    tls_get_addr = "__tls_get_addr";
d396ed
+#endif
d396ed
 	    disallow_64bit_reloc = 1;
d396ed
 	    format = ELF_TARGET_FORMAT32;
d396ed
 	    break;
d396ed
@@ -11779,6 +12758,21 @@ s_bss (int ignore ATTRIBUTE_UNUSED)
d396ed
 
d396ed
 #endif
d396ed
 
d396ed
+/* Remember constant diretive.  */
d396ed
+
d396ed
+void
d396ed
+i386_cons_worker (int ignore ATTRIBUTE_UNUSED)
d396ed
+{
d396ed
+  if (last_insn.kind != last_insn_directive
d396ed
+      && (bfd_get_section_flags (NULL, now_seg) & SEC_CODE))
d396ed
+    {
d396ed
+      last_insn.seg = now_seg;
d396ed
+      last_insn.kind = last_insn_directive;
d396ed
+      last_insn.name = "constant diretive";
d396ed
+      last_insn.file = as_where (&last_insn.line);
d396ed
+    }
d396ed
+}
d396ed
+
d396ed
 void
d396ed
 i386_validate_fix (fixS *fixp)
d396ed
 {
d396ed
diff -rupN binutils-2.32/gas/config/tc-i386.h binutils.new/gas/config/tc-i386.h
d396ed
--- binutils-2.32/gas/config/tc-i386.h	2019-01-19 16:01:33.000000000 +0000
d396ed
+++ binutils.new/gas/config/tc-i386.h	2019-11-25 14:01:00.626325922 +0000
d396ed
@@ -208,12 +208,19 @@ if ((n)									\
d396ed
 
d396ed
 #define MAX_MEM_FOR_RS_ALIGN_CODE 4095
d396ed
 
d396ed
+extern void i386_cons_worker (int);
d396ed
+#define md_cons_worker(nbytes) i386_cons_worker (nbytes)
d396ed
+
d396ed
 void i386_print_statistics (FILE *);
d396ed
 #define tc_print_statistics i386_print_statistics
d396ed
 
d396ed
 extern unsigned int i386_frag_max_var (fragS *);
d396ed
 #define md_frag_max_var i386_frag_max_var
d396ed
 
d396ed
+extern long i386_generic_table_relax_frag (segT, fragS *, long);
d396ed
+#define md_generic_table_relax_frag(segment, fragP, stretch) \
d396ed
+  i386_generic_table_relax_frag (segment, fragP, stretch)
d396ed
+
d396ed
 #define md_number_to_chars number_to_chars_littleendian
d396ed
 
d396ed
 enum processor_type
d396ed
@@ -248,9 +255,24 @@ extern i386_cpu_flags cpu_arch_isa_flags
d396ed
 
d396ed
 struct i386_tc_frag_data
d396ed
 {
d396ed
+  union
d396ed
+    {
d396ed
+      fragS *padding_fragP;
d396ed
+      fragS *branch_fragP;
d396ed
+    } u;
d396ed
+  addressT padding_address;
d396ed
   enum processor_type isa;
d396ed
   i386_cpu_flags isa_flags;
d396ed
+  unsigned int max_bytes;
d396ed
   enum processor_type tune;
d396ed
+  signed char length;
d396ed
+  signed char last_length;
d396ed
+  signed char max_prefix_length;
d396ed
+  signed char prefix_length;
d396ed
+  signed char default_prefix;
d396ed
+  signed char cmp_size;
d396ed
+  unsigned int classified : 1;
d396ed
+  unsigned int branch_type : 7;
d396ed
 };
d396ed
 
d396ed
 /* We need to emit the right NOP pattern in .align frags.  This is
d396ed
@@ -261,9 +283,20 @@ struct i386_tc_frag_data
d396ed
 #define TC_FRAG_INIT(FRAGP)					\
d396ed
  do								\
d396ed
    {								\
d396ed
+     (FRAGP)->tc_frag_data.u.padding_fragP = NULL;		\
d396ed
+     (FRAGP)->tc_frag_data.padding_address = 0;			\
d396ed
      (FRAGP)->tc_frag_data.isa = cpu_arch_isa;			\
d396ed
      (FRAGP)->tc_frag_data.isa_flags = cpu_arch_isa_flags;	\
d396ed
      (FRAGP)->tc_frag_data.tune = cpu_arch_tune;		\
d396ed
+     (FRAGP)->tc_frag_data.length = 0;				\
d396ed
+     (FRAGP)->tc_frag_data.max_bytes = max_chars;		\
d396ed
+     (FRAGP)->tc_frag_data.last_length = 0;			\
d396ed
+     (FRAGP)->tc_frag_data.max_prefix_length = 0;		\
d396ed
+     (FRAGP)->tc_frag_data.prefix_length = 0;			\
d396ed
+     (FRAGP)->tc_frag_data.default_prefix = 0;			\
d396ed
+     (FRAGP)->tc_frag_data.cmp_size = 0;			\
d396ed
+     (FRAGP)->tc_frag_data.classified = 0;			\
d396ed
+     (FRAGP)->tc_frag_data.branch_type = 0;			\
d396ed
    }								\
d396ed
  while (0)
d396ed
 
d396ed
diff -rupN binutils-2.32/gas/doc/c-i386.texi binutils.new/gas/doc/c-i386.texi
d396ed
--- binutils-2.32/gas/doc/c-i386.texi	2019-01-19 16:01:33.000000000 +0000
d396ed
+++ binutils.new/gas/doc/c-i386.texi	2019-11-25 14:01:00.615325994 +0000
d396ed
@@ -410,6 +410,43 @@ R_X86_64_REX_GOTPCRELX, in 64-bit mode.
d396ed
 relocations.  The default can be controlled by a configure option
d396ed
 @option{--enable-x86-relax-relocations}.
d396ed
 
d396ed
+@cindex @samp{-malign-branch-boundary=} option, i386
d396ed
+@cindex @samp{-malign-branch-boundary=} option, x86-64
d396ed
+@item -malign-branch-boundary=@var{NUM}
d396ed
+This option controls how the assembler should align branches with segment
d396ed
+prefixes or NOP.  @var{NUM} must be a power of 2.  It should be 0 or
d396ed
+no less than 32.  Branches will be aligned within @var{NUM} byte
d396ed
+boundary.  @option{-malign-branch-boundary=0}, which is the default,
d396ed
+doesn't align branches.
d396ed
+
d396ed
+@cindex @samp{-malign-branch=} option, i386
d396ed
+@cindex @samp{-malign-branch=} option, x86-64
d396ed
+@item -malign-branch=@var{TYPE}[+@var{TYPE}...]
d396ed
+This option specifies types of branches to align. @var{TYPE} is
d396ed
+combination of @samp{jcc}, which aligns conditional jumps,
d396ed
+@samp{fused}, which aligns fused conditional jumps, @samp{jmp},
d396ed
+which aligns unconditional jumps, @samp{call} which aligns calls,
d396ed
+@samp{ret}, which aligns rets, @samp{indirect}, which aligns indirect
d396ed
+jumps and calls.  The default is @option{-malign-branch=jcc+fused+jmp}.
d396ed
+
d396ed
+@cindex @samp{-malign-branch-prefix-size=} option, i386
d396ed
+@cindex @samp{-malign-branch-prefix-size=} option, x86-64
d396ed
+@item -malign-branch-prefix-size=@var{NUM}
d396ed
+This option specifies the maximum number of prefixes on an instruction
d396ed
+to align branches.  @var{NUM} should be between 0 and 5.  The default
d396ed
+@var{NUM} is 5.
d396ed
+
d396ed
+@cindex @samp{-mbranches-within-32B-boundaries} option, i386
d396ed
+@cindex @samp{-mbranches-within-32B-boundaries} option, x86-64
d396ed
+@item -mbranches-within-32B-boundaries
d396ed
+This option aligns conditional jumps, fused conditional jumps and
d396ed
+unconditional jumps within 32 byte boundary with up to 5 segment prefixes
d396ed
+on an instruction.  It is equivalent to
d396ed
+@option{-malign-branch-boundary=32}
d396ed
+@option{-malign-branch=jcc+fused+jmp}
d396ed
+@option{-malign-branch-prefix-size=5}.
d396ed
+The default doesn't align branches.
d396ed
+
d396ed
 @cindex @samp{-mx86-used-note=} option, i386
d396ed
 @cindex @samp{-mx86-used-note=} option, x86-64
d396ed
 @item -mx86-used-note=@var{no}
d396ed
diff -rupN binutils-2.32/gas/read.c binutils.new/gas/read.c
d396ed
--- binutils-2.32/gas/read.c	2019-01-19 16:01:33.000000000 +0000
d396ed
+++ binutils.new/gas/read.c	2019-11-25 14:01:00.616325988 +0000
d396ed
@@ -3976,6 +3976,10 @@ cons_worker (int nbytes,	/* 1=.byte, 2=.
d396ed
   md_cons_align (nbytes);
d396ed
 #endif
d396ed
 
d396ed
+#ifdef md_cons_worker
d396ed
+  md_cons_worker (nbytes);
d396ed
+#endif
d396ed
+
d396ed
   c = 0;
d396ed
   do
d396ed
     {
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-1a.d binutils.new/gas/testsuite/gas/i386/align-branch-1a.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-1a.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-1a.d	2019-11-25 14:01:00.632325883 +0000
d396ed
@@ -0,0 +1,77 @@
d396ed
+#source: align-branch-1.s
d396ed
+#as: -malign-branch-boundary=32
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	65 65 65 a3 01 00 00 00 	gs gs mov %eax,%gs:0x1
d396ed
+   8:	55                   	push   %ebp
d396ed
+   9:	55                   	push   %ebp
d396ed
+   a:	55                   	push   %ebp
d396ed
+   b:	55                   	push   %ebp
d396ed
+   c:	89 e5                	mov    %esp,%ebp
d396ed
+   e:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  20:	39 c5                	cmp    %eax,%ebp
d396ed
+  22:	74 5e                	je     82 <foo\+0x82>
d396ed
+  24:	3e 89 73 f4          	mov    %esi,%ds:-0xc\(%ebx\)
d396ed
+  28:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  2b:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  2e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3d:	5d                   	pop    %ebp
d396ed
+  3e:	5d                   	pop    %ebp
d396ed
+  3f:	5d                   	pop    %ebp
d396ed
+  40:	74 40                	je     82 <foo\+0x82>
d396ed
+  42:	5d                   	pop    %ebp
d396ed
+  43:	74 3d                	je     82 <foo\+0x82>
d396ed
+  45:	36 89 44 24 fc       	mov    %eax,%ss:-0x4\(%esp\)
d396ed
+  4a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  4d:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  50:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  53:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  56:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  59:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  5c:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  5f:	5d                   	pop    %ebp
d396ed
+  60:	eb 26                	jmp    88 <foo\+0x88>
d396ed
+  62:	eb 24                	jmp    88 <foo\+0x88>
d396ed
+  64:	eb 22                	jmp    88 <foo\+0x88>
d396ed
+  66:	89 45 fc             	mov    %eax,-0x4\(%ebp\)
d396ed
+  69:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  6c:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  6f:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  72:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  75:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  78:	5d                   	pop    %ebp
d396ed
+  79:	5d                   	pop    %ebp
d396ed
+  7a:	39 c5                	cmp    %eax,%ebp
d396ed
+  7c:	74 04                	je     82 <foo\+0x82>
d396ed
+  7e:	66 90                	xchg   %ax,%ax
d396ed
+  80:	eb 06                	jmp    88 <foo\+0x88>
d396ed
+  82:	8b 45 f4             	mov    -0xc\(%ebp\),%eax
d396ed
+  85:	89 45 fc             	mov    %eax,-0x4\(%ebp\)
d396ed
+  88:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  8e:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  94:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  9a:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  a0:	89 75 0c             	mov    %esi,0xc\(%ebp\)
d396ed
+  a3:	e9 [0-9a-f ]+       	jmp    .*
d396ed
+  a8:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  ae:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  b4:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  ba:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  c0:	89 75 00             	mov    %esi,0x0\(%ebp\)
d396ed
+  c3:	74 c3                	je     88 <foo\+0x88>
d396ed
+  c5:	74 c1                	je     88 <foo\+0x88>
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-1b.d binutils.new/gas/testsuite/gas/i386/align-branch-1b.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-1b.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-1b.d	2019-11-25 14:01:00.679325573 +0000
d396ed
@@ -0,0 +1,77 @@
d396ed
+#source: align-branch-1.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=fused+jcc+jmp
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	65 65 65 a3 01 00 00 00 	gs gs mov %eax,%gs:0x1
d396ed
+   8:	55                   	push   %ebp
d396ed
+   9:	55                   	push   %ebp
d396ed
+   a:	55                   	push   %ebp
d396ed
+   b:	55                   	push   %ebp
d396ed
+   c:	89 e5                	mov    %esp,%ebp
d396ed
+   e:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  20:	39 c5                	cmp    %eax,%ebp
d396ed
+  22:	74 5e                	je     82 <foo\+0x82>
d396ed
+  24:	3e 89 73 f4          	mov    %esi,%ds:-0xc\(%ebx\)
d396ed
+  28:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  2b:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  2e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3d:	5d                   	pop    %ebp
d396ed
+  3e:	5d                   	pop    %ebp
d396ed
+  3f:	5d                   	pop    %ebp
d396ed
+  40:	74 40                	je     82 <foo\+0x82>
d396ed
+  42:	5d                   	pop    %ebp
d396ed
+  43:	74 3d                	je     82 <foo\+0x82>
d396ed
+  45:	36 89 44 24 fc       	mov    %eax,%ss:-0x4\(%esp\)
d396ed
+  4a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  4d:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  50:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  53:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  56:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  59:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  5c:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  5f:	5d                   	pop    %ebp
d396ed
+  60:	eb 26                	jmp    88 <foo\+0x88>
d396ed
+  62:	eb 24                	jmp    88 <foo\+0x88>
d396ed
+  64:	eb 22                	jmp    88 <foo\+0x88>
d396ed
+  66:	89 45 fc             	mov    %eax,-0x4\(%ebp\)
d396ed
+  69:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  6c:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  6f:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  72:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  75:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  78:	5d                   	pop    %ebp
d396ed
+  79:	5d                   	pop    %ebp
d396ed
+  7a:	39 c5                	cmp    %eax,%ebp
d396ed
+  7c:	74 04                	je     82 <foo\+0x82>
d396ed
+  7e:	66 90                	xchg   %ax,%ax
d396ed
+  80:	eb 06                	jmp    88 <foo\+0x88>
d396ed
+  82:	8b 45 f4             	mov    -0xc\(%ebp\),%eax
d396ed
+  85:	89 45 fc             	mov    %eax,-0x4\(%ebp\)
d396ed
+  88:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  8e:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  94:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  9a:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  a0:	89 75 0c             	mov    %esi,0xc\(%ebp\)
d396ed
+  a3:	e9 [0-9a-f ]+       	jmp    .*
d396ed
+  a8:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  ae:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  b4:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  ba:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  c0:	89 75 00             	mov    %esi,0x0\(%ebp\)
d396ed
+  c3:	74 c3                	je     88 <foo\+0x88>
d396ed
+  c5:	74 c1                	je     88 <foo\+0x88>
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-1c.d binutils.new/gas/testsuite/gas/i386/align-branch-1c.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-1c.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-1c.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,77 @@
d396ed
+#source: align-branch-1.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch-prefix-size=1
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	65 a3 01 00 00 00    	mov    %eax,%gs:0x1
d396ed
+   6:	3e 55                	ds push %ebp
d396ed
+   8:	3e 55                	ds push %ebp
d396ed
+   a:	55                   	push   %ebp
d396ed
+   b:	55                   	push   %ebp
d396ed
+   c:	89 e5                	mov    %esp,%ebp
d396ed
+   e:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  20:	39 c5                	cmp    %eax,%ebp
d396ed
+  22:	74 5e                	je     82 <foo\+0x82>
d396ed
+  24:	3e 89 73 f4          	mov    %esi,%ds:-0xc\(%ebx\)
d396ed
+  28:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  2b:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  2e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3d:	5d                   	pop    %ebp
d396ed
+  3e:	5d                   	pop    %ebp
d396ed
+  3f:	5d                   	pop    %ebp
d396ed
+  40:	74 40                	je     82 <foo\+0x82>
d396ed
+  42:	5d                   	pop    %ebp
d396ed
+  43:	74 3d                	je     82 <foo\+0x82>
d396ed
+  45:	36 89 44 24 fc       	mov    %eax,%ss:-0x4\(%esp\)
d396ed
+  4a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  4d:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  50:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  53:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  56:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  59:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  5c:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  5f:	5d                   	pop    %ebp
d396ed
+  60:	eb 26                	jmp    88 <foo\+0x88>
d396ed
+  62:	eb 24                	jmp    88 <foo\+0x88>
d396ed
+  64:	eb 22                	jmp    88 <foo\+0x88>
d396ed
+  66:	89 45 fc             	mov    %eax,-0x4\(%ebp\)
d396ed
+  69:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  6c:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  6f:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  72:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  75:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  78:	5d                   	pop    %ebp
d396ed
+  79:	5d                   	pop    %ebp
d396ed
+  7a:	39 c5                	cmp    %eax,%ebp
d396ed
+  7c:	74 04                	je     82 <foo\+0x82>
d396ed
+  7e:	66 90                	xchg   %ax,%ax
d396ed
+  80:	eb 06                	jmp    88 <foo\+0x88>
d396ed
+  82:	8b 45 f4             	mov    -0xc\(%ebp\),%eax
d396ed
+  85:	89 45 fc             	mov    %eax,-0x4\(%ebp\)
d396ed
+  88:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  8e:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  94:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  9a:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  a0:	89 75 0c             	mov    %esi,0xc\(%ebp\)
d396ed
+  a3:	e9 [0-9a-f ]+       	jmp    .*
d396ed
+  a8:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  ae:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  b4:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  ba:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  c0:	89 75 00             	mov    %esi,0x0\(%ebp\)
d396ed
+  c3:	74 c3                	je     88 <foo\+0x88>
d396ed
+  c5:	74 c1                	je     88 <foo\+0x88>
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-1d.d binutils.new/gas/testsuite/gas/i386/align-branch-1d.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-1d.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-1d.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,76 @@
d396ed
+#source: align-branch-1.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=fused+jcc
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	65 65 65 a3 01 00 00 00 	gs gs mov %eax,%gs:0x1
d396ed
+   8:	55                   	push   %ebp
d396ed
+   9:	55                   	push   %ebp
d396ed
+   a:	55                   	push   %ebp
d396ed
+   b:	55                   	push   %ebp
d396ed
+   c:	89 e5                	mov    %esp,%ebp
d396ed
+   e:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  20:	39 c5                	cmp    %eax,%ebp
d396ed
+  22:	74 5b                	je     7f <foo\+0x7f>
d396ed
+  24:	3e 89 73 f4          	mov    %esi,%ds:-0xc\(%ebx\)
d396ed
+  28:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  2b:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  2e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3d:	5d                   	pop    %ebp
d396ed
+  3e:	5d                   	pop    %ebp
d396ed
+  3f:	5d                   	pop    %ebp
d396ed
+  40:	74 3d                	je     7f <foo\+0x7f>
d396ed
+  42:	5d                   	pop    %ebp
d396ed
+  43:	74 3a                	je     7f <foo\+0x7f>
d396ed
+  45:	89 44 24 fc          	mov    %eax,-0x4\(%esp\)
d396ed
+  49:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  4c:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  4f:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  52:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  55:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  58:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  5b:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  5e:	5d                   	pop    %ebp
d396ed
+  5f:	eb 24                	jmp    85 <foo\+0x85>
d396ed
+  61:	eb 22                	jmp    85 <foo\+0x85>
d396ed
+  63:	eb 20                	jmp    85 <foo\+0x85>
d396ed
+  65:	89 45 fc             	mov    %eax,-0x4\(%ebp\)
d396ed
+  68:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  6b:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  6e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  71:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  74:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  77:	5d                   	pop    %ebp
d396ed
+  78:	5d                   	pop    %ebp
d396ed
+  79:	39 c5                	cmp    %eax,%ebp
d396ed
+  7b:	74 02                	je     7f <foo\+0x7f>
d396ed
+  7d:	eb 06                	jmp    85 <foo\+0x85>
d396ed
+  7f:	8b 45 f4             	mov    -0xc\(%ebp\),%eax
d396ed
+  82:	89 45 fc             	mov    %eax,-0x4\(%ebp\)
d396ed
+  85:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  8b:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  91:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  97:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  9d:	89 75 0c             	mov    %esi,0xc\(%ebp\)
d396ed
+  a0:	e9 [0-9a-f ]+       	jmp    .*
d396ed
+  a5:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  ab:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  b1:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  b7:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  bd:	89 75 00             	mov    %esi,0x0\(%ebp\)
d396ed
+  c0:	74 c3                	je     85 <foo\+0x85>
d396ed
+  c2:	74 c1                	je     85 <foo\+0x85>
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-1e.d binutils.new/gas/testsuite/gas/i386/align-branch-1e.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-1e.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-1e.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,77 @@
d396ed
+#source: align-branch-1.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=jcc
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	65 a3 01 00 00 00    	mov    %eax,%gs:0x1
d396ed
+   6:	55                   	push   %ebp
d396ed
+   7:	55                   	push   %ebp
d396ed
+   8:	55                   	push   %ebp
d396ed
+   9:	55                   	push   %ebp
d396ed
+   a:	89 e5                	mov    %esp,%ebp
d396ed
+   c:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+   f:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  12:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  15:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  18:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1b:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1e:	39 c5                	cmp    %eax,%ebp
d396ed
+  20:	74 5a                	je     7c <foo\+0x7c>
d396ed
+  22:	89 73 f4             	mov    %esi,-0xc\(%ebx\)
d396ed
+  25:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  28:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  2b:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  2e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3a:	5d                   	pop    %ebp
d396ed
+  3b:	5d                   	pop    %ebp
d396ed
+  3c:	5d                   	pop    %ebp
d396ed
+  3d:	74 3d                	je     7c <foo\+0x7c>
d396ed
+  3f:	5d                   	pop    %ebp
d396ed
+  40:	74 3a                	je     7c <foo\+0x7c>
d396ed
+  42:	89 44 24 fc          	mov    %eax,-0x4\(%esp\)
d396ed
+  46:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  49:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  4c:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  4f:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  52:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  55:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  58:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  5b:	5d                   	pop    %ebp
d396ed
+  5c:	eb 24                	jmp    82 <foo\+0x82>
d396ed
+  5e:	eb 22                	jmp    82 <foo\+0x82>
d396ed
+  60:	eb 20                	jmp    82 <foo\+0x82>
d396ed
+  62:	89 45 fc             	mov    %eax,-0x4\(%ebp\)
d396ed
+  65:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  68:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  6b:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  6e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  71:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  74:	5d                   	pop    %ebp
d396ed
+  75:	5d                   	pop    %ebp
d396ed
+  76:	39 c5                	cmp    %eax,%ebp
d396ed
+  78:	74 02                	je     7c <foo\+0x7c>
d396ed
+  7a:	eb 06                	jmp    82 <foo\+0x82>
d396ed
+  7c:	8b 45 f4             	mov    -0xc\(%ebp\),%eax
d396ed
+  7f:	89 45 fc             	mov    %eax,-0x4\(%ebp\)
d396ed
+  82:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  88:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  8e:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  94:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  9a:	89 75 0c             	mov    %esi,0xc\(%ebp\)
d396ed
+  9d:	e9 [0-9a-f ]+       	jmp    .*
d396ed
+  a2:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  a8:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  ae:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  b4:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  ba:	89 75 00             	mov    %esi,0x0\(%ebp\)
d396ed
+  bd:	74 c3                	je     82 <foo\+0x82>
d396ed
+  bf:	90                   	nop
d396ed
+  c0:	74 c0                	je     82 <foo\+0x82>
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-1f.d binutils.new/gas/testsuite/gas/i386/align-branch-1f.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-1f.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-1f.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,77 @@
d396ed
+#source: align-branch-1.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=jcc+jmp
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	65 a3 01 00 00 00    	mov    %eax,%gs:0x1
d396ed
+   6:	55                   	push   %ebp
d396ed
+   7:	55                   	push   %ebp
d396ed
+   8:	55                   	push   %ebp
d396ed
+   9:	55                   	push   %ebp
d396ed
+   a:	89 e5                	mov    %esp,%ebp
d396ed
+   c:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+   f:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  12:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  15:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  18:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1b:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1e:	39 c5                	cmp    %eax,%ebp
d396ed
+  20:	74 5c                	je     7e <foo\+0x7e>
d396ed
+  22:	89 73 f4             	mov    %esi,-0xc\(%ebx\)
d396ed
+  25:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  28:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  2b:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  2e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3a:	5d                   	pop    %ebp
d396ed
+  3b:	5d                   	pop    %ebp
d396ed
+  3c:	5d                   	pop    %ebp
d396ed
+  3d:	74 3f                	je     7e <foo\+0x7e>
d396ed
+  3f:	5d                   	pop    %ebp
d396ed
+  40:	74 3c                	je     7e <foo\+0x7e>
d396ed
+  42:	89 44 24 fc          	mov    %eax,-0x4\(%esp\)
d396ed
+  46:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  49:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  4c:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  4f:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  52:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  55:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  58:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  5b:	5d                   	pop    %ebp
d396ed
+  5c:	eb 27                	jmp    85 <foo\+0x85>
d396ed
+  5e:	66 90                	xchg   %ax,%ax
d396ed
+  60:	eb 23                	jmp    85 <foo\+0x85>
d396ed
+  62:	eb 21                	jmp    85 <foo\+0x85>
d396ed
+  64:	89 45 fc             	mov    %eax,-0x4\(%ebp\)
d396ed
+  67:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  6a:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  6d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  70:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  73:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  76:	5d                   	pop    %ebp
d396ed
+  77:	5d                   	pop    %ebp
d396ed
+  78:	39 c5                	cmp    %eax,%ebp
d396ed
+  7a:	74 02                	je     7e <foo\+0x7e>
d396ed
+  7c:	eb 07                	jmp    85 <foo\+0x85>
d396ed
+  7e:	36 8b 45 f4          	mov    %ss:-0xc\(%ebp\),%eax
d396ed
+  82:	89 45 fc             	mov    %eax,-0x4\(%ebp\)
d396ed
+  85:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  8b:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  91:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  97:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  9d:	89 75 0c             	mov    %esi,0xc\(%ebp\)
d396ed
+  a0:	e9 [0-9a-f ]+       	jmp    .*
d396ed
+  a5:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  ab:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  b1:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  b7:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  bd:	89 75 00             	mov    %esi,0x0\(%ebp\)
d396ed
+  c0:	74 c3                	je     85 <foo\+0x85>
d396ed
+  c2:	74 c1                	je     85 <foo\+0x85>
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-1g.d binutils.new/gas/testsuite/gas/i386/align-branch-1g.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-1g.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-1g.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,77 @@
d396ed
+#source: align-branch-1.s
d396ed
+#as: -mbranches-within-32B-boundaries
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	65 65 65 a3 01 00 00 00 	gs gs mov %eax,%gs:0x1
d396ed
+   8:	55                   	push   %ebp
d396ed
+   9:	55                   	push   %ebp
d396ed
+   a:	55                   	push   %ebp
d396ed
+   b:	55                   	push   %ebp
d396ed
+   c:	89 e5                	mov    %esp,%ebp
d396ed
+   e:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  20:	39 c5                	cmp    %eax,%ebp
d396ed
+  22:	74 5e                	je     82 <foo\+0x82>
d396ed
+  24:	3e 89 73 f4          	mov    %esi,%ds:-0xc\(%ebx\)
d396ed
+  28:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  2b:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  2e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3d:	5d                   	pop    %ebp
d396ed
+  3e:	5d                   	pop    %ebp
d396ed
+  3f:	5d                   	pop    %ebp
d396ed
+  40:	74 40                	je     82 <foo\+0x82>
d396ed
+  42:	5d                   	pop    %ebp
d396ed
+  43:	74 3d                	je     82 <foo\+0x82>
d396ed
+  45:	36 89 44 24 fc       	mov    %eax,%ss:-0x4\(%esp\)
d396ed
+  4a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  4d:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  50:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  53:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  56:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  59:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  5c:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  5f:	5d                   	pop    %ebp
d396ed
+  60:	eb 26                	jmp    88 <foo\+0x88>
d396ed
+  62:	eb 24                	jmp    88 <foo\+0x88>
d396ed
+  64:	eb 22                	jmp    88 <foo\+0x88>
d396ed
+  66:	89 45 fc             	mov    %eax,-0x4\(%ebp\)
d396ed
+  69:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  6c:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  6f:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  72:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  75:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  78:	5d                   	pop    %ebp
d396ed
+  79:	5d                   	pop    %ebp
d396ed
+  7a:	39 c5                	cmp    %eax,%ebp
d396ed
+  7c:	74 04                	je     82 <foo\+0x82>
d396ed
+  7e:	66 90                	xchg   %ax,%ax
d396ed
+  80:	eb 06                	jmp    88 <foo\+0x88>
d396ed
+  82:	8b 45 f4             	mov    -0xc\(%ebp\),%eax
d396ed
+  85:	89 45 fc             	mov    %eax,-0x4\(%ebp\)
d396ed
+  88:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  8e:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  94:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  9a:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  a0:	89 75 0c             	mov    %esi,0xc\(%ebp\)
d396ed
+  a3:	e9 [0-9a-f ]+       	jmp    .*
d396ed
+  a8:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  ae:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  b4:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  ba:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  c0:	89 75 00             	mov    %esi,0x0\(%ebp\)
d396ed
+  c3:	74 c3                	je     88 <foo\+0x88>
d396ed
+  c5:	74 c1                	je     88 <foo\+0x88>
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-1h.d binutils.new/gas/testsuite/gas/i386/align-branch-1h.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-1h.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-1h.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,76 @@
d396ed
+#source: align-branch-1.s
d396ed
+#as: -mbranches-within-32B-boundaries -malign-branch-boundary=0
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	65 a3 01 00 00 00    	mov    %eax,%gs:0x1
d396ed
+   6:	55                   	push   %ebp
d396ed
+   7:	55                   	push   %ebp
d396ed
+   8:	55                   	push   %ebp
d396ed
+   9:	55                   	push   %ebp
d396ed
+   a:	89 e5                	mov    %esp,%ebp
d396ed
+   c:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+   f:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  12:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  15:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  18:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1b:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1e:	39 c5                	cmp    %eax,%ebp
d396ed
+  20:	74 5a                	je     7c <foo\+0x7c>
d396ed
+  22:	89 73 f4             	mov    %esi,-0xc\(%ebx\)
d396ed
+  25:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  28:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  2b:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  2e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3a:	5d                   	pop    %ebp
d396ed
+  3b:	5d                   	pop    %ebp
d396ed
+  3c:	5d                   	pop    %ebp
d396ed
+  3d:	74 3d                	je     7c <foo\+0x7c>
d396ed
+  3f:	5d                   	pop    %ebp
d396ed
+  40:	74 3a                	je     7c <foo\+0x7c>
d396ed
+  42:	89 44 24 fc          	mov    %eax,-0x4\(%esp\)
d396ed
+  46:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  49:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  4c:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  4f:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  52:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  55:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  58:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  5b:	5d                   	pop    %ebp
d396ed
+  5c:	eb 24                	jmp    82 <foo\+0x82>
d396ed
+  5e:	eb 22                	jmp    82 <foo\+0x82>
d396ed
+  60:	eb 20                	jmp    82 <foo\+0x82>
d396ed
+  62:	89 45 fc             	mov    %eax,-0x4\(%ebp\)
d396ed
+  65:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  68:	89 7d f8             	mov    %edi,-0x8\(%ebp\)
d396ed
+  6b:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  6e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  71:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  74:	5d                   	pop    %ebp
d396ed
+  75:	5d                   	pop    %ebp
d396ed
+  76:	39 c5                	cmp    %eax,%ebp
d396ed
+  78:	74 02                	je     7c <foo\+0x7c>
d396ed
+  7a:	eb 06                	jmp    82 <foo\+0x82>
d396ed
+  7c:	8b 45 f4             	mov    -0xc\(%ebp\),%eax
d396ed
+  7f:	89 45 fc             	mov    %eax,-0x4\(%ebp\)
d396ed
+  82:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  88:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  8e:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  94:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  9a:	89 75 0c             	mov    %esi,0xc\(%ebp\)
d396ed
+  9d:	e9 [0-9a-f ]+       	jmp    .*
d396ed
+  a2:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  a8:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  ae:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  b4:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%ebp\)
d396ed
+  ba:	89 75 00             	mov    %esi,0x0\(%ebp\)
d396ed
+  bd:	74 c3                	je     82 <foo\+0x82>
d396ed
+  bf:	74 c1                	je     82 <foo\+0x82>
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-1.s binutils.new/gas/testsuite/gas/i386/align-branch-1.s
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-1.s	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-1.s	2019-11-25 14:01:00.632325883 +0000
d396ed
@@ -0,0 +1,72 @@
d396ed
+  .text
d396ed
+  .globl  foo
d396ed
+  .p2align  4
d396ed
+foo:
d396ed
+  movl	%eax, %gs:0x1
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  movl  %esp, %ebp
d396ed
+  movl  %edi, -8(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  cmp  %eax, %ebp
d396ed
+  je  .L_2
d396ed
+  movl  %esi, -12(%ebx)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %edi, -8(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  popl  %ebp
d396ed
+  popl  %ebp
d396ed
+  popl  %ebp
d396ed
+  je  .L_2
d396ed
+  popl  %ebp
d396ed
+  je  .L_2
d396ed
+  movl  %eax, -4(%esp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %edi, -8(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  popl  %ebp
d396ed
+  jmp  .L_3
d396ed
+  jmp  .L_3
d396ed
+  jmp  .L_3
d396ed
+  movl  %eax, -4(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %edi, -8(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  popl  %ebp
d396ed
+  popl  %ebp
d396ed
+  cmp  %eax, %ebp
d396ed
+  je  .L_2
d396ed
+  jmp  .L_3
d396ed
+.L_2:
d396ed
+  movl  -12(%ebp), %eax
d396ed
+  movl  %eax, -4(%ebp)
d396ed
+.L_3:
d396ed
+  movl  %esi, -1200(%ebp)
d396ed
+  movl  %esi, -1200(%ebp)
d396ed
+  movl  %esi, -1200(%ebp)
d396ed
+  movl  %esi, -1200(%ebp)
d396ed
+  movl  %esi, 12(%ebp)
d396ed
+  jmp  bar
d396ed
+  movl  %esi, -1200(%ebp)
d396ed
+  movl  %esi, -1200(%ebp)
d396ed
+  movl  %esi, -1200(%ebp)
d396ed
+  movl  %esi, -1200(%ebp)
d396ed
+  movl  %esi, (%ebp)
d396ed
+  je .L_3
d396ed
+  je .L_3
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-2a.d binutils.new/gas/testsuite/gas/i386/align-branch-2a.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-2a.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-2a.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,55 @@
d396ed
+#source: align-branch-2.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=fused+jcc+jmp
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 a3 01 00 00 00    	mov    %eax,%fs:0x1
d396ed
+   6:	55                   	push   %ebp
d396ed
+   7:	55                   	push   %ebp
d396ed
+   8:	55                   	push   %ebp
d396ed
+   9:	55                   	push   %ebp
d396ed
+   a:	89 e5                	mov    %esp,%ebp
d396ed
+   c:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+   f:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  12:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  15:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  18:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1b:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1e:	ff e0                	jmp    \*%eax
d396ed
+  20:	55                   	push   %ebp
d396ed
+  21:	55                   	push   %ebp
d396ed
+  22:	64 a3 01 00 00 00    	mov    %eax,%fs:0x1
d396ed
+  28:	89 e5                	mov    %esp,%ebp
d396ed
+  2a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  2d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  30:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  33:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  36:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  39:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3c:	ff d0                	call   \*%eax
d396ed
+  3e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  41:	55                   	push   %ebp
d396ed
+  42:	55                   	push   %ebp
d396ed
+  43:	64 a3 01 00 00 00    	mov    %eax,%fs:0x1
d396ed
+  49:	89 e5                	mov    %esp,%ebp
d396ed
+  4b:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  4e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  51:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  54:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  57:	e8 [0-9a-f ]+       	call   .*
d396ed
+  5c:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  5f:	55                   	push   %ebp
d396ed
+  60:	55                   	push   %ebp
d396ed
+  61:	55                   	push   %ebp
d396ed
+  62:	55                   	push   %ebp
d396ed
+  63:	64 a3 01 00 00 00    	mov    %eax,%fs:0x1
d396ed
+  69:	89 e5                	mov    %esp,%ebp
d396ed
+  6b:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  6e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  71:	ff 15 00 00 00 00    	call   \*0x0
d396ed
+  77:	55                   	push   %ebp
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-2b.d binutils.new/gas/testsuite/gas/i386/align-branch-2b.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-2b.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-2b.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,55 @@
d396ed
+#source: align-branch-2.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=indirect
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 64 64 a3 01 00 00 00 	fs fs mov %eax,%fs:0x1
d396ed
+   8:	55                   	push   %ebp
d396ed
+   9:	55                   	push   %ebp
d396ed
+   a:	55                   	push   %ebp
d396ed
+   b:	55                   	push   %ebp
d396ed
+   c:	89 e5                	mov    %esp,%ebp
d396ed
+   e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  20:	ff e0                	jmp    \*%eax
d396ed
+  22:	3e 3e 55             	ds ds push %ebp
d396ed
+  25:	55                   	push   %ebp
d396ed
+  26:	64 a3 01 00 00 00    	mov    %eax,%fs:0x1
d396ed
+  2c:	89 e5                	mov    %esp,%ebp
d396ed
+  2e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  40:	ff d0                	call   \*%eax
d396ed
+  42:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  45:	55                   	push   %ebp
d396ed
+  46:	55                   	push   %ebp
d396ed
+  47:	64 a3 01 00 00 00    	mov    %eax,%fs:0x1
d396ed
+  4d:	89 e5                	mov    %esp,%ebp
d396ed
+  4f:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  52:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  55:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  58:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  5b:	e8 [0-9a-f ]+       	call   .*
d396ed
+  60:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  63:	55                   	push   %ebp
d396ed
+  64:	55                   	push   %ebp
d396ed
+  65:	55                   	push   %ebp
d396ed
+  66:	55                   	push   %ebp
d396ed
+  67:	64 a3 01 00 00 00    	mov    %eax,%fs:0x1
d396ed
+  6d:	89 e5                	mov    %esp,%ebp
d396ed
+  6f:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  72:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  75:	ff 15 00 00 00 00    	call   \*0x0
d396ed
+  7b:	55                   	push   %ebp
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-2c.d binutils.new/gas/testsuite/gas/i386/align-branch-2c.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-2c.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-2c.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,55 @@
d396ed
+#source: align-branch-2.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=indirect+call
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 64 64 a3 01 00 00 00 	fs fs mov %eax,%fs:0x1
d396ed
+   8:	55                   	push   %ebp
d396ed
+   9:	55                   	push   %ebp
d396ed
+   a:	55                   	push   %ebp
d396ed
+   b:	55                   	push   %ebp
d396ed
+   c:	89 e5                	mov    %esp,%ebp
d396ed
+   e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  20:	ff e0                	jmp    \*%eax
d396ed
+  22:	3e 3e 55             	ds ds push %ebp
d396ed
+  25:	55                   	push   %ebp
d396ed
+  26:	64 a3 01 00 00 00    	mov    %eax,%fs:0x1
d396ed
+  2c:	89 e5                	mov    %esp,%ebp
d396ed
+  2e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  40:	ff d0                	call   \*%eax
d396ed
+  42:	36 36 36 36 36 89 75 f4 	ss ss ss ss mov %esi,%ss:-0xc\(%ebp\)
d396ed
+  4a:	55                   	push   %ebp
d396ed
+  4b:	55                   	push   %ebp
d396ed
+  4c:	64 a3 01 00 00 00    	mov    %eax,%fs:0x1
d396ed
+  52:	89 e5                	mov    %esp,%ebp
d396ed
+  54:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  57:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  5a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  5d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  60:	e8 [0-9a-f ]+       	call   .*
d396ed
+  65:	36 36 36 36 36 89 75 f4 	ss ss ss ss mov %esi,%ss:-0xc\(%ebp\)
d396ed
+  6d:	3e 55                	ds push %ebp
d396ed
+  6f:	55                   	push   %ebp
d396ed
+  70:	55                   	push   %ebp
d396ed
+  71:	55                   	push   %ebp
d396ed
+  72:	64 a3 01 00 00 00    	mov    %eax,%fs:0x1
d396ed
+  78:	89 e5                	mov    %esp,%ebp
d396ed
+  7a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  7d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  80:	ff 15 00 00 00 00    	call   \*0x0
d396ed
+  86:	55                   	push   %ebp
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-2.s binutils.new/gas/testsuite/gas/i386/align-branch-2.s
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-2.s	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-2.s	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,49 @@
d396ed
+  .text
d396ed
+  .globl  foo
d396ed
+  .p2align  4
d396ed
+foo:
d396ed
+  movl  %eax, %fs:0x1
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  movl  %esp, %ebp
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  jmp  *%eax
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  movl  %eax, %fs:0x1
d396ed
+  movl  %esp, %ebp
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  call *%eax
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  movl  %eax, %fs:0x1
d396ed
+  movl  %esp, %ebp
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  call  foo
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  movl  %eax, %fs:0x1
d396ed
+  movl  %esp, %ebp
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  call  *foo
d396ed
+  pushl  %ebp
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-3.d binutils.new/gas/testsuite/gas/i386/align-branch-3.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-3.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-3.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,33 @@
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=indirect+call
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 a3 01 00 00 00    	mov    %eax,%fs:0x1
d396ed
+   6:	55                   	push   %ebp
d396ed
+   7:	55                   	push   %ebp
d396ed
+   8:	55                   	push   %ebp
d396ed
+   9:	55                   	push   %ebp
d396ed
+   a:	89 e5                	mov    %esp,%ebp
d396ed
+   c:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+   f:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  12:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  15:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  18:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1b:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1e:	e8 fc ff ff ff       	call   1f <foo\+0x1f>
d396ed
+  23:	55                   	push   %ebp
d396ed
+  24:	55                   	push   %ebp
d396ed
+  25:	64 a3 01 00 00 00    	mov    %eax,%fs:0x1
d396ed
+  2b:	89 e5                	mov    %esp,%ebp
d396ed
+  2d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  30:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  33:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  36:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  39:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3c:	ff 91 00 00 00 00    	call   \*0x0\(%ecx\)
d396ed
+  42:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-3.s binutils.new/gas/testsuite/gas/i386/align-branch-3.s
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-3.s	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-3.s	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,28 @@
d396ed
+  .text
d396ed
+  .globl  foo
d396ed
+  .p2align  4
d396ed
+foo:
d396ed
+  movl  %eax, %fs:0x1
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  movl  %esp, %ebp
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  call	___tls_get_addr
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  movl  %eax, %fs:0x1
d396ed
+  movl  %esp, %ebp
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  call *___tls_get_addr@GOT(%ecx)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-4a.d binutils.new/gas/testsuite/gas/i386/align-branch-4a.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-4a.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-4a.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,36 @@
d396ed
+#source: align-branch-4.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=fused+jcc+jmp
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 a3 01 00 00 00    	mov    %eax,%fs:0x1
d396ed
+   6:	55                   	push   %ebp
d396ed
+   7:	55                   	push   %ebp
d396ed
+   8:	55                   	push   %ebp
d396ed
+   9:	55                   	push   %ebp
d396ed
+   a:	55                   	push   %ebp
d396ed
+   b:	89 e5                	mov    %esp,%ebp
d396ed
+   d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  10:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  13:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  16:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  19:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1c:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1f:	c3                   	ret    
d396ed
+  20:	55                   	push   %ebp
d396ed
+  21:	55                   	push   %ebp
d396ed
+  22:	64 a3 01 00 00 00    	mov    %eax,%fs:0x1
d396ed
+  28:	89 e5                	mov    %esp,%ebp
d396ed
+  2a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  2d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  30:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  33:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  36:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  39:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3c:	c2 1e 00             	ret    \$0x1e
d396ed
+  3f:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-4b.d binutils.new/gas/testsuite/gas/i386/align-branch-4b.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-4b.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-4b.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,36 @@
d396ed
+#source: align-branch-4.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=ret
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 64 a3 01 00 00 00 	fs mov %eax,%fs:0x1
d396ed
+   7:	55                   	push   %ebp
d396ed
+   8:	55                   	push   %ebp
d396ed
+   9:	55                   	push   %ebp
d396ed
+   a:	55                   	push   %ebp
d396ed
+   b:	55                   	push   %ebp
d396ed
+   c:	89 e5                	mov    %esp,%ebp
d396ed
+   e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  1d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  20:	c3                   	ret    
d396ed
+  21:	3e 3e 3e 55          	ds ds ds push %ebp
d396ed
+  25:	55                   	push   %ebp
d396ed
+  26:	64 a3 01 00 00 00    	mov    %eax,%fs:0x1
d396ed
+  2c:	89 e5                	mov    %esp,%ebp
d396ed
+  2e:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3a:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  3d:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+  40:	c2 1e 00             	ret    \$0x1e
d396ed
+  43:	89 75 f4             	mov    %esi,-0xc\(%ebp\)
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-4.s binutils.new/gas/testsuite/gas/i386/align-branch-4.s
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-4.s	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-4.s	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,30 @@
d396ed
+  .text
d396ed
+  .globl  foo
d396ed
+  .p2align  4
d396ed
+foo:
d396ed
+  movl  %eax, %fs:0x1
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  movl  %esp, %ebp
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  ret
d396ed
+  pushl  %ebp
d396ed
+  pushl  %ebp
d396ed
+  movl  %eax, %fs:0x1
d396ed
+  movl  %esp, %ebp
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  movl  %esi, -12(%ebp)
d396ed
+  ret	$30
d396ed
+  movl  %esi, -12(%ebp)
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-5.d binutils.new/gas/testsuite/gas/i386/align-branch-5.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-5.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-5.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,36 @@
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=jcc+fused+jmp
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+   3:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+   6:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+   9:	89 d1                	mov    %edx,%ecx
d396ed
+   b:	31 c0                	xor    %eax,%eax
d396ed
+   d:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  10:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  13:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  16:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  19:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  1c:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  1f:	f6 c2 02             	test   \$0x2,%dl
d396ed
+  22:	f3 ab                	rep stos %eax,%es:\(%edi\)
d396ed
+  24:	75 dd                	jne    3 <foo\+0x3>
d396ed
+  26:	31 c0                	xor    %eax,%eax
d396ed
+  28:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  2b:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  2e:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  31:	89 d1                	mov    %edx,%ecx
d396ed
+  33:	31 c0                	xor    %eax,%eax
d396ed
+  35:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  38:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  3b:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  3e:	f6 c2 02             	test   \$0x2,%dl
d396ed
+  41:	e8 [0-9a-f ]+       	call   .*
d396ed
+  46:	75 e3                	jne    2b <foo\+0x2b>
d396ed
+  48:	31 c0                	xor    %eax,%eax
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/align-branch-5.s binutils.new/gas/testsuite/gas/i386/align-branch-5.s
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/align-branch-5.s	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/align-branch-5.s	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,32 @@
d396ed
+	.text
d396ed
+	.p2align 4,,15
d396ed
+foo:
d396ed
+	shrl	$2, %ecx
d396ed
+.L1:
d396ed
+	shrl	$2, %ecx
d396ed
+	shrl	$2, %ecx
d396ed
+	movl	%edx, %ecx
d396ed
+	xorl	%eax, %eax
d396ed
+	shrl	$2, %ecx
d396ed
+	shrl	$2, %ecx
d396ed
+	shrl	$2, %ecx
d396ed
+	shrl	$2, %ecx
d396ed
+	shrl	$2, %ecx
d396ed
+	shrl	$2, %ecx
d396ed
+	testb	$2, %dl
d396ed
+	rep stosl
d396ed
+	jne	.L1
d396ed
+	xorl	%eax, %eax
d396ed
+	shrl	$2, %ecx
d396ed
+.L2:
d396ed
+	shrl	$2, %ecx
d396ed
+	shrl	$2, %ecx
d396ed
+	movl	%edx, %ecx
d396ed
+	xorl	%eax, %eax
d396ed
+	shrl	$2, %ecx
d396ed
+	shrl	$2, %ecx
d396ed
+	shrl	$2, %ecx
d396ed
+	testb	$2, %dl
d396ed
+	call	bar
d396ed
+	jne	.L2
d396ed
+	xorl	%eax, %eax
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/i386.exp binutils.new/gas/testsuite/gas/i386/i386.exp
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/i386.exp	2019-01-19 16:01:33.000000000 +0000
d396ed
+++ binutils.new/gas/testsuite/gas/i386/i386.exp	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -472,6 +472,20 @@ if [expr ([istarget "i*86-*-*"] ||  [ist
d396ed
     run_dump_test "optimize-3"
d396ed
     run_dump_test "optimize-4"
d396ed
     run_dump_test "optimize-5"
d396ed
+    run_dump_test "align-branch-1a"
d396ed
+    run_dump_test "align-branch-1b"
d396ed
+    run_dump_test "align-branch-1c"
d396ed
+    run_dump_test "align-branch-1d"
d396ed
+    run_dump_test "align-branch-1e"
d396ed
+    run_dump_test "align-branch-1f"
d396ed
+    run_dump_test "align-branch-1g"
d396ed
+    run_dump_test "align-branch-1h"
d396ed
+    run_dump_test "align-branch-2a"
d396ed
+    run_dump_test "align-branch-2b"
d396ed
+    run_dump_test "align-branch-2c"
d396ed
+    run_dump_test "align-branch-4a"
d396ed
+    run_dump_test "align-branch-4b"
d396ed
+    run_dump_test "align-branch-5"
d396ed
 
d396ed
     # These tests require support for 8 and 16 bit relocs,
d396ed
     # so we only run them for ELF and COFF targets.
d396ed
@@ -543,6 +557,10 @@ if [expr ([istarget "i*86-*-*"] ||  [ist
d396ed
 	run_dump_test "evex-no-scale-32"
d396ed
 	run_dump_test "property-1"
d396ed
 
d396ed
+	if {[istarget "*-*-linux*"]} then {
d396ed
+	    run_dump_test "align-branch-3"
d396ed
+	}
d396ed
+
d396ed
 	if { [gas_64_check] } then {
d396ed
 	    run_dump_test "att-regs"
d396ed
 	    run_dump_test "intel-regs"
d396ed
@@ -982,6 +1000,20 @@ if [expr ([istarget "i*86-*-*"] || [ista
d396ed
     run_dump_test "x86-64-optimize-4"
d396ed
     run_dump_test "x86-64-optimize-5"
d396ed
     run_dump_test "x86-64-optimize-6"
d396ed
+    run_dump_test "x86-64-align-branch-1a"
d396ed
+    run_dump_test "x86-64-align-branch-1b"
d396ed
+    run_dump_test "x86-64-align-branch-1c"
d396ed
+    run_dump_test "x86-64-align-branch-1d"
d396ed
+    run_dump_test "x86-64-align-branch-1e"
d396ed
+    run_dump_test "x86-64-align-branch-1f"
d396ed
+    run_dump_test "x86-64-align-branch-1g"
d396ed
+    run_dump_test "x86-64-align-branch-1h"
d396ed
+    run_dump_test "x86-64-align-branch-2a"
d396ed
+    run_dump_test "x86-64-align-branch-2b"
d396ed
+    run_dump_test "x86-64-align-branch-2c"
d396ed
+    run_dump_test "x86-64-align-branch-4a"
d396ed
+    run_dump_test "x86-64-align-branch-4b"
d396ed
+    run_dump_test "x86-64-align-branch-5"
d396ed
 
d396ed
     if { ![istarget "*-*-aix*"]
d396ed
       && ![istarget "*-*-beos*"]
d396ed
@@ -1047,6 +1079,10 @@ if [expr ([istarget "i*86-*-*"] || [ista
d396ed
 
d396ed
 	run_dump_test "evex-no-scale-64"
d396ed
 	run_dump_test "x86-64-property-1"
d396ed
+
d396ed
+	if {[istarget "*-*-linux*"]} then {
d396ed
+	    run_dump_test "x86-64-align-branch-3"
d396ed
+	}
d396ed
     }
d396ed
 
d396ed
     set ASFLAGS "$old_ASFLAGS"
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1a.d binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1a.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1a.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1a.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,75 @@
d396ed
+#source: x86-64-align-branch-1.s
d396ed
+#as: -malign-branch-boundary=32
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 64 64 64 89 04 25 01 00 00 00 	fs fs fs mov %eax,%fs:0x1
d396ed
+   b:	55                   	push   %rbp
d396ed
+   c:	55                   	push   %rbp
d396ed
+   d:	55                   	push   %rbp
d396ed
+   e:	48 89 e5             	mov    %rsp,%rbp
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  20:	48 39 c5             	cmp    %rax,%rbp
d396ed
+  23:	74 5d                	je     82 <foo\+0x82>
d396ed
+  25:	2e 89 75 f4          	mov    %esi,%cs:-0xc\(%rbp\)
d396ed
+  29:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  2c:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  2f:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  32:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  35:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  38:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3e:	5d                   	pop    %rbp
d396ed
+  3f:	5d                   	pop    %rbp
d396ed
+  40:	74 40                	je     82 <foo\+0x82>
d396ed
+  42:	5d                   	pop    %rbp
d396ed
+  43:	74 3d                	je     82 <foo\+0x82>
d396ed
+  45:	2e 89 45 fc          	mov    %eax,%cs:-0x4\(%rbp\)
d396ed
+  49:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  4c:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  4f:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  52:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  55:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  58:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  5b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  5e:	5d                   	pop    %rbp
d396ed
+  5f:	5d                   	pop    %rbp
d396ed
+  60:	eb 26                	jmp    88 <foo\+0x88>
d396ed
+  62:	eb 24                	jmp    88 <foo\+0x88>
d396ed
+  64:	eb 22                	jmp    88 <foo\+0x88>
d396ed
+  66:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  69:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  6c:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  6f:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  72:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  75:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  78:	5d                   	pop    %rbp
d396ed
+  79:	5d                   	pop    %rbp
d396ed
+  7a:	48 39 c5             	cmp    %rax,%rbp
d396ed
+  7d:	74 03                	je     82 <foo\+0x82>
d396ed
+  7f:	90                   	nop
d396ed
+  80:	eb 06                	jmp    88 <foo\+0x88>
d396ed
+  82:	8b 45 f4             	mov    -0xc\(%rbp\),%eax
d396ed
+  85:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  88:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  8e:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  94:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  9a:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  a0:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  a6:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  ac:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  b2:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  b8:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  be:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  c4:	eb c2                	jmp    88 <foo\+0x88>
d396ed
+  c6:	5d                   	pop    %rbp
d396ed
+  c7:	c3                   	retq   
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1b.d binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1b.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1b.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1b.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,75 @@
d396ed
+#source: x86-64-align-branch-1.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=fused+jcc+jmp
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 64 64 64 89 04 25 01 00 00 00 	fs fs fs mov %eax,%fs:0x1
d396ed
+   b:	55                   	push   %rbp
d396ed
+   c:	55                   	push   %rbp
d396ed
+   d:	55                   	push   %rbp
d396ed
+   e:	48 89 e5             	mov    %rsp,%rbp
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  20:	48 39 c5             	cmp    %rax,%rbp
d396ed
+  23:	74 5d                	je     82 <foo\+0x82>
d396ed
+  25:	2e 89 75 f4          	mov    %esi,%cs:-0xc\(%rbp\)
d396ed
+  29:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  2c:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  2f:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  32:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  35:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  38:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3e:	5d                   	pop    %rbp
d396ed
+  3f:	5d                   	pop    %rbp
d396ed
+  40:	74 40                	je     82 <foo\+0x82>
d396ed
+  42:	5d                   	pop    %rbp
d396ed
+  43:	74 3d                	je     82 <foo\+0x82>
d396ed
+  45:	2e 89 45 fc          	mov    %eax,%cs:-0x4\(%rbp\)
d396ed
+  49:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  4c:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  4f:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  52:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  55:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  58:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  5b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  5e:	5d                   	pop    %rbp
d396ed
+  5f:	5d                   	pop    %rbp
d396ed
+  60:	eb 26                	jmp    88 <foo\+0x88>
d396ed
+  62:	eb 24                	jmp    88 <foo\+0x88>
d396ed
+  64:	eb 22                	jmp    88 <foo\+0x88>
d396ed
+  66:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  69:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  6c:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  6f:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  72:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  75:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  78:	5d                   	pop    %rbp
d396ed
+  79:	5d                   	pop    %rbp
d396ed
+  7a:	48 39 c5             	cmp    %rax,%rbp
d396ed
+  7d:	74 03                	je     82 <foo\+0x82>
d396ed
+  7f:	90                   	nop
d396ed
+  80:	eb 06                	jmp    88 <foo\+0x88>
d396ed
+  82:	8b 45 f4             	mov    -0xc\(%rbp\),%eax
d396ed
+  85:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  88:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  8e:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  94:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  9a:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  a0:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  a6:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  ac:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  b2:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  b8:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  be:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  c4:	eb c2                	jmp    88 <foo\+0x88>
d396ed
+  c6:	5d                   	pop    %rbp
d396ed
+  c7:	c3                   	retq   
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1c.d binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1c.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1c.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1c.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,75 @@
d396ed
+#source: x86-64-align-branch-1.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch-prefix-size=1
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+   8:	2e 55                	cs push %rbp
d396ed
+   a:	2e 55                	cs push %rbp
d396ed
+   c:	2e 55                	cs push %rbp
d396ed
+   e:	48 89 e5             	mov    %rsp,%rbp
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  20:	48 39 c5             	cmp    %rax,%rbp
d396ed
+  23:	74 5d                	je     82 <foo\+0x82>
d396ed
+  25:	2e 89 75 f4          	mov    %esi,%cs:-0xc\(%rbp\)
d396ed
+  29:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  2c:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  2f:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  32:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  35:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  38:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3e:	5d                   	pop    %rbp
d396ed
+  3f:	5d                   	pop    %rbp
d396ed
+  40:	74 40                	je     82 <foo\+0x82>
d396ed
+  42:	5d                   	pop    %rbp
d396ed
+  43:	74 3d                	je     82 <foo\+0x82>
d396ed
+  45:	2e 89 45 fc          	mov    %eax,%cs:-0x4\(%rbp\)
d396ed
+  49:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  4c:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  4f:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  52:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  55:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  58:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  5b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  5e:	5d                   	pop    %rbp
d396ed
+  5f:	5d                   	pop    %rbp
d396ed
+  60:	eb 26                	jmp    88 <foo\+0x88>
d396ed
+  62:	eb 24                	jmp    88 <foo\+0x88>
d396ed
+  64:	eb 22                	jmp    88 <foo\+0x88>
d396ed
+  66:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  69:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  6c:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  6f:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  72:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  75:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  78:	5d                   	pop    %rbp
d396ed
+  79:	5d                   	pop    %rbp
d396ed
+  7a:	48 39 c5             	cmp    %rax,%rbp
d396ed
+  7d:	74 03                	je     82 <foo\+0x82>
d396ed
+  7f:	90                   	nop
d396ed
+  80:	eb 06                	jmp    88 <foo\+0x88>
d396ed
+  82:	8b 45 f4             	mov    -0xc\(%rbp\),%eax
d396ed
+  85:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  88:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  8e:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  94:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  9a:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  a0:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  a6:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  ac:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  b2:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  b8:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  be:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  c4:	eb c2                	jmp    88 <foo\+0x88>
d396ed
+  c6:	5d                   	pop    %rbp
d396ed
+  c7:	c3                   	retq   
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1d.d binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1d.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1d.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1d.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,74 @@
d396ed
+#source: x86-64-align-branch-1.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=fused+jcc
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 64 64 64 89 04 25 01 00 00 00 	fs fs fs mov %eax,%fs:0x1
d396ed
+   b:	55                   	push   %rbp
d396ed
+   c:	55                   	push   %rbp
d396ed
+   d:	55                   	push   %rbp
d396ed
+   e:	48 89 e5             	mov    %rsp,%rbp
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  20:	48 39 c5             	cmp    %rax,%rbp
d396ed
+  23:	74 5b                	je     80 <foo\+0x80>
d396ed
+  25:	2e 89 75 f4          	mov    %esi,%cs:-0xc\(%rbp\)
d396ed
+  29:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  2c:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  2f:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  32:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  35:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  38:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3e:	5d                   	pop    %rbp
d396ed
+  3f:	5d                   	pop    %rbp
d396ed
+  40:	74 3e                	je     80 <foo\+0x80>
d396ed
+  42:	5d                   	pop    %rbp
d396ed
+  43:	74 3b                	je     80 <foo\+0x80>
d396ed
+  45:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  48:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  4b:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  4e:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  51:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  54:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  57:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  5a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  5d:	5d                   	pop    %rbp
d396ed
+  5e:	5d                   	pop    %rbp
d396ed
+  5f:	eb 25                	jmp    86 <foo\+0x86>
d396ed
+  61:	eb 23                	jmp    86 <foo\+0x86>
d396ed
+  63:	eb 21                	jmp    86 <foo\+0x86>
d396ed
+  65:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  68:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  6b:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  6e:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  71:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  74:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  77:	5d                   	pop    %rbp
d396ed
+  78:	5d                   	pop    %rbp
d396ed
+  79:	48 39 c5             	cmp    %rax,%rbp
d396ed
+  7c:	74 02                	je     80 <foo\+0x80>
d396ed
+  7e:	eb 06                	jmp    86 <foo\+0x86>
d396ed
+  80:	8b 45 f4             	mov    -0xc\(%rbp\),%eax
d396ed
+  83:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  86:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  8c:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  92:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  98:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  9e:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  a4:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  aa:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  b0:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  b6:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  bc:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  c2:	eb c2                	jmp    86 <foo\+0x86>
d396ed
+  c4:	5d                   	pop    %rbp
d396ed
+  c5:	c3                   	retq   
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1e.d binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1e.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1e.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1e.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,74 @@
d396ed
+#source: x86-64-align-branch-1.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=jcc
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+   8:	55                   	push   %rbp
d396ed
+   9:	55                   	push   %rbp
d396ed
+   a:	55                   	push   %rbp
d396ed
+   b:	48 89 e5             	mov    %rsp,%rbp
d396ed
+   e:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1d:	48 39 c5             	cmp    %rax,%rbp
d396ed
+  20:	74 5b                	je     7d <foo\+0x7d>
d396ed
+  22:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  25:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  28:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  2b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  2e:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3a:	5d                   	pop    %rbp
d396ed
+  3b:	5d                   	pop    %rbp
d396ed
+  3c:	74 3f                	je     7d <foo\+0x7d>
d396ed
+  3e:	2e 5d                	cs pop %rbp
d396ed
+  40:	74 3b                	je     7d <foo\+0x7d>
d396ed
+  42:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  45:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  48:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  4b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  4e:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  51:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  54:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  57:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  5a:	5d                   	pop    %rbp
d396ed
+  5b:	5d                   	pop    %rbp
d396ed
+  5c:	eb 25                	jmp    83 <foo\+0x83>
d396ed
+  5e:	eb 23                	jmp    83 <foo\+0x83>
d396ed
+  60:	eb 21                	jmp    83 <foo\+0x83>
d396ed
+  62:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  65:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  68:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  6b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  6e:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  71:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  74:	5d                   	pop    %rbp
d396ed
+  75:	5d                   	pop    %rbp
d396ed
+  76:	48 39 c5             	cmp    %rax,%rbp
d396ed
+  79:	74 02                	je     7d <foo\+0x7d>
d396ed
+  7b:	eb 06                	jmp    83 <foo\+0x83>
d396ed
+  7d:	8b 45 f4             	mov    -0xc\(%rbp\),%eax
d396ed
+  80:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  83:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  89:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  8f:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  95:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  9b:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  a1:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  a7:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  ad:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  b3:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  b9:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  bf:	eb c2                	jmp    83 <foo\+0x83>
d396ed
+  c1:	5d                   	pop    %rbp
d396ed
+  c2:	c3                   	retq   
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1f.d binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1f.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1f.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1f.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,75 @@
d396ed
+#source: x86-64-align-branch-1.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=jcc+jmp
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+   8:	55                   	push   %rbp
d396ed
+   9:	55                   	push   %rbp
d396ed
+   a:	55                   	push   %rbp
d396ed
+   b:	48 89 e5             	mov    %rsp,%rbp
d396ed
+   e:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1d:	48 39 c5             	cmp    %rax,%rbp
d396ed
+  20:	74 5d                	je     7f <foo\+0x7f>
d396ed
+  22:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  25:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  28:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  2b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  2e:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3a:	5d                   	pop    %rbp
d396ed
+  3b:	5d                   	pop    %rbp
d396ed
+  3c:	74 41                	je     7f <foo\+0x7f>
d396ed
+  3e:	2e 5d                	cs pop %rbp
d396ed
+  40:	74 3d                	je     7f <foo\+0x7f>
d396ed
+  42:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  45:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  48:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  4b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  4e:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  51:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  54:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  57:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  5a:	5d                   	pop    %rbp
d396ed
+  5b:	5d                   	pop    %rbp
d396ed
+  5c:	eb 27                	jmp    85 <foo\+0x85>
d396ed
+  5e:	66 90                	xchg   %ax,%ax
d396ed
+  60:	eb 23                	jmp    85 <foo\+0x85>
d396ed
+  62:	eb 21                	jmp    85 <foo\+0x85>
d396ed
+  64:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  67:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  6a:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  6d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  70:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  73:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  76:	5d                   	pop    %rbp
d396ed
+  77:	5d                   	pop    %rbp
d396ed
+  78:	48 39 c5             	cmp    %rax,%rbp
d396ed
+  7b:	74 02                	je     7f <foo\+0x7f>
d396ed
+  7d:	eb 06                	jmp    85 <foo\+0x85>
d396ed
+  7f:	8b 45 f4             	mov    -0xc\(%rbp\),%eax
d396ed
+  82:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  85:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  8b:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  91:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  97:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  9d:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  a3:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  a9:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  af:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  b5:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  bb:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  c1:	eb c2                	jmp    85 <foo\+0x85>
d396ed
+  c3:	5d                   	pop    %rbp
d396ed
+  c4:	c3                   	retq   
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1g.d binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1g.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1g.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1g.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,75 @@
d396ed
+#source: x86-64-align-branch-1.s
d396ed
+#as: -mbranches-within-32B-boundaries
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 64 64 64 89 04 25 01 00 00 00 	fs fs fs mov %eax,%fs:0x1
d396ed
+   b:	55                   	push   %rbp
d396ed
+   c:	55                   	push   %rbp
d396ed
+   d:	55                   	push   %rbp
d396ed
+   e:	48 89 e5             	mov    %rsp,%rbp
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  20:	48 39 c5             	cmp    %rax,%rbp
d396ed
+  23:	74 5d                	je     82 <foo\+0x82>
d396ed
+  25:	2e 89 75 f4          	mov    %esi,%cs:-0xc\(%rbp\)
d396ed
+  29:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  2c:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  2f:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  32:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  35:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  38:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3e:	5d                   	pop    %rbp
d396ed
+  3f:	5d                   	pop    %rbp
d396ed
+  40:	74 40                	je     82 <foo\+0x82>
d396ed
+  42:	5d                   	pop    %rbp
d396ed
+  43:	74 3d                	je     82 <foo\+0x82>
d396ed
+  45:	2e 89 45 fc          	mov    %eax,%cs:-0x4\(%rbp\)
d396ed
+  49:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  4c:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  4f:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  52:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  55:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  58:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  5b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  5e:	5d                   	pop    %rbp
d396ed
+  5f:	5d                   	pop    %rbp
d396ed
+  60:	eb 26                	jmp    88 <foo\+0x88>
d396ed
+  62:	eb 24                	jmp    88 <foo\+0x88>
d396ed
+  64:	eb 22                	jmp    88 <foo\+0x88>
d396ed
+  66:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  69:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  6c:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  6f:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  72:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  75:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  78:	5d                   	pop    %rbp
d396ed
+  79:	5d                   	pop    %rbp
d396ed
+  7a:	48 39 c5             	cmp    %rax,%rbp
d396ed
+  7d:	74 03                	je     82 <foo\+0x82>
d396ed
+  7f:	90                   	nop
d396ed
+  80:	eb 06                	jmp    88 <foo\+0x88>
d396ed
+  82:	8b 45 f4             	mov    -0xc\(%rbp\),%eax
d396ed
+  85:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  88:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  8e:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  94:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  9a:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  a0:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  a6:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  ac:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  b2:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  b8:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  be:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  c4:	eb c2                	jmp    88 <foo\+0x88>
d396ed
+  c6:	5d                   	pop    %rbp
d396ed
+  c7:	c3                   	retq   
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1h.d binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1h.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1h.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1h.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,74 @@
d396ed
+#source: x86-64-align-branch-1.s
d396ed
+#as: -mbranches-within-32B-boundaries -malign-branch-boundary=0
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+   8:	55                   	push   %rbp
d396ed
+   9:	55                   	push   %rbp
d396ed
+   a:	55                   	push   %rbp
d396ed
+   b:	48 89 e5             	mov    %rsp,%rbp
d396ed
+   e:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1d:	48 39 c5             	cmp    %rax,%rbp
d396ed
+  20:	74 5a                	je     7c <foo\+0x7c>
d396ed
+  22:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  25:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  28:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  2b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  2e:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3a:	5d                   	pop    %rbp
d396ed
+  3b:	5d                   	pop    %rbp
d396ed
+  3c:	74 3e                	je     7c <foo\+0x7c>
d396ed
+  3e:	5d                   	pop    %rbp
d396ed
+  3f:	74 3b                	je     7c <foo\+0x7c>
d396ed
+  41:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  44:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  47:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  4a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  4d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  50:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  53:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  56:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  59:	5d                   	pop    %rbp
d396ed
+  5a:	5d                   	pop    %rbp
d396ed
+  5b:	eb 25                	jmp    82 <foo\+0x82>
d396ed
+  5d:	eb 23                	jmp    82 <foo\+0x82>
d396ed
+  5f:	eb 21                	jmp    82 <foo\+0x82>
d396ed
+  61:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  64:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  67:	89 7d f8             	mov    %edi,-0x8\(%rbp\)
d396ed
+  6a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  6d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  70:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  73:	5d                   	pop    %rbp
d396ed
+  74:	5d                   	pop    %rbp
d396ed
+  75:	48 39 c5             	cmp    %rax,%rbp
d396ed
+  78:	74 02                	je     7c <foo\+0x7c>
d396ed
+  7a:	eb 06                	jmp    82 <foo\+0x82>
d396ed
+  7c:	8b 45 f4             	mov    -0xc\(%rbp\),%eax
d396ed
+  7f:	89 45 fc             	mov    %eax,-0x4\(%rbp\)
d396ed
+  82:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  88:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  8e:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  94:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  9a:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  a0:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  a6:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  ac:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  b2:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  b8:	89 b5 50 fb ff ff    	mov    %esi,-0x4b0\(%rbp\)
d396ed
+  be:	eb c2                	jmp    82 <foo\+0x82>
d396ed
+  c0:	5d                   	pop    %rbp
d396ed
+  c1:	c3                   	retq   
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1.s binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1.s
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-1.s	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-1.s	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,70 @@
d396ed
+  .text
d396ed
+  .globl  foo
d396ed
+  .p2align  4
d396ed
+foo:
d396ed
+  movl  %eax, %fs:0x1
d396ed
+  pushq  %rbp
d396ed
+  pushq  %rbp
d396ed
+  pushq  %rbp
d396ed
+  movq  %rsp, %rbp
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  cmp  %rax, %rbp
d396ed
+  je  .L_2
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %edi, -8(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  popq  %rbp
d396ed
+  popq  %rbp
d396ed
+  je  .L_2
d396ed
+  popq  %rbp
d396ed
+  je  .L_2
d396ed
+  movl  %eax, -4(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %edi, -8(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  popq  %rbp
d396ed
+  popq  %rbp
d396ed
+  jmp  .L_3
d396ed
+  jmp  .L_3
d396ed
+  jmp  .L_3
d396ed
+  movl  %eax, -4(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %edi, -8(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  popq  %rbp
d396ed
+  popq  %rbp
d396ed
+  cmp  %rax, %rbp
d396ed
+  je  .L_2
d396ed
+  jmp  .L_3
d396ed
+.L_2:
d396ed
+  movl  -12(%rbp), %eax
d396ed
+  movl  %eax, -4(%rbp)
d396ed
+.L_3:
d396ed
+  movl  %esi, -1200(%rbp)
d396ed
+  movl  %esi, -1200(%rbp)
d396ed
+  movl  %esi, -1200(%rbp)
d396ed
+  movl  %esi, -1200(%rbp)
d396ed
+  movl  %esi, -1200(%rbp)
d396ed
+  movl  %esi, -1200(%rbp)
d396ed
+  movl  %esi, -1200(%rbp)
d396ed
+  movl  %esi, -1200(%rbp)
d396ed
+  movl  %esi, -1200(%rbp)
d396ed
+  movl  %esi, -1200(%rbp)
d396ed
+  jmp  .L_3
d396ed
+  popq  %rbp
d396ed
+  retq
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-2a.d binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-2a.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-2a.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-2a.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,50 @@
d396ed
+#source: x86-64-align-branch-2.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=fused+jcc+jmp
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+   8:	55                   	push   %rbp
d396ed
+   9:	55                   	push   %rbp
d396ed
+   a:	55                   	push   %rbp
d396ed
+   b:	55                   	push   %rbp
d396ed
+   c:	48 89 e5             	mov    %rsp,%rbp
d396ed
+   f:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  12:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  15:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  18:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1e:	ff e0                	jmpq   \*%rax
d396ed
+  20:	55                   	push   %rbp
d396ed
+  21:	55                   	push   %rbp
d396ed
+  22:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+  2a:	48 89 e5             	mov    %rsp,%rbp
d396ed
+  2d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  30:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  33:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  36:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  39:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3c:	ff d0                	callq  \*%rax
d396ed
+  3e:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  41:	55                   	push   %rbp
d396ed
+  42:	55                   	push   %rbp
d396ed
+  43:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+  4b:	48 89 e5             	mov    %rsp,%rbp
d396ed
+  4e:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  51:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  54:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  57:	e8 [0-9a-f ]+       	callq  .*
d396ed
+  5c:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  5f:	55                   	push   %rbp
d396ed
+  60:	55                   	push   %rbp
d396ed
+  61:	55                   	push   %rbp
d396ed
+  62:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+  6a:	48 89 e5             	mov    %rsp,%rbp
d396ed
+  6d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  70:	ff 14 25 00 00 00 00 	callq  \*0x0
d396ed
+  77:	55                   	push   %rbp
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-2b.d binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-2b.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-2b.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-2b.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,50 @@
d396ed
+#source: x86-64-align-branch-2.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=indirect
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 64 64 89 04 25 01 00 00 00 	fs fs mov %eax,%fs:0x1
d396ed
+   a:	55                   	push   %rbp
d396ed
+   b:	55                   	push   %rbp
d396ed
+   c:	55                   	push   %rbp
d396ed
+   d:	55                   	push   %rbp
d396ed
+   e:	48 89 e5             	mov    %rsp,%rbp
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  20:	ff e0                	jmpq   \*%rax
d396ed
+  22:	2e 2e 55             	cs cs push %rbp
d396ed
+  25:	55                   	push   %rbp
d396ed
+  26:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+  2e:	48 89 e5             	mov    %rsp,%rbp
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  40:	ff d0                	callq  \*%rax
d396ed
+  42:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  45:	55                   	push   %rbp
d396ed
+  46:	55                   	push   %rbp
d396ed
+  47:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+  4f:	48 89 e5             	mov    %rsp,%rbp
d396ed
+  52:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  55:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  58:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  5b:	e8 [0-9a-f ]+       	callq  .*
d396ed
+  60:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  63:	55                   	push   %rbp
d396ed
+  64:	55                   	push   %rbp
d396ed
+  65:	55                   	push   %rbp
d396ed
+  66:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+  6e:	48 89 e5             	mov    %rsp,%rbp
d396ed
+  71:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  74:	ff 14 25 00 00 00 00 	callq  \*0x0
d396ed
+  7b:	55                   	push   %rbp
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-2c.d binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-2c.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-2c.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-2c.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,50 @@
d396ed
+#source: x86-64-align-branch-2.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=indirect+call
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 64 64 89 04 25 01 00 00 00 	fs fs mov %eax,%fs:0x1
d396ed
+   a:	55                   	push   %rbp
d396ed
+   b:	55                   	push   %rbp
d396ed
+   c:	55                   	push   %rbp
d396ed
+   d:	55                   	push   %rbp
d396ed
+   e:	48 89 e5             	mov    %rsp,%rbp
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  20:	ff e0                	jmpq   \*%rax
d396ed
+  22:	2e 2e 55             	cs cs push %rbp
d396ed
+  25:	55                   	push   %rbp
d396ed
+  26:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+  2e:	48 89 e5             	mov    %rsp,%rbp
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  40:	ff d0                	callq  \*%rax
d396ed
+  42:	2e 2e 2e 2e 2e 89 75 f4 	cs cs cs cs mov %esi,%cs:-0xc\(%rbp\)
d396ed
+  4a:	55                   	push   %rbp
d396ed
+  4b:	55                   	push   %rbp
d396ed
+  4c:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+  54:	48 89 e5             	mov    %rsp,%rbp
d396ed
+  57:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  5a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  5d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  60:	e8 [0-9a-f ]+       	callq  .*
d396ed
+  65:	2e 2e 2e 2e 2e 89 75 f4 	cs cs cs cs mov %esi,%cs:-0xc\(%rbp\)
d396ed
+  6d:	2e 2e 55             	cs cs push %rbp
d396ed
+  70:	55                   	push   %rbp
d396ed
+  71:	55                   	push   %rbp
d396ed
+  72:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+  7a:	48 89 e5             	mov    %rsp,%rbp
d396ed
+  7d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  80:	ff 14 25 00 00 00 00 	callq  \*0x0
d396ed
+  87:	55                   	push   %rbp
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-2.s binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-2.s
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-2.s	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-2.s	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,44 @@
d396ed
+  .text
d396ed
+  .globl  foo
d396ed
+  .p2align  4
d396ed
+foo:
d396ed
+  movl  %eax, %fs:0x1
d396ed
+  pushq  %rbp
d396ed
+  pushq  %rbp
d396ed
+  pushq  %rbp
d396ed
+  pushq  %rbp
d396ed
+  movq  %rsp, %rbp
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  jmp  *%rax
d396ed
+  pushq  %rbp
d396ed
+  pushq  %rbp
d396ed
+  movl  %eax, %fs:0x1
d396ed
+  movq  %rsp, %rbp
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  call *%rax
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  pushq  %rbp
d396ed
+  pushq  %rbp
d396ed
+  movl  %eax, %fs:0x1
d396ed
+  movq  %rsp, %rbp
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  call  foo
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  pushq  %rbp
d396ed
+  pushq  %rbp
d396ed
+  pushq  %rbp
d396ed
+  movl  %eax, %fs:0x1
d396ed
+  movq  %rsp, %rbp
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  call  *foo
d396ed
+  pushq  %rbp
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-3.d binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-3.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-3.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-3.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,32 @@
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=indirect+call
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+   8:	55                   	push   %rbp
d396ed
+   9:	55                   	push   %rbp
d396ed
+   a:	55                   	push   %rbp
d396ed
+   b:	55                   	push   %rbp
d396ed
+   c:	48 89 e5             	mov    %rsp,%rbp
d396ed
+   f:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  12:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  15:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  18:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1e:	e8 00 00 00 00       	callq  23 <foo\+0x23>
d396ed
+  23:	55                   	push   %rbp
d396ed
+  24:	55                   	push   %rbp
d396ed
+  25:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+  2d:	48 89 e5             	mov    %rsp,%rbp
d396ed
+  30:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  33:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  36:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  39:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3c:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3f:	ff 15 00 00 00 00    	callq  \*0x0\(%rip\)        # 45 <foo\+0x45>
d396ed
+  45:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-3.s binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-3.s
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-3.s	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-3.s	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,27 @@
d396ed
+  .text
d396ed
+  .globl  foo
d396ed
+  .p2align  4
d396ed
+foo:
d396ed
+  movl  %eax, %fs:0x1
d396ed
+  pushq  %rbp
d396ed
+  pushq  %rbp
d396ed
+  pushq  %rbp
d396ed
+  pushq  %rbp
d396ed
+  movq  %rsp, %rbp
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  call	__tls_get_addr
d396ed
+  pushq  %rbp
d396ed
+  pushq  %rbp
d396ed
+  movl  %eax, %fs:0x1
d396ed
+  movq  %rsp, %rbp
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  call	*__tls_get_addr@GOTPCREL(%rip)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-4a.d binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-4a.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-4a.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-4a.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,33 @@
d396ed
+#source: x86-64-align-branch-4.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=fused+jcc+jmp
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+   8:	55                   	push   %rbp
d396ed
+   9:	55                   	push   %rbp
d396ed
+   a:	48 89 e5             	mov    %rsp,%rbp
d396ed
+   d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  10:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  13:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  16:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  19:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1c:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1f:	c3                   	retq   
d396ed
+  20:	55                   	push   %rbp
d396ed
+  21:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+  29:	55                   	push   %rbp
d396ed
+  2a:	55                   	push   %rbp
d396ed
+  2b:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  2e:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3d:	c2 1e 00             	retq   \$0x1e
d396ed
+  40:	55                   	push   %rbp
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-4b.d binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-4b.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-4b.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-4b.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,33 @@
d396ed
+#source: x86-64-align-branch-4.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=ret
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	64 64 89 04 25 01 00 00 00 	fs mov %eax,%fs:0x1
d396ed
+   9:	55                   	push   %rbp
d396ed
+   a:	55                   	push   %rbp
d396ed
+   b:	48 89 e5             	mov    %rsp,%rbp
d396ed
+   e:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  11:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  14:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  17:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  1d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  20:	c3                   	retq   
d396ed
+  21:	2e 2e 55             	cs cs push %rbp
d396ed
+  24:	64 89 04 25 01 00 00 00 	mov    %eax,%fs:0x1
d396ed
+  2c:	55                   	push   %rbp
d396ed
+  2d:	55                   	push   %rbp
d396ed
+  2e:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  31:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  34:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  37:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3a:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  3d:	89 75 f4             	mov    %esi,-0xc\(%rbp\)
d396ed
+  40:	c2 1e 00             	retq   \$0x1e
d396ed
+  43:	55                   	push   %rbp
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-4.s binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-4.s
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-4.s	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-4.s	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,27 @@
d396ed
+  .text
d396ed
+  .globl  foo
d396ed
+  .p2align  4
d396ed
+foo:
d396ed
+  movl  %eax, %fs:0x1
d396ed
+  pushq  %rbp
d396ed
+  pushq  %rbp
d396ed
+  movq  %rsp, %rbp
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  ret
d396ed
+  pushq  %rbp
d396ed
+  movl  %eax, %fs:0x1
d396ed
+  pushq  %rbp
d396ed
+  pushq  %rbp
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  movl  %esi, -12(%rbp)
d396ed
+  ret $30
d396ed
+  pushq  %rbp
d396ed
diff -rupN binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-5.d binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-5.d
d396ed
--- binutils-2.32/gas/testsuite/gas/i386/x86-64-align-branch-5.d	1970-01-01 01:00:00.000000000 +0100
d396ed
+++ binutils.new/gas/testsuite/gas/i386/x86-64-align-branch-5.d	2019-11-25 14:01:00.680325567 +0000
d396ed
@@ -0,0 +1,37 @@
d396ed
+#source: align-branch-5.s
d396ed
+#as: -malign-branch-boundary=32 -malign-branch=jcc+fused+jmp
d396ed
+#objdump: -dw
d396ed
+
d396ed
+.*: +file format .*
d396ed
+
d396ed
+Disassembly of section .text:
d396ed
+
d396ed
+0+ <foo>:
d396ed
+   0:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+   3:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+   6:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+   9:	89 d1                	mov    %edx,%ecx
d396ed
+   b:	31 c0                	xor    %eax,%eax
d396ed
+   d:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  10:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  13:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  16:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  19:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  1c:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  1f:	f6 c2 02             	test   \$0x2,%dl
d396ed
+  22:	f3 ab                	rep stos %eax,%es:\(%rdi\)
d396ed
+  24:	75 dd                	jne    3 <foo\+0x3>
d396ed
+  26:	31 c0                	xor    %eax,%eax
d396ed
+  28:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  2b:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  2e:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  31:	89 d1                	mov    %edx,%ecx
d396ed
+  33:	31 c0                	xor    %eax,%eax
d396ed
+  35:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  38:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  3b:	c1 e9 02             	shr    \$0x2,%ecx
d396ed
+  3e:	f6 c2 02             	test   \$0x2,%dl
d396ed
+  41:	e8 00 00 00 00       	callq  46 <foo\+0x46>
d396ed
+  46:	75 e3                	jne    2b <foo\+0x2b>
d396ed
+  48:	31 c0                	xor    %eax,%eax
d396ed
+#pass
d396ed
diff -rupN binutils-2.32/gas/write.c binutils.new/gas/write.c
d396ed
--- binutils-2.32/gas/write.c	2019-11-25 14:01:09.888265017 +0000
d396ed
+++ binutils.new/gas/write.c	2019-11-25 14:01:00.901324114 +0000
d396ed
@@ -3031,7 +3031,12 @@ relax_segment (struct frag *segment_frag
d396ed
 #ifdef TC_GENERIC_RELAX_TABLE
d396ed
 		/* The default way to relax a frag is to look through
d396ed
 		   TC_GENERIC_RELAX_TABLE.  */
d396ed
+#ifdef md_generic_table_relax_frag
d396ed
+		growth = md_generic_table_relax_frag (segment, fragP,
d396ed
+						      stretch);
d396ed
+#else
d396ed
 		growth = relax_frag (segment, fragP, stretch);
d396ed
+#endif /* md_generic_table_relax_frag */
d396ed
 #endif /* TC_GENERIC_RELAX_TABLE  */
d396ed
 #endif
d396ed
 		break;