[binutils-gdb] aarch64: [SME] Add MOV and MOVA instructions

Przemyslaw Wirkus wirkus@sourceware.org
Wed Nov 17 20:36:35 GMT 2021


https://sourceware.org/git/gitweb.cgi?p=binutils-gdb.git;h=7bb5f07c8aa5168009f1e7b6857a30f0ee5ad16a

commit 7bb5f07c8aa5168009f1e7b6857a30f0ee5ad16a
Author: Przemyslaw Wirkus <przemyslaw.wirkus@arm.com>
Date:   Wed Nov 17 19:31:25 2021 +0000

    aarch64: [SME] Add MOV and MOVA instructions
    
    This patch is adding new MOV (alias) and MOVA SME instruction.
    
    gas/ChangeLog:
    
            * config/tc-aarch64.c (enum sme_hv_slice): new enum.
            (struct reloc_entry): Added ZAH and ZAV registers.
            (parse_sme_immediate): Immediate parser.
            (parse_sme_za_hv_tiles_operand): ZA tile parser.
            (parse_sme_za_hv_tiles_operand_index): Index parser.
            (parse_operands): Added ZA tile parser calls.
            (REGNUMS): New macro. Regs with suffix.
            (REGSET16S): New macro. 16 regs with suffix.
            * testsuite/gas/aarch64/sme-2-illegal.d: New test.
            * testsuite/gas/aarch64/sme-2-illegal.l: New test.
            * testsuite/gas/aarch64/sme-2-illegal.s: New test.
            * testsuite/gas/aarch64/sme-2.d: New test.
            * testsuite/gas/aarch64/sme-2.s: New test.
            * testsuite/gas/aarch64/sme-2a.d: New test.
            * testsuite/gas/aarch64/sme-2a.s: New test.
            * testsuite/gas/aarch64/sme-3-illegal.d: New test.
            * testsuite/gas/aarch64/sme-3-illegal.l: New test.
            * testsuite/gas/aarch64/sme-3-illegal.s: New test.
            * testsuite/gas/aarch64/sme-3.d: New test.
            * testsuite/gas/aarch64/sme-3.s: New test.
            * testsuite/gas/aarch64/sme-3a.d: New test.
            * testsuite/gas/aarch64/sme-3a.s: New test.
    
    include/ChangeLog:
    
            * opcode/aarch64.h (enum aarch64_opnd): New enums
            AARCH64_OPND_SME_ZA_HV_idx_src and
            AARCH64_OPND_SME_ZA_HV_idx_dest.
            (struct aarch64_opnd_info): New ZA tile vector struct.
    
    opcodes/ChangeLog:
    
            * aarch64-asm.c (aarch64_ins_sme_za_hv_tiles):
            New inserter.
            * aarch64-asm.h (AARCH64_DECL_OPD_INSERTER):
            New inserter ins_sme_za_hv_tiles.
            * aarch64-dis.c (aarch64_ext_sme_za_hv_tiles):
            New extractor.
            * aarch64-dis.h (AARCH64_DECL_OPD_EXTRACTOR):
            New extractor ext_sme_za_hv_tiles.
            * aarch64-opc.c (aarch64_print_operand):
            Handle SME_ZA_HV_idx_src and SME_ZA_HV_idx_dest.
            * aarch64-opc.h (enum aarch64_field_kind): New enums
            FLD_SME_size_10, FLD_SME_Q, FLD_SME_V and FLD_SME_Rv.
            (struct aarch64_operand): Increase fields size to 5.
            * aarch64-tbl.h (OP_SME_BHSDQ_PM_BHSDQ): New qualifiers
            aarch64-asm-2.c: Regenerate.
            aarch64-dis-2.c: Regenerate.
            aarch64-opc-2.c: Regenerate.

Diff:
---
 gas/config/tc-aarch64.c                   | 219 +++++++++++++++++-
 gas/testsuite/gas/aarch64/sme-2-illegal.d |   3 +
 gas/testsuite/gas/aarch64/sme-2-illegal.l |  27 +++
 gas/testsuite/gas/aarch64/sme-2-illegal.s |  32 +++
 gas/testsuite/gas/aarch64/sme-2.d         |  43 ++++
 gas/testsuite/gas/aarch64/sme-2.s         |  52 +++++
 gas/testsuite/gas/aarch64/sme-2a.d        |  29 +++
 gas/testsuite/gas/aarch64/sme-2a.s        |  26 +++
 gas/testsuite/gas/aarch64/sme-3-illegal.d |   3 +
 gas/testsuite/gas/aarch64/sme-3-illegal.l |  11 +
 gas/testsuite/gas/aarch64/sme-3-illegal.s |  14 ++
 gas/testsuite/gas/aarch64/sme-3.d         |  31 +++
 gas/testsuite/gas/aarch64/sme-3.s         |  31 +++
 gas/testsuite/gas/aarch64/sme-3a.d        |  29 +++
 gas/testsuite/gas/aarch64/sme-3a.s        |  26 +++
 include/opcode/aarch64.h                  |  14 ++
 opcodes/aarch64-asm-2.c                   |   9 +-
 opcodes/aarch64-asm.c                     |  55 +++++
 opcodes/aarch64-asm.h                     |   1 +
 opcodes/aarch64-dis-2.c                   | 371 ++++++++++++++++--------------
 opcodes/aarch64-dis.c                     |  58 +++++
 opcodes/aarch64-dis.h                     |   1 +
 opcodes/aarch64-opc-2.c                   |   2 +
 opcodes/aarch64-opc.c                     |  15 ++
 opcodes/aarch64-opc.h                     |   7 +-
 opcodes/aarch64-tbl.h                     |  19 ++
 26 files changed, 952 insertions(+), 176 deletions(-)

diff --git a/gas/config/tc-aarch64.c b/gas/config/tc-aarch64.c
index 7c94e9b6c31..ce761283371 100644
--- a/gas/config/tc-aarch64.c
+++ b/gas/config/tc-aarch64.c
@@ -99,6 +99,17 @@ enum vector_el_type
   NT_merge
 };
 
+/* SME horizontal or vertical slice indicator, encoded in "V".
+   Values:
+     0 - Horizontal
+     1 - vertical
+*/
+enum sme_hv_slice
+{
+  HV_horizontal = 0,
+  HV_vertical = 1
+};
+
 /* Bits for DEFINED field in vector_type_el.  */
 #define NTA_HASTYPE     1
 #define NTA_HASINDEX    2
@@ -279,6 +290,8 @@ struct reloc_entry
   BASIC_REG_TYPE(ZN)	/* z[0-31] */	\
   BASIC_REG_TYPE(PN)	/* p[0-15] */	\
   BASIC_REG_TYPE(ZA)	/* za[0-15] */	\
+  BASIC_REG_TYPE(ZAH)	/* za[0-15]h */	\
+  BASIC_REG_TYPE(ZAV)	/* za[0-15]v */	\
   /* Typecheck: any 64-bit int reg         (inc SP exc XZR).  */	\
   MULTI_REG_TYPE(R64_SP, REG_TYPE(R_64) | REG_TYPE(SP_64))		\
   /* Typecheck: same, plus SVE registers.  */				\
@@ -4276,6 +4289,178 @@ parse_sme_zada_operand (char **str, aarch64_opnd_qualifier_t *qualifier)
   return regno;
 }
 
