x86: bogus VMOVD with 64-bit operands should only allow for registers
authorJan Beulich <jbeulich@novell.com>
Thu, 8 Mar 2018 07:26:35 +0000 (08:26 +0100)
committerJan Beulich <jbeulich@suse.com>
Thu, 8 Mar 2018 07:26:35 +0000 (08:26 +0100)
These templates exist solely to satisfy gcc's needs, and gcc only
produces these with register operands.

gas/ChangeLog
gas/testsuite/gas/i386/x86-64-movd-intel.d
gas/testsuite/gas/i386/x86-64-movd.d
gas/testsuite/gas/i386/x86-64-movd.s
opcodes/ChangeLog
opcodes/i386-opc.tbl
opcodes/i386-tbl.h

index 564a2690424680186e1cecc06f127105f3f79422..6a1d0a2db9f9c0233d9dfeffe48a2609d9c5b74d 100644 (file)
@@ -1,3 +1,9 @@
+2018-03-08  Jan Beulich  <jbeulich@suse.com>
+
+       * testsuite/gas/i386/x86-64-movd.s: Drop bogus vmovd memory forms.
+       * testsuite/gas/i386/x86-64-movd.d,
+       testsuite/gas/i386/x86-64-movd-intel.d: Adjust expectations.
+
 2018-03-08  Jan Beulich  <jbeulich@suse.com>
 
        * config/tc-i386.c (operand_type_and_not): New.
index fe99f626fe8d7073dc3d731c1eb36c5e2d9c87d6..dac21c8752dfec098a645f3a848cf96eac1fe149 100644 (file)
@@ -40,8 +40,6 @@ Disassembly of section .text:
  +[a-f0-9]+:   62 f1 7d 08 7e 48 20    vmovd  DWORD PTR \[rax\+0x80\],xmm1
  +[a-f0-9]+:   62 f1 7d 08 7e 48 20    vmovd  DWORD PTR \[rax\+0x80\],xmm1
  +[a-f0-9]+:   62 f1 7d 08 7e c8       vmovd  eax,xmm1
- +[a-f0-9]+:   c4 e1 f9 6e 88 80 00 00 00      vmovq  xmm1,QWORD PTR \[rax\+0x80\]
  +[a-f0-9]+:   c4 e1 f9 6e c8          vmovq  xmm1,rax
- +[a-f0-9]+:   c4 e1 f9 7e 88 80 00 00 00      vmovq  QWORD PTR \[rax\+0x80\],xmm1
  +[a-f0-9]+:   c4 e1 f9 7e c8          vmovq  rax,xmm1
 #pass
index 5d4a6c61e8ca2e3cda487d479f5680558b29708c..b034c331cf885fe2413a7d883f49f62b28359623 100644 (file)
@@ -39,8 +39,6 @@ Disassembly of section .text:
  +[a-f0-9]+:   62 f1 7d 08 7e 48 20    vmovd  %xmm1,0x80\(%rax\)
  +[a-f0-9]+:   62 f1 7d 08 7e 48 20    vmovd  %xmm1,0x80\(%rax\)
  +[a-f0-9]+:   62 f1 7d 08 7e c8       vmovd  %xmm1,%eax
- +[a-f0-9]+:   c4 e1 f9 6e 88 80 00 00 00      vmovq  0x80\(%rax\),%xmm1
  +[a-f0-9]+:   c4 e1 f9 6e c8          vmovq  %rax,%xmm1
- +[a-f0-9]+:   c4 e1 f9 7e 88 80 00 00 00      vmovq  %xmm1,0x80\(%rax\)
  +[a-f0-9]+:   c4 e1 f9 7e c8          vmovq  %xmm1,%rax
 #pass
index 1722cef2a3a34b6f9573020f1dc59f195c884c27..7d79768528e9c3cc22ef4bc8ee5d5a3ef0a964d8 100644 (file)
@@ -35,7 +35,5 @@ _start:
        {evex} vmovd dword ptr [rax + 128], xmm1
        {evex} vmovd [rax + 128], xmm1
        {evex} vmovd eax, xmm1
-       vmovd xmm1, qword ptr [rax + 128]
        vmovd xmm1, rax
-       vmovd qword ptr [rax + 128], xmm1
        vmovd rax, xmm1
