156 lines
6.1 KiB
Diff
156 lines
6.1 KiB
Diff
|
|
diff -N -urp a/gcc/config/i386/sse.md b/gcc/config/i386/sse.md
|
||
|
|
--- a/gcc/config/i386/sse.md 2019-10-30 10:02:45.894920908 +0800
|
||
|
|
+++ b/gcc/config/i386/sse.md 2019-10-30 10:17:39.682887612 +0800
|
||
|
|
@@ -16012,9 +16012,11 @@
|
||
|
|
switch (INTVAL (operands[4]))
|
||
|
|
{
|
||
|
|
case 3:
|
||
|
|
- return "vgatherpf0<ssemodesuffix>ps\t{%5%{%0%}|%5%{%0%}}";
|
||
|
|
+ /* %X5 so that we don't emit any *WORD PTR for -masm=intel, as
|
||
|
|
+ gas changed what it requires incompatibly. */
|
||
|
|
+ return "vgatherpf0<ssemodesuffix>ps\t{%5%{%0%}|%X5%{%0%}}";
|
||
|
|
case 2:
|
||
|
|
- return "vgatherpf1<ssemodesuffix>ps\t{%5%{%0%}|%5%{%0%}}";
|
||
|
|
+ return "vgatherpf1<ssemodesuffix>ps\t{%5%{%0%}|%X5%{%0%}}";
|
||
|
|
default:
|
||
|
|
gcc_unreachable ();
|
||
|
|
}
|
||
|
|
@@ -16057,9 +16059,11 @@
|
||
|
|
switch (INTVAL (operands[4]))
|
||
|
|
{
|
||
|
|
case 3:
|
||
|
|
- return "vgatherpf0<ssemodesuffix>pd\t{%5%{%0%}|%5%{%0%}}";
|
||
|
|
+ /* %X5 so that we don't emit any *WORD PTR for -masm=intel, as
|
||
|
|
+ gas changed what it requires incompatibly. */
|
||
|
|
+ return "vgatherpf0<ssemodesuffix>pd\t{%5%{%0%}|%X5%{%0%}}";
|
||
|
|
case 2:
|
||
|
|
- return "vgatherpf1<ssemodesuffix>pd\t{%5%{%0%}|%5%{%0%}}";
|
||
|
|
+ return "vgatherpf1<ssemodesuffix>pd\t{%5%{%0%}|%X5%{%0%}}";
|
||
|
|
default:
|
||
|
|
gcc_unreachable ();
|
||
|
|
}
|
||
|
|
@@ -16103,10 +16107,12 @@
|
||
|
|
{
|
||
|
|
case 3:
|
||
|
|
case 7:
|
||
|
|
- return "vscatterpf0<ssemodesuffix>ps\t{%5%{%0%}|%5%{%0%}}";
|
||
|
|
+ /* %X5 so that we don't emit any *WORD PTR for -masm=intel, as
|
||
|
|
+ gas changed what it requires incompatibly. */
|
||
|
|
+ return "vscatterpf0<ssemodesuffix>ps\t{%5%{%0%}|%X5%{%0%}}";
|
||
|
|
case 2:
|
||
|
|
case 6:
|
||
|
|
- return "vscatterpf1<ssemodesuffix>ps\t{%5%{%0%}|%5%{%0%}}";
|
||
|
|
+ return "vscatterpf1<ssemodesuffix>ps\t{%5%{%0%}|%X5%{%0%}}";
|
||
|
|
default:
|
||
|
|
gcc_unreachable ();
|
||
|
|
}
|
||
|
|
@@ -16150,10 +16156,12 @@
|
||
|
|
{
|
||
|
|
case 3:
|
||
|
|
case 7:
|
||
|
|
- return "vscatterpf0<ssemodesuffix>pd\t{%5%{%0%}|%5%{%0%}}";
|
||
|
|
+ /* %X5 so that we don't emit any *WORD PTR for -masm=intel, as
|
||
|
|
+ gas changed what it requires incompatibly. */
|
||
|
|
+ return "vscatterpf0<ssemodesuffix>pd\t{%5%{%0%}|%X5%{%0%}}";
|
||
|
|
case 2:
|
||
|
|
case 6:
|
||
|
|
- return "vscatterpf1<ssemodesuffix>pd\t{%5%{%0%}|%5%{%0%}}";
|
||
|
|
+ return "vscatterpf1<ssemodesuffix>pd\t{%5%{%0%}|%X5%{%0%}}";
|
||
|
|
default:
|
||
|
|
gcc_unreachable ();
|
||
|
|
}
|
||
|
|
@@ -19153,12 +19161,6 @@
|
||
|
|
(set_attr "prefix" "vex")
|
||
|
|
(set_attr "mode" "<sseinsnmode>")])
|
||
|
|
|
||
|
|
-;; Memory operand override for -masm=intel of the v*gatherq* patterns.
|
||
|
|
-(define_mode_attr gatherq_mode
|
||
|
|
- [(V4SI "q") (V2DI "x") (V4SF "q") (V2DF "x")
|
||
|
|
- (V8SI "x") (V4DI "t") (V8SF "x") (V4DF "t")
|
||
|
|
- (V16SI "t") (V8DI "g") (V16SF "t") (V8DF "g")])
|
||
|
|
-
|
||
|
|
(define_expand "<avx512>_gathersi<mode>"
|
||
|
|
[(parallel [(set (match_operand:VI48F 0 "register_operand")
|
||
|
|
(unspec:VI48F
|
||
|
|
@@ -19192,7 +19194,9 @@
|
||
|
|
UNSPEC_GATHER))
|
||
|
|
(clobber (match_scratch:<avx512fmaskmode> 2 "=&Yk"))]
|
||
|
|
"TARGET_AVX512F"
|
||
|
|
- "v<sseintprefix>gatherd<ssemodesuffix>\t{%6, %0%{%2%}|%0%{%2%}, %<xtg_mode>6}"
|
||
|
|
+;; %X6 so that we don't emit any *WORD PTR for -masm=intel, as
|
||
|
|
+;; gas changed what it requires incompatibly.
|
||
|
|
+ "v<sseintprefix>gatherd<ssemodesuffix>\t{%6, %0%{%2%}|%0%{%2%}, %X6}"
|
||
|
|
[(set_attr "type" "ssemov")
|
||
|
|
(set_attr "prefix" "evex")
|
||
|
|
(set_attr "mode" "<sseinsnmode>")])
|
||
|
|
@@ -19211,7 +19215,9 @@
|
||
|
|
UNSPEC_GATHER))
|
||
|
|
(clobber (match_scratch:<avx512fmaskmode> 1 "=&Yk"))]
|
||
|
|
"TARGET_AVX512F"
|
||
|
|
- "v<sseintprefix>gatherd<ssemodesuffix>\t{%5, %0%{%1%}|%0%{%1%}, %<xtg_mode>5}"
|
||
|
|
+;; %X5 so that we don't emit any *WORD PTR for -masm=intel, as
|
||
|
|
+;; gas changed what it requires incompatibly.
|
||
|
|
+ "v<sseintprefix>gatherd<ssemodesuffix>\t{%5, %0%{%1%}|%0%{%1%}, %X5}"
|
||
|
|
[(set_attr "type" "ssemov")
|
||
|
|
(set_attr "prefix" "evex")
|
||
|
|
(set_attr "mode" "<sseinsnmode>")])
|
||
|
|
@@ -19250,9 +19256,9 @@
|
||
|
|
UNSPEC_GATHER))
|
||
|
|
(clobber (match_scratch:QI 2 "=&Yk"))]
|
||
|
|
"TARGET_AVX512F"
|
||
|
|
-{
|
||
|
|
- return "v<sseintprefix>gatherq<ssemodesuffix>\t{%6, %1%{%2%}|%1%{%2%}, %<gatherq_mode>6}";
|
||
|
|
-}
|
||
|
|
+;; %X6 so that we don't emit any *WORD PTR for -masm=intel, as
|
||
|
|
+;; gas changed what it requires incompatibly.
|
||
|
|
+ "v<sseintprefix>gatherq<ssemodesuffix>\t{%6, %1%{%2%}|%1%{%2%}, %X6}"
|
||
|
|
[(set_attr "type" "ssemov")
|
||
|
|
(set_attr "prefix" "evex")
|
||
|
|
(set_attr "mode" "<sseinsnmode>")])
|
||
|
|
@@ -19272,14 +19278,16 @@
|
||
|
|
(clobber (match_scratch:QI 1 "=&Yk"))]
|
||
|
|
"TARGET_AVX512F"
|
||
|
|
{
|
||
|
|
+ /* %X5 so that we don't emit any *WORD PTR for -masm=intel, as
|
||
|
|
+ gas changed what it requires incompatibly. */
|
||
|
|
if (<MODE>mode != <VEC_GATHER_SRCDI>mode)
|
||
|
|
{
|
||
|
|
if (<MODE_SIZE> != 64)
|
||
|
|
- return "v<sseintprefix>gatherq<ssemodesuffix>\t{%5, %x0%{%1%}|%x0%{%1%}, %<gatherq_mode>5}";
|
||
|
|
+ return "v<sseintprefix>gatherq<ssemodesuffix>\t{%5, %x0%{%1%}|%x0%{%1%}, %X5}";
|
||
|
|
else
|
||
|
|
- return "v<sseintprefix>gatherq<ssemodesuffix>\t{%5, %t0%{%1%}|%t0%{%1%}, %t5}";
|
||
|
|
+ return "v<sseintprefix>gatherq<ssemodesuffix>\t{%5, %t0%{%1%}|%t0%{%1%}, %X5}";
|
||
|
|
}
|
||
|
|
- return "v<sseintprefix>gatherq<ssemodesuffix>\t{%5, %0%{%1%}|%0%{%1%}, %<gatherq_mode>5}";
|
||
|
|
+ return "v<sseintprefix>gatherq<ssemodesuffix>\t{%5, %0%{%1%}|%0%{%1%}, %X5}";
|
||
|
|
}
|
||
|
|
[(set_attr "type" "ssemov")
|
||
|
|
(set_attr "prefix" "evex")
|
||
|
|
@@ -19316,7 +19324,9 @@
|
||
|
|
UNSPEC_SCATTER))
|
||
|
|
(clobber (match_scratch:<avx512fmaskmode> 1 "=&Yk"))]
|
||
|
|
"TARGET_AVX512F"
|
||
|
|
- "v<sseintprefix>scatterd<ssemodesuffix>\t{%3, %5%{%1%}|%5%{%1%}, %3}"
|
||
|
|
+;; %X5 so that we don't emit any *WORD PTR for -masm=intel, as
|
||
|
|
+;; gas changed what it requires incompatibly.
|
||
|
|
+ "v<sseintprefix>scatterd<ssemodesuffix>\t{%3, %5%{%1%}|%X5%{%1%}, %3}"
|
||
|
|
[(set_attr "type" "ssemov")
|
||
|
|
(set_attr "prefix" "evex")
|
||
|
|
(set_attr "mode" "<sseinsnmode>")])
|
||
|
|
@@ -19352,11 +19362,9 @@
|
||
|
|
UNSPEC_SCATTER))
|
||
|
|
(clobber (match_scratch:QI 1 "=&Yk"))]
|
||
|
|
"TARGET_AVX512F"
|
||
|
|
-{
|
||
|
|
- if (GET_MODE_SIZE (GET_MODE_INNER (<MODE>mode)) == 8)
|
||
|
|
- return "v<sseintprefix>scatterq<ssemodesuffix>\t{%3, %5%{%1%}|%5%{%1%}, %3}";
|
||
|
|
- return "v<sseintprefix>scatterq<ssemodesuffix>\t{%3, %5%{%1%}|%t5%{%1%}, %3}";
|
||
|
|
-}
|
||
|
|
+;; %X5 so that we don't emit any *WORD PTR for -masm=intel, as
|
||
|
|
+;; gas changed what it requires incompatibly.
|
||
|
|
+ "v<sseintprefix>scatterq<ssemodesuffix>\t{%3, %5%{%1%}|%X5%{%1%}, %3}"
|
||
|
|
[(set_attr "type" "ssemov")
|
||
|
|
(set_attr "prefix" "evex")
|
||
|
|
(set_attr "mode" "<sseinsnmode>")])
|