aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/config/i386/i386.cc111
-rw-r--r--gcc/config/i386/i386.md38
-rw-r--r--gcc/config/i386/mmx.md31
-rw-r--r--gcc/config/i386/sse.md293
4 files changed, 255 insertions, 218 deletions
diff --git a/gcc/config/i386/i386.cc b/gcc/config/i386/i386.cc
index 0f17f7d..fdc9362 100644
--- a/gcc/config/i386/i386.cc
+++ b/gcc/config/i386/i386.cc
@@ -11357,93 +11357,116 @@ ix86_validate_address_register (rtx op)
return NULL_RTX;
}
-/* Return true if insn memory address can use any available reg
- in BASE_REG_CLASS or INDEX_REG_CLASS, otherwise false.
- For APX, some instruction can't be encoded with gpr32
- which is BASE_REG_CLASS or INDEX_REG_CLASS, for that case
- returns false. */
-static bool
-ix86_memory_address_use_extended_reg_class_p (rtx_insn* insn)
+/* Determine which memory address register set insn can use. */
+
+static enum attr_addr
+ix86_memory_address_reg_class (rtx_insn* insn)
{
- /* LRA will do some initialization with insn == NULL,
- return the maximum reg class for that.
- For other cases, real insn will be passed and checked. */
- bool ret = true;
+ /* LRA can do some initialization with NULL insn,
+ return maximum register class in this case. */
+ enum attr_addr addr_rclass = ADDR_GPR32;
+
if (TARGET_APX_EGPR && insn)
{
if (asm_noperands (PATTERN (insn)) >= 0
|| GET_CODE (PATTERN (insn)) == ASM_INPUT)
- return ix86_apx_inline_asm_use_gpr32;
+ return ix86_apx_inline_asm_use_gpr32 ? ADDR_GPR32 : ADDR_GPR16;
+ /* Return maximum register class for unrecognized instructions. */
if (INSN_CODE (insn) < 0)
- return false;
+ return addr_rclass;
- /* Try recog the insn before calling get_attr_gpr32. Save
- the current recog_data first. */
- /* Also save which_alternative for current recog. */
+ /* Try to recognize the insn before calling get_attr_addr.
+ Save current recog_data and current alternative. */
+ struct recog_data_d saved_recog_data = recog_data;
+ int saved_alternative = which_alternative;
- struct recog_data_d recog_data_save = recog_data;
- int which_alternative_saved = which_alternative;
-
- /* Update the recog_data for alternative check. */
+ /* Update recog_data for processing of alternatives. */
if (recog_data.insn != insn)
extract_insn_cached (insn);
- /* If alternative is not set, loop throught each alternative
- of insn and get gpr32 attr for all enabled alternatives.
- If any enabled alternatives has 0 value for gpr32, disallow
- gpr32 for addressing. */
- if (which_alternative_saved == -1)
+ /* If current alternative is not set, loop throught enabled
+ alternatives and get the most limited register class. */
+ if (saved_alternative == -1)
{
alternative_mask enabled = get_enabled_alternatives (insn);
- bool curr_insn_gpr32 = false;
+
for (int i = 0; i < recog_data.n_alternatives; i++)
{
if (!TEST_BIT (enabled, i))
continue;
+
which_alternative = i;
- curr_insn_gpr32 = get_attr_gpr32 (insn);
- if (!curr_insn_gpr32)
- ret = false;
+ addr_rclass = MIN (addr_rclass, get_attr_addr (insn));
}
}
else
{
- which_alternative = which_alternative_saved;
- ret = get_attr_gpr32 (insn);
+ which_alternative = saved_alternative;
+ addr_rclass = get_attr_addr (insn);
}
- recog_data = recog_data_save;
- which_alternative = which_alternative_saved;
+ recog_data = saved_recog_data;
+ which_alternative = saved_alternative;
}
- return ret;
+ return addr_rclass;
}
-/* For APX, some instructions can't be encoded with gpr32. */
+/* Return memory address register class insn can use. */
+
enum reg_class
ix86_insn_base_reg_class (rtx_insn* insn)
{
- if (ix86_memory_address_use_extended_reg_class_p (insn))
- return BASE_REG_CLASS;
- return GENERAL_GPR16;
+ switch (ix86_memory_address_reg_class (insn))
+ {
+ case ADDR_GPR8:
+ gcc_unreachable ();
+ case ADDR_GPR16:
+ return GENERAL_GPR16;
+ case ADDR_GPR32:
+ break;
+ default:
+ gcc_unreachable ();
+ }
+
+ return BASE_REG_CLASS;
}
bool
ix86_regno_ok_for_insn_base_p (int regno, rtx_insn* insn)
{
+ switch (ix86_memory_address_reg_class (insn))
+ {
+ case ADDR_GPR8:
+ gcc_unreachable ();
+ case ADDR_GPR16:
+ return GENERAL_GPR16_REGNO_P (regno);
+ case ADDR_GPR32:
+ break;
+ default:
+ gcc_unreachable ();
+ }
- if (ix86_memory_address_use_extended_reg_class_p (insn))
- return GENERAL_REGNO_P (regno);
- return GENERAL_GPR16_REGNO_P (regno);
+ return GENERAL_REGNO_P (regno);
}
enum reg_class
ix86_insn_index_reg_class (rtx_insn* insn)
{
- if (ix86_memory_address_use_extended_reg_class_p (insn))
- return INDEX_REG_CLASS;
- return INDEX_GPR16;
+ switch (ix86_memory_address_reg_class (insn))
+ {
+ case ADDR_GPR8:
+ gcc_unreachable ();
+ case ADDR_GPR16:
+ return INDEX_GPR16;
+ case ADDR_GPR32:
+ break;
+ default:
+ gcc_unreachable ();
+ }
+
+ return INDEX_REG_CLASS;
}
/* Recognizes RTL expressions that are valid memory addresses for an
diff --git a/gcc/config/i386/i386.md b/gcc/config/i386/i386.md
index 663db73..ecc74e9 100644
--- a/gcc/config/i386/i386.md
+++ b/gcc/config/i386/i386.md
@@ -882,8 +882,8 @@
;; Define attribute to indicate unaligned ssemov insns
(define_attr "movu" "0,1" (const_string "0"))
-;; Define attribute to indicate gpr32 insns.
-(define_attr "gpr32" "0, 1" (const_string "1"))
+;; Define attribute to limit memory address register set.
+(define_attr "addr" "gpr8,gpr16,gpr32" (const_string "gpr32"))
;; Define instruction set of MMX instructions
(define_attr "mmx_isa" "base,native,sse,sse_noavx,avx"
@@ -2987,10 +2987,10 @@
(const_string "avx")
]
(const_string "*")))
- (set (attr "gpr32")
+ (set (attr "addr")
(if_then_else (eq_attr "alternative" "14")
- (const_string "0")
- (const_string "1")))
+ (const_string "gpr16")
+ (const_string "*")))
(set (attr "type")
(cond [(eq_attr "alternative" "4,5,6,7")
(const_string "mskmov")
@@ -4470,10 +4470,10 @@
(const_string "avx")
]
(const_string "*")))
- (set (attr "gpr32")
- (if_then_else (eq_attr "alternative" "8")
- (const_string "0")
- (const_string "1")))
+ (set (attr "addr")
+ (if_then_else (eq_attr "alternative" "7")
+ (const_string "gpr16")
+ (const_string "*")))
(set (attr "type")
(cond [(eq_attr "alternative" "4")
(const_string "sselog1")
@@ -16913,7 +16913,7 @@
cmp%D3<ssemodesuffix>\t{%2, %0|%0, %2}
vcmp%D3<ssemodesuffix>\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set_attr "type" "ssecmp")
(set_attr "length_immediate" "1")
(set_attr "prefix" "orig,vex")
@@ -20379,7 +20379,7 @@
rcpss\t{%1, %d0|%d0, %1}
vrcpss\t{%1, %d0|%d0, %1}"
[(set_attr "isa" "*,*,noavx,avx")
- (set_attr "gpr32" "1,1,1,0")
+ (set_attr "addr" "*,*,*,gpr16")
(set_attr "type" "sse")
(set_attr "atom_sse_attr" "rcp")
(set_attr "btver2_sse_attr" "rcp")
@@ -20642,7 +20642,7 @@
rsqrtss\t{%1, %d0|%d0, %1}
vrsqrtss\t{%1, %d0|%d0, %1}"
[(set_attr "isa" "*,*,noavx,avx")
- (set_attr "gpr32" "1,1,1,0")
+ (set_attr "addr" "*,*,*,gpr16")
(set_attr "type" "sse")
(set_attr "atom_sse_attr" "rcp")
(set_attr "btver2_sse_attr" "rcp")
@@ -21881,7 +21881,7 @@
[(set_attr "type" "ssecvt")
(set_attr "prefix_extra" "1,1,1,*,*")
(set_attr "length_immediate" "1")
- (set_attr "gpr32" "1,1,0,1,1")
+ (set_attr "addr" "*,*,gpr16,*,*")
(set_attr "prefix" "maybe_vex,maybe_vex,maybe_vex,evex,evex")
(set_attr "isa" "noavx512f,noavx512f,noavx512f,avx512f,avx512f")
(set_attr "avx_partial_xmm_update" "false,false,true,false,true")
@@ -25924,7 +25924,7 @@
"TARGET_64BIT && TARGET_FXSR"
"fxsave64\t%0"
[(set_attr "type" "other")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "memory" "store")
(set (attr "length")
(symbol_ref "ix86_attr_length_address_default (insn) + 4"))])
@@ -25945,7 +25945,7 @@
"TARGET_64BIT && TARGET_FXSR"
"fxrstor64\t%0"
[(set_attr "type" "other")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "memory" "load")
(set (attr "length")
(symbol_ref "ix86_attr_length_address_default (insn) + 4"))])
@@ -26008,7 +26008,7 @@
"<xsave>\t%0"
[(set_attr "type" "other")
(set_attr "memory" "store")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set (attr "length")
(symbol_ref "ix86_attr_length_address_default (insn) + 3"))])
@@ -26022,7 +26022,7 @@
"<xsave>\t%0"
[(set_attr "type" "other")
(set_attr "memory" "store")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set (attr "length")
(symbol_ref "ix86_attr_length_address_default (insn) + 4"))])
@@ -26048,7 +26048,7 @@
"<xrstor>\t%0"
[(set_attr "type" "other")
(set_attr "memory" "load")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set (attr "length")
(symbol_ref "ix86_attr_length_address_default (insn) + 3"))])
@@ -26062,7 +26062,7 @@
"<xrstor>64\t%0"
[(set_attr "type" "other")
(set_attr "memory" "load")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set (attr "length")
(symbol_ref "ix86_attr_length_address_default (insn) + 4"))])
diff --git a/gcc/config/i386/mmx.md b/gcc/config/i386/mmx.md
index ba81ff7..50402b5 100644
--- a/gcc/config/i386/mmx.md
+++ b/gcc/config/i386/mmx.md
@@ -467,10 +467,10 @@
(const_string "avx")
]
(const_string "*")))
- (set (attr "gpr32")
+ (set (attr "addr")
(if_then_else (eq_attr "alternative" "7")
- (const_string "0")
- (const_string "1")))
+ (const_string "gpr16")
+ (const_string "*")))
(set (attr "type")
(cond [(eq_attr "alternative" "6,7,8")
(if_then_else (match_test "TARGET_AVX512FP16")
@@ -1205,7 +1205,7 @@
}
}
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")
+ (set_attr "addr" "*,*,gpr16")
(set_attr "type" "sselog")
(set_attr "prefix_data16" "1,1,*")
(set_attr "prefix_extra" "1")
@@ -4874,7 +4874,7 @@
}
}
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "prefix_extra" "1")
(set_attr "type" "sselog")
(set_attr "length_immediate" "1")
@@ -4947,7 +4947,7 @@
}
[(set_attr "isa" "noavx,avx")
(set_attr "type" "sselog")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
(set_attr "prefix" "orig,vex")
@@ -4966,7 +4966,7 @@
pextrw\t{%2, %1, %0|%0, %1, %2}
vpextrw\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "*,sse2,sse4_noavx,avx")
- (set_attr "gpr32" "1,1,0,1")
+ (set_attr "addr" "*,*,gpr16,*")
(set_attr "mmx_isa" "native,*,*,*")
(set_attr "type" "mmxcvt,sselog1,sselog1,sselog1")
(set_attr "length_immediate" "1")
@@ -5003,7 +5003,7 @@
vpextrb\t{%2, %1, %k0|%k0, %1, %2}
vpextrb\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,noavx,avx,avx")
- (set_attr "gpr32" "1,0,1,1")
+ (set_attr "addr" "*,gpr16,*,*")
(set_attr "type" "sselog1")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
@@ -5036,7 +5036,7 @@
pshufb\t{%2, %0|%0, %2}
vpshufb\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "type" "sselog1")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,maybe_evex")
@@ -5054,7 +5054,7 @@
pshufb\t{%2, %0|%0, %2}
vpshufb\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "type" "sselog1")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,maybe_evex")
@@ -5330,7 +5330,10 @@
#
#"
[(set_attr "isa" "*,sse4_noavx,avx,sse2,noavx,*,*,*")
- (set_attr "gpr32" "1,0,1,1,1,1,1,1")
+ (set (attr "addr")
+ (if_then_else (eq_attr "alternative" "1")
+ (const_string "gpr16")
+ (const_string "*")))
(set_attr "mmx_isa" "native,*,*,*,*,native,*,*")
(set_attr "type" "mmxcvt,ssemov,ssemov,sseshuf1,sseshuf1,mmxmov,ssemov,imov")
(set (attr "length_immediate")
@@ -5534,7 +5537,7 @@
}
}
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "type" "sselog")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
@@ -5552,7 +5555,7 @@
pextrw\t{%2, %1, %0|%0, %1, %2}
vpextrw\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "*,sse4_noavx,avx")
- (set_attr "gpr32" "1,0,1")
+ (set_attr "addr" "*,gpr16,*")
(set_attr "type" "sselog1")
(set_attr "length_immediate" "1")
(set_attr "prefix" "maybe_vex")
@@ -5583,7 +5586,7 @@
vpextrb\t{%2, %1, %k0|%k0, %1, %2}
vpextrb\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,noavx,avx,avx")
- (set_attr "gpr32" "1,0,1,1")
+ (set_attr "addr" "*,gpr16,*,*")
(set_attr "type" "sselog1")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
diff --git a/gcc/config/i386/sse.md b/gcc/config/i386/sse.md
index 906212f..e6a5c79 100644
--- a/gcc/config/i386/sse.md
+++ b/gcc/config/i386/sse.md
@@ -1874,7 +1874,7 @@
"%vlddqu\t{%1, %0|%0, %1}"
[(set_attr "isa" "noavx,avx")
(set_attr "type" "ssemov")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set_attr "movu" "1")
(set (attr "prefix_data16")
(if_then_else
@@ -2578,7 +2578,7 @@
"%vrcpps\t{%1, %0|%0, %1}"
[(set_attr "isa" "noavx,avx")
(set_attr "type" "sse")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set_attr "atom_sse_attr" "rcp")
(set_attr "btver2_sse_attr" "rcp")
(set_attr "prefix" "maybe_vex")
@@ -2597,7 +2597,7 @@
vrcpss\t{%1, %2, %0|%0, %2, %k1}"
[(set_attr "isa" "noavx,avx")
(set_attr "type" "sse")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set_attr "atom_sse_attr" "rcp")
(set_attr "btver2_sse_attr" "rcp")
(set_attr "prefix" "orig,vex")
@@ -2617,7 +2617,7 @@
vrcpss\t{%1, %2, %0|%0, %2, %1}"
[(set_attr "isa" "noavx,avx")
(set_attr "type" "sse")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set_attr "atom_sse_attr" "rcp")
(set_attr "btver2_sse_attr" "rcp")
(set_attr "prefix" "orig,vex")
@@ -2801,7 +2801,7 @@
"%vrsqrtps\t{%1, %0|%0, %1}"
[(set_attr "isa" "noavx,avx")
(set_attr "type" "sse")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set_attr "prefix" "maybe_vex")
(set_attr "mode" "<MODE>")])
@@ -2870,7 +2870,7 @@
vrsqrtss\t{%1, %2, %0|%0, %2, %k1}"
[(set_attr "isa" "noavx,avx")
(set_attr "type" "sse")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set_attr "prefix" "orig,vex")
(set_attr "mode" "SF")])
@@ -2888,7 +2888,7 @@
vrsqrtss\t{%1, %2, %0|%0, %2, %1}"
[(set_attr "isa" "noavx,avx")
(set_attr "type" "sse")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set_attr "prefix" "orig,vex")
(set_attr "mode" "SF")])
@@ -3073,7 +3073,7 @@
vaddsub<ssemodesuffix>\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx")
(set_attr "type" "sseadd")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set (attr "atom_unit")
(if_then_else
(match_test "<MODE>mode == V2DFmode")
@@ -3230,7 +3230,7 @@
"TARGET_AVX"
"vh<plusminus_mnemonic>pd\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "type" "sseadd")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix" "vex")
(set_attr "mode" "V4DF")])
@@ -3273,7 +3273,7 @@
haddpd\t{%2, %0|%0, %2}
vhaddpd\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set_attr "type" "sseadd")
(set_attr "prefix" "orig,vex")
(set_attr "mode" "V2DF")])
@@ -3297,7 +3297,7 @@
vhsubpd\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx")
(set_attr "type" "sseadd")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set_attr "prefix" "orig,vex")
(set_attr "mode" "V2DF")])
@@ -3378,7 +3378,7 @@
"TARGET_AVX"
"vh<plusminus_mnemonic>ps\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "type" "sseadd")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix" "vex")
(set_attr "mode" "V8SF")])
@@ -3409,7 +3409,7 @@
vh<plusminus_mnemonic>ps\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx")
(set_attr "type" "sseadd")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set_attr "atom_unit" "complex")
(set_attr "prefix" "orig,vex")
(set_attr "prefix_rep" "1,*")
@@ -3613,7 +3613,7 @@
"TARGET_AVX"
"vcmp<ssemodesuffix>\t{%3, %2, %1, %0|%0, %1, %2, %3}"
[(set_attr "type" "ssecmp")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "length_immediate" "1")
(set_attr "prefix" "vex")
(set_attr "mode" "<MODE>")])
@@ -3827,7 +3827,7 @@
"TARGET_AVX"
"vcmp<ssescalarmodesuffix>\t{%3, %2, %1, %0|%0, %1, %<iptr>2, %3}"
[(set_attr "type" "ssecmp")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "length_immediate" "1")
(set_attr "prefix" "vex")
(set_attr "mode" "<ssescalarmode>")])
@@ -3843,7 +3843,7 @@
cmp%D3<ssemodesuffix>\t{%2, %0|%0, %2}
vcmp%D3<ssemodesuffix>\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set_attr "type" "ssecmp")
(set_attr "length_immediate" "1")
(set_attr "prefix" "orig,vex")
@@ -3859,7 +3859,7 @@
cmp%D3<ssemodesuffix>\t{%2, %0|%0, %2}
vcmp%D3<ssemodesuffix>\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set_attr "type" "ssecmp")
(set_attr "length_immediate" "1")
(set_attr "prefix" "orig,vex")
@@ -3878,7 +3878,7 @@
cmp%D3<ssescalarmodesuffix>\t{%2, %0|%0, %<iptr>2}
vcmp%D3<ssescalarmodesuffix>\t{%2, %1, %0|%0, %1, %<iptr>2}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set_attr "type" "ssecmp")
(set_attr "length_immediate" "1,*")
(set_attr "prefix" "orig,vex")
@@ -4826,7 +4826,7 @@
return "";
}
[(set_attr "isa" "noavx,avx_noavx512f,avx512dq,avx512f")
- (set_attr "gpr32" "1,0,1,1")
+ (set_attr "addr" "*,gpr16,*,*")
(set_attr "type" "sselog")
(set_attr "prefix" "orig,maybe_vex,evex,evex")
(set (attr "mode")
@@ -5170,7 +5170,7 @@
return "";
}
[(set_attr "isa" "noavx,avx_noavx512f,avx512vl,avx512f_512")
- (set_attr "gpr32" "1,0,1,1")
+ (set_attr "addr" "*,gpr16,*,*")
(set_attr "type" "sselog")
(set (attr "prefix_data16")
(if_then_else
@@ -10958,10 +10958,10 @@
(if_then_else (eq_attr "alternative" "7,8")
(const_string "native")
(const_string "*")))
- (set (attr "gpr32")
+ (set (attr "addr")
(if_then_else (eq_attr "alternative" "3,4")
- (const_string "0")
- (const_string "1")))
+ (const_string "gpr16")
+ (const_string "*")))
(set (attr "prefix_data16")
(if_then_else (eq_attr "alternative" "3,4")
(const_string "1")
@@ -11093,10 +11093,10 @@
(const_string "fmov")
]
(const_string "ssemov")))
- (set (attr "gpr32")
+ (set (attr "addr")
(if_then_else (eq_attr "alternative" "8,9")
- (const_string "0")
- (const_string "1")))
+ (const_string "gpr16")
+ (const_string "*")))
(set (attr "prefix_extra")
(if_then_else (eq_attr "alternative" "8,9,10")
(const_string "1")
@@ -11288,7 +11288,7 @@
}
[(set_attr "isa" "noavx,noavx,avx")
(set_attr "type" "sselog")
- (set_attr "gpr32" "0,0,1")
+ (set_attr "addr" "gpr16,gpr16,*")
(set_attr "prefix_data16" "1,1,*")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
@@ -11389,7 +11389,7 @@
}
}
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")
+ (set_attr "addr" "gpr16,gpr16,*")
(set_attr "type" "sselog")
(set_attr "prefix_data16" "1,1,*")
(set_attr "prefix_extra" "1")
@@ -11501,7 +11501,7 @@
DONE;
}
[(set_attr "isa" "noavx,noavx,avx,noavx,avx")
- (set_attr "gpr32" "0,0,1,1,1")
+ (set_attr "addr" "gpr16,gpr16,*,*,*")
(set_attr "type" "sselog,sselog,sselog,*,*")
(set_attr "prefix_data16" "1,1,1,*,*")
(set_attr "prefix_extra" "1,1,1,*,*")
@@ -12354,7 +12354,7 @@
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
(set_attr "isa" "noavx512vl,avx512vl")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "prefix" "vex,evex")
(set_attr "mode" "OI")])
@@ -12400,7 +12400,7 @@
}
}
[(set_attr "isa" "*,sse4_noavx,avx,noavx,avx")
- (set_attr "gpr32" "1,0,1,1,1")
+ (set_attr "addr" "*,gpr16,*,*,*")
(set_attr "type" "sselog1,sselog1,sselog1,sseishft1,sseishft1")
(set_attr "prefix" "maybe_evex")
(set_attr "mode" "TI")])
@@ -15774,7 +15774,7 @@
pmuldq\t{%2, %0|%0, %2}
vpmuldq\t{%2, %1, %0<mask_operand3>|%0<mask_operand3>, %1, %2}"
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")
+ (set_attr "addr" "gpr16,gpr16,*")
(set_attr "type" "sseimul")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,orig,vex")
@@ -16020,7 +16020,7 @@
pmulld\t{%2, %0|%0, %2}
vpmulld\t{%2, %1, %0<mask_operand3>|%0<mask_operand3>, %1, %2}"
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")
+ (set_attr "addr" "gpr16,gpr16,*")
(set_attr "type" "sseimul")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "<bcst_mask_prefix4>")
@@ -16836,7 +16836,7 @@
[(set_attr "isa" "noavx,noavx,avx")
(set_attr "type" "sseiadd")
(set_attr "prefix_extra" "1")
- (set_attr "gpr32" "0,0,1")
+ (set_attr "addr" "gpr16,gpr16,*")
(set_attr "prefix" "orig,orig,vex")
(set_attr "mode" "TI")])
@@ -16851,7 +16851,7 @@
vp<maxmin_int>w\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx")
(set_attr "type" "sseiadd")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "prefix" "orig,vex")
(set_attr "mode" "TI")])
@@ -16919,7 +16919,7 @@
vp<maxmin_int><ssemodesuffix>\t{%2, %1, %0<mask_operand3>|%0<mask_operand3>, %1, %2}"
[(set_attr "isa" "noavx,noavx,avx")
(set_attr "type" "sseiadd")
- (set_attr "gpr32" "0,0,1")
+ (set_attr "addr" "gpr16,gpr16,*")
(set_attr "prefix_extra" "1,1,*")
(set_attr "prefix" "orig,orig,vex")
(set_attr "mode" "TI")])
@@ -16934,7 +16934,7 @@
p<maxmin_int>b\t{%2, %0|%0, %2}
vp<maxmin_int>b\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "type" "sseiadd")
(set_attr "prefix" "orig,vex")
(set_attr "mode" "TI")])
@@ -16957,7 +16957,7 @@
(if_then_else (eq (const_string "<MODE>mode") (const_string "V4DImode"))
(const_string "1")
(const_string "*")))
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix" "vex")
(set_attr "mode" "OI")])
@@ -17148,7 +17148,7 @@
vpcmpeqq\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,noavx,avx")
(set_attr "type" "ssecmp")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,orig,vex")
(set_attr "mode" "TI")])
@@ -17164,7 +17164,7 @@
pcmpeq<ssemodesuffix>\t{%2, %0|%0, %2}
vpcmpeq<ssemodesuffix>\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set_attr "type" "ssecmp")
(set_attr "prefix" "orig,vex")
(set_attr "mode" "TI")])
@@ -17181,7 +17181,7 @@
vpcmpgtq\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,noavx,avx")
(set_attr "type" "ssecmp")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,orig,vex")
(set_attr "mode" "TI")])
@@ -17198,7 +17198,7 @@
(if_then_else (eq (const_string "<MODE>mode") (const_string "V4DImode"))
(const_string "1")
(const_string "*")))
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix" "vex")
(set_attr "mode" "OI")])
@@ -17228,7 +17228,7 @@
pcmpgt<ssemodesuffix>\t{%2, %0|%0, %2}
vpcmpgt<ssemodesuffix>\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set_attr "type" "ssecmp")
(set_attr "prefix" "orig,vex")
(set_attr "mode" "TI")])
@@ -17637,7 +17637,7 @@
return "";
}
[(set_attr "isa" "noavx,avx_noavx512f,avx512f,*,*")
- (set_attr "gpr32" "1,0,1,1,1")
+ (set_attr "addr" "*,gpr16,*,*,*")
(set_attr "type" "sselog")
(set (attr "prefix_data16")
(if_then_else
@@ -17868,7 +17868,7 @@
return "";
}
[(set_attr "isa" "noavx,avx_noavx512f,avx512f")
- (set_attr "gpr32" "1,0,1")
+ (set_attr "addr" "*,gpr16,*")
(set_attr "type" "sselog")
(set (attr "prefix_data16")
(if_then_else
@@ -17965,7 +17965,7 @@
return "";
}
[(set_attr "isa" "noavx,avx_noavx512f,avx512f")
- (set_attr "gpr32" "1,0,1")
+ (set_attr "addr" "*,gpr16,*")
(set_attr "type" "sselog")
(set (attr "prefix_data16")
(if_then_else
@@ -17999,7 +17999,7 @@
vp<logic>\t{%2, %1, %0|%0, %1, %2}
vp<logic>d\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx_noavx512vl,avx512vl")
- (set_attr "gpr32" "1,0,1")
+ (set_attr "addr" "*,gpr16,*")
(set_attr "prefix" "orig,vex,evex")
(set_attr "prefix_data16" "1,*,*")
(set_attr "type" "sselog")
@@ -18980,7 +18980,10 @@
}
[(set_attr "isa" "noavx,noavx,avx,avx,<pinsr_evex_isa>,<pinsr_evex_isa>,avx2")
(set_attr "type" "sselog")
- (set_attr "gpr32" "0,0,1,1,1,1,1")
+ (set (attr "addr")
+ (if_then_else (eq_attr "alternative" "0,1")
+ (const_string "gpr16")
+ (const_string "*")))
(set (attr "prefix_rex")
(if_then_else
(and (not (match_test "TARGET_AVX"))
@@ -20157,7 +20160,7 @@
pextr<ssemodesuffix>\t{%2, %1, %0|%0, %1, %2}
vpextr<ssemodesuffix>\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "sse2_noavx,avx,sse4_noavx,avx")
- (set_attr "gpr32" "1,1,0,1")
+ (set_attr "addr" "*,*,gpr16,*")
(set_attr "type" "sselog1")
(set (attr "prefix_extra")
(if_then_else
@@ -20334,7 +20337,10 @@
}
[(set_attr "isa" "noavx,avx,avx512dq,noavx,noavx,avx")
(set_attr "type" "sselog1,sselog1,sselog1,sseishft1,sseishft1,sseishft1")
- (set_attr "gpr32" "0,1,1,1,1,1")
+ (set (attr "addr")
+ (if_then_else (eq_attr "alternative" "0")
+ (const_string "gpr16")
+ (const_string "*")))
(set (attr "prefix_extra")
(if_then_else (eq_attr "alternative" "0,1")
(const_string "1")
@@ -20425,7 +20431,10 @@
(const_string "imov")
]
(const_string "sselog1")))
- (set_attr "gpr32" "0,1,1,1,1,1,1,1,1,1")
+ (set (attr "addr")
+ (if_then_else (eq_attr "alternative" "0")
+ (const_string "gpr16")
+ (const_string "*")))
(set (attr "length_immediate")
(if_then_else (eq_attr "alternative" "0,1,2,4,5,6")
(const_string "1")
@@ -20585,10 +20594,10 @@
(const_string "mmxmov")
]
(const_string "sselog")))
- (set (attr "gpr32")
+ (set (attr "addr")
(if_then_else (eq_attr "alternative" "0,1")
- (const_string "0")
- (const_string "1")))
+ (const_string "gpr16")
+ (const_string "*")))
(set (attr "prefix_extra")
(if_then_else (eq_attr "alternative" "0,1,2,3")
(const_string "1")
@@ -20743,10 +20752,10 @@
(eq_attr "alternative" "0,1,2,3,4,5")
(const_string "sselog")
(const_string "ssemov")))
- (set (attr "gpr32")
+ (set (attr "addr")
(if_then_else (eq_attr "alternative" "0,1")
- (const_string "0")
- (const_string "1")))
+ (const_string "gpr16")
+ (const_string "*")))
(set (attr "prefix_rex")
(if_then_else (eq_attr "alternative" "0,1,2,3")
(const_string "1")
@@ -21339,7 +21348,7 @@
"%vldmxcsr\t%0"
[(set_attr "isa" "noavx,avx")
(set_attr "type" "sse")
- (set_attr "gpr32" "1,0")
+ (set_attr "addr" "*,gpr16")
(set_attr "atom_sse_attr" "mxcsr")
(set_attr "prefix" "maybe_vex")
(set_attr "memory" "load")])
@@ -21351,7 +21360,7 @@
"%vstmxcsr\t%0"
[(set_attr "isa" "noavx,avx")
(set_attr "type" "sse")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "atom_sse_attr" "mxcsr")
(set_attr "prefix" "maybe_vex")
(set_attr "memory" "store")])
@@ -21422,7 +21431,7 @@
"TARGET_AVX2"
"vph<plusminus_mnemonic>w\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "type" "sseiadd")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "vex")
(set_attr "mode" "OI")])
@@ -21448,7 +21457,7 @@
vph<plusminus_mnemonic>w\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx")
(set_attr "type" "sseiadd")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "atom_unit" "complex")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,vex")
@@ -21512,7 +21521,7 @@
"TARGET_AVX2"
"vph<plusminus_mnemonic>d\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "type" "sseiadd")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "vex")
(set_attr "mode" "OI")])
@@ -21536,7 +21545,7 @@
vph<plusminus_mnemonic>d\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx")
(set_attr "type" "sseiadd")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "atom_unit" "complex")
(set_attr "prefix_data16" "1,*")
(set_attr "prefix_extra" "1")
@@ -21576,7 +21585,7 @@
}
[(set_attr "mmx_isa" "native,sse_noavx,avx")
(set_attr "type" "sseiadd")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "atom_unit" "complex")
(set_attr "prefix_extra" "1")
(set (attr "prefix_rex") (symbol_ref "x86_extended_reg_mentioned_p (insn)"))
@@ -21721,7 +21730,7 @@
pmaddubsw\t{%2, %0|%0, %2}
vpmaddubsw\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "type" "sseiadd")
(set_attr "atom_unit" "simul")
(set_attr "prefix_extra" "1")
@@ -21850,7 +21859,7 @@
pmulhrsw\t{%2, %0|%0, %2}
vpmulhrsw\t{%2, %1, %0<mask_operand4>|%0<mask_operand4>, %1, %2}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "type" "sseimul")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,maybe_evex")
@@ -21974,7 +21983,7 @@
pshufb\t{%2, %0|%0, %2}
vpshufb\t{%2, %1, %0<mask_operand3>|%0<mask_operand3>, %1, %2}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "type" "sselog1")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,maybe_evex")
@@ -22042,7 +22051,7 @@
vpsign<ssemodesuffix>\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,avx")
(set_attr "type" "sselog1")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,vex")
(set_attr "mode" "<sseinsnmode>")])
@@ -22108,7 +22117,7 @@
}
}
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "type" "sseishft")
(set_attr "atom_unit" "sishuf")
(set_attr "prefix_extra" "1")
@@ -22183,7 +22192,7 @@
}
[(set_attr "mmx_isa" "native,sse_noavx,avx")
(set_attr "type" "sseishft")
- (set_attr "gpr32" "0,0,1")
+ (set_attr "addr" "gpr16,gpr16,*")
(set_attr "atom_unit" "sishuf")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
@@ -22206,7 +22215,7 @@
"TARGET_SSSE3"
"%vpabs<ssemodesuffix>\t{%1, %0|%0, %1}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "type" "sselog1")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "maybe_vex")
@@ -22355,7 +22364,7 @@
vblend<ssemodesuffix>\t{%3, %2, %1, %0|%0, %1, %2, %3}"
[(set_attr "isa" "noavx,noavx,avx")
(set_attr "type" "ssemov")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "length_immediate" "1")
(set_attr "prefix_data16" "1,1,*")
(set_attr "prefix_extra" "1")
@@ -22376,7 +22385,7 @@
vblendv<ssemodesuffix>\t{%3, %2, %1, %0|%0, %1, %2, %3}"
[(set_attr "isa" "noavx,noavx,avx")
(set_attr "type" "ssemov")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "length_immediate" "1")
(set_attr "prefix_data16" "1,1,*")
(set_attr "prefix_extra" "1")
@@ -22442,7 +22451,7 @@
"operands[3] = gen_lowpart (<MODE>mode, operands[3]);"
[(set_attr "isa" "noavx,noavx,avx")
(set_attr "type" "ssemov")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "length_immediate" "1")
(set_attr "prefix_data16" "1,1,*")
(set_attr "prefix_extra" "1")
@@ -22481,7 +22490,7 @@
}
[(set_attr "isa" "noavx,noavx,avx")
(set_attr "type" "ssemov")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "length_immediate" "1")
(set_attr "prefix_data16" "1,1,*")
(set_attr "prefix_extra" "1")
@@ -22530,7 +22539,7 @@
vdp<ssemodesuffix>\t{%3, %2, %1, %0|%0, %1, %2, %3}"
[(set_attr "isa" "noavx,noavx,avx")
(set_attr "type" "ssemul")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "length_immediate" "1")
(set_attr "prefix_data16" "1,1,*")
(set_attr "prefix_extra" "1")
@@ -22550,7 +22559,7 @@
"TARGET_SSE4_1"
"%vmovntdqa\t{%1, %0|%0, %1}"
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")
+ (set_attr "addr" "gpr16,gpr16,*")
(set_attr "type" "ssemov")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,orig,maybe_evex")
@@ -22569,9 +22578,8 @@
mpsadbw\t{%3, %2, %0|%0, %2, %3}
vmpsadbw\t{%3, %2, %1, %0|%0, %1, %2, %3}"
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")
+ (set_attr "addr" "gpr16")
(set_attr "type" "sselog1")
- (set_attr "gpr32" "0")
(set_attr "length_immediate" "1")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,orig,vex")
@@ -22591,7 +22599,7 @@
packusdw\t{%2, %0|%0, %2}
vpackusdw\t{%2, %1, %0<mask_operand3>|%0<mask_operand3>, %1, %2}"
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")
+ (set_attr "addr" "gpr16,gpr16,*")
(set_attr "type" "sselog")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,orig,<mask_prefix>")
@@ -22611,7 +22619,7 @@
vpblendvb\t{%3, %2, %1, %0|%0, %1, %2, %3}"
[(set_attr "isa" "noavx,noavx,avx")
(set_attr "type" "ssemov")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "*,*,1")
(set_attr "prefix" "orig,orig,vex")
@@ -22664,7 +22672,7 @@
""
[(set_attr "isa" "noavx,noavx,avx")
(set_attr "type" "ssemov")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "*,*,1")
(set_attr "prefix" "orig,orig,vex")
@@ -22706,7 +22714,7 @@
vpblendw\t{%3, %2, %1, %0|%0, %1, %2, %3}"
[(set_attr "isa" "noavx,noavx,avx")
(set_attr "type" "ssemov")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
(set_attr "prefix" "orig,orig,vex")
@@ -22778,7 +22786,7 @@
return "vpblendw\t{%3, %2, %1, %0|%0, %1, %2, %3}";
}
[(set_attr "type" "ssemov")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
(set_attr "prefix" "vex")
@@ -22805,7 +22813,7 @@
"TARGET_SSE4_1"
"%vphminposuw\t{%1, %0|%0, %1}"
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "type" "sselog1")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,orig,vex")
@@ -22945,7 +22953,7 @@
pmov<extsuffix>bw\t{%1, %0|%0, %1}
vpmov<extsuffix>bw\t{%1, %0<mask_operand2>|%0<mask_operand2>, %1}"
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")
+ (set_attr "addr" "gpr16,gpr16,*")
(set_attr "type" "ssemov")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,orig,maybe_evex")
@@ -23001,7 +23009,7 @@
}
}
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")])
+ (set_attr "addr" "gpr16,gpr16,*")])
(define_insn_and_split "*sse4_1_zero_extendv8qiv8hi2_4"
[(set (match_operand:V16QI 0 "register_operand" "=Yr,*x,Yw")
@@ -23037,7 +23045,7 @@
operands[1] = lowpart_subreg (V16QImode, operands[1], <ssehalfvecmode>mode);
}
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")])
+ (set_attr "addr" "gpr16,gpr16,*")])
(define_expand "<insn>v8qiv8hi2"
[(set (match_operand:V8HI 0 "register_operand")
@@ -23160,7 +23168,7 @@
"TARGET_SSE4_1 && <mask_avx512vl_condition>"
"%vpmov<extsuffix>bd\t{%1, %0<mask_operand2>|%0<mask_operand2>, %1}"
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")
+ (set_attr "addr" "gpr16,gpr16,*")
(set_attr "type" "ssemov")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,orig,maybe_evex")
@@ -23333,7 +23341,7 @@
"TARGET_SSE4_1 && <mask_avx512vl_condition>"
"%vpmov<extsuffix>wd\t{%1, %0<mask_operand2>|%0<mask_operand2>, %1}"
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")
+ (set_attr "addr" "gpr16,gpr16,*")
(set_attr "type" "ssemov")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,orig,maybe_evex")
@@ -23406,7 +23414,7 @@
}
}
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")])
+ (set_attr "addr" "gpr16,gpr16,*")])
(define_insn_and_split "*sse4_1_zero_extendv4hiv4si2_4"
[(set (match_operand:V8HI 0 "register_operand" "=Yr,*x,v")
@@ -23440,7 +23448,7 @@
operands[1] = lowpart_subreg (V8HImode, operands[1], <ssehalfvecmode>mode);
}
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")])
+ (set_attr "addr" "gpr16,gpr16,*")])
(define_insn "avx512f_<code>v8qiv8di2<mask_name>"
[(set (match_operand:V8DI 0 "register_operand" "=v")
@@ -23584,7 +23592,7 @@
"TARGET_SSE4_1 && <mask_avx512vl_condition>"
"%vpmov<extsuffix>bq\t{%1, %0<mask_operand2>|%0<mask_operand2>, %1}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "type" "ssemov")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "maybe_evex")
@@ -23723,7 +23731,7 @@
"TARGET_SSE4_1 && <mask_avx512vl_condition>"
"%vpmov<extsuffix>wq\t{%1, %0<mask_operand2>|%0<mask_operand2>, %1}"
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")
+ (set_attr "addr" "gpr16,gpr16,*")
(set_attr "type" "ssemov")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,orig,maybe_evex")
@@ -23889,7 +23897,7 @@
"TARGET_SSE4_1 && <mask_avx512vl_condition>"
"%vpmov<extsuffix>dq\t{%1, %0<mask_operand2>|%0<mask_operand2>, %1}"
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")
+ (set_attr "addr" "gpr16,gpr16,*")
(set_attr "type" "ssemov")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,orig,maybe_evex")
@@ -23938,7 +23946,7 @@
}
}
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")])
+ (set_attr "addr" "gpr16,gpr16,*")])
(define_insn_and_split "*sse4_1_zero_extendv2siv2di2_4"
[(set (match_operand:V4SI 0 "register_operand" "=Yr,*x,v")
@@ -23968,7 +23976,7 @@
operands[1] = lowpart_subreg (V4SImode, operands[1], V2SImode);
}
[(set_attr "isa" "noavx,noavx,avx")
- (set_attr "gpr32" "0,0,1")])
+ (set_attr "addr" "gpr16,gpr16,*")])
(define_expand "<insn>v2siv2di2"
[(set (match_operand:V2DI 0 "register_operand")
@@ -24001,7 +24009,7 @@
"TARGET_AVX"
"vtest<ssemodesuffix>\t{%1, %0|%0, %1}"
[(set_attr "type" "ssecomi")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "vex")
(set_attr "mode" "<MODE>")])
@@ -24017,7 +24025,7 @@
"%vptest\t{%1, %0|%0, %1}"
[(set_attr "isa" "noavx,noavx,avx")
(set_attr "type" "ssecomi")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,orig,vex")
(set (attr "btver2_decode")
@@ -24060,7 +24068,7 @@
"%vptest\t{%1, %0|%0, %1}"
[(set_attr "isa" "noavx,noavx,avx")
(set_attr "type" "ssecomi")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,orig,vex")
(set_attr "mode" "TI")])
@@ -24178,7 +24186,7 @@
"%vround<ssemodesuffix>\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,noavx,avx")
(set_attr "type" "ssecvt")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_data16" "1,1,*")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
@@ -24290,7 +24298,7 @@
}
[(set_attr "isa" "noavx,noavx,noavx512f,avx512f")
(set_attr "type" "ssecvt")
- (set_attr "gpr32" "0,0,0,1")
+ (set_attr "addr" "gpr16,gpr16,gpr16,*")
(set_attr "length_immediate" "1")
(set_attr "prefix_data16" "1,1,*,*")
(set_attr "prefix_extra" "1")
@@ -24327,7 +24335,7 @@
}
[(set_attr "isa" "noavx,noavx,noavx512f,avx512f")
(set_attr "type" "ssecvt")
- (set_attr "gpr32" "0,0,0,1")
+ (set_attr "addr" "gpr16,gpr16,gpr16,*")
(set_attr "length_immediate" "1")
(set_attr "prefix_data16" "1,1,*,*")
(set_attr "prefix_extra" "1")
@@ -24596,7 +24604,7 @@
"TARGET_SSE4_2"
"%vpcmpestri\t{%5, %3, %1|%1, %3, %5}"
[(set_attr "type" "sselog")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "maybe_vex")
(set_attr "length_immediate" "1")
@@ -24624,7 +24632,7 @@
"TARGET_SSE4_2"
"%vpcmpestrm\t{%5, %3, %1|%1, %3, %5}"
[(set_attr "type" "sselog")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
(set_attr "prefix" "maybe_vex")
@@ -24650,7 +24658,7 @@
%vpcmpestri\t{%6, %4, %2|%2, %4, %6}
%vpcmpestri\t{%6, %4, %2|%2, %4, %6}"
[(set_attr "type" "sselog")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
(set_attr "memory" "none,load,none,load")
@@ -24705,7 +24713,7 @@
DONE;
}
[(set_attr "type" "sselog")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
(set_attr "memory" "none,load")
@@ -24727,7 +24735,7 @@
"TARGET_SSE4_2"
"%vpcmpistri\t{%3, %2, %1|%1, %2, %3}"
[(set_attr "type" "sselog")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
(set_attr "prefix" "maybe_vex")
@@ -24751,7 +24759,7 @@
"TARGET_SSE4_2"
"%vpcmpistrm\t{%3, %2, %1|%1, %2, %3}"
[(set_attr "type" "sselog")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
(set_attr "prefix" "maybe_vex")
@@ -24775,7 +24783,7 @@
%vpcmpistri\t{%4, %3, %2|%2, %3, %4}
%vpcmpistri\t{%4, %3, %2|%2, %3, %4}"
[(set_attr "type" "sselog")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
(set_attr "memory" "none,load,none,load")
@@ -26202,7 +26210,7 @@
vaesenc\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,aes,avx512vl")
(set_attr "type" "sselog1")
- (set_attr "gpr32" "0,1,1")
+ (set_attr "addr" "gpr16,*,*")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,vex,evex")
(set_attr "btver2_decode" "double,double,double")
@@ -26220,7 +26228,7 @@
vaesenclast\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,aes,avx512vl")
(set_attr "type" "sselog1")
- (set_attr "gpr32" "0,1,1")
+ (set_attr "addr" "gpr16,*,*")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,vex,evex")
(set_attr "btver2_decode" "double,double,double")
@@ -26238,7 +26246,7 @@
vaesdec\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,aes,avx512vl")
(set_attr "type" "sselog1")
- (set_attr "gpr32" "0,1,1")
+ (set_attr "addr" "gpr16,*,*")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,vex,evex")
(set_attr "btver2_decode" "double,double,double")
@@ -26255,7 +26263,7 @@
vaesdeclast\t{%2, %1, %0|%0, %1, %2}
vaesdeclast\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "isa" "noavx,aes,avx512vl")
- (set_attr "gpr32" "0,1,1")
+ (set_attr "addr" "gpr16,*,*")
(set_attr "type" "sselog1")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,vex,evex")
@@ -26269,7 +26277,7 @@
"TARGET_AES"
"%vaesimc\t{%1, %0|%0, %1}"
[(set_attr "type" "sselog1")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "maybe_vex")
(set_attr "mode" "TI")])
@@ -26282,7 +26290,7 @@
"TARGET_AES"
"%vaeskeygenassist\t{%2, %1, %0|%0, %1, %2}"
[(set_attr "type" "sselog1")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
(set_attr "prefix" "maybe_vex")
@@ -26301,7 +26309,7 @@
vpclmulqdq\t{%3, %2, %1, %0|%0, %1, %2, %3}"
[(set_attr "isa" "noavx,avx,vpclmulqdqvl")
(set_attr "type" "sselog1")
- (set_attr "gpr32" "0,1,1")
+ (set_attr "addr" "gpr16,*,*")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
(set_attr "prefix" "orig,vex,evex")
@@ -26743,7 +26751,7 @@
(set_attr "mode" "<sseinsnmode>")])
;; TODO (APX): vmovaps supports EGPR but not others, could split
-;; pattern to enable gpr32 for this one.
+;; pattern to enable rex2 address for this one.
(define_insn "avx2_permv2ti"
[(set (match_operand:V4DI 0 "register_operand" "=x")
(unspec:V4DI
@@ -26775,7 +26783,7 @@
return "vperm2i128\t{%3, %2, %1, %0|%0, %1, %2, %3}";
}
[(set_attr "type" "sselog")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix" "vex")
(set_attr "mode" "OI")])
@@ -27109,7 +27117,10 @@
vinsert<shuffletype>32x4\t{$1, %1, %0, %0|%0, %0, %1, 1}"
[(set_attr "isa" "noavx512vl,*,*,avx512dq,avx512dq,avx512vl,avx512vl")
(set_attr "type" "ssemov,sselog1,sselog1,ssemov,sselog1,ssemov,sselog1")
- (set_attr "gpr32" "0,1,1,1,1,1,1")
+ (set (attr "addr")
+ (if_then_else (eq_attr "alternative" "0")
+ (const_string "gpr16")
+ (const_string "*")))
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "0,1,1,0,1,0,1")
(set_attr "prefix" "vex,vex,vex,evex,evex,evex,evex")
@@ -27404,7 +27415,7 @@
"TARGET_AVX"
"vperm2<i128>\t{%3, %2, %1, %0|%0, %1, %2, %3}"
[(set_attr "type" "sselog")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
(set_attr "prefix" "vex")
@@ -27432,7 +27443,7 @@
return "vperm2<i128>\t{%3, %2, %1, %0|%0, %1, %2, %3}";
}
[(set_attr "type" "sselog")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
(set_attr "prefix" "vex")
@@ -27537,7 +27548,7 @@
return "vinsert<i128>\t{$0x0, %2, %1, %0|%0, %1, %2, 0x0}";
}
[(set_attr "isa" "noavx512vl,avx512vl")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "type" "sselog")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
@@ -27582,7 +27593,7 @@
return "vinsert<i128>\t{$0x0, %2, %1, %0|%0, %1, %2, 0x0}";
}
[(set_attr "isa" "noavx512vl,avx512vl")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "type" "sselog")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
@@ -27605,7 +27616,7 @@
return "vinsert<i128>\t{$0x1, %2, %1, %0|%0, %1, %2, 0x1}";
}
[(set_attr "isa" "noavx512vl,avx512vl")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "type" "sselog")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
@@ -27627,7 +27638,7 @@
vinsert%~128\t{$0x0, %2, %1, %0|%0, %1, %2, 0x0}
vinserti32x4\t{$0x0, %2, %1, %0|%0, %1, %2, 0x0}"
[(set_attr "isa" "noavx512vl,avx512vl")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "type" "sselog")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
@@ -27649,7 +27660,7 @@
vinsert%~128\t{$0x1, %2, %1, %0|%0, %1, %2, 0x1}
vinserti32x4\t{$0x1, %2, %1, %0|%0, %1, %2, 0x1}"
[(set_attr "isa" "noavx512vl,avx512vl")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "type" "sselog")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
@@ -27676,7 +27687,7 @@
vinserti32x4\t{$0x0, %2, %1, %0|%0, %1, %2, 0x0}"
[(set_attr "isa" "noavx512vl,avx512vl")
(set_attr "type" "sselog")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
(set_attr "prefix" "vex,evex")
@@ -27701,7 +27712,7 @@
vinsert%~128\t{$0x1, %2, %1, %0|%0, %1, %2, 0x1}
vinserti32x4\t{$0x1, %2, %1, %0|%0, %1, %2, 0x1}"
[(set_attr "isa" "noavx512vl,avx512vl")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "type" "sselog")
(set_attr "prefix_extra" "1")
(set_attr "length_immediate" "1")
@@ -27722,7 +27733,7 @@
return "vmaskmov<ssefltmodesuffix>\t{%1, %2, %0|%0, %2, %1}";
}
[(set_attr "type" "sselog1")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "vex")
(set_attr "btver2_decode" "vector")
@@ -27743,7 +27754,7 @@
return "vmaskmov<ssefltmodesuffix>\t{%2, %1, %0|%0, %1, %2}";
}
[(set_attr "type" "sselog1")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "vex")
(set_attr "btver2_decode" "vector")
@@ -28102,7 +28113,7 @@
}
}
[(set_attr "isa" "noavx512f,avx512f,*,*")
- (set_attr "gpr32" "0,1,1,1")
+ (set_attr "addr" "gpr16,*,*,*")
(set_attr "type" "sselog,sselog,ssemov,ssemov")
(set_attr "prefix_extra" "1,1,*,*")
(set_attr "length_immediate" "1,1,*,*")
@@ -28352,7 +28363,7 @@
"TARGET_AVX2"
"%M3v<sseintprefix>gatherd<ssemodesuffix>\t{%1, %7, %0|%0, %7, %1}"
[(set_attr "type" "ssemov")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix" "vex")
(set_attr "mode" "<sseinsnmode>")])
@@ -28373,7 +28384,7 @@
"TARGET_AVX2"
"%M2v<sseintprefix>gatherd<ssemodesuffix>\t{%1, %6, %0|%0, %6, %1}"
[(set_attr "type" "ssemov")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix" "vex")
(set_attr "mode" "<sseinsnmode>")])
@@ -28415,7 +28426,7 @@
"TARGET_AVX2"
"%M3v<sseintprefix>gatherq<ssemodesuffix>\t{%5, %7, %2|%2, %7, %5}"
[(set_attr "type" "ssemov")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix" "vex")
(set_attr "mode" "<sseinsnmode>")])
@@ -28440,7 +28451,7 @@
return "%M2v<sseintprefix>gatherq<ssemodesuffix>\t{%4, %6, %0|%0, %6, %4}";
}
[(set_attr "type" "ssemov")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix" "vex")
(set_attr "mode" "<sseinsnmode>")])
@@ -28464,7 +28475,7 @@
"TARGET_AVX2"
"%M3v<sseintprefix>gatherq<ssemodesuffix>\t{%5, %7, %0|%0, %7, %5}"
[(set_attr "type" "ssemov")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix" "vex")
(set_attr "mode" "<sseinsnmode>")])
@@ -28488,7 +28499,7 @@
"TARGET_AVX2"
"%M2v<sseintprefix>gatherq<ssemodesuffix>\t{%4, %6, %0|%0, %6, %4}"
[(set_attr "type" "ssemov")
- (set_attr "gpr32" "0")
+ (set_attr "addr" "gpr16")
(set_attr "prefix" "vex")
(set_attr "mode" "<sseinsnmode>")])
@@ -29688,7 +29699,7 @@
gf2p8affineinvqb\t{%3, %2, %0| %0, %2, %3}
vgf2p8affineinvqb\t{%3, %2, %1, %0<mask_operand4>| %0<mask_operand4>, %1, %2, %3}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,maybe_evex")
(set_attr "mode" "<sseinsnmode>")])
@@ -29705,7 +29716,7 @@
gf2p8affineqb\t{%3, %2, %0| %0, %2, %3}
vgf2p8affineqb\t{%3, %2, %1, %0<mask_operand4>| %0<mask_operand4>, %1, %2, %3}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,maybe_evex")
(set_attr "mode" "<sseinsnmode>")])
@@ -29721,7 +29732,7 @@
gf2p8mulb\t{%2, %0| %0, %2}
vgf2p8mulb\t{%2, %1, %0<mask_operand3>| %0<mask_operand3>, %1, %2}"
[(set_attr "isa" "noavx,avx")
- (set_attr "gpr32" "0,1")
+ (set_attr "addr" "gpr16,*")
(set_attr "prefix_extra" "1")
(set_attr "prefix" "orig,maybe_evex")
(set_attr "mode" "<sseinsnmode>")])