+/* Parse STR for unsigned, immediate (1-2 digits) in format:
+
+     #<imm>
+     <imm>
+
+  Function return TRUE if immediate was found, or FALSE.
+*/
+static bool
+parse_sme_immediate (char **str, int64_t *imm)
+{
+  int64_t val;
+  if (! parse_constant_immediate (str, &val, REG_TYPE_R_N))
+    return false;
+
+  *imm = val;
+  return true;
+}
+
+/* Parse index with vector select register and immediate:
+
+   [<Wv>, <imm>]
+   [<Wv>, #<imm>]
+   where <Wv> is in W12-W15 range and # is optional for immediate.
+
+   Function performs extra check for mandatory immediate value if REQUIRE_IMM
+   is set to true.
+
+   On success function returns TRUE and populated VECTOR_SELECT_REGISTER and
+   IMM output.
+*/
+static bool
+parse_sme_za_hv_tiles_operand_index (char **str,
+                                     int *vector_select_register,
+                                     int64_t *imm)
+{
+  const reg_entry *reg;
+
+  if (!skip_past_char (str, '['))
+    {
+      set_syntax_error (_("expected '['"));
+      return false;
+    }
+
+  /* Vector select register W12-W15 encoded in the 2-bit Rv field.  */
+  reg = parse_reg (str);
+  if (reg == NULL || reg->type != REG_TYPE_R_32
+      || reg->number < 12 || reg->number > 15)
+    {
+      set_syntax_error (_("expected vector select register W12-W15"));
+      return false;
+    }
+  *vector_select_register = reg->number;
+
+  if (!skip_past_char (str, ','))    /* Optional index offset immediate.  */
+    {
+      set_syntax_error (_("expected ','"));
+      return false;
+    }
+
+  if (!parse_sme_immediate (str, imm))
+    {
+      set_syntax_error (_("index offset immediate expected"));
+      return false;
+    }
+
+  if (!skip_past_char (str, ']'))
+    {
+      set_syntax_error (_("expected ']'"));
+      return false;
+    }
+
+  return true;
+}
+
+/* Parse SME ZA horizontal or vertical vector access to tiles.
+   Function extracts from STR to SLICE_INDICATOR <HV> horizontal (0) or
+   vertical (1) ZA tile vector orientation. VECTOR_SELECT_REGISTER
+   contains <Wv> select register and corresponding optional IMMEDIATE.
+   In addition QUALIFIER is extracted.
+
+   Field format examples:
+
+   ZA0<HV>.B[<Wv>, #<imm>]
+   <ZAn><HV>.H[<Wv>, #<imm>]
+   <ZAn><HV>.S[<Wv>, #<imm>]
+   <ZAn><HV>.D[<Wv>, #<imm>]
+   <ZAn><HV>.Q[<Wv>, #<imm>]
+
+   Function returns <ZAda> register number or PARSE_FAIL.
+*/
+static int
+parse_sme_za_hv_tiles_operand (char **str,
+                               enum sme_hv_slice *slice_indicator,
+                               int *vector_select_register,
+                               int *imm,
+                               aarch64_opnd_qualifier_t *qualifier)
+{
+  char *qh, *qv;
+  int regno;
+  int regno_limit;
+  int64_t imm_limit;
+  int64_t imm_value;
+  const reg_entry *reg;
+
+  qh = qv = *str;
+  if ((reg = parse_reg_with_qual (&qh, REG_TYPE_ZAH, qualifier)) != NULL)
+    {
+      *slice_indicator = HV_horizontal;
+      *str = qh;
+    }
+  else if ((reg = parse_reg_with_qual (&qv, REG_TYPE_ZAV, qualifier)) != NULL)
+    {
+      *slice_indicator = HV_vertical;
+      *str = qv;
+    }
+  else
+    return PARSE_FAIL;
+  regno = reg->number;
+
+  switch (*qualifier)
+    {
+    case AARCH64_OPND_QLF_S_B:
+      regno_limit = 0;
+      imm_limit = 15;
+      break;
+    case AARCH64_OPND_QLF_S_H:
+      regno_limit = 1;
+      imm_limit = 7;
+      break;
+    case AARCH64_OPND_QLF_S_S:
+      regno_limit = 3;
+      imm_limit = 3;
+      break;
+    case AARCH64_OPND_QLF_S_D:
+      regno_limit = 7;
+      imm_limit = 1;
+      break;
+    case AARCH64_OPND_QLF_S_Q:
+      regno_limit = 15;
+      imm_limit = 0;
+      break;
+    default:
+      set_syntax_error (_("invalid ZA tile element size, allowed b, h, s, d and q"));
+      return PARSE_FAIL;
+    }
+
+  /* Check if destination register ZA tile vector is in range for given
+     instruction variant.  */
+  if (regno < 0 || regno > regno_limit)
+    {
+      set_syntax_error (_("ZA tile vector out of range"));
+      return PARSE_FAIL;
+    }
+
+  if (!parse_sme_za_hv_tiles_operand_index (str, vector_select_register,
+                                            &imm_value))
+    return PARSE_FAIL;
+
+  /* Check if optional index offset is in the range for instruction
+     variant.  */
+  if (imm_value < 0 || imm_value > imm_limit)
+    {
+      set_syntax_error (_("index offset out of range"));
+      return PARSE_FAIL;
+    }
+
+  *imm = imm_value;
+
+  return regno;
+}
+
+
 /* Parse a system register or a PSTATE field name for an MSR/MRS instruction.
    Returns the encoding for the option, or PARSE_FAIL.
 
@@ -6989,6 +7174,26 @@ parse_operands (char *str, const aarch64_opcode *opcode)
 	  info->qualifier = qualifier;
 	  break;
 
+	case AARCH64_OPND_SME_ZA_HV_idx_src:
+	case AARCH64_OPND_SME_ZA_HV_idx_dest:
+	  {
+	    enum sme_hv_slice vector_indicator;
+	    int vector_select_register;
+	    int imm;
+	    val = parse_sme_za_hv_tiles_operand (&str, &vector_indicator,
+	                                         &vector_select_register,
+	                                         &imm,
+	                                         &qualifier);
+	    if (val == PARSE_FAIL)
+	      goto failure;
+	    info->za_tile_vector.regno = val;
+	    info->za_tile_vector.index.regno = vector_select_register;
+	    info->za_tile_vector.index.imm = imm;
+	    info->za_tile_vector.v = vector_indicator;
+	    info->qualifier = qualifier;
+	    break;
+	  }
+
 	default:
 	  as_fatal (_("unhandled operand code %d"), operands[i]);
 	}
@@ -7533,11 +7738,17 @@ aarch64_canonicalize_symbol_name (char *name)
 #define REGDEF(s,n,t) { #s, n, REG_TYPE_##t, true }
 #define REGDEF_ALIAS(s, n, t) { #s, n, REG_TYPE_##t, false}
 #define REGNUM(p,n,t) REGDEF(p##n, n, t)
+#define REGNUMS(p,n,s,t) REGDEF(p##n##s, n, t)
 #define REGSET16(p,t) \
   REGNUM(p, 0,t), REGNUM(p, 1,t), REGNUM(p, 2,t), REGNUM(p, 3,t), \
   REGNUM(p, 4,t), REGNUM(p, 5,t), REGNUM(p, 6,t), REGNUM(p, 7,t), \
   REGNUM(p, 8,t), REGNUM(p, 9,t), REGNUM(p,10,t), REGNUM(p,11,t), \
   REGNUM(p,12,t), REGNUM(p,13,t), REGNUM(p,14,t), REGNUM(p,15,t)
+#define REGSET16S(p,s,t) \
+  REGNUMS(p, 0,s,t), REGNUMS(p, 1,s,t), REGNUMS(p, 2,s,t), REGNUMS(p, 3,s,t), \
+  REGNUMS(p, 4,s,t), REGNUMS(p, 5,s,t), REGNUMS(p, 6,s,t), REGNUMS(p, 7,s,t), \
+  REGNUMS(p, 8,s,t), REGNUMS(p, 9,s,t), REGNUMS(p,10,s,t), REGNUMS(p,11,s,t), \
+  REGNUMS(p,12,s,t), REGNUMS(p,13,s,t), REGNUMS(p,14,s,t), REGNUMS(p,15,s,t)
 #define REGSET31(p,t) \
   REGSET16(p, t), \
   REGNUM(p,16,t), REGNUM(p,17,t), REGNUM(p,18,t), REGNUM(p,19,t), \
@@ -7588,7 +7799,13 @@ static const reg_entry reg_names[] = {
   REGSET16 (p, PN), REGSET16 (P, PN),
 
   /* SME ZA tile registers.  */
-  REGSET16 (za, ZA), REGSET16 (ZA, ZA)
+  REGSET16 (za, ZA), REGSET16 (ZA, ZA),
+
+  /* SME ZA tile registers (horizontal slice).  */
+  REGSET16S (za, h, ZAH), REGSET16S (ZA, H, ZAH),
+
+  /* SME ZA tile registers (vertical slice).  */
+  REGSET16S (za, v, ZAV), REGSET16S (ZA, V, ZAV)
 };
 
 #undef REGDEF
