Blame SOURCES/binutils-x86-gas-scaled-8-bit-displacements.patch

3c8e67
--- binutils.orig/gas/config/tc-i386.c	2020-08-21 10:21:00.595678097 +0100
3c8e67
+++ binutils-2.30/gas/config/tc-i386.c	2020-08-21 10:22:15.009449340 +0100
3c8e67
@@ -8035,7 +8035,8 @@ output_disp (fragS *insn_start_frag, off
3c8e67
 	      int size = disp_size (n);
3c8e67
 	      offsetT val = i.op[n].disps->X_add_number;
3c8e67
 
3c8e67
-	      val = offset_in_range (val >> i.memshift, size);
3c8e67
+	      val = offset_in_range (val >> (size == 1 ? i.memshift : 0),
3c8e67
+				     size);
3c8e67
 	      p = frag_more (size);
3c8e67
 	      md_number_to_chars (p, val, size);
3c8e67
 	    }
3c8e67
--- binutils.orig/gas/testsuite/gas/i386/i386.exp	2020-08-21 10:21:00.669677873 +0100
3c8e67
+++ binutils-2.30/gas/testsuite/gas/i386/i386.exp	2020-08-21 10:39:22.921167674 +0100
3c8e67
@@ -216,6 +216,7 @@ if [expr ([istarget "i*86-*-*"] ||  [ist
3c8e67
     run_dump_test "evex-lig512-intel"
3c8e67
     run_dump_test "evex-wig1"
3c8e67
     run_dump_test "evex-wig1-intel"
3c8e67
+    run_dump_test "evex-no-scale-32"
3c8e67
     run_dump_test "sse2avx"
3c8e67
     run_list_test "inval-avx" "-al"
3c8e67
     run_list_test "inval-avx512f" "-al"
3c8e67
@@ -692,6 +693,7 @@ if [expr ([istarget "i*86-*-*"] || [ista
3c8e67
     run_dump_test "x86-64-avx256int-intel"
3c8e67
     run_dump_test "x86-64-avx2"
3c8e67
     run_dump_test "x86-64-avx2-intel"
3c8e67
+    run_dump_test "evex-no-scale-64"
3c8e67
     run_dump_test "x86-64-avx-gather"
3c8e67
     run_dump_test "x86-64-avx-gather-intel"
3c8e67
     run_dump_test "x86-64-avx512f"
3c8e67
--- /dev/null	2020-08-21 07:54:54.335936348 +0100
3c8e67
+++ binutils-2.30/gas/testsuite/gas/i386/evex-no-scale.s	2020-08-21 10:41:30.411757740 +0100
3c8e67
@@ -0,0 +1,18 @@
3c8e67
+	.allow_index_reg
3c8e67
+	.struct
3c8e67
+	inc	%eax
3c8e67
+.equiv is_64bit, . > 1
3c8e67
+
3c8e67
+	.text
3c8e67
+disp:
3c8e67
+.if is_64bit
3c8e67
+	vmovaps	-1024(%rip), %zmm0
3c8e67
+	vmovaps	64(,%rax), %zmm0
3c8e67
+	vmovaps	64(,%riz), %zmm0
3c8e67
+.endif
3c8e67
+	vmovaps	64(,%eax), %zmm0
3c8e67
+	vmovaps	64(,%eiz), %zmm0
3c8e67
+	vmovaps	64, %zmm0
3c8e67
+.if !is_64bit
3c8e67
+	addr16 vmovaps 64, %zmm0
3c8e67
+.endif
3c8e67
--- /dev/null	2020-08-21 07:54:54.335936348 +0100
3c8e67
+++ binutils-2.30/gas/testsuite/gas/i386/evex-no-scale-32.d	2020-08-21 10:41:37.347735430 +0100
3c8e67
@@ -0,0 +1,14 @@
3c8e67
+#source: evex-no-scale.s
3c8e67
+#objdump: -dw
3c8e67
+#name: ix86 EVEX no disp scaling
3c8e67
+
3c8e67
+.*: +file format .*
3c8e67
+
3c8e67
+Disassembly of section .text:
3c8e67
+
3c8e67
+0+ <disp>:
3c8e67
+ +[a-f0-9]+:	62 f1 7c 48 28 04 05 40 00 00 00 	vmovaps 0x40\(,%eax,1\),%zmm0
3c8e67
+ +[a-f0-9]+:	62 f1 7c 48 28 04 25 40 00 00 00 	vmovaps 0x40\(,%eiz,1\),%zmm0
3c8e67
+ +[a-f0-9]+:	62 f1 7c 48 28 05 40 00 00 00 	vmovaps 0x40,%zmm0
3c8e67
+ +[a-f0-9]+:	67 62 f1 7c 48 28 06 40 00 	vmovaps 0x40,%zmm0
3c8e67
+#pass
3c8e67
--- /dev/null	2020-08-21 07:54:54.335936348 +0100
3c8e67
+++ binutils-2.30/gas/testsuite/gas/i386/evex-no-scale-64.d	2020-08-21 10:41:42.539718727 +0100
3c8e67
@@ -0,0 +1,16 @@
3c8e67
+#source: evex-no-scale.s
3c8e67
+#objdump: -dw
3c8e67
+#name: x86-64 EVEX no disp scaling
3c8e67
+
3c8e67
+.*: +file format .*
3c8e67
+
3c8e67
+Disassembly of section .text:
3c8e67
+
3c8e67
+0+ <disp>:
3c8e67
+ +[a-f0-9]+:	62 f1 7c 48 28 05 00 fc ff ff 	vmovaps -0x400\(%rip\),%zmm0        # .*
3c8e67
+ +[a-f0-9]+:	62 f1 7c 48 28 04 05 40 00 00 00 	vmovaps 0x40\(,%rax,1\),%zmm0
3c8e67
+ +[a-f0-9]+:	62 f1 7c 48 28 04 25 40 00 00 00 	vmovaps 0x40,%zmm0
3c8e67
+ +[a-f0-9]+:	67 62 f1 7c 48 28 04 05 40 00 00 00 	vmovaps 0x40\(,%eax,1\),%zmm0
3c8e67
+ +[a-f0-9]+:	67 62 f1 7c 48 28 04 25 40 00 00 00 	vmovaps 0x40\(,%eiz,1\),%zmm0
3c8e67
+ +[a-f0-9]+:	62 f1 7c 48 28 04 25 40 00 00 00 	vmovaps 0x40,%zmm0
3c8e67
+#pass
3c8e67
--- binutils.orig/gas/testsuite/gas/i386/evex-no-scale.s	2020-08-21 12:48:57.859030235 +0100
3c8e67
+++ binutils-2.30/gas/testsuite/gas/i386/evex-no-scale.s	2020-08-21 12:53:26.631149341 +0100
3c8e67
@@ -5,7 +5,7 @@
3c8e67
 
3c8e67
 	.text
3c8e67
 disp:
3c8e67
-.if is_64bit
3c8e67
+.ifdef x86_64
3c8e67
 	vmovaps	-1024(%rip), %zmm0
3c8e67
 	vmovaps	64(,%rax), %zmm0
3c8e67
 	vmovaps	64(,%riz), %zmm0
3c8e67
@@ -13,6 +13,6 @@ disp:
3c8e67
 	vmovaps	64(,%eax), %zmm0
3c8e67
 	vmovaps	64(,%eiz), %zmm0
3c8e67
 	vmovaps	64, %zmm0
3c8e67
-.if !is_64bit
3c8e67
+.ifndef x86_64
3c8e67
 	addr16 vmovaps 64, %zmm0
3c8e67
 .endif
3c8e67
--- binutils.orig/gas/testsuite/gas/i386/evex-no-scale-64.d	2020-08-21 12:48:57.860030232 +0100
3c8e67
+++ binutils-2.30/gas/testsuite/gas/i386/evex-no-scale-64.d	2020-08-21 13:20:59.174525430 +0100
3c8e67
@@ -11,6 +11,6 @@ Disassembly of section .text:
3c8e67
  +[a-f0-9]+:	62 f1 7c 48 28 04 05 40 00 00 00 	vmovaps 0x40\(,%rax,1\),%zmm0
3c8e67
  +[a-f0-9]+:	62 f1 7c 48 28 04 25 40 00 00 00 	vmovaps 0x40,%zmm0
3c8e67
  +[a-f0-9]+:	67 62 f1 7c 48 28 04 05 40 00 00 00 	vmovaps 0x40\(,%eax,1\),%zmm0
3c8e67
- +[a-f0-9]+:	67 62 f1 7c 48 28 04 25 40 00 00 00 	vmovaps 0x40\(,%eiz,1\),%zmm0
3c8e67
+ +[a-f0-9]+:	67 62 f1 7c 48 28 04 25 40 00 00 00 	addr32 vmovaps 0x40,%zmm0
3c8e67
  +[a-f0-9]+:	62 f1 7c 48 28 04 25 40 00 00 00 	vmovaps 0x40,%zmm0
3c8e67
 #pass