index da0d7e2953e02532e1b70117e8904bfd82a0e48e..309a034bfc72a02bb3355b4d6796cae9fc8f3eb1 100644 (file)
@@ -1,3 +1,8 @@
+2018-03-08  Jan Beulich  <jbeulich@suse.com>
+
+       * i386-opc.tbl (vmovd): Disallow Qword memory operands.
+       * i386-tlb.h: Re-generate.
+
 2018-03-08  Jan Beulich  <jbeulich@suse.com>
 
        * i386-opc.tbl (vcvtpd2ps): Fold AVX 128- and 256-bit memory
index ee4bc039de68519b6fd286f94006efdcfd23106d..f2d40d81d7b9d17c24f143985579e838fad4df22 100644 (file)
@@ -2058,9 +2058,9 @@ vmovaps, 2, 0x29, None, 1, CpuAVX, Modrm|Vex|VexOpcode=0|VexW=1|CheckRegSize|No_
 // support assembler for AMD64, we accept 64bit operand on vmovd so
 // that we can use one template for both SSE and AVX instructions.
 vmovd, 2, 0x666e, None, 1, CpuAVX, Modrm|Vex=3|VexOpcode=0|IgnoreSize|No_bSuf|No_wSuf|No_lSuf|No_sSuf|No_qSuf|No_ldSuf, { Reg32|Dword|Unspecified|BaseIndex, RegXMM }
-vmovd, 2, 0x666e, None, 1, CpuAVX|Cpu64, Modrm|Vex=3|VexOpcode=0|IgnoreSize|No_bSuf|No_wSuf|No_lSuf|No_sSuf|No_qSuf|No_ldSuf|Size64, { Reg64|Qword|BaseIndex, RegXMM }
+vmovd, 2, 0x666e, None, 1, CpuAVX|Cpu64, Modrm|Vex=3|VexOpcode=0|IgnoreSize|No_bSuf|No_wSuf|No_lSuf|No_sSuf|No_qSuf|No_ldSuf|Size64, { Reg64, RegXMM }
 vmovd, 2, 0x667e, None, 1, CpuAVX, Modrm|Vex=3|VexOpcode=0|IgnoreSize|No_bSuf|No_wSuf|No_lSuf|No_sSuf|No_qSuf|No_ldSuf, { RegXMM, Dword|Unspecified|Reg32|BaseIndex }
-vmovd, 2, 0x667e, None, 1, CpuAVX|Cpu64, Modrm|Vex=3|VexOpcode=0|IgnoreSize|No_bSuf|No_wSuf|No_lSuf|No_sSuf|No_qSuf|No_ldSuf|Size64, { RegXMM, Reg64|Qword|BaseIndex }
+vmovd, 2, 0x667e, None, 1, CpuAVX|Cpu64, Modrm|Vex=3|VexOpcode=0|IgnoreSize|No_bSuf|No_wSuf|No_lSuf|No_sSuf|No_qSuf|No_ldSuf|Size64, { RegXMM, Reg64|RegMem }
 vmovddup, 2, 0xf212, None, 1, CpuAVX, Modrm|Vex|VexOpcode=0|VexW=1|IgnoreSize|No_bSuf|No_wSuf|No_lSuf|No_sSuf|No_qSuf|No_ldSuf, { Qword|Unspecified|BaseIndex|RegXMM, RegXMM }
 vmovddup, 2, 0xf212, None, 1, CpuAVX, Modrm|Vex=2|VexOpcode=0|VexW=1|IgnoreSize|No_bSuf|No_wSuf|No_lSuf|No_sSuf|No_qSuf|No_ldSuf, { Ymmword|Unspecified|BaseIndex|RegYMM, RegYMM }
 vmovdqa, 2, 0x666f, None, 1, CpuAVX, Load|Modrm|Vex|VexOpcode=0|VexW=1|CheckRegSize|No_bSuf|No_wSuf|No_lSuf|No_sSuf|No_qSuf|No_ldSuf, { Unspecified|BaseIndex|RegXMM|RegYMM, RegXMM|RegYMM }
index a9f30fe2452775627ec70227f51200d0de7ba4fc..57eacbc0bd589b6f2a553f6f3510d787b97b3e02 100644 (file)
@@ -40876,8 +40876,8 @@ const insn_template i386_optab[] =
       1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0, 0, 0, 0, 0, 0 },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1,
-         0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
          0, 0, 0 } },
       { { 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
          0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0,
@@ -40913,8 +40913,8 @@ const insn_template i386_optab[] =
     { { { 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
          0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0,
          0, 0, 0 } },
-      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1,
-         0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
          0, 0, 0 } } } },
   { "vmovd", 2, 0x666E, None, 1,
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,