diff --git a/gas/testsuite/gas/aarch64/sme-2-illegal.d b/gas/testsuite/gas/aarch64/sme-2-illegal.d
new file mode 100644
index 00000000000..0ff10535ae0
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme-2-illegal.d
@@ -0,0 +1,3 @@
+#as: -march=armv8-a+sme
+#source: sme-2-illegal.s
+#error_output: sme-2-illegal.l
diff --git a/gas/testsuite/gas/aarch64/sme-2-illegal.l b/gas/testsuite/gas/aarch64/sme-2-illegal.l
new file mode 100644
index 00000000000..d36456175fe
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme-2-illegal.l
@@ -0,0 +1,27 @@
+[^:]*: Assembler messages:
+[^:]*:[0-9]+: Error: ZA tile vector out of range at operand 3 -- `mova z0\.b,p0/m,za1h\.b\[w12,#0\]'
+[^:]*:[0-9]+: Error: ZA tile vector out of range at operand 3 -- `mova z0\.h,p0/m,za2h\.h\[w12,#0\]'
+[^:]*:[0-9]+: Error: ZA tile vector out of range at operand 3 -- `mova z0\.s,p0/m,za4h\.s\[w12,#0\]'
+[^:]*:[0-9]+: Error: ZA tile vector out of range at operand 3 -- `mova z0\.d,p0/m,za8h\.d\[w12,#0\]'
+[^:]*:[0-9]+: Error: operand 3 must be an SME horizontal or vertical vector access register -- `mova z0\.q,p0/m,za16h.q\[w12\]'
+[^:]*:[0-9]+: Error: index offset out of range at operand 3 -- `mova z31\.b,p7/m,za0v\.b\[w15,#16\]'
+[^:]*:[0-9]+: Error: index offset out of range at operand 3 -- `mova z31\.h,p7/m,za1v\.h\[w15,#8\]'
+[^:]*:[0-9]+: Error: index offset out of range at operand 3 -- `mova z31\.s,p7/m,za3v\.s\[w15,#4\]'
+[^:]*:[0-9]+: Error: index offset out of range at operand 3 -- `mova z31\.d,p7/m,za7v\.d\[w15,#2\]'
+[^:]*:[0-9]+: Error: index offset out of range at operand 3 -- `mova z31\.q,p7/m,za15v\.q\[w15,#1\]'
+[^:]*:[0-9]+: Error: expected ',' at operand 3 -- `mova z31\.q,p7/m,za15v\.q\[w15\]'
+[^:]*:[0-9]+: Error: expected '\[' at operand 3 -- `mova z0\.b,p0/m,za0v.b'
+[^:]*:[0-9]+: Error: expected vector select register W12-W15 at operand 3 -- `mova z31\.b,p7/m,za0v\.b\[15,w15\]'
+[^:]*:[0-9]+: Error: expected ',' at operand 3 -- `mova z0\.h,p0/m,za0v\.h\[w12\. 0\]'
+[^:]*:[0-9]+: Error: expected vector select register W12-W15 at operand 3 -- `mova z0\.s,p0/m,za0v\.s\[x12,0]'
+[^:]*:[0-9]+: Error: expected vector select register W12-W15 at operand 3 -- `mova z0\.d,p0/m,za0v\.d\[w21,0\]'
+[^:]*:[0-9]+: Error: expected vector select register W12-W15 at operand 3 -- `mova z0\.q,p0/m,za0v\.q\[s12\]'
+[^:]*:[0-9]+: Error: expected vector select register W12-W15 at operand 3 -- `mova z0\.q,p0/m,za0v\.q\[d12\]'
+[^:]*:[0-9]+: Error: index offset immediate expected at operand 3 -- `mova z0.q,p0/m,za0v\.q\[w12,\]'
+[^:]*:[0-9]+: Error: expected ',' at operand 3 -- `mova z0\.q,p0/m,za0v\.q\[w12\.\]'
+[^:]*:[0-9]+: Error: index offset immediate expected at operand 3 -- `mova z0\.q,p0/m,za0v\.q\[w12,abc\]'
+[^:]*:[0-9]+: Error: index offset immediate expected at operand 3 -- `mova z0\.q,p0/m,za0v\.q\[w12,#abc\]'
+[^:]*:[0-9]+: Error: expected '\]' at operand 3 -- `mova z0\.q,p0/m,za0v\.q\[w12,1a\]'
+[^:]*:[0-9]+: Error: expected '\]' at operand 3 -- `mova z0\.q,p0/m,za0v\.q\[w12,#1a\]'
+[^:]*:[0-9]+: Error: expected '\]' at operand 3 -- `mova z0\.q,p0/m,za0v\.q\[w12,1a2\]'
+[^:]*:[0-9]+: Error: expected '\]' at operand 3 -- `mova z0\.q,p0/m,za0v\.q\[w12,#1a2\]'
diff --git a/gas/testsuite/gas/aarch64/sme-2-illegal.s b/gas/testsuite/gas/aarch64/sme-2-illegal.s
new file mode 100644
index 00000000000..28eb6719c91
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme-2-illegal.s
@@ -0,0 +1,32 @@
+/* Scalable Matrix Extension (SME).  */
+
+/* MOVA (tile to vector) variant.  */
+mova	z0.b, p0/m, za1h.b[w12, #0]
+mova	z0.h, p0/m, za2h.h[w12, #0]
+mova	z0.s, p0/m, za4h.s[w12, #0]
+mova	z0.d, p0/m, za8h.d[w12, #0]
+mova	z0.q, p0/m, za16h.q[w12]
+
+mova	z31.b, p7/m, za0v.b[w15, #16]
+mova	z31.h, p7/m, za1v.h[w15, #8]
+mova	z31.s, p7/m, za3v.s[w15, #4]
+mova	z31.d, p7/m, za7v.d[w15, #2]
+mova    z31.q, p7/m, za15v.q[w15, #1]
+mova    z31.q, p7/m, za15v.q[w15]
+
+/* Syntax issues.  */
+mova    z0.b, p0/m, za0v.b
+mova    z31.b, p7/m, za0v.b[15, w15]
+mova    z0.h, p0/m, za0v.h[w12. 0]
+mova    z0.s, p0/m, za0v.s[x12, 0]
+mova    z0.d, p0/m, za0v.d[w21, 0]
+mova    z0.q, p0/m, za0v.q[s12]
+mova    z0.q, p0/m, za0v.q[d12]
+mova    z0.q, p0/m, za0v.q[w12,]
+mova    z0.q, p0/m, za0v.q[w12.]
+mova    z0.q, p0/m, za0v.q[w12, abc]
+mova    z0.q, p0/m, za0v.q[w12, #abc]
+mova    z0.q, p0/m, za0v.q[w12, 1a]
+mova    z0.q, p0/m, za0v.q[w12, #1a]
+mova    z0.q, p0/m, za0v.q[w12, 1a2]
+mova    z0.q, p0/m, za0v.q[w12, #1a2]
diff --git a/gas/testsuite/gas/aarch64/sme-2.d b/gas/testsuite/gas/aarch64/sme-2.d
new file mode 100644
index 00000000000..2764aac83c9
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme-2.d
@@ -0,0 +1,43 @@
+#name: SME extension, MOVA (tile to vector)
+#as: -march=armv8-a+sme
+#objdump: -dr
+
+.*:     file format .*
+
+Disassembly of section \.text:
+
+0+ <.*>:
+   0:	c0028000 	mov	z0.b, p0/m, za0v.b\[w12, 0\]
+   4:	c0428000 	mov	z0.h, p0/m, za0v.h\[w12, 0\]
+   8:	c0828000 	mov	z0.s, p0/m, za0v.s\[w12, 0\]
+   c:	c0c28000 	mov	z0.d, p0/m, za0v.d\[w12, 0\]
+  10:	c0c38000 	mov	z0.q, p0/m, za0v.q\[w12, 0\]
+  14:	c002fdff 	mov	z31.b, p7/m, za0v.b\[w15, 15\]
+  18:	c042fdff 	mov	z31.h, p7/m, za1v.h\[w15, 7\]
+  1c:	c082fdff 	mov	z31.s, p7/m, za3v.s\[w15, 3\]
+  20:	c0c2fdff 	mov	z31.d, p7/m, za7v.d\[w15, 1\]
+  24:	c0c3fdff 	mov	z31.q, p7/m, za15v.q\[w15, 0\]
+  28:	c0020000 	mov	z0.b, p0/m, za0h.b\[w12, 0\]
+  2c:	c0420000 	mov	z0.h, p0/m, za0h.h\[w12, 0\]
+  30:	c0820000 	mov	z0.s, p0/m, za0h.s\[w12, 0\]
+  34:	c0c20000 	mov	z0.d, p0/m, za0h.d\[w12, 0\]
+  38:	c0c30000 	mov	z0.q, p0/m, za0h.q\[w12, 0\]
+  3c:	c0027dff 	mov	z31.b, p7/m, za0h.b\[w15, 15\]
+  40:	c0427dff 	mov	z31.h, p7/m, za1h.h\[w15, 7\]
+  44:	c0827dff 	mov	z31.s, p7/m, za3h.s\[w15, 3\]
+  48:	c0c27dff 	mov	z31.d, p7/m, za7h.d\[w15, 1\]
+  4c:	c0c37dff 	mov	z31.q, p7/m, za15h.q\[w15, 0\]
+  50:	c0027dff 	mov	z31.b, p7/m, za0h.b\[w15, 15\]
+  54:	c0427dff 	mov	z31.h, p7/m, za1h.h\[w15, 7\]
+  58:	c0827dff 	mov	z31.s, p7/m, za3h.s\[w15, 3\]
+  5c:	c0c27dff 	mov	z31.d, p7/m, za7h.d\[w15, 1\]
+  60:	c0c37dff 	mov	z31.q, p7/m, za15h.q\[w15, 0\]
+  64:	c0027dff 	mov	z31.b, p7/m, za0h.b\[w15, 15\]
+  68:	c0427dff 	mov	z31.h, p7/m, za1h.h\[w15, 7\]
+  6c:	c0827dff 	mov	z31.s, p7/m, za3h.s\[w15, 3\]
+  70:	c0c27dff 	mov	z31.d, p7/m, za7h.d\[w15, 1\]
+  74:	c0c37dff 	mov	z31.q, p7/m, za15h.q\[w15, 0\]
+  78:	c0c27dff 	mov	z31.d, p7/m, za7h.d\[w15, 1\]
+  7c:	c0c37dff 	mov	z31.q, p7/m, za15h.q\[w15, 0\]
+  80:	c002a400 	mov	z0.b, p1/m, za0v.b\[w13, 0\]
+  84:	c002a4e0 	mov	z0.b, p1/m, za0v.b\[w13, 7\]
diff --git a/gas/testsuite/gas/aarch64/sme-2.s b/gas/testsuite/gas/aarch64/sme-2.s
new file mode 100644
index 00000000000..a2d0f0a6491
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme-2.s
@@ -0,0 +1,52 @@
+/* Scalable Matrix Extension (SME).  */
+
+/* MOVA (tile to vector) variant.  */
+mova	z0.b, p0/m, za0v.b[w12, 0]
+mova	z0.h, p0/m, za0v.h[w12, 0]
+mova	z0.s, p0/m, za0v.s[w12, 0]
+mova	z0.d, p0/m, za0v.d[w12, 0]
+mova	z0.q, p0/m, za0v.q[w12, 0]
+
+mova	z31.b, p7/m, za0v.b[w15, 15]
+mova	z31.h, p7/m, za1v.h[w15, 7]
+mova	z31.s, p7/m, za3v.s[w15, 3]
+mova	z31.d, p7/m, za7v.d[w15, 1]
+mova	z31.q, p7/m, za15v.q[w15, 0]
+
+mova	z0.b, p0/m, za0h.b[w12, 0]
+mova	z0.h, p0/m, za0h.h[w12, 0]
+mova	z0.s, p0/m, za0h.s[w12, 0]
+mova	z0.d, p0/m, za0h.d[w12, 0]
+mova	z0.q, p0/m, za0h.q[w12, 0]
+
+mova	z31.b, p7/m, za0h.b[w15, 15]
+mova	z31.h, p7/m, za1h.h[w15, 7]
+mova	z31.s, p7/m, za3h.s[w15, 3]
+mova	z31.d, p7/m, za7h.d[w15, 1]
+mova	z31.q, p7/m, za15h.q[w15, 0]
+
+/* Parser checks.  */
+mova	z31.b , p7/m , za0h.b [ w15 , 15 ]
+mova	z31.h , p7/m , za1h.h [ w15 , 7 ]
+mova	z31.s , p7/m , za3h.s [ w15 , 3 ]
+mova	z31.d , p7/m , za7h.d [ w15 , 1 ]
+mova	z31.q , p7/m , za15h.q [ w15 , #0 ]
+mova	z31.b , p7/m , za0h.b [ w15 , #15 ]
+mova	z31.h , p7/m , za1h.h [ w15 , #7 ]
+mova	z31.s , p7/m , za3h.s [ w15 , #3 ]
+mova	z31.d , p7/m , za7h.d [ w15 , #1 ]
+mova	z31.q , p7/m , za15h.q [ w15, #0 ]
+
+/* Register aliases.  */
+foo .req w15
+bar .req za7h
+baz .req z31
+
+mova	z31.d , p7/m , bar.d [ foo , #1 ]
+mova	baz.q , p7/m , za15h.q [ foo , #0 ]
+
+/* Named immediate.  */
+val_zero = 0
+val_seven = 7
+mova z0.b, p1/m, za0v.b[w13, #val_zero]
+mova z0.b, p1/m, za0v.b[w13, #val_seven]
diff --git a/gas/testsuite/gas/aarch64/sme-2a.d b/gas/testsuite/gas/aarch64/sme-2a.d
new file mode 100644
index 00000000000..9515e3fc6dc
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme-2a.d
@@ -0,0 +1,29 @@
+#name: SME extension, MOV (tile to vector)
+#as: -march=armv8-a+sme
+#objdump: -dr
+
+.*:     file format .*
+
+Disassembly of section \.text:
+
+0+ <.*>:
+   0:	c0028000 	mov	z0\.b, p0/m, za0v\.b\[w12, 0\]
+   4:	c0428000 	mov	z0\.h, p0/m, za0v\.h\[w12, 0\]
+   8:	c0828000 	mov	z0\.s, p0/m, za0v\.s\[w12, 0\]
+   c:	c0c28000 	mov	z0\.d, p0/m, za0v\.d\[w12, 0\]
+  10:	c0c38000 	mov	z0\.q, p0/m, za0v\.q\[w12, 0\]
+  14:	c002fdff 	mov	z31\.b, p7/m, za0v\.b\[w15, 15\]
+  18:	c042fdff 	mov	z31\.h, p7/m, za1v\.h\[w15, 7\]
+  1c:	c082fdff 	mov	z31\.s, p7/m, za3v\.s\[w15, 3\]
+  20:	c0c2fdff 	mov	z31\.d, p7/m, za7v\.d\[w15, 1\]
+  24:	c0c3fdff 	mov	z31\.q, p7/m, za15v\.q\[w15, 0\]
+  28:	c0020000 	mov	z0\.b, p0/m, za0h\.b\[w12, 0\]
+  2c:	c0420000 	mov	z0\.h, p0/m, za0h\.h\[w12, 0\]
+  30:	c0820000 	mov	z0\.s, p0/m, za0h\.s\[w12, 0\]
+  34:	c0c20000 	mov	z0\.d, p0/m, za0h\.d\[w12, 0\]
+  38:	c0c30000 	mov	z0\.q, p0/m, za0h\.q\[w12, 0\]
+  3c:	c0027dff 	mov	z31\.b, p7/m, za0h\.b\[w15, 15\]
+  40:	c0427dff 	mov	z31\.h, p7/m, za1h\.h\[w15, 7\]
+  44:	c0827dff 	mov	z31\.s, p7/m, za3h\.s\[w15, 3\]
+  48:	c0c27dff 	mov	z31\.d, p7/m, za7h\.d\[w15, 1\]
+  4c:	c0c37dff 	mov	z31\.q, p7/m, za15h\.q\[w15, 0\]
diff --git a/gas/testsuite/gas/aarch64/sme-2a.s b/gas/testsuite/gas/aarch64/sme-2a.s
new file mode 100644
index 00000000000..47549818756
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme-2a.s
@@ -0,0 +1,26 @@
+/* Scalable Matrix Extension (SME).  */
+
+/* MOV alias (tile to vector) variant.  */
+mov	z0.b, p0/m, za0v.b[w12, 0]
+mov	z0.h, p0/m, za0v.h[w12, 0]
+mov	z0.s, p0/m, za0v.s[w12, 0]
+mov	z0.d, p0/m, za0v.d[w12, 0]
+mov	z0.q, p0/m, za0v.q[w12, 0]
+
+mov	z31.b, p7/m, za0v.b[w15, 15]
+mov	z31.h, p7/m, za1v.h[w15, 7]
+mov	z31.s, p7/m, za3v.s[w15, 3]
+mov	z31.d, p7/m, za7v.d[w15, 1]
+mov	z31.q, p7/m, za15v.q[w15, 0]
+
+mov	z0.b, p0/m, za0h.b[w12, 0]
+mov	z0.h, p0/m, za0h.h[w12, 0]
+mov	z0.s, p0/m, za0h.s[w12, 0]
+mov	z0.d, p0/m, za0h.d[w12, 0]
+mov	z0.q, p0/m, za0h.q[w12, 0]
+
+mov	z31.b, p7/m, za0h.b[w15, 15]
+mov	z31.h, p7/m, za1h.h[w15, 7]
+mov	z31.s, p7/m, za3h.s[w15, 3]
+mov	z31.d, p7/m, za7h.d[w15, 1]
+mov	z31.q, p7/m, za15h.q[w15, 0]
diff --git a/gas/testsuite/gas/aarch64/sme-3-illegal.d b/gas/testsuite/gas/aarch64/sme-3-illegal.d
new file mode 100644
index 00000000000..5ee89d32d02
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme-3-illegal.d
@@ -0,0 +1,3 @@
+#as: -march=armv8-a+sme
+#source: sme-3-illegal.s
+#error_output: sme-3-illegal.l
diff --git a/gas/testsuite/gas/aarch64/sme-3-illegal.l b/gas/testsuite/gas/aarch64/sme-3-illegal.l
new file mode 100644
index 00000000000..8babf4c7251
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme-3-illegal.l
@@ -0,0 +1,11 @@
+[^:]*: Assembler messages:
+[^:]*:[0-9]+: Error: ZA tile vector out of range at operand 1 -- `mova za1v\.b\[w12,#0\],p0/m,z0.b'
+[^:]*:[0-9]+: Error: ZA tile vector out of range at operand 1 -- `mova za2v\.h\[w12,#0\],p0/m,z0.h'
+[^:]*:[0-9]+: Error: ZA tile vector out of range at operand 1 -- `mova za4v\.s\[w12,#0\],p0/m,z0.s'
+[^:]*:[0-9]+: Error: ZA tile vector out of range at operand 1 -- `mova za8v\.d\[w12,#0\],p0/m,z0.d'
+[^:]*:[0-9]+: Error: operand 1 must be an SME horizontal or vertical vector access register -- `mova za16v\.q\[w12\],p0/m,z0.q'
+[^:]*:[0-9]+: Error: index offset out of range at operand 1 -- `mova za0v\.b\[w15,#16\],p7/m,z31.b'
+[^:]*:[0-9]+: Error: index offset out of range at operand 1 -- `mova za1v\.h\[w15,#8\],p7/m,z31.h'
+[^:]*:[0-9]+: Error: index offset out of range at operand 1 -- `mova za3v\.s\[w15,#4\],p7/m,z31.s'
+[^:]*:[0-9]+: Error: index offset out of range at operand 1 -- `mova za7v\.d\[w15,#2\],p7/m,z31.d'
+[^:]*:[0-9]+: Error: index offset out of range at operand 1 -- `mova za15v\.q\[w15,#1\],p7/m,z31.q'
diff --git a/gas/testsuite/gas/aarch64/sme-3-illegal.s b/gas/testsuite/gas/aarch64/sme-3-illegal.s
new file mode 100644
index 00000000000..6ed58ec60a1
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme-3-illegal.s
@@ -0,0 +1,14 @@
+/* Scalable Matrix Extension (SME).  */
+
+/* MOVA (vector to tile) variant.  */
+mova    za1v.b[w12, #0], p0/m, z0.b
+mova    za2v.h[w12, #0], p0/m, z0.h
+mova    za4v.s[w12, #0], p0/m, z0.s
+mova    za8v.d[w12, #0], p0/m, z0.d
+mova    za16v.q[w12], p0/m, z0.q
+
+mova    za0v.b[w15, #16], p7/m, z31.b
+mova    za1v.h[w15, #8], p7/m, z31.h
+mova    za3v.s[w15, #4], p7/m, z31.s
+mova    za7v.d[w15, #2], p7/m, z31.d
+mova    za15v.q[w15, #1], p7/m, z31.q
diff --git a/gas/testsuite/gas/aarch64/sme-3.d b/gas/testsuite/gas/aarch64/sme-3.d
new file mode 100644
index 00000000000..82f72ac9751
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme-3.d
@@ -0,0 +1,31 @@
+#name: SME extension, MOVA (vector to tile)
+#as: -march=armv8-a+sme
+#objdump: -dr
+
+.*:     file format .*
+
+Disassembly of section \.text:
+
+0+ <.*>:
+   0:	c0008000 	mov	za0v\.b\[w12, 0\], p0/m, z0\.b
+   4:	c0408000 	mov	za0v\.h\[w12, 0\], p0/m, z0\.h
+   8:	c0808000 	mov	za0v\.s\[w12, 0\], p0/m, z0\.s
+   c:	c0c08000 	mov	za0v\.d\[w12, 0\], p0/m, z0\.d
+  10:	c0c18000 	mov	za0v\.q\[w12, 0\], p0/m, z0\.q
+  14:	c000ffef 	mov	za0v\.b\[w15, 15\], p7/m, z31\.b
+  18:	c040ffef 	mov	za1v\.h\[w15, 7\], p7/m, z31\.h
+  1c:	c080ffef 	mov	za3v\.s\[w15, 3\], p7/m, z31\.s
+  20:	c0c0ffef 	mov	za7v\.d\[w15, 1\], p7/m, z31\.d
+  24:	c0c1ffef 	mov	za15v\.q\[w15, 0\], p7/m, z31\.q
+  28:	c0000000 	mov	za0h\.b\[w12, 0\], p0/m, z0\.b
+  2c:	c0400000 	mov	za0h\.h\[w12, 0\], p0/m, z0\.h
+  30:	c0800000 	mov	za0h\.s\[w12, 0\], p0/m, z0\.s
+  34:	c0c00000 	mov	za0h\.d\[w12, 0\], p0/m, z0\.d
+  38:	c0c10000 	mov	za0h\.q\[w12, 0\], p0/m, z0\.q
+  3c:	c0007fef 	mov	za0h\.b\[w15, 15\], p7/m, z31\.b
+  40:	c0407fef 	mov	za1h\.h\[w15, 7\], p7/m, z31\.h
+  44:	c0807fef 	mov	za3h\.s\[w15, 3\], p7/m, z31\.s
+  48:	c0c07fef 	mov	za7h\.d\[w15, 1\], p7/m, z31\.d
+  4c:	c0c17fef 	mov	za15h\.q\[w15, 0\], p7/m, z31\.q
+  50:	c0008000 	mov	za0v\.b\[w12, 0\], p0/m, z0\.b
+  54:	c0c17fef 	mov	za15h\.q\[w15, 0\], p7/m, z31\.q
diff --git a/gas/testsuite/gas/aarch64/sme-3.s b/gas/testsuite/gas/aarch64/sme-3.s
new file mode 100644
index 00000000000..8efc896f3ab
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme-3.s
@@ -0,0 +1,31 @@
+/* Scalable Matrix Extension (SME).  */
+
+/* MOVA (vector to tile) variant.  */
+mova    za0v.b[w12, 0], p0/m, z0.b
+mova    za0v.h[w12, 0], p0/m, z0.h
+mova    za0v.s[w12, 0], p0/m, z0.s
+mova    za0v.d[w12, 0], p0/m, z0.d
+mova    za0v.q[w12, 0], p0/m, z0.q
+
+mova    za0v.b[w15, 15], p7/m, z31.b
+mova    za1v.h[w15, 7], p7/m, z31.h
+mova    za3v.s[w15, 3], p7/m, z31.s
+mova    za7v.d[w15, 1], p7/m, z31.d
+mova    za15v.q[w15, 0], p7/m, z31.q
+
+mova    za0h.b[w12, 0], p0/m, z0.b
+mova    za0h.h[w12, 0], p0/m, z0.h
+mova    za0h.s[w12, 0], p0/m, z0.s
+mova    za0h.d[w12, 0], p0/m, z0.d
+mova    za0h.q[w12, 0], p0/m, z0.q
+
+mova    za0h.b[w15, 15], p7/m, z31.b
+mova    za1h.h[w15, 7], p7/m, z31.h
+mova    za3h.s[w15, 3], p7/m, z31.s
+mova    za7h.d[w15, 1], p7/m, z31.d
+mova    za15h.q[w15, 0], p7/m, z31.q
+
+foo .req w12
+bar .req w15
+mova    za0v.b[foo, 0], p0/m, z0.b
+mova    za15h.q[bar, 0], p7/m, z31.q
diff --git a/gas/testsuite/gas/aarch64/sme-3a.d b/gas/testsuite/gas/aarch64/sme-3a.d
new file mode 100644
index 00000000000..82835ae0dd5
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme-3a.d
@@ -0,0 +1,29 @@
+#name: SME extension, MOV (vector to tile)
+#as: -march=armv8-a+sme
+#objdump: -dr
+
+.*:     file format .*
+
+Disassembly of section \.text:
+
+0+ <.*>:
+   0:	c0008000 	mov	za0v\.b\[w12, 0\], p0/m, z0\.b
+   4:	c0408000 	mov	za0v\.h\[w12, 0\], p0/m, z0\.h
+   8:	c0808000 	mov	za0v\.s\[w12, 0\], p0/m, z0\.s
+   c:	c0c08000 	mov	za0v\.d\[w12, 0\], p0/m, z0\.d
+  10:	c0c18000 	mov	za0v\.q\[w12, 0\], p0/m, z0\.q
+  14:	c000ffef 	mov	za0v\.b\[w15, 15\], p7/m, z31\.b
+  18:	c040ffef 	mov	za1v\.h\[w15, 7\], p7/m, z31\.h
+  1c:	c080ffef 	mov	za3v\.s\[w15, 3\], p7/m, z31\.s
+  20:	c0c0ffef 	mov	za7v\.d\[w15, 1\], p7/m, z31\.d
+  24:	c0c1ffef 	mov	za15v\.q\[w15, 0\], p7/m, z31\.q
+  28:	c0000000 	mov	za0h\.b\[w12, 0\], p0/m, z0\.b
+  2c:	c0400000 	mov	za0h\.h\[w12, 0\], p0/m, z0\.h
+  30:	c0800000 	mov	za0h\.s\[w12, 0\], p0/m, z0\.s
+  34:	c0c00000 	mov	za0h\.d\[w12, 0\], p0/m, z0\.d
+  38:	c0c10000 	mov	za0h\.q\[w12, 0\], p0/m, z0\.q
+  3c:	c0007fef 	mov	za0h\.b\[w15, 15\], p7/m, z31\.b
+  40:	c0407fef 	mov	za1h\.h\[w15, 7\], p7/m, z31\.h
+  44:	c0807fef 	mov	za3h\.s\[w15, 3\], p7/m, z31\.s
+  48:	c0c07fef 	mov	za7h\.d\[w15, 1\], p7/m, z31\.d
+  4c:	c0c17fef 	mov	za15h\.q\[w15, 0\], p7/m, z31\.q
diff --git a/gas/testsuite/gas/aarch64/sme-3a.s b/gas/testsuite/gas/aarch64/sme-3a.s
new file mode 100644
index 00000000000..892a30e28cd
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme-3a.s
@@ -0,0 +1,26 @@
+/* Scalable Matrix Extension (SME).  */
+
+/* MOV alias (vector to tile) variant.  */
+mov    za0v.b[w12, 0], p0/m, z0.b
+mov    za0v.h[w12, 0], p0/m, z0.h
+mov    za0v.s[w12, 0], p0/m, z0.s
+mov    za0v.d[w12, 0], p0/m, z0.d
+mov    za0v.q[w12, 0], p0/m, z0.q
+
+mov    za0v.b[w15, 15], p7/m, z31.b
+mov    za1v.h[w15, 7], p7/m, z31.h
+mov    za3v.s[w15, 3], p7/m, z31.s
+mov    za7v.d[w15, 1], p7/m, z31.d
+mov    za15v.q[w15, 0], p7/m, z31.q
+
+mov    za0h.b[w12, 0], p0/m, z0.b
+mov    za0h.h[w12, 0], p0/m, z0.h
+mov    za0h.s[w12, 0], p0/m, z0.s
+mov    za0h.d[w12, 0], p0/m, z0.d
+mov    za0h.q[w12, 0], p0/m, z0.q
+
+mov    za0h.b[w15, 15], p7/m, z31.b
+mov    za1h.h[w15, 7], p7/m, z31.h
+mov    za3h.s[w15, 3], p7/m, z31.s
+mov    za7h.d[w15, 1], p7/m, z31.d
+mov    za15h.q[w15, 0], p7/m, z31.q
diff --git a/include/opcode/aarch64.h b/include/opcode/aarch64.h
index cc5a5f3a6aa..249450c1aba 100644
--- a/include/opcode/aarch64.h
+++ b/include/opcode/aarch64.h
@@ -447,6 +447,8 @@ enum aarch64_opnd
   AARCH64_OPND_SVE_ZtxN,	/* SVE vector register list in Zt.  */
   AARCH64_OPND_SME_ZAda_2b,	/* SME <ZAda>.S, 2-bits.  */
   AARCH64_OPND_SME_ZAda_3b,	/* SME <ZAda>.D, 3-bits.  */
+  AARCH64_OPND_SME_ZA_HV_idx_src,	/* SME source ZA tile vector.  */
+  AARCH64_OPND_SME_ZA_HV_idx_dest,	/* SME destination ZA tile vector.  */
   AARCH64_OPND_SME_Pm,		/* SME scalable predicate register, bits [15:13].  */
   AARCH64_OPND_TME_UIMM16,	/* TME unsigned 16-bit immediate.  */
   AARCH64_OPND_SM3_IMM2,	/* SM3 encodes lane in bits [13, 14].  */
@@ -1114,6 +1116,18 @@ struct aarch64_opnd_info
 	  uint32_t flags;
 	} sysreg;
 
+      /* ZA tile vector, e.g. <ZAn><HV>.D[<Wv>{, <imm>}]  */
+      struct
+	{
+	  int regno;      /* <ZAn> */
+	  struct
+	  {
+	    int regno;    /* <Wv>  */
+	    int imm;      /* <imm>  */
+	  } index;
+	  unsigned v : 1;	/* <HV> horizontal or vertical vector indicator.  */
+	} za_tile_vector;
+
       const aarch64_cond *cond;
       /* The encoding of the PSTATE field.  */
       aarch64_insn pstatefield;
diff --git a/opcodes/aarch64-asm-2.c b/opcodes/aarch64-asm-2.c
index 4839fef8049..eda943eb674 100644
--- a/opcodes/aarch64-asm-2.c
+++ b/opcodes/aarch64-asm-2.c
@@ -663,7 +663,7 @@ aarch64_insert_operand (const aarch64_operand *self,
     case 207:
     case 209:
     case 210:
-    case 211:
+    case 213:
       return aarch64_ins_regno (self, info, code, inst, errors);
     case 15:
       return aarch64_ins_reg_extended (self, info, code, inst, errors);
@@ -675,7 +675,7 @@ aarch64_insert_operand (const aarch64_operand *self,
     case 33:
     case 34:
     case 35:
-    case 213:
+    case 215:
       return aarch64_ins_reglane (self, info, code, inst, errors);
     case 36:
       return aarch64_ins_reglist (self, info, code, inst, errors);
@@ -720,7 +720,7 @@ aarch64_insert_operand (const aarch64_operand *self,
     case 187:
     case 188:
     case 189:
-    case 212:
+    case 214:
       return aarch64_ins_imm (self, info, code, inst, errors);
     case 44:
     case 45:
@@ -879,6 +879,9 @@ aarch64_insert_operand (const aarch64_operand *self,
     case 206:
     case 208:
       return aarch64_ins_sve_reglist (self, info, code, inst, errors);
+    case 211:
+    case 212:
+      return aarch64_ins_sme_za_hv_tiles (self, info, code, inst, errors);
     default: assert (0); abort ();
     }
 }
diff --git a/opcodes/aarch64-asm.c b/opcodes/aarch64-asm.c
index 7cc81465ff7..9a77d0f7d9a 100644
--- a/opcodes/aarch64-asm.c
+++ b/opcodes/aarch64-asm.c
@@ -1325,6 +1325,61 @@ aarch64_ins_sve_float_zero_one (const aarch64_operand *self,
   return true;
 }
 
+/* Encode in SME instruction such as MOVA ZA tile vector register number,
+   vector indicator, vector selector and immediate.  */
+bool
+aarch64_ins_sme_za_hv_tiles (const aarch64_operand *self,
+                             const aarch64_opnd_info *info,
+                             aarch64_insn *code,
+                             const aarch64_inst *inst ATTRIBUTE_UNUSED,
+                             aarch64_operand_error *errors ATTRIBUTE_UNUSED)
+{
+  int fld_size;
+  int fld_q;
+  int fld_v = info->za_tile_vector.v;
+  int fld_rv = info->za_tile_vector.index.regno - 12;
+  int fld_zan_imm = info->za_tile_vector.index.imm;
+  int regno = info->za_tile_vector.regno;
+
+  switch (info->qualifier)
+    {
+    case AARCH64_OPND_QLF_S_B:
+      fld_size = 0;
+      fld_q = 0;
+      break;
+    case AARCH64_OPND_QLF_S_H:
+      fld_size = 1;
+      fld_q = 0;
+      fld_zan_imm |= regno << 3;
+      break;
+    case AARCH64_OPND_QLF_S_S:
+      fld_size = 2;
+      fld_q = 0;
+      fld_zan_imm |= regno << 2;
+      break;
+    case AARCH64_OPND_QLF_S_D:
+      fld_size = 3;
+      fld_q = 0;
+      fld_zan_imm |= regno << 1;
+      break;
+    case AARCH64_OPND_QLF_S_Q:
+      fld_size = 3;
+      fld_q = 1;
+      fld_zan_imm = regno;
+      break;
+    default:
+      assert (0);
+    }
+
+  insert_field (self->fields[0], code, fld_size, 0);
+  insert_field (self->fields[1], code, fld_q, 0);
+  insert_field (self->fields[2], code, fld_v, 0);
+  insert_field (self->fields[3], code, fld_rv, 0);
+  insert_field (self->fields[4], code, fld_zan_imm, 0);
+
+  return true;
+}
+
 /* Miscellaneous encoding functions.  */
 
 /* Encode size[0], i.e. bit 22, for
diff --git a/opcodes/aarch64-asm.h b/opcodes/aarch64-asm.h
index 5ea24badab7..9cbcd7a8630 100644
--- a/opcodes/aarch64-asm.h
+++ b/opcodes/aarch64-asm.h
@@ -98,6 +98,7 @@ AARCH64_DECL_OPD_INSERTER (ins_sve_reglist);
 AARCH64_DECL_OPD_INSERTER (ins_sve_scale);
 AARCH64_DECL_OPD_INSERTER (ins_sve_shlimm);
 AARCH64_DECL_OPD_INSERTER (ins_sve_shrimm);
+AARCH64_DECL_OPD_INSERTER (ins_sme_za_hv_tiles);
 AARCH64_DECL_OPD_INSERTER (ins_imm_rotate1);
 AARCH64_DECL_OPD_INSERTER (ins_imm_rotate2);
 
diff --git a/opcodes/aarch64-dis-2.c b/opcodes/aarch64-dis-2.c
index 4376e3bc569..6bde0f35d70 100644
--- a/opcodes/aarch64-dis-2.c
+++ b/opcodes/aarch64-dis-2.c
@@ -38,23 +38,23 @@ aarch64_opcode_lookup_1 (uint32_t word)
                     {
                       if (((word >> 21) & 0x1) == 0)
                         {
-                          if (((word >> 22) & 0x1) == 0)
+                          if (((word >> 29) & 0x1) == 0)
                             {
-                              if (((word >> 23) & 0x1) == 0)
-                                {
-                                  /* 33222222222211111111110000000000
-                                     10987654321098765432109876543210
-                                     xxx00000000xxxxxxxxxxxxxxxxxxxxx
-                                     udf.  */
-                                  return 754;
-                                }
-                              else
+                              if (((word >> 30) & 0x1) == 0)
                                 {
-                                  if (((word >> 4) & 0x1) == 0)
+                                  if (((word >> 22) & 0x1) == 0)
                                     {
-                                      if (((word >> 29) & 0x1) == 0)
+                                      if (((word >> 23) & 0x1) == 0)
                                         {
-                                          if (((word >> 30) & 0x1) == 0)
+                                          /* 33222222222211111111110000000000
+                                             10987654321098765432109876543210
+                                             x0000000000xxxxxxxxxxxxxxxxxxxxx
+                                             udf.  */
+                                          return 754;
+                                        }
+                                      else
+                                        {
+                                          if (((word >> 4) & 0x1) == 0)
                                             {
                                               /* 33222222222211111111110000000000
                                                  10987654321098765432109876543210
@@ -64,88 +64,110 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                             }
                                           else
                                             {
-                                              if (((word >> 16) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     x1000000100xxxx0xxxxxxxxxxx0xxxx
-                                                     addha.  */
-                                                  return 2348;
-                                                }
-                                              else
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     x1000000100xxxx1xxxxxxxxxxx0xxxx
-                                                     addva.  */
-                                                  return 2350;
-                                                }
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 x0000000100xxxxxxxxxxxxxxxx1xxxx
+                                                 fmops.  */
+                                              return 2357;
                                             }
                                         }
-                                      else
-                                        {
-                                          /* 33222222222211111111110000000000
-                                             10987654321098765432109876543210
-                                             xx100000100xxxxxxxxxxxxxxxx0xxxx
-                                             smopa.  */
-                                          return 2360;
-                                        }
                                     }
                                   else
                                     {
-                                      if (((word >> 29) & 0x1) == 0)
+                                      if (((word >> 4) & 0x1) == 0)
                                         {
                                           /* 33222222222211111111110000000000
                                              10987654321098765432109876543210
-                                             xx000000100xxxxxxxxxxxxxxxx1xxxx
-                                             fmops.  */
-                                          return 2357;
+                                             x0000000x10xxxxxxxxxxxxxxxx0xxxx
+                                             fmopa.  */
+                                          return 2355;
                                         }
                                       else
                                         {
                                           /* 33222222222211111111110000000000
                                              10987654321098765432109876543210
-                                             xx100000100xxxxxxxxxxxxxxxx1xxxx
-                                             smops.  */
-                                          return 2362;
+                                             x0000000x10xxxxxxxxxxxxxxxx1xxxx
+                                             fmops.  */
+                                          return 2358;
                                         }
                                     }
                                 }
-                            }
-                          else
-                            {
-                              if (((word >> 4) & 0x1) == 0)
+                              else
                                 {
-                                  if (((word >> 29) & 0x1) == 0)
+                                  if (((word >> 17) & 0x1) == 0)
                                     {
-                                      if (((word >> 30) & 0x1) == 0)
+                                      if (((word >> 20) & 0x1) == 0)
                                         {
                                           /* 33222222222211111111110000000000
                                              10987654321098765432109876543210
-                                             x0000000x10xxxxxxxxxxxxxxxx0xxxx
-                                             fmopa.  */
-                                          return 2355;
+                                             x1000000xx00xx0xxxxxxxxxxxxxxxxx
+                                             mov.  */
+                                          return 2377;
                                         }
                                       else
                                         {
                                           if (((word >> 16) & 0x1) == 0)
                                             {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 x1000000x10xxxx0xxxxxxxxxxx0xxxx
-                                                 addha.  */
-                                              return 2349;
+                                              if (((word >> 22) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     x1000000x001xx00xxxxxxxxxxxxxxxx
+                                                     addha.  */
+                                                  return 2348;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     x1000000x101xx00xxxxxxxxxxxxxxxx
+                                                     addha.  */
+                                                  return 2349;
+                                                }
                                             }
                                           else
                                             {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 x1000000x10xxxx1xxxxxxxxxxx0xxxx
-                                                 addva.  */
-                                              return 2351;
+                                              if (((word >> 22) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     x1000000x001xx01xxxxxxxxxxxxxxxx
+                                                     addva.  */
+                                                  return 2350;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     x1000000x101xx01xxxxxxxxxxxxxxxx
+                                                     addva.  */
+                                                  return 2351;
+                                                }
                                             }
                                         }
                                     }
+                                  else
+                                    {
+                                      /* 33222222222211111111110000000000
+                                         10987654321098765432109876543210
+                                         x1000000xx0xxx1xxxxxxxxxxxxxxxxx
+                                         mov.  */
+                                      return 2376;
+                                    }
+                                }
+                            }
+                          else
+                            {
+                              if (((word >> 4) & 0x1) == 0)
+                                {
+                                  if (((word >> 22) & 0x1) == 0)
+                                    {
+                                      /* 33222222222211111111110000000000
+                                         10987654321098765432109876543210
+                                         xx100000x00xxxxxxxxxxxxxxxx0xxxx
+                                         smopa.  */
+                                      return 2360;
+                                    }
                                   else
                                     {
                                       /* 33222222222211111111110000000000
@@ -157,13 +179,13 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                 }
                               else
                                 {
-                                  if (((word >> 29) & 0x1) == 0)
+                                  if (((word >> 22) & 0x1) == 0)
                                     {
                                       /* 33222222222211111111110000000000
                                          10987654321098765432109876543210
-                                         xx000000x10xxxxxxxxxxxxxxxx1xxxx
-                                         fmops.  */
-                                      return 2358;
+                                         xx100000x00xxxxxxxxxxxxxxxx1xxxx
+                                         smops.  */
+                                      return 2362;
                                     }
                                   else
                                     {
@@ -2731,7 +2753,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          00011001000xxxxxxxxx00xxxxxxxxxx
                                                          stlurb.  */
-                                                      return 2416;
+                                                      return 2420;
                                                     }
                                                   else
                                                     {
@@ -2739,7 +2761,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          10011001000xxxxxxxxx00xxxxxxxxxx
                                                          stlur.  */
-                                                      return 2424;
+                                                      return 2428;
                                                     }
                                                 }
                                               else
@@ -2750,7 +2772,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          01011001000xxxxxxxxx00xxxxxxxxxx
                                                          stlurh.  */
-                                                      return 2420;
+                                                      return 2424;
                                                     }
                                                   else
                                                     {
@@ -2758,7 +2780,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          11011001000xxxxxxxxx00xxxxxxxxxx
                                                          stlur.  */
-                                                      return 2427;
+                                                      return 2431;
                                                     }
                                                 }
                                             }
@@ -2838,7 +2860,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          00011001010xxxxxxxxx00xxxxxxxxxx
                                                          ldapurb.  */
-                                                      return 2417;
+                                                      return 2421;
                                                     }
                                                   else
                                                     {
@@ -2846,7 +2868,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          10011001010xxxxxxxxx00xxxxxxxxxx
                                                          ldapur.  */
-                                                      return 2425;
+                                                      return 2429;
                                                     }
                                                 }
                                               else
@@ -2857,7 +2879,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          01011001010xxxxxxxxx00xxxxxxxxxx
                                                          ldapurh.  */
-                                                      return 2421;
+                                                      return 2425;
                                                     }
                                                   else
                                                     {
@@ -2865,7 +2887,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          11011001010xxxxxxxxx00xxxxxxxxxx
                                                          ldapur.  */
-                                                      return 2428;
+                                                      return 2432;
                                                     }
                                                 }
                                             }
@@ -2948,7 +2970,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          00011001100xxxxxxxxx00xxxxxxxxxx
                                                          ldapursb.  */
-                                                      return 2419;
+                                                      return 2423;
                                                     }
                                                   else
                                                     {
@@ -2956,7 +2978,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          10011001100xxxxxxxxx00xxxxxxxxxx
                                                          ldapursw.  */
-                                                      return 2426;
+                                                      return 2430;
                                                     }
                                                 }
                                               else
@@ -2965,7 +2987,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1011001100xxxxxxxxx00xxxxxxxxxx
                                                      ldapursh.  */
-                                                  return 2423;
+                                                  return 2427;
                                                 }
                                             }
                                           else
@@ -2976,7 +2998,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x0011001110xxxxxxxxx00xxxxxxxxxx
                                                      ldapursb.  */
-                                                  return 2418;
+                                                  return 2422;
                                                 }
                                               else
                                                 {
@@ -2984,7 +3006,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1011001110xxxxxxxxx00xxxxxxxxxx
                                                      ldapursh.  */
-                                                  return 2422;
+                                                  return 2426;
                                                 }
                                             }
                                         }
@@ -3470,7 +3492,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              xxx11010x00xxxxxx0xx10xxxxxxxxxx
                                              setf8.  */
-                                          return 2414;
+                                          return 2418;
                                         }
                                       else
                                         {
@@ -3478,7 +3500,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              xxx11010x00xxxxxx1xx10xxxxxxxxxx
                                              setf16.  */
-                                          return 2415;
+                                          return 2419;
                                         }
                                     }
                                   else
@@ -3624,7 +3646,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              xxx11010000xxxxxxxxx01xxxxxxxxxx
                                              rmif.  */
-                                          return 2413;
+                                          return 2417;
                                         }
                                       else
                                         {
@@ -4673,7 +4695,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  010001x01x1xxxxx000110xxxxxxxxxx
                                                                  usdot.  */
-                                                              return 2433;
+                                                              return 2437;
                                                             }
                                                         }
                                                     }
@@ -4747,7 +4769,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  010001x01x1xxxxx000111xxxxxxxxxx
                                                                  sudot.  */
-                                                              return 2434;
+                                                              return 2438;
                                                             }
                                                         }
                                                     }
@@ -7366,7 +7388,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              010001x0xx0xxxxx011110xxxxxxxxxx
                                                              usdot.  */
-                                                          return 2432;
+                                                          return 2436;
                                                         }
                                                     }
                                                 }
@@ -9070,7 +9092,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  011001x0100xxx10101xxxxxxxxxxxxx
                                                                  bfcvtnt.  */
-                                                              return 2461;
+                                                              return 2465;
                                                             }
                                                         }
                                                       else
@@ -9313,7 +9335,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  101001x00x1xxxxxx00xxxxxxxxxxxxx
                                                  ld1rob.  */
-                                              return 2437;
+                                              return 2441;
                                             }
                                           else
                                             {
@@ -9321,7 +9343,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  101001x01x1xxxxxx00xxxxxxxxxxxxx
                                                  ld1roh.  */
-                                              return 2438;
+                                              return 2442;
                                             }
                                         }
                                       else
@@ -9553,7 +9575,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          011001x0011xxxxx010xxxxxxxxxxxxx
                                                          bfdot.  */
-                                                      return 2458;
+                                                      return 2462;
                                                     }
                                                   else
                                                     {
@@ -9574,7 +9596,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              011001x0111xxxxx010xx0xxxxxxxxxx
                                                              bfmlalb.  */
-                                                          return 2465;
+                                                          return 2469;
                                                         }
                                                       else
                                                         {
@@ -9582,7 +9604,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              011001x0111xxxxx010xx1xxxxxxxxxx
                                                              bfmlalt.  */
-                                                          return 2464;
+                                                          return 2468;
                                                         }
                                                     }
                                                   else
@@ -9637,7 +9659,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  x11001x0011xxxxx1x0xxxxxxxxxxxxx
                                                  bfdot.  */
-                                              return 2457;
+                                              return 2461;
                                             }
                                           else
                                             {
@@ -9649,7 +9671,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          011001x0111xxxxx1x0xx0xxxxxxxxxx
                                                          bfmlalb.  */
-                                                      return 2463;
+                                                      return 2467;
                                                     }
                                                   else
                                                     {
@@ -9657,7 +9679,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          011001x0111xxxxx1x0xx1xxxxxxxxxx
                                                          bfmlalt.  */
-                                                      return 2462;
+                                                      return 2466;
                                                     }
                                                 }
                                               else
@@ -9708,7 +9730,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      101001x00x1xxxxx001xxxxxxxxxxxxx
                                                      ld1rob.  */
-                                                  return 2441;
+                                                  return 2445;
                                                 }
                                               else
                                                 {
@@ -9716,7 +9738,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      101001x01x1xxxxx001xxxxxxxxxxxxx
                                                      ld1roh.  */
-                                                  return 2442;
+                                                  return 2446;
                                                 }
                                             }
                                           else
@@ -10075,7 +10097,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          011001x0101xxxxx111xxxxxxxxxxxxx
                                                          fmmla.  */
-                                                      return 2435;
+                                                      return 2439;
                                                     }
                                                   else
                                                     {
@@ -10108,7 +10130,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          011001x0011xxxxx111xxxxxxxxxxxxx
                                                          bfmmla.  */
-                                                      return 2459;
+                                                      return 2463;
                                                     }
                                                   else
                                                     {
@@ -10138,7 +10160,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          011001x0111xxxxx111xxxxxxxxxxxxx
                                                          fmmla.  */
-                                                      return 2436;
+                                                      return 2440;
                                                     }
                                                   else
                                                     {
@@ -10267,7 +10289,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  000001x1101xxxxx000x00xxxxxxxxxx
                                                                  zip1.  */
-                                                              return 2445;
+                                                              return 2449;
                                                             }
                                                           else
                                                             {
@@ -10277,7 +10299,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      000001x1101xxxxx000010xxxxxxxxxx
                                                                      uzp1.  */
-                                                                  return 2447;
+                                                                  return 2451;
                                                                 }
                                                               else
                                                                 {
@@ -10285,7 +10307,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      000001x1101xxxxx000110xxxxxxxxxx
                                                                      trn1.  */
-                                                                  return 2449;
+                                                                  return 2453;
                                                                 }
                                                             }
                                                         }
@@ -10297,7 +10319,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  000001x1101xxxxx000x01xxxxxxxxxx
                                                                  zip2.  */
-                                                              return 2446;
+                                                              return 2450;
                                                             }
                                                           else
                                                             {
@@ -10307,7 +10329,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      000001x1101xxxxx000011xxxxxxxxxx
                                                                      uzp2.  */
-                                                                  return 2448;
+                                                                  return 2452;
                                                                 }
                                                               else
                                                                 {
@@ -10315,7 +10337,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      000001x1101xxxxx000111xxxxxxxxxx
                                                                      trn2.  */
-                                                                  return 2450;
+                                                                  return 2454;
                                                                 }
                                                             }
                                                         }
@@ -11363,7 +11385,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      010001x1000xxxxx100110xxxxxxxxxx
                                                                      smmla.  */
-                                                                  return 2429;
+                                                                  return 2433;
                                                                 }
                                                               else
                                                                 {
@@ -11371,7 +11393,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      010001x1100xxxxx100110xxxxxxxxxx
                                                                      usmmla.  */
-                                                                  return 2431;
+                                                                  return 2435;
                                                                 }
                                                             }
                                                           else
