mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-06 12:09:26 +08:00
f3aa142b8b
ARMv8.2 adds 16-bit floating point operations as an optional extension to the floating point and Adv.SIMD support. This patch adds FP16 instructions to the group Vector Two Register Misc, making them available when +simd+fp16 is enabled. The instructions added are: FCMGT, FCMGE, FCMEQ, FCMLE, FCMLT, FABS, FNEG, FRINTN, FRINTA, FRINTP, FRINTM, FRINTX, FRINTZ, FRINTI, FCVTNS, FCVTNU, FCVTPS, FCVTPU, FCVTMS, FCVTMU, FCVTZS, FCVTZU, FCVTAS, FCVTAU, SCVTF, UCVTF, FRECPE, FRSQRTE and FSQRT. The general form for these instructions is <OP> <Vd>.<T>, <Vs>.<T> where T is 4h or 8h. gas/testsuite/ 2015-12-14 Matthew Wahab <matthew.wahab@arm.com> * gas/aarch64/advsimd-fp16.d: Update expected output. * gas/aarch64/advsimd-fp16.s: Add tests for vector two register misc. instructions. opcodes/ 2015-12-14 Matthew Wahab <matthew.wahab@arm.com> * aarch64-asm-2.c: Regenerate. * aarch64-dis-2.c: Regenerate. * aarch64-opc-2.c: Regenerate. * aarch64-tbl.h (QL_V2SAMEH): New. (aarch64_opcode_table): Add fp16 versions of frintn, frintm, fcvtns, fcvtms, fcvtas, scvtf, fcmgt, fcmeq, fcmlt, fabs, frintp, frintz, fcvtps, fcvtzs, frecpe, frinta, frintx, fcvtnu, fcvtmu, fcvtau, ucvtf, fcmge, fcmle, fneg, frinti, fcvtpu, fcvtzu, frsqrte and fsqrt to the vector register misc. group. Change-Id: I0267511a7f7ea14247504d29fe4752e84c9af9ad
10102 lines
631 KiB
C
10102 lines
631 KiB
C
/* This file is automatically generated by aarch64-gen. Do not edit! */
|
|
/* Copyright (C) 2012-2015 Free Software Foundation, Inc.
|
|
Contributed by ARM Ltd.
|
|
|
|
This file is part of the GNU opcodes library.
|
|
|
|
This library is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3, or (at your option)
|
|
any later version.
|
|
|
|
It is distributed in the hope that it will be useful, but WITHOUT
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
|
|
License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; see the file COPYING3. If not,
|
|
see <http://www.gnu.org/licenses/>. */
|
|
|
|
#include "sysdep.h"
|
|
#include "aarch64-dis.h"
|
|
|
|
/* Called by aarch64_opcode_lookup. */
|
|
|
|
static int
|
|
aarch64_opcode_lookup_1 (uint32_t word)
|
|
{
|
|
if (((word >> 26) & 0x1) == 0)
|
|
{
|
|
if (((word >> 25) & 0x1) == 0)
|
|
{
|
|
if (((word >> 27) & 0x1) == 0)
|
|
{
|
|
if (((word >> 24) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxxx0000xxx0
|
|
adr. */
|
|
return 1069;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxxx0000xxx1
|
|
adrp. */
|
|
return 1070;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxxx1000x00x
|
|
add. */
|
|
return 12;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxxx1000x01x
|
|
sub. */
|
|
return 16;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxxx1000x10x
|
|
adds. */
|
|
return 14;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxxx1000x11x
|
|
subs. */
|
|
return 17;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx000x0010000
|
|
stxrb. */
|
|
return 827;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx000x0010010
|
|
stxrh. */
|
|
return 833;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx000x00100x1
|
|
stxr. */
|
|
return 839;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx100x00100x0
|
|
casp. */
|
|
return 904;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx100x00100x1
|
|
stxp. */
|
|
return 841;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx000x0010000
|
|
stlxrb. */
|
|
return 828;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx000x0010010
|
|
stlxrh. */
|
|
return 834;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx000x00100x1
|
|
stlxr. */
|
|
return 840;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx100x00100x0
|
|
caspl. */
|
|
return 906;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx100x00100x1
|
|
stlxp. */
|
|
return 842;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx00x00101xx
|
|
stnp. */
|
|
return 855;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx001x00100x0
|
|
stllrb. */
|
|
return 853;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx001x00100x1
|
|
stllr. */
|
|
return 852;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx101x0010000
|
|
casb. */
|
|
return 892;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx101x0010010
|
|
cash. */
|
|
return 893;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx101x00100x1
|
|
cas. */
|
|
return 894;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx001x0010000
|
|
stlrb. */
|
|
return 831;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx001x0010010
|
|
stlrh. */
|
|
return 837;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx001x00100x1
|
|
stlr. */
|
|
return 847;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx101x0010000
|
|
caslb. */
|
|
return 896;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx101x0010010
|
|
caslh. */
|
|
return 899;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx101x00100x1
|
|
casl. */
|
|
return 902;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx01x00101xx
|
|
stp. */
|
|
return 864;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx010x0010000
|
|
ldxrb. */
|
|
return 829;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx010x0010010
|
|
ldxrh. */
|
|
return 835;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx010x00100x1
|
|
ldxr. */
|
|
return 843;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx110x00100x0
|
|
caspa. */
|
|
return 905;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx110x00100x1
|
|
ldxp. */
|
|
return 845;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx010x0010000
|
|
ldaxrb. */
|
|
return 830;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx010x0010010
|
|
ldaxrh. */
|
|
return 836;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx010x00100x1
|
|
ldaxr. */
|
|
return 844;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx110x00100x0
|
|
caspal. */
|
|
return 907;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx110x00100x1
|
|
ldaxp. */
|
|
return 846;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx10x001010x
|
|
ldnp. */
|
|
return 856;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx10x001011x
|
|
ldpsw. */
|
|
return 863;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx011x0010000
|
|
ldlarb. */
|
|
return 850;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx011x0010010
|
|
ldlarh. */
|
|
return 851;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx011x00100x1
|
|
ldlar. */
|
|
return 849;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx111x0010000
|
|
casab. */
|
|
return 895;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx111x0010010
|
|
casah. */
|
|
return 898;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx111x00100x1
|
|
casa. */
|
|
return 901;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx011x0010000
|
|
ldarb. */
|
|
return 832;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx011x0010010
|
|
ldarh. */
|
|
return 838;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx011x00100x1
|
|
ldar. */
|
|
return 848;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx111x0010000
|
|
casalb. */
|
|
return 897;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx111x0010010
|
|
casalh. */
|
|
return 900;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx111x00100x1
|
|
casal. */
|
|
return 903;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx11x001010x
|
|
ldp. */
|
|
return 865;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx11x001011x
|
|
ldpsw. */
|
|
return 868;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 24) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxxx000110x0
|
|
ldr. */
|
|
return 869;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxxx00011001
|
|
ldrsw. */
|
|
return 871;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxxx00011011
|
|
prfm. */
|
|
return 872;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 10) & 0x1) == 0)
|
|
{
|
|
if (((word >> 11) & 0x1) == 0)
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx00000011100
|
|
sturb. */
|
|
return 815;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx00000011110
|
|
sturh. */
|
|
return 820;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx000000111x1
|
|
stur. */
|
|
return 823;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx01000011100
|
|
ldurb. */
|
|
return 816;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx01000011110
|
|
ldurh. */
|
|
return 821;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx010000111x1
|
|
ldur. */
|
|
return 824;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx0x100011100
|
|
ldursb. */
|
|
return 817;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx0x100011101
|
|
ldursw. */
|
|
return 825;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx0x100011110
|
|
ldursh. */
|
|
return 822;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx0x100011111
|
|
prfum. */
|
|
return 826;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000xxxxx10000011100
|
|
ldaddb. */
|
|
return 920;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000xxxxx10000011110
|
|
ldaddh. */
|
|
return 921;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000xxxxx100000111x1
|
|
ldadd. */
|
|
return 922;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000xxxxx10100011100
|
|
ldaddab. */
|
|
return 923;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000xxxxx10100011110
|
|
ldaddah. */
|
|
return 926;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000xxxxx101000111x1
|
|
ldadda. */
|
|
return 929;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000xxxxx11000011100
|
|
ldaddlb. */
|
|
return 924;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000xxxxx11000011110
|
|
ldaddlh. */
|
|
return 927;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000xxxxx110000111x1
|
|
ldaddl. */
|
|
return 930;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000xxxxx11100011100
|
|
ldaddalb. */
|
|
return 925;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000xxxxx11100011110
|
|
ldaddalh. */
|
|
return 928;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000xxxxx111000111x1
|
|
ldaddal. */
|
|
return 931;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000001xxxxx10000011100
|
|
swpb. */
|
|
return 908;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000001xxxxx10000011110
|
|
swph. */
|
|
return 909;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000001xxxxx100000111x1
|
|
swp. */
|
|
return 910;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000001xxxxx10100011100
|
|
swpab. */
|
|
return 911;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000001xxxxx10100011110
|
|
swpah. */
|
|
return 914;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000001xxxxx101000111x1
|
|
swpa. */
|
|
return 917;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000001xxxxx11000011100
|
|
swplb. */
|
|
return 912;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000001xxxxx11000011110
|
|
swplh. */
|
|
return 915;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000001xxxxx110000111x1
|
|
swpl. */
|
|
return 918;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000001xxxxx11100011100
|
|
swpalb. */
|
|
return 913;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000001xxxxx11100011110
|
|
swpalh. */
|
|
return 916;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000001xxxxx111000111x1
|
|
swpal. */
|
|
return 919;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00001xxxxxx10000011100
|
|
ldsmaxb. */
|
|
return 968;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00001xxxxxx10000011110
|
|
ldsmaxh. */
|
|
return 969;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00001xxxxxx100000111x1
|
|
ldsmax. */
|
|
return 970;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00001xxxxxx10100011100
|
|
ldsmaxab. */
|
|
return 971;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00001xxxxxx10100011110
|
|
ldsmaxah. */
|
|
return 974;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00001xxxxxx101000111x1
|
|
ldsmaxa. */
|
|
return 977;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00001xxxxxx11000011100
|
|
ldsmaxlb. */
|
|
return 972;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00001xxxxxx11000011110
|
|
ldsmaxlh. */
|
|
return 975;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00001xxxxxx110000111x1
|
|
ldsmaxl. */
|
|
return 978;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00001xxxxxx11100011100
|
|
ldsmaxalb. */
|
|
return 973;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00001xxxxxx11100011110
|
|
ldsmaxalh. */
|
|
return 976;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00001xxxxxx111000111x1
|
|
ldsmaxal. */
|
|
return 979;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00010xxxxxx10000011100
|
|
ldeorb. */
|
|
return 944;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00010xxxxxx10000011110
|
|
ldeorh. */
|
|
return 945;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00010xxxxxx100000111x1
|
|
ldeor. */
|
|
return 946;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00010xxxxxx10100011100
|
|
ldeorab. */
|
|
return 947;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00010xxxxxx10100011110
|
|
ldeorah. */
|
|
return 950;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00010xxxxxx101000111x1
|
|
ldeora. */
|
|
return 953;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00010xxxxxx11000011100
|
|
ldeorlb. */
|
|
return 948;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00010xxxxxx11000011110
|
|
ldeorlh. */
|
|
return 951;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00010xxxxxx110000111x1
|
|
ldeorl. */
|
|
return 954;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00010xxxxxx11100011100
|
|
ldeoralb. */
|
|
return 949;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00010xxxxxx11100011110
|
|
ldeoralh. */
|
|
return 952;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00010xxxxxx111000111x1
|
|
ldeoral. */
|
|
return 955;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00011xxxxxx10000011100
|
|
ldumaxb. */
|
|
return 992;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00011xxxxxx10000011110
|
|
ldumaxh. */
|
|
return 993;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00011xxxxxx100000111x1
|
|
ldumax. */
|
|
return 994;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00011xxxxxx10100011100
|
|
ldumaxab. */
|
|
return 995;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00011xxxxxx10100011110
|
|
ldumaxah. */
|
|
return 998;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00011xxxxxx101000111x1
|
|
ldumaxa. */
|
|
return 1001;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00011xxxxxx11000011100
|
|
ldumaxlb. */
|
|
return 996;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00011xxxxxx11000011110
|
|
ldumaxlh. */
|
|
return 999;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00011xxxxxx110000111x1
|
|
ldumaxl. */
|
|
return 1002;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00011xxxxxx11100011100
|
|
ldumaxalb. */
|
|
return 997;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00011xxxxxx11100011110
|
|
ldumaxalh. */
|
|
return 1000;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00011xxxxxx111000111x1
|
|
ldumaxal. */
|
|
return 1003;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00100xxxxxx10000011100
|
|
ldclrb. */
|
|
return 932;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00100xxxxxx10000011110
|
|
ldclrh. */
|
|
return 933;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00100xxxxxx100000111x1
|
|
ldclr. */
|
|
return 934;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00100xxxxxx10100011100
|
|
ldclrab. */
|
|
return 935;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00100xxxxxx10100011110
|
|
ldclrah. */
|
|
return 938;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00100xxxxxx101000111x1
|
|
ldclra. */
|
|
return 941;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00100xxxxxx11000011100
|
|
ldclrlb. */
|
|
return 936;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00100xxxxxx11000011110
|
|
ldclrlh. */
|
|
return 939;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00100xxxxxx110000111x1
|
|
ldclrl. */
|
|
return 942;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00100xxxxxx11100011100
|
|
ldclralb. */
|
|
return 937;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00100xxxxxx11100011110
|
|
ldclralh. */
|
|
return 940;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00100xxxxxx111000111x1
|
|
ldclral. */
|
|
return 943;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00101xxxxxx10000011100
|
|
ldsminb. */
|
|
return 980;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00101xxxxxx10000011110
|
|
ldsminh. */
|
|
return 981;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00101xxxxxx100000111x1
|
|
ldsmin. */
|
|
return 982;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00101xxxxxx10100011100
|
|
ldsminab. */
|
|
return 983;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00101xxxxxx10100011110
|
|
ldsminah. */
|
|
return 986;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00101xxxxxx101000111x1
|
|
ldsmina. */
|
|
return 989;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00101xxxxxx11000011100
|
|
ldsminlb. */
|
|
return 984;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00101xxxxxx11000011110
|
|
ldsminlh. */
|
|
return 987;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00101xxxxxx110000111x1
|
|
ldsminl. */
|
|
return 990;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00101xxxxxx11100011100
|
|
ldsminalb. */
|
|
return 985;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00101xxxxxx11100011110
|
|
ldsminalh. */
|
|
return 988;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00101xxxxxx111000111x1
|
|
ldsminal. */
|
|
return 991;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00110xxxxxx10000011100
|
|
ldsetb. */
|
|
return 956;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00110xxxxxx10000011110
|
|
ldseth. */
|
|
return 957;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00110xxxxxx100000111x1
|
|
ldset. */
|
|
return 958;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00110xxxxxx10100011100
|
|
ldsetab. */
|
|
return 959;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00110xxxxxx10100011110
|
|
ldsetah. */
|
|
return 962;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00110xxxxxx101000111x1
|
|
ldseta. */
|
|
return 965;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00110xxxxxx11000011100
|
|
ldsetlb. */
|
|
return 960;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00110xxxxxx11000011110
|
|
ldsetlh. */
|
|
return 963;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00110xxxxxx110000111x1
|
|
ldsetl. */
|
|
return 966;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00110xxxxxx11100011100
|
|
ldsetalb. */
|
|
return 961;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00110xxxxxx11100011110
|
|
ldsetalh. */
|
|
return 964;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00110xxxxxx111000111x1
|
|
ldsetal. */
|
|
return 967;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00111xxxxxx10000011100
|
|
lduminb. */
|
|
return 1004;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00111xxxxxx10000011110
|
|
lduminh. */
|
|
return 1005;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00111xxxxxx100000111x1
|
|
ldumin. */
|
|
return 1006;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00111xxxxxx10100011100
|
|
lduminab. */
|
|
return 1007;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00111xxxxxx10100011110
|
|
lduminah. */
|
|
return 1010;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00111xxxxxx101000111x1
|
|
ldumina. */
|
|
return 1013;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00111xxxxxx11000011100
|
|
lduminlb. */
|
|
return 1008;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00111xxxxxx11000011110
|
|
lduminlh. */
|
|
return 1011;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00111xxxxxx110000111x1
|
|
lduminl. */
|
|
return 1014;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00111xxxxxx11100011100
|
|
lduminalb. */
|
|
return 1009;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00111xxxxxx11100011110
|
|
lduminalh. */
|
|
return 1012;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00111xxxxxx111000111x1
|
|
lduminal. */
|
|
return 1015;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx00000011100
|
|
sttrb. */
|
|
return 806;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx00000011110
|
|
sttrh. */
|
|
return 809;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx000000111x1
|
|
sttr. */
|
|
return 812;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx01000011100
|
|
ldtrb. */
|
|
return 807;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx01000011110
|
|
ldtrh. */
|
|
return 810;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx010000111x1
|
|
ldtr. */
|
|
return 813;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx0x100011100
|
|
ldtrsb. */
|
|
return 808;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx0x100011101
|
|
ldtrsw. */
|
|
return 814;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx0x10001111x
|
|
ldtrsh. */
|
|
return 811;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx10000011100
|
|
strb. */
|
|
return 794;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx10000011110
|
|
strh. */
|
|
return 799;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx100000111x1
|
|
str. */
|
|
return 802;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx11000011100
|
|
ldrb. */
|
|
return 795;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx11000011110
|
|
ldrh. */
|
|
return 800;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx110000111x1
|
|
ldr. */
|
|
return 803;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx1x100011100
|
|
ldrsb. */
|
|
return 796;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx1x100011101
|
|
ldrsw. */
|
|
return 804;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx1x100011110
|
|
ldrsh. */
|
|
return 801;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx1x100011111
|
|
prfm. */
|
|
return 805;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1xxxxxxxxxxx0000011100
|
|
strb. */
|
|
return 771;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1xxxxxxxxxxx0000011110
|
|
strh. */
|
|
return 776;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1xxxxxxxxxxx00000111x1
|
|
str. */
|
|
return 779;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1xxxxxxxxxxx1000011100
|
|
ldrb. */
|
|
return 772;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1xxxxxxxxxxx1000011110
|
|
ldrh. */
|
|
return 777;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1xxxxxxxxxxx10000111x1
|
|
ldr. */
|
|
return 780;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1xxxxxxxxxxxx100011100
|
|
ldrsb. */
|
|
return 773;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1xxxxxxxxxxxx100011101
|
|
ldrsw. */
|
|
return 781;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1xxxxxxxxxxxx10001111x
|
|
ldrsh. */
|
|
return 778;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx0010011x00
|
|
strb. */
|
|
return 782;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx0010011x10
|
|
strh. */
|
|
return 787;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx0010011xx1
|
|
str. */
|
|
return 790;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx1010011x00
|
|
ldrb. */
|
|
return 783;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx1010011x10
|
|
ldrh. */
|
|
return 788;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx1010011xx1
|
|
ldr. */
|
|
return 791;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxx110011x00
|
|
ldrsb. */
|
|
return 784;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxx110011x01
|
|
ldrsw. */
|
|
return 792;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxx110011x10
|
|
ldrsh. */
|
|
return 789;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxx110011x11
|
|
prfm. */
|
|
return 793;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 24) & 0x1) == 0)
|
|
{
|
|
if (((word >> 27) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxx00100x00x
|
|
and. */
|
|
return 873;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxx00100x01x
|
|
eor. */
|
|
return 877;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxx00100x10x
|
|
orr. */
|
|
return 875;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxx00100x11x
|
|
ands. */
|
|
return 878;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxx10100x00x
|
|
movn. */
|
|
return 1064;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxx10100x01x
|
|
movz. */
|
|
return 1066;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxx10100x1xx
|
|
movk. */
|
|
return 1068;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx0xx0101000x
|
|
and. */
|
|
return 880;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx0xx0101001x
|
|
eor. */
|
|
return 887;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx0xx0101010x
|
|
orr. */
|
|
return 882;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx0xx0101011x
|
|
ands. */
|
|
return 889;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 10) & 0x1) == 0)
|
|
{
|
|
if (((word >> 11) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx0000101100x
|
|
adc. */
|
|
return 0;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx0000101101x
|
|
sbc. */
|
|
return 2;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx0000101110x
|
|
adcs. */
|
|
return 1;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx0000101111x
|
|
sbcs. */
|
|
return 4;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx00101011x0x
|
|
csel. */
|
|
return 595;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx00101011x1x
|
|
csinv. */
|
|
return 599;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx01001011x0x
|
|
ccmn. */
|
|
return 593;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxx01001011x1x
|
|
ccmp. */
|
|
return 594;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00000xxxxxx01101011xxx
|
|
rbit. */
|
|
return 618;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00001xxxxxx01101011xxx
|
|
crc32b. */
|
|
return 636;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0001xxxxxxx01101011xxx
|
|
lslv. */
|
|
return 628;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001x0xxxxxx01101011xxx
|
|
clz. */
|
|
return 623;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001x1xxxxxx01101011xxx
|
|
crc32cb. */
|
|
return 640;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx0x001011x0x
|
|
ccmn. */
|
|
return 591;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxx0x001011x1x
|
|
ccmp. */
|
|
return 592;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01000xxxxxx0x101011x0x
|
|
udiv. */
|
|
return 626;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01000xxxxxx0x101011x10
|
|
rev. */
|
|
return 620;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01000xxxxxx0x101011x11
|
|
rev32. */
|
|
return 625;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01001xxxxxx0x101011xxx
|
|
crc32w. */
|
|
return 638;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101xxxxxxx0x101011xxx
|
|
asrv. */
|
|
return 632;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx011xxxxxxxx0x101011xxx
|
|
crc32cw. */
|
|
return 642;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 11) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx10xxxxxxxxx00x01011x0x
|
|
csinc. */
|
|
return 596;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx10xxxxxxxxx00x01011x1x
|
|
csneg. */
|
|
return 602;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx10000xxxxxx01x01011xxx
|
|
rev16. */
|
|
return 619;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx10001xxxxxx01x01011xxx
|
|
crc32h. */
|
|
return 637;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1001xxxxxxx01x01011xxx
|
|
lsrv. */
|
|
return 630;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101x0xxxxxx01x01011xxx
|
|
cls. */
|
|
return 624;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101x1xxxxxx01x01011xxx
|
|
crc32ch. */
|
|
return 641;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11000xxxxxx0xx01011x0x
|
|
sdiv. */
|
|
return 627;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11000xxxxxx0xx01011x1x
|
|
rev. */
|
|
return 621;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11001xxxxxx0xx01011xxx
|
|
crc32x. */
|
|
return 639;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1101xxxxxxx0xx01011xxx
|
|
rorv. */
|
|
return 634;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111xxxxxxxx0xx01011xxx
|
|
crc32cx. */
|
|
return 643;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx1xx0101x00x
|
|
bic. */
|
|
return 881;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx1xx0101x01x
|
|
eon. */
|
|
return 888;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx1xx0101x10x
|
|
orn. */
|
|
return 885;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx1xx0101x11x
|
|
bics. */
|
|
return 891;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 27) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxx01100x00x
|
|
sbfm. */
|
|
return 563;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxx01100x01x
|
|
ubfm. */
|
|
return 574;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxx01100x1xx
|
|
bfm. */
|
|
return 570;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxx11100xxxx
|
|
extr. */
|
|
return 666;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx0xx1101000x
|
|
add. */
|
|
return 19;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx0xx1101001x
|
|
sub. */
|
|
return 22;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx0xx1101010x
|
|
adds. */
|
|
return 20;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx0xx1101011x
|
|
subs. */
|
|
return 24;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx00x11011xxx
|
|
madd. */
|
|
return 644;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx01011011xxx
|
|
smulh. */
|
|
return 652;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx01111011xxx
|
|
umulh. */
|
|
return 657;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx0xx11011xxx
|
|
msub. */
|
|
return 646;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx1x01101000x
|
|
add. */
|
|
return 6;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx1x01101001x
|
|
sub. */
|
|
return 9;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx1x01101010x
|
|
adds. */
|
|
return 7;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx1x01101011x
|
|
subs. */
|
|
return 10;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx1x011011xxx
|
|
smaddl. */
|
|
return 648;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx1x011011xxx
|
|
smsubl. */
|
|
return 650;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx1x11101xxxx
|
|
umaddl. */
|
|
return 653;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx1x11101xxxx
|
|
umsubl. */
|
|
return 655;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 27) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxxxxx10x000
|
|
b. */
|
|
return 581;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxxxxx10x001
|
|
bl. */
|
|
return 582;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 24) & 0x1) == 0)
|
|
{
|
|
if (((word >> 25) & 0x1) == 0)
|
|
{
|
|
if (((word >> 31) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxxx0010x010
|
|
b.c. */
|
|
return 590;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 0) & 0x1) == 0)
|
|
{
|
|
if (((word >> 1) & 0x1) == 0)
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
00xxxxxxxxxxxxxxxxxxx0xx0010x011
|
|
hlt. */
|
|
return 662;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
00xxxxxxxxxxxxxxxxxxx1xx0010x011
|
|
brk. */
|
|
return 661;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
01xxxxxxxxxxxxxxxxxxx0xx0010x011
|
|
hvc. */
|
|
return 659;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
01xxxxxxxxxxxxxxxxxxx1xx0010x011
|
|
dcps2. */
|
|
return 664;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 1) & 0x1) == 0)
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
10xxxxxxxxxxxxxxxxxxx0xx0010x011
|
|
svc. */
|
|
return 658;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
10xxxxxxxxxxxxxxxxxxx1xx0010x011
|
|
dcps1. */
|
|
return 663;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
11xxxxxxxxxxxxxxxxxxx0xx0010x011
|
|
smc. */
|
|
return 660;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
11xxxxxxxxxxxxxxxxxxx1xx0010x011
|
|
dcps3. */
|
|
return 665;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx0000110x01x
|
|
br. */
|
|
return 583;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx0010110x01x
|
|
eret. */
|
|
return 586;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx01x0110x01x
|
|
ret. */
|
|
return 585;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx1x00110x01x
|
|
blr. */
|
|
return 584;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx1x10110x01x
|
|
drps. */
|
|
return 587;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx0xx1x10x01x
|
|
msr. */
|
|
return 1071;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx1xx1x10x01x
|
|
sysl. */
|
|
return 1091;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 24) & 0x1) == 0)
|
|
{
|
|
if (((word >> 25) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxxx0010x1xx
|
|
cbz. */
|
|
return 588;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxxx0110x1xx
|
|
tbz. */
|
|
return 1093;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 25) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxxx1010x1xx
|
|
cbnz. */
|
|
return 589;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxxx1110x1xx
|
|
tbnz. */
|
|
return 1094;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 25) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 24) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx00001100xx
|
|
st4. */
|
|
return 414;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx00001101xx
|
|
stnp. */
|
|
return 857;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxx0xxxxxxx000101100xx
|
|
st1. */
|
|
return 430;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxx0xxxxxxx100101100xx
|
|
st2. */
|
|
return 432;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxx1xxxxxxx000101100xx
|
|
st3. */
|
|
return 431;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxx1xxxxxxx100101100xx
|
|
st4. */
|
|
return 433;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx00101101xx
|
|
stp. */
|
|
return 861;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
if (((word >> 24) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx001001100xx
|
|
st4. */
|
|
return 422;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxx0xxxxxxx001101100xx
|
|
st1. */
|
|
return 442;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxx1xxxxxxx001101100xx
|
|
st3. */
|
|
return 443;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxx0xxxxxxx101x01100xx
|
|
st2. */
|
|
return 444;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxx1xxxxxxx101x01100xx
|
|
st4. */
|
|
return 445;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx01x01101xx
|
|
stp. */
|
|
return 866;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 24) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx10001100xx
|
|
ld4. */
|
|
return 418;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx10001101xx
|
|
ldnp. */
|
|
return 858;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxx0xxxxxxx010101100xx
|
|
ld1. */
|
|
return 434;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxx0xxxxxxx110101100xx
|
|
ld2. */
|
|
return 438;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxx1xxxxxxx010101100xx
|
|
ld3. */
|
|
return 435;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxx1xxxxxxx110101100xx
|
|
ld4. */
|
|
return 439;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx10101101xx
|
|
ldp. */
|
|
return 862;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
if (((word >> 24) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxx011001100xx
|
|
ld4. */
|
|
return 426;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxx0xxxxxxx011101100xx
|
|
ld1. */
|
|
return 446;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxx1xxxxxxx011101100xx
|
|
ld3. */
|
|
return 447;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxx0xxxxxxx111x01100xx
|
|
ld2. */
|
|
return 450;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxx1xxxxxxx111x01100xx
|
|
ld4. */
|
|
return 451;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx11x01101xx
|
|
ldp. */
|
|
return 867;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 24) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxxxx001110xx
|
|
ldr. */
|
|
return 870;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 10) & 0x1) == 0)
|
|
{
|
|
if (((word >> 11) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxxx0x001111xx
|
|
stur. */
|
|
return 818;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00xxxxxxxxxx1x001111xx
|
|
ldur. */
|
|
return 819;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxxx0x001111xx
|
|
str. */
|
|
return 797;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01xxxxxxxxxx1x001111xx
|
|
ldr. */
|
|
return 798;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1xxxxxxxxxxx0x001111xx
|
|
str. */
|
|
return 774;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1xxxxxxxxxxx1x001111xx
|
|
ldr. */
|
|
return 775;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx0x10111xxx
|
|
str. */
|
|
return 785;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxxxxxxxx1x10111xxx
|
|
ldr. */
|
|
return 786;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 24) & 0x1) == 0)
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 10) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 11) & 0x1) == 0)
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000xxxxxxxx0xx011100xx
|
|
tbl. */
|
|
return 398;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001xxxxxxxx0xx011100xx
|
|
tbx. */
|
|
return 399;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010x0xxxxxx0xx011100xx
|
|
trn1. */
|
|
return 247;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010x1xxxxxx0xx011100xx
|
|
trn2. */
|
|
return 250;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01100xxxxxx0xx011100xx
|
|
uzp1. */
|
|
return 246;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01101xxxxxx0xx011100xx
|
|
uzp2. */
|
|
return 249;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01110xxxxxx0xx011100xx
|
|
zip1. */
|
|
return 248;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx01111xxxxxx0xx011100xx
|
|
zip2. */
|
|
return 251;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0xxxxxxxxxx0xx011101xx
|
|
ext. */
|
|
return 121;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 11) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx10xxx0xxxxx00x011100xx
|
|
dup. */
|
|
return 137;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1100x0xxxxx00x011100xx
|
|
dup. */
|
|
return 138;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1101x0xxxxx00x011100xx
|
|
smov. */
|
|
return 139;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1110x0xxxxx00x011100xx
|
|
ins. */
|
|
return 142;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1111x0xxxxx00x011100xx
|
|
umov. */
|
|
return 140;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1xxxx0xxxxx00x011101xx
|
|
ins. */
|
|
return 144;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 11) & 0x1) == 0)
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1000x0xxxxx010011100xx
|
|
fmaxnm. */
|
|
return 276;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1000x0xxxxx010011101xx
|
|
fmaxnmp. */
|
|
return 327;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1000x0xxxxx011011100xx
|
|
fminnm. */
|
|
return 292;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1000x0xxxxx011011101xx
|
|
fminnmp. */
|
|
return 343;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1001x0xxxxx010011100xx
|
|
fcmeq. */
|
|
return 284;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1001x0xxxxx010011101xx
|
|
fcmge. */
|
|
return 333;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1001x0xxxxx01101110xxx
|
|
fcmgt. */
|
|
return 347;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1010x0xxxxx010011100xx
|
|
fadd. */
|
|
return 280;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1010x0xxxxx010011101xx
|
|
faddp. */
|
|
return 329;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1010x0xxxxx011011100xx
|
|
fsub. */
|
|
return 296;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1010x0xxxxx011011101xx
|
|
fabd. */
|
|
return 345;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1011x0xxxxx010011100xx
|
|
fmax. */
|
|
return 286;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1011x0xxxxx010011101xx
|
|
fmaxp. */
|
|
return 337;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1011x0xxxxx011011100xx
|
|
fmin. */
|
|
return 298;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1011x0xxxxx011011101xx
|
|
fminp. */
|
|
return 351;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1100x0xxxxx01001110xxx
|
|
fmla. */
|
|
return 278;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1100x0xxxxx01101110xxx
|
|
fmls. */
|
|
return 294;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1101x0xxxxx01001110xxx
|
|
facge. */
|
|
return 335;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1101x0xxxxx01101110xxx
|
|
facgt. */
|
|
return 349;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1110x0xxxxx01x011100xx
|
|
fmulx. */
|
|
return 282;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1110x0xxxxx01x011101xx
|
|
fmul. */
|
|
return 331;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1111x0xxxxx010011100xx
|
|
frecps. */
|
|
return 288;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1111x0xxxxx010011101xx
|
|
fdiv. */
|
|
return 339;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1111x0xxxxx01101110xxx
|
|
frsqrts. */
|
|
return 300;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 11) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx10xxx1xxxxx0xx01110xxx
|
|
sqrdmlah. */
|
|
return 354;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11xxx1xxxxx0xx01110xxx
|
|
sqrdmlsh. */
|
|
return 355;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
if (((word >> 16) & 0x1) == 0)
|
|
{
|
|
if (((word >> 17) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxx00xxx0xx0111100x
|
|
fcvtzs. */
|
|
return 672;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxx01xxx0xx0111100x
|
|
scvtf. */
|
|
return 668;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 17) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxx10xxx0xx0111100x
|
|
fcvtzu. */
|
|
return 674;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxxx11xxx0xx0111100x
|
|
ucvtf. */
|
|
return 670;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 10) & 0x1) == 0)
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x000xxxxxx0xx0111101x
|
|
sha1c. */
|
|
return 611;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x001xxxxxx0xx0111101x
|
|
sha256h. */
|
|
return 615;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x010xxxxxx0xx0111101x
|
|
sha1m. */
|
|
return 613;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x011xxxxxx0xx0111101x
|
|
sha256su1. */
|
|
return 617;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x100xxxxxx0xx0111101x
|
|
sha1p. */
|
|
return 612;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x101xxxxxx0xx0111101x
|
|
sha256h2. */
|
|
return 616;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x11xxxxxxx0xx0111101x
|
|
sha1su0. */
|
|
return 614;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 11) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx10x0xxxxxxx0xx0111101x
|
|
dup. */
|
|
return 489;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx10x1xxxxxxx0xx0111101x
|
|
fcmeq. */
|
|
return 505;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11x0xxxxxxx0xx0111101x
|
|
fmulx. */
|
|
return 503;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11x1xxxxxxx0x00111101x
|
|
frecps. */
|
|
return 507;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11x1xxxxxxx0x10111101x
|
|
frsqrts. */
|
|
return 509;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 11) & 0x1) == 0)
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxx000xxxxxxx0xx011111xx
|
|
sqrdmlah. */
|
|
return 537;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxx001xxxxxxx0x0011111xx
|
|
fcmge. */
|
|
return 522;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxx001xxxxxxx0x1011111xx
|
|
fcmgt. */
|
|
return 528;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxx01xxxxxxxx0xx011111xx
|
|
fabd. */
|
|
return 526;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxx1x0xxxxxxx0xx011111xx
|
|
sqrdmlsh. */
|
|
return 538;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxx1x1xxxxxxx0x0011111xx
|
|
facge. */
|
|
return 524;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxx1x1xxxxxxx0x1011111xx
|
|
facgt. */
|
|
return 530;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 10) & 0x1) == 0)
|
|
{
|
|
if (((word >> 11) & 0x1) == 0)
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000xxxxx1xx0111000x
|
|
saddl. */
|
|
return 38;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000xxxxx1xx0111001x
|
|
saddl2. */
|
|
return 39;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000xxxxx1xx0111010x
|
|
uaddl. */
|
|
return 70;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000xxxxx1xx0111011x
|
|
uaddl2. */
|
|
return 71;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 16) & 0x1) == 0)
|
|
{
|
|
if (((word >> 17) & 0x1) == 0)
|
|
{
|
|
if (((word >> 18) & 0x1) == 0)
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
if (((word >> 20) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000000001xx01111xxx
|
|
fcvtns. */
|
|
return 676;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000000011xx01111xxx
|
|
fcvtms. */
|
|
return 696;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 20) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000000101xx01111xxx
|
|
fcvtps. */
|
|
return 692;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000000111xx01111xxx
|
|
fcvtzs. */
|
|
return 700;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000001xx1xx01111xxx
|
|
fcvtas. */
|
|
return 684;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 18) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000010xx1xx01111xxx
|
|
scvtf. */
|
|
return 680;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0000000110x1xx01111xxx
|
|
fmov. */
|
|
return 688;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0000000111x1xx01111xxx
|
|
fmov. */
|
|
return 704;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 17) & 0x1) == 0)
|
|
{
|
|
if (((word >> 18) & 0x1) == 0)
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
if (((word >> 20) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000100001xx01111xxx
|
|
fcvtnu. */
|
|
return 678;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000100011xx01111xxx
|
|
fcvtmu. */
|
|
return 698;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 20) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000100101xx01111xxx
|
|
fcvtpu. */
|
|
return 694;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000100111xx01111xxx
|
|
fcvtzu. */
|
|
return 702;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000101xx1xx01111xxx
|
|
fcvtau. */
|
|
return 686;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 18) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000000110xx1xx01111xxx
|
|
ucvtf. */
|
|
return 682;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0000001110x1xx01111xxx
|
|
fmov. */
|
|
return 690;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0000001111x1xx01111xxx
|
|
fmov. */
|
|
return 705;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000001xxxxx1xx0111x00x
|
|
smlal. */
|
|
return 54;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000001xxxxx1xx0111x01x
|
|
smlal2. */
|
|
return 55;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000001xxxxx1xx0111x10x
|
|
umlal. */
|
|
return 86;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000001xxxxx1xx0111x11x
|
|
umlal2. */
|
|
return 87;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000010xxxxx1xx0111000x
|
|
addhn. */
|
|
return 46;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000010xxxxx1xx0111001x
|
|
addhn2. */
|
|
return 47;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000010xxxxx1xx0111010x
|
|
raddhn. */
|
|
return 78;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000010xxxxx1xx0111011x
|
|
raddhn2. */
|
|
return 79;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000011xxxxx1xx0111000x
|
|
smull. */
|
|
return 62;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000011xxxxx1xx0111001x
|
|
smull2. */
|
|
return 63;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000011xxxxx1xx0111010x
|
|
umull. */
|
|
return 90;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000011xxxxx1xx0111011x
|
|
umull2. */
|
|
return 91;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 17) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 16) & 0x1) == 0)
|
|
{
|
|
if (((word >> 18) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000010000xx1xx01111xxx
|
|
fmov. */
|
|
return 718;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000010001xx1xx01111xxx
|
|
frintn. */
|
|
return 727;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 18) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000010100xx1xx01111xxx
|
|
fneg. */
|
|
return 722;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000010101xx1xx01111xxx
|
|
frintm. */
|
|
return 731;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 16) & 0x1) == 0)
|
|
{
|
|
if (((word >> 18) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000011000xx1xx01111xxx
|
|
fabs. */
|
|
return 720;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000011001xx1xx01111xxx
|
|
frintp. */
|
|
return 729;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 18) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000011100xx1xx01111xxx
|
|
fsqrt. */
|
|
return 724;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000011101xx1xx01111xxx
|
|
frintz. */
|
|
return 733;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 18) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00001xx10xx1xx01111xxx
|
|
fcvt. */
|
|
return 726;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 16) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000010011xx1xx01111xxx
|
|
frinta. */
|
|
return 735;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000010111xx1xx01111xxx
|
|
frintx. */
|
|
return 737;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000011x11xx1xx01111xxx
|
|
frinti. */
|
|
return 739;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000100xxxxx1xx0111000x
|
|
ssubl. */
|
|
return 42;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000100xxxxx1xx0111001x
|
|
ssubl2. */
|
|
return 43;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000100xxxxx1xx0111010x
|
|
usubl. */
|
|
return 74;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000100xxxxx1xx0111011x
|
|
usubl2. */
|
|
return 75;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 3) & 0x1) == 0)
|
|
{
|
|
if (((word >> 4) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxx00xxxxx000100xxxxx1xx01111xxx
|
|
fcmp. */
|
|
return 710;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxx01xxxxx000100xxxxx1xx01111xxx
|
|
fcmpe. */
|
|
return 712;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 4) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxx10xxxxx000100xxxxx1xx01111xxx
|
|
fcmp. */
|
|
return 714;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxx11xxxxx000100xxxxx1xx01111xxx
|
|
fcmpe. */
|
|
return 716;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000101xxxxx1xx0111x00x
|
|
smlsl. */
|
|
return 58;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000101xxxxx1xx0111x01x
|
|
smlsl2. */
|
|
return 59;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000101xxxxx1xx0111x10x
|
|
umlsl. */
|
|
return 88;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000101xxxxx1xx0111x11x
|
|
umlsl2. */
|
|
return 89;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000110xxxxx1xx0111x00x
|
|
subhn. */
|
|
return 50;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000110xxxxx1xx0111x01x
|
|
subhn2. */
|
|
return 51;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000110xxxxx1xx0111x10x
|
|
rsubhn. */
|
|
return 82;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000110xxxxx1xx0111x11x
|
|
rsubhn2. */
|
|
return 83;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000111xxxxx10x0111xx0x
|
|
pmull. */
|
|
return 66;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000111xxxxx10x0111xx1x
|
|
pmull2. */
|
|
return 68;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000111xxxxx11x0111xx0x
|
|
pmull. */
|
|
return 67;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx000111xxxxx11x0111xx1x
|
|
pmull2. */
|
|
return 69;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001000xxxxx1xx0111000x
|
|
saddw. */
|
|
return 40;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001000xxxxx1xx0111001x
|
|
saddw2. */
|
|
return 41;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001000xxxxx1xx0111010x
|
|
uaddw. */
|
|
return 72;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001000xxxxx1xx0111011x
|
|
uaddw2. */
|
|
return 73;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001001xxxxx1xx01110x0x
|
|
sqdmlal. */
|
|
return 56;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001001xxxxx1xx01110x1x
|
|
sqdmlal2. */
|
|
return 57;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001010xxxxx1xx0111000x
|
|
sabal. */
|
|
return 48;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001010xxxxx1xx0111001x
|
|
sabal2. */
|
|
return 49;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001010xxxxx1xx0111010x
|
|
uabal. */
|
|
return 80;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001010xxxxx1xx0111011x
|
|
uabal2. */
|
|
return 81;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001011xxxxx1xx01110x0x
|
|
sqdmull. */
|
|
return 64;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001011xxxxx1xx01110x1x
|
|
sqdmull2. */
|
|
return 65;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001100xxxxx1xx0111000x
|
|
ssubw. */
|
|
return 44;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001100xxxxx1xx0111001x
|
|
ssubw2. */
|
|
return 45;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001100xxxxx1xx0111010x
|
|
usubw. */
|
|
return 76;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001100xxxxx1xx0111011x
|
|
usubw2. */
|
|
return 77;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001101xxxxx1xx01110x0x
|
|
sqdmlsl. */
|
|
return 60;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001101xxxxx1xx01110x1x
|
|
sqdmlsl2. */
|
|
return 61;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00111xxxxxx1xx0111000x
|
|
sabdl. */
|
|
return 52;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00111xxxxxx1xx0111001x
|
|
sabdl2. */
|
|
return 53;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00111xxxxxx1xx0111010x
|
|
uabdl. */
|
|
return 84;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00111xxxxxx1xx0111011x
|
|
uabdl2. */
|
|
return 85;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx001xxxxxxxx1xx01111x0x
|
|
fmov. */
|
|
return 767;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00100xxxxxx1xx01111x1x
|
|
sqdmlal. */
|
|
return 400;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx00101xxxxxx1xx01111x1x
|
|
sqdmull. */
|
|
return 402;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0011xxxxxxx1xx01111x1x
|
|
sqdmlsl. */
|
|
return 401;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010000xxxxx1xx011100xx
|
|
rev64. */
|
|
return 146;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010000xxxxx1xx011101xx
|
|
rev32. */
|
|
return 197;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010000xxxxx1xx01111x0x
|
|
fmul. */
|
|
return 741;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010000xxxxx1xx01111x1x
|
|
sha1h. */
|
|
return 608;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 16) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100010xxxx1xx011100xx
|
|
cmgt. */
|
|
return 154;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100010xxxx1xx011101xx
|
|
cmge. */
|
|
return 203;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100011xx0x1x0011100xx
|
|
frintn. */
|
|
return 166;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100011xx0x1x0011101xx
|
|
frinta. */
|
|
return 214;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100011xx0x1x101110xxx
|
|
frintp. */
|
|
return 186;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100011xx1x1x0011100xx
|
|
frintn. */
|
|
return 167;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100011xx1x1x0011101xx
|
|
frinta. */
|
|
return 215;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100011xx1x1x101110xxx
|
|
frintp. */
|
|
return 187;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010001xxxxx1xx0111100x
|
|
fnmul. */
|
|
return 757;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010001xxxxx1xx0111101x
|
|
cmgt. */
|
|
return 456;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010001xxxxx1xx011111xx
|
|
cmge. */
|
|
return 474;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 16) & 0x1) == 0)
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100100xx0x1xx011100xx
|
|
cls. */
|
|
return 150;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100100xx0x1xx011101xx
|
|
clz. */
|
|
return 200;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100100xx1x1xx01110xxx
|
|
aese. */
|
|
return 604;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100101xxxx1xx0111000x
|
|
sqxtn. */
|
|
return 160;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100101xxxx1xx0111001x
|
|
sqxtn2. */
|
|
return 161;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100101xxxx1xx0111010x
|
|
uqxtn. */
|
|
return 210;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100101xxxx1xx0111011x
|
|
uqxtn2. */
|
|
return 211;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010010xxxxx1xx0111100x
|
|
fmax. */
|
|
return 749;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010010xxxxx1xx0111101x
|
|
sqxtn. */
|
|
return 460;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010010xxxxx1xx011111xx
|
|
uqxtn. */
|
|
return 478;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 16) & 0x1) == 0)
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
if (((word >> 20) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100110xx001xx011100xx
|
|
fcmgt. */
|
|
return 178;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100110xx001xx011101xx
|
|
fcmge. */
|
|
return 229;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100110xx001xx011110xx
|
|
fcmgt. */
|
|
return 465;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100110xx001xx011111xx
|
|
fcmge. */
|
|
return 484;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100110xx011x001110xxx
|
|
fmaxnmv. */
|
|
return 34;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100110xx011x001111xxx
|
|
fmaxnmp. */
|
|
return 492;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100110xx011x101110xxx
|
|
fminnmv. */
|
|
return 36;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100110xx011x101111xxx
|
|
fminnmp. */
|
|
return 495;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100110xx1x1xx0111x0xx
|
|
fcmgt. */
|
|
return 179;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100110xx1x1xx0111x1xx
|
|
fcmge. */
|
|
return 230;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100111xx0x1x0011100xx
|
|
fcvtas. */
|
|
return 174;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100111xx0x1x0011101xx
|
|
fcvtau. */
|
|
return 222;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100111xx0x1x0011110xx
|
|
fcvtas. */
|
|
return 463;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100111xx0x1x0011111xx
|
|
fcvtau. */
|
|
return 482;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100111xx0x1x10111x0xx
|
|
urecpe. */
|
|
return 194;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100111xx0x1x10111x1xx
|
|
ursqrte. */
|
|
return 241;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100111xx1x1xx0111x0xx
|
|
fcvtas. */
|
|
return 175;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0100111xx1x1xx0111x1xx
|
|
fcvtau. */
|
|
return 223;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 16) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101000xxxx1xx011100xx
|
|
saddlp. */
|
|
return 148;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101000xxxx1xx011101xx
|
|
uaddlp. */
|
|
return 198;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101001xxxx1xx0111000x
|
|
xtn. */
|
|
return 158;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101001xxxx1xx0111001x
|
|
xtn2. */
|
|
return 159;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101001xxxx1xx0111010x
|
|
sqxtun. */
|
|
return 206;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101001xxxx1xx0111011x
|
|
sqxtun2. */
|
|
return 207;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010100xxxxx1xx0111100x
|
|
fadd. */
|
|
return 745;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010100xxxxx1xx0111101x
|
|
sha256su0. */
|
|
return 610;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010100xxxxx1xx011111xx
|
|
sqxtun. */
|
|
return 477;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 16) & 0x1) == 0)
|
|
{
|
|
if (((word >> 20) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101010xxx01xx01110xxx
|
|
cmlt. */
|
|
return 156;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101010xxx01xx01111xxx
|
|
cmlt. */
|
|
return 458;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101010xxx11xx0111x0xx
|
|
smaxv. */
|
|
return 28;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101010xxx11xx0111x1xx
|
|
umaxv. */
|
|
return 32;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
if (((word >> 20) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101011xx001x0011100xx
|
|
fcvtns. */
|
|
return 170;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101011xx001x0011101xx
|
|
fcvtnu. */
|
|
return 218;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101011xx001x0011110xx
|
|
fcvtns. */
|
|
return 461;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101011xx001x0011111xx
|
|
fcvtnu. */
|
|
return 480;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101011xx001x1011100xx
|
|
fcvtps. */
|
|
return 190;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101011xx001x1011101xx
|
|
fcvtpu. */
|
|
return 237;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101011xx001x1011110xx
|
|
fcvtps. */
|
|
return 468;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101011xx001x1011111xx
|
|
fcvtpu. */
|
|
return 486;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101011xx011xx0111x0xx
|
|
sminv. */
|
|
return 29;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101011xx011xx0111x1xx
|
|
uminv. */
|
|
return 33;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101011xx1x1x00111x0xx
|
|
fcvtns. */
|
|
return 171;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101011xx1x1x00111x1xx
|
|
fcvtnu. */
|
|
return 219;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101011xx1x1x10111x0xx
|
|
fcvtps. */
|
|
return 191;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101011xx1x1x10111x1xx
|
|
fcvtpu. */
|
|
return 238;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 16) & 0x1) == 0)
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101100xx0x1xx011100xx
|
|
sadalp. */
|
|
return 152;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101100xx0x1xx011101xx
|
|
uadalp. */
|
|
return 201;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101100xx1x1xx01110xxx
|
|
aesmc. */
|
|
return 606;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101101xxxx1xx0111000x
|
|
fcvtn. */
|
|
return 162;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101101xxxx1xx0111001x
|
|
fcvtn2. */
|
|
return 163;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101101xxxx1xx0111010x
|
|
fcvtxn. */
|
|
return 212;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0101101xxxx1xx0111011x
|
|
fcvtxn2. */
|
|
return 213;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010110xxxxx1xx011110xx
|
|
fmaxnm. */
|
|
return 753;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010110xxxxx1xx011111xx
|
|
fcvtxn. */
|
|
return 479;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010111xxx0x1xx01110xxx
|
|
fcmlt. */
|
|
return 182;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010111xxx0x1xx01111xxx
|
|
fcmlt. */
|
|
return 467;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx010111xxx1x1xx0111xxxx
|
|
fcmlt. */
|
|
return 183;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx011000xxxxx1xx01110xxx
|
|
rev16. */
|
|
return 147;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx011000xxxxx1xx01111x0x
|
|
fdiv. */
|
|
return 743;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx011000xxxxx1xx01111x1x
|
|
sha1su1. */
|
|
return 609;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 16) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110010xxxx1xx011100xx
|
|
cmeq. */
|
|
return 155;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110010xxxx1xx011101xx
|
|
cmle. */
|
|
return 204;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110010xxxx1xx011110xx
|
|
cmeq. */
|
|
return 457;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110010xxxx1xx011111xx
|
|
cmle. */
|
|
return 475;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110011xx0x1x00111x0xx
|
|
frintm. */
|
|
return 168;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110011xx0x1x00111x1xx
|
|
frintx. */
|
|
return 216;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110011xx0x1x10111x0xx
|
|
frintz. */
|
|
return 188;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110011xx0x1x10111x1xx
|
|
frinti. */
|
|
return 235;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110011xx1x1x00111x0xx
|
|
frintm. */
|
|
return 169;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110011xx1x1x00111x1xx
|
|
frintx. */
|
|
return 217;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110011xx1x1x10111x0xx
|
|
frintz. */
|
|
return 189;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110011xx1x1x10111x1xx
|
|
frinti. */
|
|
return 236;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx011010xxx0x1xx011100xx
|
|
cnt. */
|
|
return 151;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx011010xxx0x10x011101xx
|
|
not. */
|
|
return 226;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx011010xxx0x11x011101xx
|
|
rbit. */
|
|
return 228;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx011010xxx1x1xx01110xxx
|
|
aesd. */
|
|
return 605;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx011010xxxxx1xx01111xxx
|
|
fmin. */
|
|
return 751;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 16) & 0x1) == 0)
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
if (((word >> 20) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110110xx001xx011100xx
|
|
fcmeq. */
|
|
return 180;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110110xx001xx011101xx
|
|
fcmle. */
|
|
return 231;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110110xx001xx011110xx
|
|
fcmeq. */
|
|
return 466;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110110xx001xx011111xx
|
|
fcmle. */
|
|
return 485;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110110xx011xx0111xxxx
|
|
faddp. */
|
|
return 493;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110110xx1x1xx0111x0xx
|
|
fcmeq. */
|
|
return 181;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110110xx1x1xx0111x1xx
|
|
fcmle. */
|
|
return 232;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110111xx0x1x0011100xx
|
|
scvtf. */
|
|
return 176;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110111xx0x1x0011101xx
|
|
ucvtf. */
|
|
return 224;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110111xx0x1x0011110xx
|
|
scvtf. */
|
|
return 464;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110111xx0x1x0011111xx
|
|
ucvtf. */
|
|
return 483;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110111xx0x1x1011100xx
|
|
frecpe. */
|
|
return 195;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110111xx0x1x1011101xx
|
|
frsqrte. */
|
|
return 242;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110111xx0x1x1011110xx
|
|
frecpe. */
|
|
return 470;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110111xx0x1x1011111xx
|
|
frsqrte. */
|
|
return 488;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110111xx1x1x00111x0xx
|
|
scvtf. */
|
|
return 177;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110111xx1x1x00111x1xx
|
|
ucvtf. */
|
|
return 225;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110111xx1x1x10111x0xx
|
|
frecpe. */
|
|
return 196;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0110111xx1x1x10111x1xx
|
|
frsqrte. */
|
|
return 243;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 16) & 0x1) == 0)
|
|
{
|
|
if (((word >> 20) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111000xxx01xx011100xx
|
|
suqadd. */
|
|
return 149;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111000xxx01xx011101xx
|
|
usqadd. */
|
|
return 199;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111000xxx11xx011100xx
|
|
saddlv. */
|
|
return 27;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111000xxx11xx011101xx
|
|
uaddlv. */
|
|
return 31;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111001xxxx1xx01110x0x
|
|
shll. */
|
|
return 208;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111001xxxx1xx01110x1x
|
|
shll2. */
|
|
return 209;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx011100xxxxx1xx0111100x
|
|
fsub. */
|
|
return 747;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx011100xxxxx1xx0111101x
|
|
suqadd. */
|
|
return 454;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx011100xxxxx1xx011111xx
|
|
usqadd. */
|
|
return 472;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 16) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111010xxxx1xx011100xx
|
|
abs. */
|
|
return 157;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111010xxxx1xx011101xx
|
|
neg. */
|
|
return 205;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111010xxxx1xx011110xx
|
|
abs. */
|
|
return 459;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111010xxxx1xx011111xx
|
|
neg. */
|
|
return 476;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
if (((word >> 20) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111011xx001x0011100xx
|
|
fcvtms. */
|
|
return 172;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111011xx001x0011101xx
|
|
fcvtmu. */
|
|
return 220;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111011xx001x0011110xx
|
|
fcvtms. */
|
|
return 462;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111011xx001x0011111xx
|
|
fcvtmu. */
|
|
return 481;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111011xx001x1011100xx
|
|
fcvtzs. */
|
|
return 192;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111011xx001x1011101xx
|
|
fcvtzu. */
|
|
return 239;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111011xx001x1011110xx
|
|
fcvtzs. */
|
|
return 469;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111011xx001x1011111xx
|
|
fcvtzu. */
|
|
return 487;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111011xx011xx01110xxx
|
|
addv. */
|
|
return 30;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111011xx011xx01111xxx
|
|
addp. */
|
|
return 491;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111011xx1x1x00111x0xx
|
|
fcvtms. */
|
|
return 173;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111011xx1x1x00111x1xx
|
|
fcvtmu. */
|
|
return 221;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111011xx1x1x10111x0xx
|
|
fcvtzs. */
|
|
return 193;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111011xx1x1x10111x1xx
|
|
fcvtzu. */
|
|
return 240;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 16) & 0x1) == 0)
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111100xx0x1xx011100xx
|
|
sqabs. */
|
|
return 153;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111100xx0x1xx011101xx
|
|
sqneg. */
|
|
return 202;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111100xx1x1xx01110xxx
|
|
aesimc. */
|
|
return 607;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111101xxxx1xx01110x0x
|
|
fcvtl. */
|
|
return 164;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111101xxxx1xx01110x1x
|
|
fcvtl2. */
|
|
return 165;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx011110xxxxx1xx0111100x
|
|
fminnm. */
|
|
return 755;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx011110xxxxx1xx0111101x
|
|
sqabs. */
|
|
return 455;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx011110xxxxx1xx011111xx
|
|
sqneg. */
|
|
return 473;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 16) & 0x1) == 0)
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
if (((word >> 20) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111110xx001xx0111x0xx
|
|
fabs. */
|
|
return 184;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111110xx001xx0111x1xx
|
|
fneg. */
|
|
return 233;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111110xx011x001110xxx
|
|
fmaxv. */
|
|
return 35;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111110xx011x001111xxx
|
|
fmaxp. */
|
|
return 494;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111110xx011x101110xxx
|
|
fminv. */
|
|
return 37;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111110xx011x101111xxx
|
|
fminp. */
|
|
return 496;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111110xx1x1xx0111x0xx
|
|
fabs. */
|
|
return 185;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111110xx1x1xx0111x1xx
|
|
fneg. */
|
|
return 234;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 19) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111111xx0x1xx01110xxx
|
|
fsqrt. */
|
|
return 244;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111111xx0x1xx01111xxx
|
|
frecpx. */
|
|
return 471;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0111111xx1x1xx0111xxxx
|
|
fsqrt. */
|
|
return 245;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 11) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100000xxxxx1xx011100xx
|
|
shadd. */
|
|
return 252;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100000xxxxx1xx011101xx
|
|
uhadd. */
|
|
return 304;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100001xxxxx1xx011100xx
|
|
add. */
|
|
return 267;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100001xxxxx1xx011101xx
|
|
sub. */
|
|
return 319;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100010xxxxx1xx011100xx
|
|
sshl. */
|
|
return 259;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100010xxxxx1xx011101xx
|
|
ushl. */
|
|
return 311;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100011xxxxx1x0011100xx
|
|
fmaxnm. */
|
|
return 275;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100011xxxxx1x0011101xx
|
|
fmaxnmp. */
|
|
return 326;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100011xxxxx1x1011100xx
|
|
fminnm. */
|
|
return 291;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100011xxxxx1x1011101xx
|
|
fminnmp. */
|
|
return 342;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100100xxxxx1xx011100xx
|
|
shsub. */
|
|
return 255;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100100xxxxx1xx011101xx
|
|
uhsub. */
|
|
return 307;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100101xxxxx1xx011100xx
|
|
smaxp. */
|
|
return 271;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100101xxxxx1xx011101xx
|
|
umaxp. */
|
|
return 323;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100110xxxxx1xx011100xx
|
|
smax. */
|
|
return 263;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100110xxxxx1xx011101xx
|
|
umax. */
|
|
return 315;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100111xxxxx1x0011100xx
|
|
fcmeq. */
|
|
return 283;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100111xxxxx1x0011101xx
|
|
fcmge. */
|
|
return 332;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100111xxxxx1x101110xxx
|
|
fcmgt. */
|
|
return 346;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101000xxxxx1xx011100xx
|
|
srhadd. */
|
|
return 254;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101000xxxxx1xx011101xx
|
|
urhadd. */
|
|
return 306;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101001xxxxx1xx011100xx
|
|
mla. */
|
|
return 269;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101001xxxxx1xx011101xx
|
|
mls. */
|
|
return 321;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101010xxxxx1xx011100xx
|
|
srshl. */
|
|
return 261;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101010xxxxx1xx011101xx
|
|
urshl. */
|
|
return 313;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101011xxxxx1x0011100xx
|
|
fadd. */
|
|
return 279;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101011xxxxx1x0011101xx
|
|
faddp. */
|
|
return 328;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101011xxxxx1x1011100xx
|
|
fsub. */
|
|
return 295;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101011xxxxx1x1011101xx
|
|
fabd. */
|
|
return 344;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101100xxxxx1xx011100xx
|
|
cmgt. */
|
|
return 257;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101100xxxxx1xx011101xx
|
|
cmhi. */
|
|
return 309;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101101xxxxx1xx011100xx
|
|
sqdmulh. */
|
|
return 273;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101101xxxxx1xx011101xx
|
|
sqrdmulh. */
|
|
return 325;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101110xxxxx1xx011100xx
|
|
sabd. */
|
|
return 265;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101110xxxxx1xx011101xx
|
|
uabd. */
|
|
return 317;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101111xxxxx1x0011100xx
|
|
fmax. */
|
|
return 285;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101111xxxxx1x0011101xx
|
|
fmaxp. */
|
|
return 336;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101111xxxxx1x1011100xx
|
|
fmin. */
|
|
return 297;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101111xxxxx1x1011101xx
|
|
fminp. */
|
|
return 350;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
if (((word >> 4) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxx0xxxxx10xxxxxxxxx1xx0111100x
|
|
fccmp. */
|
|
return 706;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxx1xxxxx10xxxxxxxxx1xx0111100x
|
|
fccmpe. */
|
|
return 708;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx10000xxxxxx1xx0111101x
|
|
add. */
|
|
return 514;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx10001xxxxxx1xx0111101x
|
|
sshl. */
|
|
return 512;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1001xxxxxxx1xx0111101x
|
|
fcmeq. */
|
|
return 504;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1010xxxxxxx1xx0111101x
|
|
srshl. */
|
|
return 513;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1011x0xxxxx1xx0111101x
|
|
cmgt. */
|
|
return 510;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1011x1xxxxx1xx0111101x
|
|
sqdmulh. */
|
|
return 501;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx10000xxxxxx1xx011111xx
|
|
sub. */
|
|
return 535;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx10001xxxxxx1xx011111xx
|
|
ushl. */
|
|
return 533;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1001xxxxxxx1x0011111xx
|
|
fcmge. */
|
|
return 521;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1001xxxxxxx1x1011111xx
|
|
fcmgt. */
|
|
return 527;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1010x0xxxxx1xx011111xx
|
|
urshl. */
|
|
return 534;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1010x1xxxxx1xx011111xx
|
|
fabd. */
|
|
return 525;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1011x0xxxxx1xx011111xx
|
|
cmhi. */
|
|
return 531;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1011x1xxxxx1xx011111xx
|
|
sqrdmulh. */
|
|
return 520;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110000xxxxx1xx011100xx
|
|
sqadd. */
|
|
return 253;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110000xxxxx1xx011101xx
|
|
uqadd. */
|
|
return 305;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110001xxxxx1xx011100xx
|
|
cmtst. */
|
|
return 268;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110001xxxxx1xx011101xx
|
|
cmeq. */
|
|
return 320;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110010xxxxx1xx011100xx
|
|
sqshl. */
|
|
return 260;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110010xxxxx1xx011101xx
|
|
uqshl. */
|
|
return 312;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110011xxxxx1x001110xxx
|
|
fmla. */
|
|
return 277;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110011xxxxx1x101110xxx
|
|
fmls. */
|
|
return 293;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110100xxxxx1xx011100xx
|
|
sqsub. */
|
|
return 256;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110100xxxxx1xx011101xx
|
|
uqsub. */
|
|
return 308;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110101xxxxx1xx011100xx
|
|
sminp. */
|
|
return 272;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110101xxxxx1xx011101xx
|
|
uminp. */
|
|
return 324;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110110xxxxx1xx011100xx
|
|
smin. */
|
|
return 264;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110110xxxxx1xx011101xx
|
|
umin. */
|
|
return 316;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110111xxxxx1x001110xxx
|
|
facge. */
|
|
return 334;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110111xxxxx1x101110xxx
|
|
facgt. */
|
|
return 348;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 22) & 0x1) == 0)
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111000xxxxx100011100xx
|
|
and. */
|
|
return 289;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111000xxxxx100011101xx
|
|
eor. */
|
|
return 340;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111000xxxxx101011100xx
|
|
orr. */
|
|
return 301;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111000xxxxx101011101xx
|
|
bit. */
|
|
return 352;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111000xxxxx110011100xx
|
|
bic. */
|
|
return 290;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111000xxxxx110011101xx
|
|
bsl. */
|
|
return 341;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111000xxxxx111011100xx
|
|
orn. */
|
|
return 303;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111000xxxxx111011101xx
|
|
bif. */
|
|
return 353;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111001xxxxx1xx011100xx
|
|
mul. */
|
|
return 270;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111001xxxxx1xx011101xx
|
|
pmul. */
|
|
return 322;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111010xxxxx1xx011100xx
|
|
sqrshl. */
|
|
return 262;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111010xxxxx1xx011101xx
|
|
uqrshl. */
|
|
return 314;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111011xxxxx1xx011100xx
|
|
fmulx. */
|
|
return 281;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111011xxxxx1xx011101xx
|
|
fmul. */
|
|
return 330;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111100xxxxx1xx011100xx
|
|
cmge. */
|
|
return 258;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111100xxxxx1xx011101xx
|
|
cmhs. */
|
|
return 310;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111101xxxxx1xx01110xxx
|
|
addp. */
|
|
return 274;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111110xxxxx1xx011100xx
|
|
saba. */
|
|
return 266;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111110xxxxx1xx011101xx
|
|
uaba. */
|
|
return 318;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111111xxxxx1x0011100xx
|
|
frecps. */
|
|
return 287;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111111xxxxx1x0011101xx
|
|
fdiv. */
|
|
return 338;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx111111xxxxx1x101110xxx
|
|
frsqrts. */
|
|
return 299;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11xxxxxxxxx1xx0111100x
|
|
fcsel. */
|
|
return 769;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110000xxxxx1xx0111101x
|
|
sqadd. */
|
|
return 497;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110001xxxxx1xx0111101x
|
|
cmtst. */
|
|
return 515;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11001xxxxxx1xx0111101x
|
|
sqshl. */
|
|
return 499;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1101xxxxxxx1xx0111101x
|
|
sqsub. */
|
|
return 498;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1110x0xxxxx1xx0111101x
|
|
sqrshl. */
|
|
return 500;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1110x1xxxxx1xx0111101x
|
|
fmulx. */
|
|
return 502;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11110xxxxxx1xx0111101x
|
|
cmge. */
|
|
return 511;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11111xxxxxx1x00111101x
|
|
frecps. */
|
|
return 506;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11111xxxxxx1x10111101x
|
|
frsqrts. */
|
|
return 508;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110000xxxxx1xx011111xx
|
|
uqadd. */
|
|
return 516;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110001xxxxx1xx011111xx
|
|
cmeq. */
|
|
return 536;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11001xxxxxx1xx011111xx
|
|
uqshl. */
|
|
return 518;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11010xxxxxx1xx011111xx
|
|
uqsub. */
|
|
return 517;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 23) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11011xxxxxx1x0011111xx
|
|
facge. */
|
|
return 523;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11011xxxxxx1x1011111xx
|
|
facgt. */
|
|
return 529;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1110xxxxxxx1xx011111xx
|
|
uqrshl. */
|
|
return 519;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1111xxxxxxx1xx011111xx
|
|
cmhs. */
|
|
return 532;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 15) & 0x1) == 0)
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 10) & 0x1) == 0)
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x0000xxxxxxxx11110xxx
|
|
mla. */
|
|
return 110;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x0010xxxxxxxx11110xxx
|
|
mls. */
|
|
return 113;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x0100xxxxxxxx1111000x
|
|
smlal. */
|
|
return 92;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x0100xxxxxxxx1111001x
|
|
smlal2. */
|
|
return 93;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x0100xxxxxxxx1111010x
|
|
umlal. */
|
|
return 111;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x0100xxxxxxxx1111011x
|
|
umlal2. */
|
|
return 112;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x0110xxxxxxxx1111000x
|
|
smlsl. */
|
|
return 96;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x0110xxxxxxxx1111001x
|
|
smlsl2. */
|
|
return 97;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x0110xxxxxxxx1111010x
|
|
umlsl. */
|
|
return 114;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x0110xxxxxxxx1111011x
|
|
umlsl2. */
|
|
return 115;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x1000xxxxxxxx11110xxx
|
|
fmla. */
|
|
return 107;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x1010xxxxxxxx11110xxx
|
|
fmls. */
|
|
return 108;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x1100xxxxxxxx11110x0x
|
|
sqdmlal. */
|
|
return 94;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x1100xxxxxxxx11110x1x
|
|
sqdmlal2. */
|
|
return 95;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x1110xxxxxxxx11110x0x
|
|
sqdmlsl. */
|
|
return 98;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x1110xxxxxxxx11110x1x
|
|
sqdmlsl2. */
|
|
return 99;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1x0xx0xxxxxxxx111100xx
|
|
movi. */
|
|
return 122;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1x0xx0xxxxxxxx111101xx
|
|
mvni. */
|
|
return 129;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1x1xx0xxxxxxxx111100xx
|
|
orr. */
|
|
return 123;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1x1xx0xxxxxxxx111101xx
|
|
bic. */
|
|
return 130;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx0xx1111100x
|
|
fmadd. */
|
|
return 759;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx0xxxxx1xx1111100x
|
|
fnmadd. */
|
|
return 763;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 10) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0xx000xxxxxxxx1111101x
|
|
fmla. */
|
|
return 408;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0xx010xxxxxxxx1111101x
|
|
fmls. */
|
|
return 409;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0xx100xxxxxxxx1111101x
|
|
sqdmlal. */
|
|
return 403;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0xx110xxxxxxxx1111101x
|
|
sqdmlsl. */
|
|
return 404;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1x00x0xxxxxxxx1111101x
|
|
sshr. */
|
|
return 539;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1x01x0xxxxxxxx1111101x
|
|
srshr. */
|
|
return 541;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1x1000xxxxxxxx1111101x
|
|
ssra. */
|
|
return 540;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1x1010xxxxxxxx1111101x
|
|
shl. */
|
|
return 543;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1x1100xxxxxxxx1111101x
|
|
srsra. */
|
|
return 542;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1x1110xxxxxxxx1111101x
|
|
sqshl. */
|
|
return 544;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxx0000xxxxxxxx111111xx
|
|
ushr. */
|
|
return 549;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxx0010xxxxxxxx111111xx
|
|
sri. */
|
|
return 553;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxx0100xxxxxxxx111111xx
|
|
urshr. */
|
|
return 551;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxx0110xxxxxxxx111111xx
|
|
sqshlu. */
|
|
return 555;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxx1000xxxxxxxx111111xx
|
|
usra. */
|
|
return 550;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxx1010xxxxxxxx111111xx
|
|
sli. */
|
|
return 554;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxx1100xxxxxxxx111111xx
|
|
ursra. */
|
|
return 552;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxx1110xxxxxxxx111111xx
|
|
uqshl. */
|
|
return 556;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 28) & 0x1) == 0)
|
|
{
|
|
if (((word >> 10) & 0x1) == 0)
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x0001xxxxxxxx11110xxx
|
|
mul. */
|
|
return 100;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x0011xxxxxxxx11110xxx
|
|
sqdmulh. */
|
|
return 105;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x01x1xxxxxxxx1111000x
|
|
smull. */
|
|
return 101;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x01x1xxxxxxxx1111001x
|
|
smull2. */
|
|
return 102;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x01x1xxxxxxxx1111010x
|
|
umull. */
|
|
return 116;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x01x1xxxxxxxx1111011x
|
|
umull2. */
|
|
return 117;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x1001xxxxxxxx111100xx
|
|
fmul. */
|
|
return 109;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x1001xxxxxxxx111101xx
|
|
fmulx. */
|
|
return 118;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x1011xxxxxxxx111100xx
|
|
sqrdmulh. */
|
|
return 106;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x1011xxxxxxxx111101xx
|
|
sqrdmlah. */
|
|
return 119;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x1101xxxxxxxx11110x0x
|
|
sqdmull. */
|
|
return 103;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x1101xxxxxxxx11110x1x
|
|
sqdmull2. */
|
|
return 104;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x1111xxxxxxxx11110xxx
|
|
sqrdmlsh. */
|
|
return 120;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 11) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100x01xxxxxxxx111100xx
|
|
movi. */
|
|
return 124;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100x01xxxxxxxx111101xx
|
|
mvni. */
|
|
return 131;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101x01xxxxxxxx111100xx
|
|
orr. */
|
|
return 125;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101x01xxxxxxxx111101xx
|
|
bic. */
|
|
return 132;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx10x011xxxxxxxx111100xx
|
|
movi. */
|
|
return 126;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx10x011xxxxxxxx111101xx
|
|
mvni. */
|
|
return 133;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100111xxxxxxxx111100xx
|
|
movi. */
|
|
return 127;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100111xxxxxxxx111101xx
|
|
movi. */
|
|
return 134;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101111xxxxxxxx111100xx
|
|
fmov. */
|
|
return 128;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101111xxxxxxxx111101xx
|
|
fmov. */
|
|
return 136;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110xx1xxxxxxxx1111000x
|
|
rshrn. */
|
|
return 364;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110xx1xxxxxxxx1111001x
|
|
rshrn2. */
|
|
return 365;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110xx1xxxxxxxx1111010x
|
|
sqrshrun. */
|
|
return 386;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110xx1xxxxxxxx1111011x
|
|
sqrshrun2. */
|
|
return 387;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1110x1xxxxxxxx1111000x
|
|
sqrshrn. */
|
|
return 368;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1110x1xxxxxxxx1111001x
|
|
sqrshrn2. */
|
|
return 369;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1110x1xxxxxxxx1111010x
|
|
uqrshrn. */
|
|
return 390;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1110x1xxxxxxxx1111011x
|
|
uqrshrn2. */
|
|
return 391;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1111x1xxxxxxxx111100xx
|
|
fcvtzs. */
|
|
return 375;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1111x1xxxxxxxx111101xx
|
|
fcvtzu. */
|
|
return 397;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 29) & 0x1) == 0)
|
|
{
|
|
if (((word >> 30) & 0x1) == 0)
|
|
{
|
|
if (((word >> 21) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx0xx1111100x
|
|
fmsub. */
|
|
return 761;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxxxxxxx1xxxxx1xx1111100x
|
|
fnmsub. */
|
|
return 765;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 10) & 0x1) == 0)
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x0xx1xxxxxxxx1111101x
|
|
sqdmulh. */
|
|
return 406;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x1001xxxxxxxx1111101x
|
|
fmul. */
|
|
return 410;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x1011xxxxxxxx1111101x
|
|
sqrdmulh. */
|
|
return 407;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0x11x1xxxxxxxx1111101x
|
|
sqdmull. */
|
|
return 405;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 11) & 0x1) == 0)
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx100xx1xxxxxxxx1111101x
|
|
scvtf. */
|
|
return 547;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101xx1xxxxxxxx1111101x
|
|
sqshrn. */
|
|
return 545;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11x0x1xxxxxxxx1111101x
|
|
sqrshrn. */
|
|
return 546;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx11x1x1xxxxxxxx1111101x
|
|
fcvtzs. */
|
|
return 548;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 10) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
if (((word >> 14) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0xx001xxxxxxxx111111xx
|
|
fmulx. */
|
|
return 411;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0xx011xxxxxxxx111111xx
|
|
sqrdmlah. */
|
|
return 412;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx0xx1x1xxxxxxxx111111xx
|
|
sqrdmlsh. */
|
|
return 413;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 11) & 0x1) == 0)
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1000x1xxxxxxxx111111xx
|
|
sqshrun. */
|
|
return 557;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1001x1xxxxxxxx111111xx
|
|
ucvtf. */
|
|
return 561;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx101xx1xxxxxxxx111111xx
|
|
uqshrn. */
|
|
return 559;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 12) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx110xx1xxxxxxxx111111xx
|
|
sqrshrun. */
|
|
return 558;
|
|
}
|
|
else
|
|
{
|
|
if (((word >> 13) & 0x1) == 0)
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1110x1xxxxxxxx111111xx
|
|
uqrshrn. */
|
|
return 560;
|
|
}
|
|
else
|
|
{
|
|
/* 33222222222211111111110000000000
|
|
10987654321098765432109876543210
|
|
xxxxxxxxxx1111x1xxxxxxxx111111xx
|
|
fcvtzu. */
|
|
return 562;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/* Lookup opcode WORD in the opcode table. N.B. all alias
|
|
opcodes are ignored here. */
|
|
|
|
const aarch64_opcode *
|
|
aarch64_opcode_lookup (uint32_t word)
|
|
{
|
|
return aarch64_opcode_table + aarch64_opcode_lookup_1 (word);
|
|
}
|
|
|
|
const aarch64_opcode *
|
|
aarch64_find_next_opcode (const aarch64_opcode *opcode)
|
|
{
|
|
/* Use the index as the key to locate the next opcode. */
|
|
int key = opcode - aarch64_opcode_table;
|
|
int value;
|
|
switch (key)
|
|
{
|
|
case 855: value = 859; break; /* stnp --> stp. */
|
|
case 859: return NULL; /* stp --> NULL. */
|
|
case 853: value = 854; break; /* stllrb --> stllrh. */
|
|
case 854: return NULL; /* stllrh --> NULL. */
|
|
case 856: value = 860; break; /* ldnp --> ldp. */
|
|
case 860: return NULL; /* ldp --> NULL. */
|
|
case 1071: value = 1072; break; /* msr --> hint. */
|
|
case 1072: value = 1081; break; /* hint --> clrex. */
|
|
case 1081: value = 1082; break; /* clrex --> dsb. */
|
|
case 1082: value = 1083; break; /* dsb --> dmb. */
|
|
case 1083: value = 1084; break; /* dmb --> isb. */
|
|
case 1084: value = 1085; break; /* isb --> sys. */
|
|
case 1085: value = 1090; break; /* sys --> msr. */
|
|
case 1090: return NULL; /* msr --> NULL. */
|
|
case 1091: value = 1092; break; /* sysl --> mrs. */
|
|
case 1092: return NULL; /* mrs --> NULL. */
|
|
case 414: value = 415; break; /* st4 --> st1. */
|
|
case 415: value = 416; break; /* st1 --> st2. */
|
|
case 416: value = 417; break; /* st2 --> st3. */
|
|
case 417: return NULL; /* st3 --> NULL. */
|
|
case 422: value = 423; break; /* st4 --> st1. */
|
|
case 423: value = 424; break; /* st1 --> st2. */
|
|
case 424: value = 425; break; /* st2 --> st3. */
|
|
case 425: return NULL; /* st3 --> NULL. */
|
|
case 418: value = 419; break; /* ld4 --> ld1. */
|
|
case 419: value = 420; break; /* ld1 --> ld2. */
|
|
case 420: value = 421; break; /* ld2 --> ld3. */
|
|
case 421: return NULL; /* ld3 --> NULL. */
|
|
case 434: value = 436; break; /* ld1 --> ld1r. */
|
|
case 436: return NULL; /* ld1r --> NULL. */
|
|
case 438: value = 440; break; /* ld2 --> ld2r. */
|
|
case 440: return NULL; /* ld2r --> NULL. */
|
|
case 435: value = 437; break; /* ld3 --> ld3r. */
|
|
case 437: return NULL; /* ld3r --> NULL. */
|
|
case 439: value = 441; break; /* ld4 --> ld4r. */
|
|
case 441: return NULL; /* ld4r --> NULL. */
|
|
case 426: value = 427; break; /* ld4 --> ld1. */
|
|
case 427: value = 428; break; /* ld1 --> ld2. */
|
|
case 428: value = 429; break; /* ld2 --> ld3. */
|
|
case 429: return NULL; /* ld3 --> NULL. */
|
|
case 446: value = 448; break; /* ld1 --> ld1r. */
|
|
case 448: return NULL; /* ld1r --> NULL. */
|
|
case 447: value = 449; break; /* ld3 --> ld3r. */
|
|
case 449: return NULL; /* ld3r --> NULL. */
|
|
case 450: value = 452; break; /* ld2 --> ld2r. */
|
|
case 452: return NULL; /* ld2r --> NULL. */
|
|
case 451: value = 453; break; /* ld4 --> ld4r. */
|
|
case 453: return NULL; /* ld4r --> NULL. */
|
|
case 672: value = 673; break; /* fcvtzs --> fcvtzs. */
|
|
case 673: return NULL; /* fcvtzs --> NULL. */
|
|
case 668: value = 669; break; /* scvtf --> scvtf. */
|
|
case 669: return NULL; /* scvtf --> NULL. */
|
|
case 674: value = 675; break; /* fcvtzu --> fcvtzu. */
|
|
case 675: return NULL; /* fcvtzu --> NULL. */
|
|
case 670: value = 671; break; /* ucvtf --> ucvtf. */
|
|
case 671: return NULL; /* ucvtf --> NULL. */
|
|
case 676: value = 677; break; /* fcvtns --> fcvtns. */
|
|
case 677: return NULL; /* fcvtns --> NULL. */
|
|
case 696: value = 697; break; /* fcvtms --> fcvtms. */
|
|
case 697: return NULL; /* fcvtms --> NULL. */
|
|
case 692: value = 693; break; /* fcvtps --> fcvtps. */
|
|
case 693: return NULL; /* fcvtps --> NULL. */
|
|
case 700: value = 701; break; /* fcvtzs --> fcvtzs. */
|
|
case 701: return NULL; /* fcvtzs --> NULL. */
|
|
case 684: value = 685; break; /* fcvtas --> fcvtas. */
|
|
case 685: return NULL; /* fcvtas --> NULL. */
|
|
case 680: value = 681; break; /* scvtf --> scvtf. */
|
|
case 681: return NULL; /* scvtf --> NULL. */
|
|
case 688: value = 689; break; /* fmov --> fmov. */
|
|
case 689: return NULL; /* fmov --> NULL. */
|
|
case 678: value = 679; break; /* fcvtnu --> fcvtnu. */
|
|
case 679: return NULL; /* fcvtnu --> NULL. */
|
|
case 698: value = 699; break; /* fcvtmu --> fcvtmu. */
|
|
case 699: return NULL; /* fcvtmu --> NULL. */
|
|
case 694: value = 695; break; /* fcvtpu --> fcvtpu. */
|
|
case 695: return NULL; /* fcvtpu --> NULL. */
|
|
case 702: value = 703; break; /* fcvtzu --> fcvtzu. */
|
|
case 703: return NULL; /* fcvtzu --> NULL. */
|
|
case 686: value = 687; break; /* fcvtau --> fcvtau. */
|
|
case 687: return NULL; /* fcvtau --> NULL. */
|
|
case 682: value = 683; break; /* ucvtf --> ucvtf. */
|
|
case 683: return NULL; /* ucvtf --> NULL. */
|
|
case 690: value = 691; break; /* fmov --> fmov. */
|
|
case 691: return NULL; /* fmov --> NULL. */
|
|
case 718: value = 719; break; /* fmov --> fmov. */
|
|
case 719: return NULL; /* fmov --> NULL. */
|
|
case 727: value = 728; break; /* frintn --> frintn. */
|
|
case 728: return NULL; /* frintn --> NULL. */
|
|
case 722: value = 723; break; /* fneg --> fneg. */
|
|
case 723: return NULL; /* fneg --> NULL. */
|
|
case 731: value = 732; break; /* frintm --> frintm. */
|
|
case 732: return NULL; /* frintm --> NULL. */
|
|
case 720: value = 721; break; /* fabs --> fabs. */
|
|
case 721: return NULL; /* fabs --> NULL. */
|
|
case 729: value = 730; break; /* frintp --> frintp. */
|
|
case 730: return NULL; /* frintp --> NULL. */
|
|
case 724: value = 725; break; /* fsqrt --> fsqrt. */
|
|
case 725: return NULL; /* fsqrt --> NULL. */
|
|
case 733: value = 734; break; /* frintz --> frintz. */
|
|
case 734: return NULL; /* frintz --> NULL. */
|
|
case 735: value = 736; break; /* frinta --> frinta. */
|
|
case 736: return NULL; /* frinta --> NULL. */
|
|
case 737: value = 738; break; /* frintx --> frintx. */
|
|
case 738: return NULL; /* frintx --> NULL. */
|
|
case 739: value = 740; break; /* frinti --> frinti. */
|
|
case 740: return NULL; /* frinti --> NULL. */
|
|
case 710: value = 711; break; /* fcmp --> fcmp. */
|
|
case 711: return NULL; /* fcmp --> NULL. */
|
|
case 712: value = 713; break; /* fcmpe --> fcmpe. */
|
|
case 713: return NULL; /* fcmpe --> NULL. */
|
|
case 714: value = 715; break; /* fcmp --> fcmp. */
|
|
case 715: return NULL; /* fcmp --> NULL. */
|
|
case 716: value = 717; break; /* fcmpe --> fcmpe. */
|
|
case 717: return NULL; /* fcmpe --> NULL. */
|
|
case 767: value = 768; break; /* fmov --> fmov. */
|
|
case 768: return NULL; /* fmov --> NULL. */
|
|
case 741: value = 742; break; /* fmul --> fmul. */
|
|
case 742: return NULL; /* fmul --> NULL. */
|
|
case 757: value = 758; break; /* fnmul --> fnmul. */
|
|
case 758: return NULL; /* fnmul --> NULL. */
|
|
case 749: value = 750; break; /* fmax --> fmax. */
|
|
case 750: return NULL; /* fmax --> NULL. */
|
|
case 745: value = 746; break; /* fadd --> fadd. */
|
|
case 746: return NULL; /* fadd --> NULL. */
|
|
case 753: value = 754; break; /* fmaxnm --> fmaxnm. */
|
|
case 754: return NULL; /* fmaxnm --> NULL. */
|
|
case 743: value = 744; break; /* fdiv --> fdiv. */
|
|
case 744: return NULL; /* fdiv --> NULL. */
|
|
case 751: value = 752; break; /* fmin --> fmin. */
|
|
case 752: return NULL; /* fmin --> NULL. */
|
|
case 747: value = 748; break; /* fsub --> fsub. */
|
|
case 748: return NULL; /* fsub --> NULL. */
|
|
case 755: value = 756; break; /* fminnm --> fminnm. */
|
|
case 756: return NULL; /* fminnm --> NULL. */
|
|
case 706: value = 707; break; /* fccmp --> fccmp. */
|
|
case 707: return NULL; /* fccmp --> NULL. */
|
|
case 708: value = 709; break; /* fccmpe --> fccmpe. */
|
|
case 709: return NULL; /* fccmpe --> NULL. */
|
|
case 769: value = 770; break; /* fcsel --> fcsel. */
|
|
case 770: return NULL; /* fcsel --> NULL. */
|
|
case 122: value = 356; break; /* movi --> sshr. */
|
|
case 356: value = 358; break; /* sshr --> srshr. */
|
|
case 358: return NULL; /* srshr --> NULL. */
|
|
case 129: value = 376; break; /* mvni --> ushr. */
|
|
case 376: value = 378; break; /* ushr --> urshr. */
|
|
case 378: value = 380; break; /* urshr --> sri. */
|
|
case 380: value = 382; break; /* sri --> sqshlu. */
|
|
case 382: return NULL; /* sqshlu --> NULL. */
|
|
case 123: value = 357; break; /* orr --> ssra. */
|
|
case 357: value = 359; break; /* ssra --> srsra. */
|
|
case 359: value = 360; break; /* srsra --> shl. */
|
|
case 360: value = 361; break; /* shl --> sqshl. */
|
|
case 361: return NULL; /* sqshl --> NULL. */
|
|
case 130: value = 377; break; /* bic --> usra. */
|
|
case 377: value = 379; break; /* usra --> ursra. */
|
|
case 379: value = 381; break; /* ursra --> sli. */
|
|
case 381: value = 383; break; /* sli --> uqshl. */
|
|
case 383: return NULL; /* uqshl --> NULL. */
|
|
case 759: value = 760; break; /* fmadd --> fmadd. */
|
|
case 760: return NULL; /* fmadd --> NULL. */
|
|
case 763: value = 764; break; /* fnmadd --> fnmadd. */
|
|
case 764: return NULL; /* fnmadd --> NULL. */
|
|
case 124: value = 362; break; /* movi --> shrn. */
|
|
case 362: value = 363; break; /* shrn --> shrn2. */
|
|
case 363: value = 370; break; /* shrn2 --> sshll. */
|
|
case 370: value = 372; break; /* sshll --> sshll2. */
|
|
case 372: return NULL; /* sshll2 --> NULL. */
|
|
case 131: value = 384; break; /* mvni --> sqshrun. */
|
|
case 384: value = 385; break; /* sqshrun --> sqshrun2. */
|
|
case 385: value = 392; break; /* sqshrun2 --> ushll. */
|
|
case 392: value = 394; break; /* ushll --> ushll2. */
|
|
case 394: return NULL; /* ushll2 --> NULL. */
|
|
case 125: value = 366; break; /* orr --> sqshrn. */
|
|
case 366: value = 367; break; /* sqshrn --> sqshrn2. */
|
|
case 367: return NULL; /* sqshrn2 --> NULL. */
|
|
case 132: value = 388; break; /* bic --> uqshrn. */
|
|
case 388: value = 389; break; /* uqshrn --> uqshrn2. */
|
|
case 389: return NULL; /* uqshrn2 --> NULL. */
|
|
case 127: value = 374; break; /* movi --> scvtf. */
|
|
case 374: return NULL; /* scvtf --> NULL. */
|
|
case 134: value = 135; break; /* movi --> movi. */
|
|
case 135: value = 396; break; /* movi --> ucvtf. */
|
|
case 396: return NULL; /* ucvtf --> NULL. */
|
|
case 761: value = 762; break; /* fmsub --> fmsub. */
|
|
case 762: return NULL; /* fmsub --> NULL. */
|
|
case 765: value = 766; break; /* fnmsub --> fnmsub. */
|
|
case 766: return NULL; /* fnmsub --> NULL. */
|
|
default: return NULL;
|
|
}
|
|
|
|
return aarch64_opcode_table + value;
|
|
}
|
|
|
|
const aarch64_opcode *
|
|
aarch64_find_alias_opcode (const aarch64_opcode *opcode)
|
|
{
|
|
/* Use the index as the key to locate the alias opcode. */
|
|
int key = opcode - aarch64_opcode_table;
|
|
int value;
|
|
switch (key)
|
|
{
|
|
case 2: value = 3; break; /* sbc --> ngc. */
|
|
case 4: value = 5; break; /* sbcs --> ngcs. */
|
|
case 7: value = 8; break; /* adds --> cmn. */
|
|
case 10: value = 11; break; /* subs --> cmp. */
|
|
case 12: value = 13; break; /* add --> mov. */
|
|
case 14: value = 15; break; /* adds --> cmn. */
|
|
case 17: value = 18; break; /* subs --> cmp. */
|
|
case 20: value = 21; break; /* adds --> cmn. */
|
|
case 22: value = 23; break; /* sub --> neg. */
|
|
case 24: value = 26; break; /* subs --> negs. */
|
|
case 140: value = 141; break; /* umov --> mov. */
|
|
case 142: value = 143; break; /* ins --> mov. */
|
|
case 144: value = 145; break; /* ins --> mov. */
|
|
case 226: value = 227; break; /* not --> mvn. */
|
|
case 301: value = 302; break; /* orr --> mov. */
|
|
case 370: value = 371; break; /* sshll --> sxtl. */
|
|
case 372: value = 373; break; /* sshll2 --> sxtl2. */
|
|
case 392: value = 393; break; /* ushll --> uxtl. */
|
|
case 394: value = 395; break; /* ushll2 --> uxtl2. */
|
|
case 489: value = 490; break; /* dup --> mov. */
|
|
case 563: value = 568; break; /* sbfm --> sxtw. */
|
|
case 570: value = 572; break; /* bfm --> bfc. */
|
|
case 574: value = 578; break; /* ubfm --> uxth. */
|
|
case 596: value = 598; break; /* csinc --> cset. */
|
|
case 599: value = 601; break; /* csinv --> csetm. */
|
|
case 602: value = 603; break; /* csneg --> cneg. */
|
|
case 621: value = 621; break; /* rev --> rev. */
|
|
case 628: value = 629; break; /* lslv --> lsl. */
|
|
case 630: value = 631; break; /* lsrv --> lsr. */
|
|
case 632: value = 633; break; /* asrv --> asr. */
|
|
case 634: value = 635; break; /* rorv --> ror. */
|
|
case 644: value = 645; break; /* madd --> mul. */
|
|
case 646: value = 647; break; /* msub --> mneg. */
|
|
case 648: value = 649; break; /* smaddl --> smull. */
|
|
case 650: value = 651; break; /* smsubl --> smnegl. */
|
|
case 653: value = 654; break; /* umaddl --> umull. */
|
|
case 655: value = 656; break; /* umsubl --> umnegl. */
|
|
case 666: value = 667; break; /* extr --> ror. */
|
|
case 873: value = 874; break; /* and --> bic. */
|
|
case 875: value = 876; break; /* orr --> mov. */
|
|
case 878: value = 879; break; /* ands --> tst. */
|
|
case 882: value = 884; break; /* orr --> uxtw. */
|
|
case 885: value = 886; break; /* orn --> mvn. */
|
|
case 889: value = 890; break; /* ands --> tst. */
|
|
case 920: value = 1016; break; /* ldaddb --> staddb. */
|
|
case 921: value = 1017; break; /* ldaddh --> staddh. */
|
|
case 922: value = 1018; break; /* ldadd --> stadd. */
|
|
case 924: value = 1019; break; /* ldaddlb --> staddlb. */
|
|
case 927: value = 1020; break; /* ldaddlh --> staddlh. */
|
|
case 930: value = 1021; break; /* ldaddl --> staddl. */
|
|
case 932: value = 1022; break; /* ldclrb --> stclrb. */
|
|
case 933: value = 1023; break; /* ldclrh --> stclrh. */
|
|
case 934: value = 1024; break; /* ldclr --> stclr. */
|
|
case 936: value = 1025; break; /* ldclrlb --> stclrlb. */
|
|
case 939: value = 1026; break; /* ldclrlh --> stclrlh. */
|
|
case 942: value = 1027; break; /* ldclrl --> stclrl. */
|
|
case 944: value = 1028; break; /* ldeorb --> steorb. */
|
|
case 945: value = 1029; break; /* ldeorh --> steorh. */
|
|
case 946: value = 1030; break; /* ldeor --> steor. */
|
|
case 948: value = 1031; break; /* ldeorlb --> steorlb. */
|
|
case 951: value = 1032; break; /* ldeorlh --> steorlh. */
|
|
case 954: value = 1033; break; /* ldeorl --> steorl. */
|
|
case 956: value = 1034; break; /* ldsetb --> stsetb. */
|
|
case 957: value = 1035; break; /* ldseth --> stseth. */
|
|
case 958: value = 1036; break; /* ldset --> stset. */
|
|
case 960: value = 1037; break; /* ldsetlb --> stsetlb. */
|
|
case 963: value = 1038; break; /* ldsetlh --> stsetlh. */
|
|
case 966: value = 1039; break; /* ldsetl --> stsetl. */
|
|
case 968: value = 1040; break; /* ldsmaxb --> stsmaxb. */
|
|
case 969: value = 1041; break; /* ldsmaxh --> stsmaxh. */
|
|
case 970: value = 1042; break; /* ldsmax --> stsmax. */
|
|
case 972: value = 1043; break; /* ldsmaxlb --> stsmaxlb. */
|
|
case 975: value = 1044; break; /* ldsmaxlh --> stsmaxlh. */
|
|
case 978: value = 1045; break; /* ldsmaxl --> stsmaxl. */
|
|
case 980: value = 1046; break; /* ldsminb --> stsminb. */
|
|
case 981: value = 1047; break; /* ldsminh --> stsminh. */
|
|
case 982: value = 1048; break; /* ldsmin --> stsmin. */
|
|
case 984: value = 1049; break; /* ldsminlb --> stsminlb. */
|
|
case 987: value = 1050; break; /* ldsminlh --> stsminlh. */
|
|
case 990: value = 1051; break; /* ldsminl --> stsminl. */
|
|
case 992: value = 1052; break; /* ldumaxb --> stumaxb. */
|
|
case 993: value = 1053; break; /* ldumaxh --> stumaxh. */
|
|
case 994: value = 1054; break; /* ldumax --> stumax. */
|
|
case 996: value = 1055; break; /* ldumaxlb --> stumaxlb. */
|
|
case 999: value = 1056; break; /* ldumaxlh --> stumaxlh. */
|
|
case 1002: value = 1057; break; /* ldumaxl --> stumaxl. */
|
|
case 1004: value = 1058; break; /* lduminb --> stuminb. */
|
|
case 1005: value = 1059; break; /* lduminh --> stuminh. */
|
|
case 1006: value = 1060; break; /* ldumin --> stumin. */
|
|
case 1008: value = 1061; break; /* lduminlb --> stuminlb. */
|
|
case 1011: value = 1062; break; /* lduminlh --> stuminlh. */
|
|
case 1014: value = 1063; break; /* lduminl --> stuminl. */
|
|
case 1064: value = 1065; break; /* movn --> mov. */
|
|
case 1066: value = 1067; break; /* movz --> mov. */
|
|
case 1072: value = 1080; break; /* hint --> psb. */
|
|
case 1085: value = 1089; break; /* sys --> tlbi. */
|
|
default: return NULL;
|
|
}
|
|
|
|
return aarch64_opcode_table + value;
|
|
}
|
|
|
|
const aarch64_opcode *
|
|
aarch64_find_next_alias_opcode (const aarch64_opcode *opcode)
|
|
{
|
|
/* Use the index as the key to locate the next opcode. */
|
|
int key = opcode - aarch64_opcode_table;
|
|
int value;
|
|
switch (key)
|
|
{
|
|
case 3: value = 2; break; /* ngc --> sbc. */
|
|
case 5: value = 4; break; /* ngcs --> sbcs. */
|
|
case 8: value = 7; break; /* cmn --> adds. */
|
|
case 11: value = 10; break; /* cmp --> subs. */
|
|
case 13: value = 12; break; /* mov --> add. */
|
|
case 15: value = 14; break; /* cmn --> adds. */
|
|
case 18: value = 17; break; /* cmp --> subs. */
|
|
case 21: value = 20; break; /* cmn --> adds. */
|
|
case 23: value = 22; break; /* neg --> sub. */
|
|
case 26: value = 25; break; /* negs --> cmp. */
|
|
case 25: value = 24; break; /* cmp --> subs. */
|
|
case 141: value = 140; break; /* mov --> umov. */
|
|
case 143: value = 142; break; /* mov --> ins. */
|
|
case 145: value = 144; break; /* mov --> ins. */
|
|
case 227: value = 226; break; /* mvn --> not. */
|
|
case 302: value = 301; break; /* mov --> orr. */
|
|
case 371: value = 370; break; /* sxtl --> sshll. */
|
|
case 373: value = 372; break; /* sxtl2 --> sshll2. */
|
|
case 393: value = 392; break; /* uxtl --> ushll. */
|
|
case 395: value = 394; break; /* uxtl2 --> ushll2. */
|
|
case 490: value = 489; break; /* mov --> dup. */
|
|
case 568: value = 567; break; /* sxtw --> sxth. */
|
|
case 567: value = 566; break; /* sxth --> sxtb. */
|
|
case 566: value = 569; break; /* sxtb --> asr. */
|
|
case 569: value = 565; break; /* asr --> sbfx. */
|
|
case 565: value = 564; break; /* sbfx --> sbfiz. */
|
|
case 564: value = 563; break; /* sbfiz --> sbfm. */
|
|
case 572: value = 573; break; /* bfc --> bfxil. */
|
|
case 573: value = 571; break; /* bfxil --> bfi. */
|
|
case 571: value = 570; break; /* bfi --> bfm. */
|
|
case 578: value = 577; break; /* uxth --> uxtb. */
|
|
case 577: value = 580; break; /* uxtb --> lsr. */
|
|
case 580: value = 579; break; /* lsr --> lsl. */
|
|
case 579: value = 576; break; /* lsl --> ubfx. */
|
|
case 576: value = 575; break; /* ubfx --> ubfiz. */
|
|
case 575: value = 574; break; /* ubfiz --> ubfm. */
|
|
case 598: value = 597; break; /* cset --> cinc. */
|
|
case 597: value = 596; break; /* cinc --> csinc. */
|
|
case 601: value = 600; break; /* csetm --> cinv. */
|
|
case 600: value = 599; break; /* cinv --> csinv. */
|
|
case 603: value = 602; break; /* cneg --> csneg. */
|
|
case 621: value = 622; break; /* rev --> rev64. */
|
|
case 629: value = 628; break; /* lsl --> lslv. */
|
|
case 631: value = 630; break; /* lsr --> lsrv. */
|
|
case 633: value = 632; break; /* asr --> asrv. */
|
|
case 635: value = 634; break; /* ror --> rorv. */
|
|
case 645: value = 644; break; /* mul --> madd. */
|
|
case 647: value = 646; break; /* mneg --> msub. */
|
|
case 649: value = 648; break; /* smull --> smaddl. */
|
|
case 651: value = 650; break; /* smnegl --> smsubl. */
|
|
case 654: value = 653; break; /* umull --> umaddl. */
|
|
case 656: value = 655; break; /* umnegl --> umsubl. */
|
|
case 667: value = 666; break; /* ror --> extr. */
|
|
case 874: value = 873; break; /* bic --> and. */
|
|
case 876: value = 875; break; /* mov --> orr. */
|
|
case 879: value = 878; break; /* tst --> ands. */
|
|
case 884: value = 883; break; /* uxtw --> mov. */
|
|
case 883: value = 882; break; /* mov --> orr. */
|
|
case 886: value = 885; break; /* mvn --> orn. */
|
|
case 890: value = 889; break; /* tst --> ands. */
|
|
case 1016: value = 920; break; /* staddb --> ldaddb. */
|
|
case 1017: value = 921; break; /* staddh --> ldaddh. */
|
|
case 1018: value = 922; break; /* stadd --> ldadd. */
|
|
case 1019: value = 924; break; /* staddlb --> ldaddlb. */
|
|
case 1020: value = 927; break; /* staddlh --> ldaddlh. */
|
|
case 1021: value = 930; break; /* staddl --> ldaddl. */
|
|
case 1022: value = 932; break; /* stclrb --> ldclrb. */
|
|
case 1023: value = 933; break; /* stclrh --> ldclrh. */
|
|
case 1024: value = 934; break; /* stclr --> ldclr. */
|
|
case 1025: value = 936; break; /* stclrlb --> ldclrlb. */
|
|
case 1026: value = 939; break; /* stclrlh --> ldclrlh. */
|
|
case 1027: value = 942; break; /* stclrl --> ldclrl. */
|
|
case 1028: value = 944; break; /* steorb --> ldeorb. */
|
|
case 1029: value = 945; break; /* steorh --> ldeorh. */
|
|
case 1030: value = 946; break; /* steor --> ldeor. */
|
|
case 1031: value = 948; break; /* steorlb --> ldeorlb. */
|
|
case 1032: value = 951; break; /* steorlh --> ldeorlh. */
|
|
case 1033: value = 954; break; /* steorl --> ldeorl. */
|
|
case 1034: value = 956; break; /* stsetb --> ldsetb. */
|
|
case 1035: value = 957; break; /* stseth --> ldseth. */
|
|
case 1036: value = 958; break; /* stset --> ldset. */
|
|
case 1037: value = 960; break; /* stsetlb --> ldsetlb. */
|
|
case 1038: value = 963; break; /* stsetlh --> ldsetlh. */
|
|
case 1039: value = 966; break; /* stsetl --> ldsetl. */
|
|
case 1040: value = 968; break; /* stsmaxb --> ldsmaxb. */
|
|
case 1041: value = 969; break; /* stsmaxh --> ldsmaxh. */
|
|
case 1042: value = 970; break; /* stsmax --> ldsmax. */
|
|
case 1043: value = 972; break; /* stsmaxlb --> ldsmaxlb. */
|
|
case 1044: value = 975; break; /* stsmaxlh --> ldsmaxlh. */
|
|
case 1045: value = 978; break; /* stsmaxl --> ldsmaxl. */
|
|
case 1046: value = 980; break; /* stsminb --> ldsminb. */
|
|
case 1047: value = 981; break; /* stsminh --> ldsminh. */
|
|
case 1048: value = 982; break; /* stsmin --> ldsmin. */
|
|
case 1049: value = 984; break; /* stsminlb --> ldsminlb. */
|
|
case 1050: value = 987; break; /* stsminlh --> ldsminlh. */
|
|
case 1051: value = 990; break; /* stsminl --> ldsminl. */
|
|
case 1052: value = 992; break; /* stumaxb --> ldumaxb. */
|
|
case 1053: value = 993; break; /* stumaxh --> ldumaxh. */
|
|
case 1054: value = 994; break; /* stumax --> ldumax. */
|
|
case 1055: value = 996; break; /* stumaxlb --> ldumaxlb. */
|
|
case 1056: value = 999; break; /* stumaxlh --> ldumaxlh. */
|
|
case 1057: value = 1002; break; /* stumaxl --> ldumaxl. */
|
|
case 1058: value = 1004; break; /* stuminb --> lduminb. */
|
|
case 1059: value = 1005; break; /* stuminh --> lduminh. */
|
|
case 1060: value = 1006; break; /* stumin --> ldumin. */
|
|
case 1061: value = 1008; break; /* stuminlb --> lduminlb. */
|
|
case 1062: value = 1011; break; /* stuminlh --> lduminlh. */
|
|
case 1063: value = 1014; break; /* stuminl --> lduminl. */
|
|
case 1065: value = 1064; break; /* mov --> movn. */
|
|
case 1067: value = 1066; break; /* mov --> movz. */
|
|
case 1080: value = 1079; break; /* psb --> esb. */
|
|
case 1079: value = 1078; break; /* esb --> sevl. */
|
|
case 1078: value = 1077; break; /* sevl --> sev. */
|
|
case 1077: value = 1076; break; /* sev --> wfi. */
|
|
case 1076: value = 1075; break; /* wfi --> wfe. */
|
|
case 1075: value = 1074; break; /* wfe --> yield. */
|
|
case 1074: value = 1073; break; /* yield --> nop. */
|
|
case 1073: value = 1072; break; /* nop --> hint. */
|
|
case 1089: value = 1088; break; /* tlbi --> ic. */
|
|
case 1088: value = 1087; break; /* ic --> dc. */
|
|
case 1087: value = 1086; break; /* dc --> at. */
|
|
case 1086: value = 1085; break; /* at --> sys. */
|
|
default: return NULL;
|
|
}
|
|
|
|
return aarch64_opcode_table + value;
|
|
}
|
|
|
|
int
|
|
aarch64_extract_operand (const aarch64_operand *self,
|
|
aarch64_opnd_info *info,
|
|
aarch64_insn code, const aarch64_inst *inst)
|
|
{
|
|
/* Use the index as the key. */
|
|
int key = self - aarch64_operands;
|
|
switch (key)
|
|
{
|
|
case 1:
|
|
case 2:
|
|
case 3:
|
|
case 4:
|
|
case 5:
|
|
case 6:
|
|
case 7:
|
|
case 9:
|
|
case 10:
|
|
case 14:
|
|
case 15:
|
|
case 16:
|
|
case 17:
|
|
case 19:
|
|
case 20:
|
|
case 21:
|
|
case 22:
|
|
case 23:
|
|
case 24:
|
|
case 25:
|
|
case 26:
|
|
case 27:
|
|
case 35:
|
|
case 36:
|
|
return aarch64_ext_regno (self, info, code, inst);
|
|
case 8:
|
|
return aarch64_ext_regrt_sysins (self, info, code, inst);
|
|
case 11:
|
|
return aarch64_ext_regno_pair (self, info, code, inst);
|
|
case 12:
|
|
return aarch64_ext_reg_extended (self, info, code, inst);
|
|
case 13:
|
|
return aarch64_ext_reg_shifted (self, info, code, inst);
|
|
case 18:
|
|
return aarch64_ext_ft (self, info, code, inst);
|
|
case 28:
|
|
case 29:
|
|
case 30:
|
|
return aarch64_ext_reglane (self, info, code, inst);
|
|
case 31:
|
|
return aarch64_ext_reglist (self, info, code, inst);
|
|
case 32:
|
|
return aarch64_ext_ldst_reglist (self, info, code, inst);
|
|
case 33:
|
|
return aarch64_ext_ldst_reglist_r (self, info, code, inst);
|
|
case 34:
|
|
return aarch64_ext_ldst_elemlist (self, info, code, inst);
|
|
case 37:
|
|
case 46:
|
|
case 47:
|
|
case 48:
|
|
case 49:
|
|
case 50:
|
|
case 51:
|
|
case 52:
|
|
case 53:
|
|
case 54:
|
|
case 55:
|
|
case 56:
|
|
case 57:
|
|
case 58:
|
|
case 66:
|
|
case 67:
|
|
case 68:
|
|
case 69:
|
|
case 70:
|
|
return aarch64_ext_imm (self, info, code, inst);
|
|
case 38:
|
|
case 39:
|
|
return aarch64_ext_advsimd_imm_shift (self, info, code, inst);
|
|
case 40:
|
|
case 41:
|
|
case 42:
|
|
return aarch64_ext_advsimd_imm_modified (self, info, code, inst);
|
|
case 43:
|
|
return aarch64_ext_shll_imm (self, info, code, inst);
|
|
case 59:
|
|
return aarch64_ext_limm (self, info, code, inst);
|
|
case 60:
|
|
return aarch64_ext_aimm (self, info, code, inst);
|
|
case 61:
|
|
return aarch64_ext_imm_half (self, info, code, inst);
|
|
case 62:
|
|
return aarch64_ext_fbits (self, info, code, inst);
|
|
case 64:
|
|
case 65:
|
|
return aarch64_ext_cond (self, info, code, inst);
|
|
case 71:
|
|
case 77:
|
|
return aarch64_ext_addr_simple (self, info, code, inst);
|
|
case 72:
|
|
return aarch64_ext_addr_regoff (self, info, code, inst);
|
|
case 73:
|
|
case 74:
|
|
case 75:
|
|
return aarch64_ext_addr_simm (self, info, code, inst);
|
|
case 76:
|
|
return aarch64_ext_addr_uimm12 (self, info, code, inst);
|
|
case 78:
|
|
return aarch64_ext_simd_addr_post (self, info, code, inst);
|
|
case 79:
|
|
return aarch64_ext_sysreg (self, info, code, inst);
|
|
case 80:
|
|
return aarch64_ext_pstatefield (self, info, code, inst);
|
|
case 81:
|
|
case 82:
|
|
case 83:
|
|
case 84:
|
|
return aarch64_ext_sysins_op (self, info, code, inst);
|
|
case 85:
|
|
case 86:
|
|
return aarch64_ext_barrier (self, info, code, inst);
|
|
case 87:
|
|
return aarch64_ext_prfop (self, info, code, inst);
|
|
case 88:
|
|
return aarch64_ext_hint (self, info, code, inst);
|
|
default: assert (0); abort ();
|
|
}
|
|
}
|