@@ -11380,7 +11402,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  010001x1x10xxxxx100110xxxxxxxxxx
                                                                  ummla.  */
-                                                              return 2430;
+                                                              return 2434;
                                                             }
                                                         }
                                                     }
@@ -12876,7 +12898,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      101001x10x1xxxxx000xxxxxxxxxxxxx
                                                      ld1row.  */
-                                                  return 2439;
+                                                  return 2443;
                                                 }
                                               else
                                                 {
@@ -12884,7 +12906,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      101001x11x1xxxxx000xxxxxxxxxxxxx
                                                      ld1rod.  */
-                                                  return 2440;
+                                                  return 2444;
                                                 }
                                             }
                                         }
@@ -13258,7 +13280,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      101001x10x1xxxxx001xxxxxxxxxxxxx
                                                      ld1row.  */
-                                                  return 2443;
+                                                  return 2447;
                                                 }
                                               else
                                                 {
@@ -13266,7 +13288,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      101001x11x1xxxxx001xxxxxxxxxxxxx
                                                      ld1rod.  */
-                                                  return 2444;
+                                                  return 2448;
                                                 }
                                             }
                                         }
@@ -14700,7 +14722,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          011001x110001x10101xxxxxxxxxxxxx
                                                                          bfcvt.  */
-                                                                      return 2460;
+                                                                      return 2464;
                                                                     }
                                                                 }
                                                               else
@@ -16769,7 +16791,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          0x001110xx0xxxxx1x1001xxxxxxxxxx
                                                          smmla.  */
-                                                      return 2451;
+                                                      return 2455;
                                                     }
                                                 }
                                             }
@@ -16802,7 +16824,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          0x001110xx0xxxxx1x0101xxxxxxxxxx
                                                          sdot.  */
-                                                      return 2377;
+                                                      return 2381;
                                                     }
                                                 }
                                               else
@@ -16876,7 +16898,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          0x001110xx0xxxxx1x1011xxxxxxxxxx
                                                          usmmla.  */
-                                                      return 2453;
+                                                      return 2457;
                                                     }
                                                 }
                                             }
@@ -16909,7 +16931,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          0x001110xx0xxxxx1x0111xxxxxxxxxx
                                                          usdot.  */
-                                                      return 2454;
+                                                      return 2458;
                                                     }
                                                 }
                                               else
@@ -16956,7 +16978,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              1x001110000xxxxxxxxxxxxxxxxxxxxx
                                              eor3.  */
-                                          return 2384;
+                                          return 2388;
                                         }
                                       else
                                         {
@@ -16964,7 +16986,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              1x001110100xxxxxxxxxxxxxxxxxxxxx
                                              xar.  */
-                                          return 2386;
+                                          return 2390;
                                         }
                                     }
                                   else
@@ -16975,7 +16997,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              1x001110x10xxxxx0xxxxxxxxxxxxxxx
                                              sm3ss1.  */
-                                          return 2388;
+                                          return 2392;
                                         }
                                       else
                                         {
@@ -16989,7 +17011,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          1x001110010xxxxx1xxx00xxxxxxxxxx
                                                          sm3tt1a.  */
-                                                      return 2389;
+                                                      return 2393;
                                                     }
                                                   else
                                                     {
@@ -16997,7 +17019,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          1x001110110xxxxx1xxx00xxxxxxxxxx
                                                          sha512su0.  */
-                                                      return 2382;
+                                                      return 2386;
                                                     }
                                                 }
                                               else
@@ -17006,7 +17028,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      1x001110x10xxxxx1xxx10xxxxxxxxxx
                                                      sm3tt2a.  */
-                                                  return 2391;
+                                                  return 2395;
                                                 }
                                             }
                                           else
@@ -17019,7 +17041,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          1x001110010xxxxx1xxx01xxxxxxxxxx
                                                          sm3tt1b.  */
-                                                      return 2390;
+                                                      return 2394;
                                                     }
                                                   else
                                                     {
@@ -17027,7 +17049,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          1x001110110xxxxx1xxx01xxxxxxxxxx
                                                          sm4e.  */
-                                                      return 2395;
+                                                      return 2399;
                                                     }
                                                 }
                                               else
@@ -17036,7 +17058,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      1x001110x10xxxxx1xxx11xxxxxxxxxx
                                                      sm3tt2b.  */
-                                                  return 2392;
+                                                  return 2396;
                                                 }
                                             }
                                         }
@@ -17217,7 +17239,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx101110xx0xxxxx100101xxxxxxxxxx
                                                          udot.  */
-                                                      return 2376;
+                                                      return 2380;
                                                     }
                                                 }
                                               else
@@ -17248,7 +17270,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx101110xx0xxxxx101x01xxxxxxxxxx
                                                      ummla.  */
-                                                  return 2452;
+                                                  return 2456;
                                                 }
                                               else
                                                 {
@@ -17267,7 +17289,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx101110xx0xxxxx1x1011xxxxxxxxxx
                                                      bfmmla.  */
-                                                  return 2468;
+                                                  return 2472;
                                                 }
                                               else
                                                 {
@@ -17277,7 +17299,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx1011100x0xxxxx1x1111xxxxxxxxxx
                                                          bfdot.  */
-                                                      return 2466;
+                                                      return 2470;
                                                     }
                                                   else
                                                     {
@@ -17287,7 +17309,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x01011101x0xxxxx1x1111xxxxxxxxxx
                                                              bfmlalb.  */
-                                                          return 2473;
+                                                          return 2477;
                                                         }
                                                       else
                                                         {
@@ -17295,7 +17317,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x11011101x0xxxxx1x1111xxxxxxxxxx
                                                              bfmlalt.  */
-                                                          return 2472;
+                                                          return 2476;
                                                         }
                                                     }
                                                 }
@@ -17879,7 +17901,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          000011101x1xxxx1011010xxxxxxxxxx
                                                                          bfcvtn.  */
-                                                                      return 2469;
+                                                                      return 2473;
                                                                     }
                                                                   else
                                                                     {
@@ -17887,7 +17909,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          010011101x1xxxx1011010xxxxxxxxxx
                                                                          bfcvtn2.  */
-                                                                      return 2470;
+                                                                      return 2474;
                                                                     }
                                                                 }
                                                             }
@@ -18205,7 +18227,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                          10987654321098765432109876543210
                                          1x001110xx1xxxxx0xxxxxxxxxxxxxxx
                                          bcax.  */
-                                      return 2387;
+                                      return 2391;
                                     }
                                 }
                               else
@@ -18816,7 +18838,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  11001110xx1xxxxx100000xxxxxxxxxx
                                                                  sha512h.  */
-                                                              return 2380;
+                                                              return 2384;
                                                             }
                                                         }
                                                     }
@@ -18868,7 +18890,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  11001110xx1xxxxx110000xxxxxxxxxx
                                                                  sm3partw1.  */
-                                                              return 2393;
+                                                              return 2397;
                                                             }
                                                         }
                                                     }
@@ -19111,7 +19133,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              1x001110xx1xxxxx100010xxxxxxxxxx
                                                              sha512su1.  */
-                                                          return 2383;
+                                                          return 2387;
                                                         }
                                                     }
                                                   else
@@ -19187,7 +19209,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  1x0011100x1xxxxx110010xxxxxxxxxx
                                                                  sm4ekey.  */
-                                                              return 2396;
+                                                              return 2400;
                                                             }
                                                         }
                                                       else
@@ -20013,7 +20035,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              1x001110xx1xxxxx100001xxxxxxxxxx
                                                              sha512h2.  */
-                                                          return 2381;
+                                                          return 2385;
                                                         }
                                                     }
                                                   else
@@ -20045,7 +20067,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  1x0011100x1xxxxx110001xxxxxxxxxx
                                                                  sm3partw2.  */
-                                                              return 2394;
+                                                              return 2398;
                                                             }
                                                         }
                                                       else
@@ -20285,7 +20307,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              1x001110xx1xxxxx100011xxxxxxxxxx
                                                              rax1.  */
-                                                          return 2385;
+                                                          return 2389;
                                                         }
                                                     }
                                                   else
@@ -20317,7 +20339,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x01011100x1xxxxx110011xxxxxxxxxx
                                                                  fmlal2.  */
-                                                              return 2399;
+                                                              return 2403;
                                                             }
                                                           else
                                                             {
@@ -20325,7 +20347,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x11011100x1xxxxx110011xxxxxxxxxx
                                                                  fmlal2.  */
-                                                              return 2403;
+                                                              return 2407;
                                                             }
                                                         }
                                                     }
@@ -20347,7 +20369,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x01011101x1xxxxx110011xxxxxxxxxx
                                                                  fmlsl2.  */
-                                                              return 2400;
+                                                              return 2404;
                                                             }
                                                           else
                                                             {
@@ -20355,7 +20377,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x11011101x1xxxxx110011xxxxxxxxxx
                                                                  fmlsl2.  */
-                                                              return 2404;
+                                                              return 2408;
                                                             }
                                                         }
                                                     }
@@ -20394,7 +20416,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x00011100x1xxxxx111011xxxxxxxxxx
                                                                  fmlal.  */
-                                                              return 2397;
+                                                              return 2401;
                                                             }
                                                           else
                                                             {
@@ -20402,7 +20424,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10011100x1xxxxx111011xxxxxxxxxx
                                                                  fmlal.  */
-                                                              return 2401;
+                                                              return 2405;
                                                             }
                                                         }
                                                       else
@@ -20424,7 +20446,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x00011101x1xxxxx111011xxxxxxxxxx
                                                                  fmlsl.  */
-                                                              return 2398;
+                                                              return 2402;
                                                             }
                                                           else
                                                             {
@@ -20432,7 +20454,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10011101x1xxxxx111011xxxxxxxxxx
                                                                  fmlsl.  */
-                                                              return 2402;
+                                                              return 2406;
                                                             }
                                                         }
                                                       else
@@ -22240,7 +22262,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x0001111xxxxxxxx0000x0xxxxxxxxxx
                                                      fmlal.  */
-                                                  return 2405;
+                                                  return 2409;
                                                 }
                                               else
                                                 {
@@ -22248,7 +22270,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1001111xxxxxxxx0000x0xxxxxxxxxx
                                                      fmlal.  */
-                                                  return 2409;
+                                                  return 2413;
                                                 }
                                             }
                                           else
@@ -22270,7 +22292,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x0001111xxxxxxxx0100x0xxxxxxxxxx
                                                      fmlsl.  */
-                                                  return 2406;
+                                                  return 2410;
                                                 }
                                               else
                                                 {
@@ -22278,7 +22300,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1001111xxxxxxxx0100x0xxxxxxxxxx
                                    [...]

[diff truncated at 100000 bytes]


More information about the Binutils-cvs mailing list