diff --git a/core/rexcode/arm32/mnemonic_builders.odin b/core/rexcode/arm32/mnemonic_builders.odin index 937fa6ff4..6fc7d33ec 100644 --- a/core/rexcode/arm32/mnemonic_builders.odin +++ b/core/rexcode/arm32/mnemonic_builders.odin @@ -482,6 +482,12 @@ inst_pli_mem :: #force_inline proc "contextless" (dst: Memor emit_pli_mem :: #force_inline proc(instructions: ^[dynamic]Instruction, dst: Memory) { append(instructions, inst_pli_mem(dst)) } inst_hlt_imm :: #force_inline proc "contextless" (imm: i64) -> Instruction { return Instruction{mnemonic = .HLT, operand_count = 1, mode = .A32, cond = 14, length = 4, ops = {op_imm(imm), {}, {}, {}}} } emit_hlt_imm :: #force_inline proc(instructions: ^[dynamic]Instruction, imm: i64) { append(instructions, inst_hlt_imm(imm)) } +inst_dcps1_none :: #force_inline proc "contextless" () -> Instruction { return Instruction{mnemonic = .DCPS1, operand_count = 0, mode = .T32, cond = 14, length = 4, ops = {{}, {}, {}, {}}} } +emit_dcps1_none :: #force_inline proc(instructions: ^[dynamic]Instruction) { append(instructions, inst_dcps1_none()) } +inst_dcps2_none :: #force_inline proc "contextless" () -> Instruction { return Instruction{mnemonic = .DCPS2, operand_count = 0, mode = .T32, cond = 14, length = 4, ops = {{}, {}, {}, {}}} } +emit_dcps2_none :: #force_inline proc(instructions: ^[dynamic]Instruction) { append(instructions, inst_dcps2_none()) } +inst_dcps3_none :: #force_inline proc "contextless" () -> Instruction { return Instruction{mnemonic = .DCPS3, operand_count = 0, mode = .T32, cond = 14, length = 4, ops = {{}, {}, {}, {}}} } +emit_dcps3_none :: #force_inline proc(instructions: ^[dynamic]Instruction) { append(instructions, inst_dcps3_none()) } inst_eret_none :: #force_inline proc "contextless" () -> Instruction { return Instruction{mnemonic = .ERET, operand_count = 0, mode = .A32, cond = 14, length = 4, ops = {{}, {}, {}, {}}} } emit_eret_none :: #force_inline proc(instructions: ^[dynamic]Instruction) { append(instructions, inst_eret_none()) } inst_esb_none :: #force_inline proc "contextless" () -> Instruction { return Instruction{mnemonic = .ESB, operand_count = 0, mode = .A32, cond = 14, length = 4, ops = {{}, {}, {}, {}}} } @@ -1757,6 +1763,12 @@ inst_pli :: inst_pli_mem emit_pli :: emit_pli_mem inst_hlt :: inst_hlt_imm emit_hlt :: emit_hlt_imm +inst_dcps1 :: inst_dcps1_none +emit_dcps1 :: emit_dcps1_none +inst_dcps2 :: inst_dcps2_none +emit_dcps2 :: emit_dcps2_none +inst_dcps3 :: inst_dcps3_none +emit_dcps3 :: emit_dcps3_none inst_eret :: inst_eret_none emit_eret :: emit_eret_none inst_esb :: inst_esb_none diff --git a/core/rexcode/arm32/tablegen/encoding_table.odin b/core/rexcode/arm32/tablegen/encoding_table.odin index 65d2bb4a4..41d91f479 100644 --- a/core/rexcode/arm32/tablegen/encoding_table.odin +++ b/core/rexcode/arm32/tablegen/encoding_table.odin @@ -3661,6 +3661,11 @@ ENCODING_TABLE := #partial [Mnemonic][]Encoding{ {.VCVTR, {.SPR, .DPR, .NONE, .NONE}, {.VD_S, .VM_D, .NONE, .NONE}, 0x0EBC0B40, 0x0FBF0FD0, .VFPV2, .A32, {}}, }, + // Debug change PE state (T32, fixed encoding, no operands). + .DCPS1 = { {.DCPS1, {.NONE, .NONE, .NONE, .NONE}, {.NONE, .NONE, .NONE, .NONE}, 0xF78F8001, 0xFFFFFFFF, .V8, .T32, {thumb32=true, cond_in_28=false}} }, + .DCPS2 = { {.DCPS2, {.NONE, .NONE, .NONE, .NONE}, {.NONE, .NONE, .NONE, .NONE}, 0xF78F8002, 0xFFFFFFFF, .V8, .T32, {thumb32=true, cond_in_28=false}} }, + .DCPS3 = { {.DCPS3, {.NONE, .NONE, .NONE, .NONE}, {.NONE, .NONE, .NONE, .NONE}, 0xF78F8003, 0xFFFFFFFF, .V8, .T32, {thumb32=true, cond_in_28=false}} }, + // SPECGEN:BEGIN .VADDL = { {.VADDL, {.QPR, .DPR, .DPR, .NONE}, {.VD_Q, .VN_D, .VM_D, .NONE}, 0xF2800000, 0xFFB01F50, .NEON, .A32, {cond_in_28=false}}, diff --git a/core/rexcode/arm32/tablegen/generated/decode_tables.odin b/core/rexcode/arm32/tablegen/generated/decode_tables.odin index 11fccdab0..196058eff 100644 --- a/core/rexcode/arm32/tablegen/generated/decode_tables.odin +++ b/core/rexcode/arm32/tablegen/generated/decode_tables.odin @@ -8,7 +8,7 @@ package rexcode_arm32_generated import lib "../.." @(rodata) -DECODE_ENTRIES := [1657]lib.Decode_Entry{ +DECODE_ENTRIES := [1660]lib.Decode_Entry{ { .MUL, {.GPR,.GPR,.GPR,.NONE}, {.RN_A32,.RM_A32,.RS_A32,.NONE}, 0x00000090, 0x0FE000F0, .BASE, .A32, {} }, { .AND, {.GPR,.GPR,.GPR_RSR,.NONE}, {.RD,.RN_A32,.RM_A32,.NONE}, 0x00000010, 0x0FE00090, .BASE, .A32, {} }, { .AND, {.GPR,.GPR,.GPR_SHIFTED,.NONE}, {.RD,.RN_A32,.RM_A32,.NONE}, 0x00000000, 0x0FE00010, .BASE, .A32, {} }, @@ -186,8 +186,8 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VADD, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2000840, 0xFFB00F50, .NEON, .A32, {} }, { .VADD, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2000D40, 0xFFB00F50, .NEON, .A32, {} }, { .VMUL, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2000950, 0xFFB00F50, .NEON, .A32, {} }, - { .VMLA, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2000D50, 0xFFB00F50, .NEON, .A32, {} }, { .VMLA, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2000940, 0xFFB00F50, .NEON, .A32, {} }, + { .VMLA, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2000D50, 0xFFB00F50, .NEON, .A32, {} }, { .VFMA, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2000C50, 0xFFB00F50, .NEON, .A32, {} }, { .VHADD, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2000040, 0xFFB00F50, .NEON, .A32, {} }, { .VHSUB, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2000240, 0xFFB00F50, .NEON, .A32, {} }, @@ -212,11 +212,11 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VQSHL, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VM_Q,.VN_Q,.NONE}, 0xF2000450, 0xFFB00F50, .NEON, .A32, {} }, { .VQRSHL, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VM_D,.VN_D,.NONE}, 0xF2000510, 0xFFB00F50, .NEON, .A32, {} }, { .SHA1C, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2000C40, 0xFFB00F50, .CRYPTO, .A32, {} }, - { .VADD, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2000D00, 0xFFB00F10, .NEON, .A32, {} }, { .VADD, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2000800, 0xFFB00F10, .NEON, .A32, {} }, + { .VADD, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2000D00, 0xFFB00F10, .NEON, .A32, {} }, { .VMUL, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2000910, 0xFFB00F10, .NEON, .A32, {} }, - { .VMLA, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2000D10, 0xFFB00F10, .NEON, .A32, {} }, { .VMLA, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2000900, 0xFFB00F10, .NEON, .A32, {} }, + { .VMLA, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2000D10, 0xFFB00F10, .NEON, .A32, {} }, { .VFMA, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2000C10, 0xFFB00F10, .NEON, .A32, {} }, { .VHADD, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2000000, 0xFFB00F10, .NEON, .A32, {} }, { .VHSUB, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2000200, 0xFFB00F10, .NEON, .A32, {} }, @@ -267,8 +267,8 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VMIN, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2100650, 0xFFB00F50, .NEON, .A32, {} }, { .VQRSHL, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VM_D,.VN_D,.NONE}, 0xF2100510, 0xFFB00F50, .NEON, .A32, {} }, { .SHA1P, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2100C40, 0xFFB00F50, .CRYPTO, .A32, {} }, - { .VADD, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2100800, 0xFFB00F10, .NEON, .A32, {} }, { .VADD, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2100D00, 0xFFB00F10, .NEON_HALF_FP, .A32, {} }, + { .VADD, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2100800, 0xFFB00F10, .NEON, .A32, {} }, { .VMUL, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2100910, 0xFFB00F10, .NEON, .A32, {} }, { .VMLA, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2100900, 0xFFB00F10, .NEON, .A32, {} }, { .VHADD, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2100000, 0xFFB00F10, .NEON, .A32, {} }, @@ -283,8 +283,8 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VCEQ, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2100E00, 0xFFB00F10, .NEON_HALF_FP, .A32, {} }, { .VCGE, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2100310, 0xFFB00F10, .NEON, .A32, {} }, { .VCGT, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2100300, 0xFFB00F10, .NEON, .A32, {} }, - { .VMAX, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2100600, 0xFFB00F10, .NEON, .A32, {} }, { .VMAX, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2100F00, 0xFFB00F10, .NEON_HALF_FP, .A32, {} }, + { .VMAX, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2100600, 0xFFB00F10, .NEON, .A32, {} }, { .VMIN, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2100610, 0xFFB00F10, .NEON, .A32, {} }, { .VPMAX, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2100A00, 0xFFB00F10, .NEON, .A32, {} }, { .VPMIN, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2100A10, 0xFFB00F10, .NEON, .A32, {} }, @@ -314,8 +314,8 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VCLE, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VM_D,.VN_D,.NONE}, 0xF2200310, 0xFFB00F50, .NEON, .A32, {} }, { .VCLT, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VM_D,.VN_D,.NONE}, 0xF2200300, 0xFFB00F50, .NEON, .A32, {} }, { .VMAX, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2200640, 0xFFB00F50, .NEON, .A32, {} }, - { .VMIN, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2200F40, 0xFFB00F50, .NEON, .A32, {} }, { .VMIN, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2200650, 0xFFB00F50, .NEON, .A32, {} }, + { .VMIN, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2200F40, 0xFFB00F50, .NEON, .A32, {} }, { .VRSQRTS, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2200F50, 0xFFB00F50, .NEON, .A32, {} }, { .VQRSHL, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VM_D,.VN_D,.NONE}, 0xF2200510, 0xFFB00F50, .NEON, .A32, {} }, { .SHA1M, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF2200C40, 0xFFB00F50, .CRYPTO, .A32, {} }, @@ -337,8 +337,8 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VCGE, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2200310, 0xFFB00F10, .NEON, .A32, {} }, { .VCGT, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2200300, 0xFFB00F10, .NEON, .A32, {} }, { .VMAX, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2200600, 0xFFB00F10, .NEON, .A32, {} }, - { .VMIN, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2200610, 0xFFB00F10, .NEON, .A32, {} }, { .VMIN, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2200F00, 0xFFB00F10, .NEON, .A32, {} }, + { .VMIN, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2200610, 0xFFB00F10, .NEON, .A32, {} }, { .VPMAX, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2200A00, 0xFFB00F10, .NEON, .A32, {} }, { .VPMIN, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2200A10, 0xFFB00F10, .NEON, .A32, {} }, { .VPADD, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2200B10, 0xFFB00F10, .NEON, .A32, {} }, @@ -370,40 +370,40 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VADDW, {.QPR,.QPR,.DPR,.NONE}, {.VD_Q,.VN_Q,.VM_D,.NONE}, 0xF2800100, 0xFFB11F50, .NEON, .A32, {} }, { .VSUBW, {.QPR,.QPR,.DPR,.NONE}, {.VD_Q,.VN_Q,.VM_D,.NONE}, 0xF2800300, 0xFFB11F50, .NEON, .A32, {} }, { .VMOVL, {.QPR,.DPR,.NONE,.NONE}, {.VD_Q,.VM_D,.NONE,.NONE}, 0xF2880A10, 0xFFB80FD0, .NEON, .A32, {} }, - { .VMOV, {.QPR,.IMM,.NONE,.NONE}, {.VD_Q,.NONE,.NONE,.NONE}, 0xF2800850, 0xFEB80FD0, .NEON, .A32, {} }, - { .VMOV, {.QPR,.IMM,.NONE,.NONE}, {.VD_Q,.NONE,.NONE,.NONE}, 0xF2800E70, 0xFEB80FD0, .NEON, .A32, {} }, { .VMOV, {.QPR,.IMM,.NONE,.NONE}, {.VD_Q,.NONE,.NONE,.NONE}, 0xF2800F50, 0xFEB80FD0, .NEON, .A32, {} }, { .VMOV, {.QPR,.IMM,.NONE,.NONE}, {.VD_Q,.NONE,.NONE,.NONE}, 0xF2800E50, 0xFEB80FD0, .NEON, .A32, {} }, { .VMOV, {.QPR,.IMM,.NONE,.NONE}, {.VD_Q,.NONE,.NONE,.NONE}, 0xF2800050, 0xFEB80FD0, .NEON, .A32, {} }, + { .VMOV, {.QPR,.IMM,.NONE,.NONE}, {.VD_Q,.NONE,.NONE,.NONE}, 0xF2800E70, 0xFEB80FD0, .NEON, .A32, {} }, + { .VMOV, {.QPR,.IMM,.NONE,.NONE}, {.VD_Q,.NONE,.NONE,.NONE}, 0xF2800850, 0xFEB80FD0, .NEON, .A32, {} }, { .VADDL, {.QPR,.DPR,.DPR,.NONE}, {.VD_Q,.VN_D,.VM_D,.NONE}, 0xF2800000, 0xFFB01F50, .NEON, .A32, {} }, { .VSUBL, {.QPR,.DPR,.DPR,.NONE}, {.VD_Q,.VN_D,.VM_D,.NONE}, 0xF2800200, 0xFFB01F50, .NEON, .A32, {} }, { .VABAL, {.QPR,.DPR,.DPR,.NONE}, {.VD_Q,.VN_D,.VM_D,.NONE}, 0xF2800500, 0xFFB01F50, .NEON, .A32, {} }, { .VABDL, {.QPR,.DPR,.DPR,.NONE}, {.VD_Q,.VN_D,.VM_D,.NONE}, 0xF2800700, 0xFFB01F50, .NEON, .A32, {} }, { .VMVN, {.QPR,.IMM,.NONE,.NONE}, {.VD_Q,.NONE,.NONE,.NONE}, 0xF2800870, 0xFEB80FD0, .NEON, .A32, {} }, { .VMVN, {.QPR,.IMM,.NONE,.NONE}, {.VD_Q,.NONE,.NONE,.NONE}, 0xF2800070, 0xFEB80FD0, .NEON, .A32, {} }, - { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800610, 0xFEB80F90, .NEON, .A32, {} }, - { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800410, 0xFEB80F90, .NEON, .A32, {} }, - { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800A10, 0xFEB80F90, .NEON, .A32, {} }, - { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800E10, 0xFEB80F90, .NEON, .A32, {} }, - { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800D10, 0xFEB80F90, .NEON, .A32, {} }, - { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800210, 0xFEB80F90, .NEON, .A32, {} }, - { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800E30, 0xFEB80F90, .NEON, .A32, {} }, { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800810, 0xFEB80F90, .NEON, .A32, {} }, + { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800410, 0xFEB80F90, .NEON, .A32, {} }, + { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800D10, 0xFEB80F90, .NEON, .A32, {} }, { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800F10, 0xFEB80F90, .NEON, .A32, {} }, - { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800010, 0xFEB80F90, .NEON, .A32, {} }, + { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800A10, 0xFEB80F90, .NEON, .A32, {} }, { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800C10, 0xFEB80F90, .NEON, .A32, {} }, - { .VMULL, {.QPR,.DPR,.DPR,.NONE}, {.VD_Q,.VN_D,.VM_D,.NONE}, 0xF2800C00, 0xFFB00F50, .NEON, .A32, {} }, + { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800E30, 0xFEB80F90, .NEON, .A32, {} }, + { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800E10, 0xFEB80F90, .NEON, .A32, {} }, + { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800610, 0xFEB80F90, .NEON, .A32, {} }, + { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800210, 0xFEB80F90, .NEON, .A32, {} }, + { .VMOV, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800010, 0xFEB80F90, .NEON, .A32, {} }, { .VMULL, {.QPR,.DPR,.DPR,.NONE}, {.VD_Q,.VN_D,.VM_D,.NONE}, 0xF2800E00, 0xFFB00F50, .NEON, .A32, {} }, + { .VMULL, {.QPR,.DPR,.DPR,.NONE}, {.VD_Q,.VN_D,.VM_D,.NONE}, 0xF2800C00, 0xFFB00F50, .NEON, .A32, {} }, { .VMLAL, {.QPR,.DPR,.DPR,.NONE}, {.VD_Q,.VN_D,.VM_D,.NONE}, 0xF2800800, 0xFFB00F50, .NEON, .A32, {} }, { .VMLSL, {.QPR,.DPR,.DPR,.NONE}, {.VD_Q,.VN_D,.VM_D,.NONE}, 0xF2800A00, 0xFFB00F50, .NEON, .A32, {} }, - { .VMVN, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800630, 0xFEB80F90, .NEON, .A32, {} }, { .VMVN, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800C30, 0xFEB80F90, .NEON, .A32, {} }, - { .VMVN, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800030, 0xFEB80F90, .NEON, .A32, {} }, { .VMVN, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800D30, 0xFEB80F90, .NEON, .A32, {} }, - { .VMVN, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800230, 0xFEB80F90, .NEON, .A32, {} }, - { .VMVN, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800430, 0xFEB80F90, .NEON, .A32, {} }, { .VMVN, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800A30, 0xFEB80F90, .NEON, .A32, {} }, + { .VMVN, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800430, 0xFEB80F90, .NEON, .A32, {} }, + { .VMVN, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800030, 0xFEB80F90, .NEON, .A32, {} }, { .VMVN, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800830, 0xFEB80F90, .NEON, .A32, {} }, + { .VMVN, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800230, 0xFEB80F90, .NEON, .A32, {} }, + { .VMVN, {.DPR,.IMM,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0xF2800630, 0xFEB80F90, .NEON, .A32, {} }, { .VQSHRN, {.DPR,.QPR,.IMM,.NONE}, {.VD_D,.VM_Q,.NEON_SHIFT_IMM6,.NONE}, 0xF2800910, 0xFE800FD0, .NEON, .A32, {} }, { .VQRSHRN, {.DPR,.QPR,.IMM,.NONE}, {.VD_D,.VM_Q,.NEON_SHIFT_IMM6,.NONE}, 0xF2800950, 0xFE800FD0, .NEON, .A32, {} }, { .VSHRN, {.DPR,.QPR,.IMM,.NONE}, {.VD_D,.VM_Q,.NEON_SHIFT_IMM6,.NONE}, 0xF2800810, 0xFE800FD0, .NEON, .A32, {} }, @@ -460,10 +460,10 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VQDMLSL, {.QPR,.DPR,.DPR,.NONE}, {.VD_Q,.VN_D,.VM_D,.NONE}, 0xF2A00B00, 0xFFB00F50, .NEON, .A32, {} }, { .VMUL_LANE, {.DPR,.DPR,.DPR_ELEM,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2A00840, 0xFFB00F50, .NEON, .A32, {} }, { .VMUL_LANE, {.DPR,.DPR,.DPR_ELEM,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2A008C0, 0xFFB00F50, .NEON, .A32, {} }, - { .VMLA_LANE, {.DPR,.DPR,.DPR_ELEM,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2A00040, 0xFFB00F50, .NEON, .A32, {} }, { .VMLA_LANE, {.DPR,.DPR,.DPR_ELEM,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2A000C0, 0xFFB00F50, .NEON, .A32, {} }, - { .VMLS_LANE, {.DPR,.DPR,.DPR_ELEM,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2A00440, 0xFFB00F50, .NEON, .A32, {} }, + { .VMLA_LANE, {.DPR,.DPR,.DPR_ELEM,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2A00040, 0xFFB00F50, .NEON, .A32, {} }, { .VMLS_LANE, {.DPR,.DPR,.DPR_ELEM,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2A004C0, 0xFFB00F50, .NEON, .A32, {} }, + { .VMLS_LANE, {.DPR,.DPR,.DPR_ELEM,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF2A00440, 0xFFB00F50, .NEON, .A32, {} }, { .VMULL_LANE, {.QPR,.DPR,.DPR_ELEM,.NONE}, {.VD_Q,.VN_D,.VM_D,.NONE}, 0xF2A00A40, 0xFFB00F50, .NEON, .A32, {} }, { .VMLAL_LANE, {.QPR,.DPR,.DPR_ELEM,.NONE}, {.VD_Q,.VN_D,.VM_D,.NONE}, 0xF2A00240, 0xFFB00F50, .NEON, .A32, {} }, { .VMLSL_LANE, {.QPR,.DPR,.DPR_ELEM,.NONE}, {.VD_Q,.VN_D,.VM_D,.NONE}, 0xF2A00640, 0xFFB00F50, .NEON, .A32, {} }, @@ -482,8 +482,8 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .SBC, {.GPR,.GPR,.IMM_MOD,.NONE}, {.RD,.RN_A32,.A32_IMM_MOD,.NONE}, 0x02D00000, 0x0FF00000, .BASE, .A32, {sets_flags=true} }, { .RSC, {.GPR,.GPR,.IMM_MOD,.NONE}, {.RD,.RN_A32,.A32_IMM_MOD,.NONE}, 0x02E00000, 0x0FE00000, .BASE, .A32, {} }, { .RSC, {.GPR,.GPR,.IMM_MOD,.NONE}, {.RD,.RN_A32,.A32_IMM_MOD,.NONE}, 0x02F00000, 0x0FF00000, .BASE, .A32, {sets_flags=true} }, - { .VCLE, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VM_Q,.VN_Q,.NONE}, 0xF3000E40, 0xFFB11F51, .NEON, .A32, {} }, { .VCLE, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VM_Q,.VN_Q,.NONE}, 0xF3000350, 0xFFB11F51, .NEON, .A32, {} }, + { .VCLE, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VM_Q,.VN_Q,.NONE}, 0xF3000E40, 0xFFB11F51, .NEON, .A32, {} }, { .VCLT, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VM_Q,.VN_Q,.NONE}, 0xF3000340, 0xFFB11F51, .NEON, .A32, {} }, { .VACLE, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VM_Q,.VN_Q,.NONE}, 0xF3000E50, 0xFFB11F51, .NEON, .A32, {} }, { .VQRSHL, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VM_Q,.VN_Q,.NONE}, 0xF3000550, 0xFFB11F51, .NEON, .A32, {} }, @@ -502,8 +502,8 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VCGE, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF3000350, 0xFFB00F50, .NEON, .A32, {} }, { .VCGE, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF3000E40, 0xFFB00F50, .NEON, .A32, {} }, { .VCGT, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF3000340, 0xFFB00F50, .NEON, .A32, {} }, - { .VCLE, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VM_D,.VN_D,.NONE}, 0xF3000E00, 0xFFB00F50, .NEON, .A32, {} }, { .VCLE, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VM_D,.VN_D,.NONE}, 0xF3000310, 0xFFB00F50, .NEON, .A32, {} }, + { .VCLE, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VM_D,.VN_D,.NONE}, 0xF3000E00, 0xFFB00F50, .NEON, .A32, {} }, { .VCLT, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VM_D,.VN_D,.NONE}, 0xF3000300, 0xFFB00F50, .NEON, .A32, {} }, { .VACGE, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF3000E50, 0xFFB00F50, .NEON, .A32, {} }, { .VACLE, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VM_D,.VN_D,.NONE}, 0xF3000E10, 0xFFB00F50, .NEON, .A32, {} }, @@ -526,8 +526,8 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VABD, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3000700, 0xFFB00F10, .NEON, .A32, {} }, { .VEOR, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3000110, 0xFFB00F10, .NEON, .A32, {} }, { .VCEQ, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3000810, 0xFFB00F10, .NEON, .A32, {} }, - { .VCGE, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3000E00, 0xFFB00F10, .NEON, .A32, {} }, { .VCGE, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3000310, 0xFFB00F10, .NEON, .A32, {} }, + { .VCGE, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3000E00, 0xFFB00F10, .NEON, .A32, {} }, { .VCGT, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3000300, 0xFFB00F10, .NEON, .A32, {} }, { .VACGE, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3000E10, 0xFFB00F10, .NEON, .A32, {} }, { .VMAX, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3000600, 0xFFB00F10, .NEON, .A32, {} }, @@ -595,8 +595,8 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VCEQ, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF3200850, 0xFFB00F50, .NEON, .A32, {} }, { .VCGT, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF3200E40, 0xFFB00F50, .NEON, .A32, {} }, { .VCLE, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VM_D,.VN_D,.NONE}, 0xF3200310, 0xFFB00F50, .NEON, .A32, {} }, - { .VCLT, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VM_D,.VN_D,.NONE}, 0xF3200300, 0xFFB00F50, .NEON, .A32, {} }, { .VCLT, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VM_D,.VN_D,.NONE}, 0xF3200E00, 0xFFB00F50, .NEON, .A32, {} }, + { .VCLT, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VM_D,.VN_D,.NONE}, 0xF3200300, 0xFFB00F50, .NEON, .A32, {} }, { .VACGT, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xF3200E50, 0xFFB00F50, .NEON, .A32, {} }, { .VACLT, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VM_D,.VN_D,.NONE}, 0xF3200E10, 0xFFB00F50, .NEON, .A32, {} }, { .VQRSHL, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VM_D,.VN_D,.NONE}, 0xF3200510, 0xFFB00F50, .NEON, .A32, {} }, @@ -684,8 +684,8 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VMUL_LANE, {.QPR,.QPR,.DPR_ELEM,.NONE}, {.VD_Q,.VN_Q,.VM_D,.NONE}, 0xF3A008C0, 0xFFB00F50, .NEON, .A32, {} }, { .VMLA_LANE, {.QPR,.QPR,.DPR_ELEM,.NONE}, {.VD_Q,.VN_Q,.VM_D,.NONE}, 0xF3A00040, 0xFFB00F50, .NEON, .A32, {} }, { .VMLA_LANE, {.QPR,.QPR,.DPR_ELEM,.NONE}, {.VD_Q,.VN_Q,.VM_D,.NONE}, 0xF3A000C0, 0xFFB00F50, .NEON, .A32, {} }, - { .VMLS_LANE, {.QPR,.QPR,.DPR_ELEM,.NONE}, {.VD_Q,.VN_Q,.VM_D,.NONE}, 0xF3A004C0, 0xFFB00F50, .NEON, .A32, {} }, { .VMLS_LANE, {.QPR,.QPR,.DPR_ELEM,.NONE}, {.VD_Q,.VN_Q,.VM_D,.NONE}, 0xF3A00440, 0xFFB00F50, .NEON, .A32, {} }, + { .VMLS_LANE, {.QPR,.QPR,.DPR_ELEM,.NONE}, {.VD_Q,.VN_Q,.VM_D,.NONE}, 0xF3A004C0, 0xFFB00F50, .NEON, .A32, {} }, { .VMULL_LANE, {.QPR,.DPR,.DPR_ELEM,.NONE}, {.VD_Q,.VN_D,.VM_D,.NONE}, 0xF3A00A40, 0xFFB00F50, .NEON, .A32, {} }, { .VMLAL_LANE, {.QPR,.DPR,.DPR_ELEM,.NONE}, {.VD_Q,.VN_D,.VM_D,.NONE}, 0xF3A00240, 0xFFB00F50, .NEON, .A32, {} }, { .VMLSL_LANE, {.QPR,.DPR,.DPR_ELEM,.NONE}, {.VD_Q,.VN_D,.VM_D,.NONE}, 0xF3A00640, 0xFFB00F50, .NEON, .A32, {} }, @@ -694,202 +694,202 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VQRDMLAH_LANE, {.QPR,.QPR,.DPR_ELEM,.NONE}, {.VD_Q,.VN_Q,.VM_D,.NONE}, 0xF3A00E40, 0xFFB00F50, .V8, .A32, {} }, { .VQRDMLSH_LANE, {.QPR,.QPR,.DPR_ELEM,.NONE}, {.VD_Q,.VN_Q,.VM_D,.NONE}, 0xF3A00F40, 0xFFB00F50, .V8, .A32, {} }, { .MOV, {.GPR,.IMM_MOD,.NONE,.NONE}, {.RD,.A32_IMM_MOD,.NONE,.NONE}, 0x03A00000, 0x0FEF0000, .BASE, .A32, {} }, - { .VRECPE, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3BB0400, 0xFFBF0FD0, .NEON, .A32, {} }, - { .VRECPE, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3BB0500, 0xFFBF0FD0, .NEON, .A32, {} }, { .VRECPE, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3BB0440, 0xFFBF0FD0, .NEON, .A32, {} }, + { .VRECPE, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3BB0500, 0xFFBF0FD0, .NEON, .A32, {} }, + { .VRECPE, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3BB0400, 0xFFBF0FD0, .NEON, .A32, {} }, { .VRECPE, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3BB0540, 0xFFBF0FD0, .NEON, .A32, {} }, { .VRSQRTE, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3BB0480, 0xFFBF0FD0, .NEON, .A32, {} }, - { .VRSQRTE, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3BB05C0, 0xFFBF0FD0, .NEON, .A32, {} }, { .VRSQRTE, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3BB04C0, 0xFFBF0FD0, .NEON, .A32, {} }, + { .VRSQRTE, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3BB05C0, 0xFFBF0FD0, .NEON, .A32, {} }, { .VRSQRTE, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3BB0580, 0xFFBF0FD0, .NEON, .A32, {} }, { .VRECPE_F, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3BB0500, 0xFFBF0FD0, .NEON, .A32, {} }, { .VRECPE_F, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3BB0540, 0xFFBF0FD0, .NEON, .A32, {} }, - { .VRSQRTE_F, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3BB05C0, 0xFFBF0FD0, .NEON, .A32, {} }, { .VRSQRTE_F, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3BB0580, 0xFFBF0FD0, .NEON, .A32, {} }, + { .VRSQRTE_F, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3BB05C0, 0xFFBF0FD0, .NEON, .A32, {} }, { .SHA1H, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B902C0, 0xFFBF0FD0, .CRYPTO, .A32, {} }, { .SHA1SU1, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3BA0380, 0xFFBF0FD0, .CRYPTO, .A32, {} }, { .SHA256SU0, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3BA03C0, 0xFFBF0FD0, .CRYPTO, .A32, {} }, { .VCVT_BF16, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3B60600, 0xFFBF0FD0, .BF16, .A32, {} }, - { .VABS, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B10300, 0xFFB30FD0, .NEON, .A32, {} }, - { .VABS, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B90700, 0xFFB30FD0, .NEON, .A32, {} }, + { .VABS, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B90740, 0xFFB30FD0, .NEON, .A32, {} }, { .VABS, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B90340, 0xFFB30FD0, .NEON, .A32, {} }, { .VABS, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B50300, 0xFFB30FD0, .NEON, .A32, {} }, - { .VABS, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B90740, 0xFFB30FD0, .NEON, .A32, {} }, { .VABS, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B50340, 0xFFB30FD0, .NEON, .A32, {} }, - { .VABS, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B90300, 0xFFB30FD0, .NEON, .A32, {} }, { .VABS, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B10340, 0xFFB30FD0, .NEON, .A32, {} }, - { .VNEG, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B10380, 0xFFB30FD0, .NEON, .A32, {} }, - { .VNEG, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B907C0, 0xFFB30FD0, .NEON, .A32, {} }, - { .VNEG, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B90780, 0xFFB30FD0, .NEON, .A32, {} }, - { .VNEG, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B903C0, 0xFFB30FD0, .NEON, .A32, {} }, - { .VNEG, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B50380, 0xFFB30FD0, .NEON, .A32, {} }, + { .VABS, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B10300, 0xFFB30FD0, .NEON, .A32, {} }, + { .VABS, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B90700, 0xFFB30FD0, .NEON, .A32, {} }, + { .VABS, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B90300, 0xFFB30FD0, .NEON, .A32, {} }, { .VNEG, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B90380, 0xFFB30FD0, .NEON, .A32, {} }, + { .VNEG, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B907C0, 0xFFB30FD0, .NEON, .A32, {} }, + { .VNEG, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B903C0, 0xFFB30FD0, .NEON, .A32, {} }, { .VNEG, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B503C0, 0xFFB30FD0, .NEON, .A32, {} }, + { .VNEG, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B90780, 0xFFB30FD0, .NEON, .A32, {} }, + { .VNEG, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B50380, 0xFFB30FD0, .NEON, .A32, {} }, + { .VNEG, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B10380, 0xFFB30FD0, .NEON, .A32, {} }, { .VNEG, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B103C0, 0xFFB30FD0, .NEON, .A32, {} }, { .VMVN, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B005C0, 0xFFB30FD0, .NEON, .A32, {} }, { .VMVN, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B00580, 0xFFB30FD0, .NEON, .A32, {} }, - { .VMOVN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3B20200, 0xFFB30FD0, .NEON, .A32, {} }, { .VMOVN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3BA0200, 0xFFB30FD0, .NEON, .A32, {} }, + { .VMOVN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3B20200, 0xFFB30FD0, .NEON, .A32, {} }, { .VMOVN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3B60200, 0xFFB30FD0, .NEON, .A32, {} }, - { .VQMOVN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3BA02C0, 0xFFB30FD0, .NEON, .A32, {} }, - { .VQMOVN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3B602C0, 0xFFB30FD0, .NEON, .A32, {} }, { .VQMOVN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3BA0280, 0xFFB30FD0, .NEON, .A32, {} }, - { .VQMOVN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3B202C0, 0xFFB30FD0, .NEON, .A32, {} }, - { .VQMOVN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3B20280, 0xFFB30FD0, .NEON, .A32, {} }, + { .VQMOVN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3B602C0, 0xFFB30FD0, .NEON, .A32, {} }, { .VQMOVN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3B60280, 0xFFB30FD0, .NEON, .A32, {} }, + { .VQMOVN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3B202C0, 0xFFB30FD0, .NEON, .A32, {} }, + { .VQMOVN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3BA02C0, 0xFFB30FD0, .NEON, .A32, {} }, + { .VQMOVN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3B20280, 0xFFB30FD0, .NEON, .A32, {} }, { .VQMOVUN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3B60240, 0xFFB30FD0, .NEON, .A32, {} }, - { .VQMOVUN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3BA0240, 0xFFB30FD0, .NEON, .A32, {} }, { .VQMOVUN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3B20240, 0xFFB30FD0, .NEON, .A32, {} }, + { .VQMOVUN, {.DPR,.QPR,.NONE,.NONE}, {.VD_D,.VM_Q,.NONE,.NONE}, 0xF3BA0240, 0xFFB30FD0, .NEON, .A32, {} }, { .VPADDL, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B40200, 0xFFB30FD0, .NEON, .A32, {} }, - { .VPADDL, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B80200, 0xFFB30FD0, .NEON, .A32, {} }, - { .VPADDL, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B00280, 0xFFB30FD0, .NEON, .A32, {} }, - { .VPADDL, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B00200, 0xFFB30FD0, .NEON, .A32, {} }, - { .VPADDL, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B00240, 0xFFB30FD0, .NEON, .A32, {} }, { .VPADDL, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B002C0, 0xFFB30FD0, .NEON, .A32, {} }, - { .VPADAL, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B006C0, 0xFFB30FD0, .NEON, .A32, {} }, + { .VPADDL, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B00280, 0xFFB30FD0, .NEON, .A32, {} }, + { .VPADDL, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B80200, 0xFFB30FD0, .NEON, .A32, {} }, + { .VPADDL, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B00240, 0xFFB30FD0, .NEON, .A32, {} }, + { .VPADDL, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B00200, 0xFFB30FD0, .NEON, .A32, {} }, + { .VPADAL, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B00680, 0xFFB30FD0, .NEON, .A32, {} }, { .VPADAL, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B00640, 0xFFB30FD0, .NEON, .A32, {} }, { .VPADAL, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B00600, 0xFFB30FD0, .NEON, .A32, {} }, - { .VPADAL, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B00680, 0xFFB30FD0, .NEON, .A32, {} }, - { .VSHLL, {.QPR,.DPR,.NONE,.NONE}, {.VD_Q,.VM_D,.NONE,.NONE}, 0xF3B60300, 0xFFB30FD0, .NEON, .A32, {} }, + { .VPADAL, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B006C0, 0xFFB30FD0, .NEON, .A32, {} }, { .VSHLL, {.QPR,.DPR,.NONE,.NONE}, {.VD_Q,.VM_D,.NONE,.NONE}, 0xF3BA0300, 0xFFB30FD0, .NEON, .A32, {} }, { .VSHLL, {.QPR,.DPR,.NONE,.NONE}, {.VD_Q,.VM_D,.NONE,.NONE}, 0xF3B20300, 0xFFB30FD0, .NEON, .A32, {} }, + { .VSHLL, {.QPR,.DPR,.NONE,.NONE}, {.VD_Q,.VM_D,.NONE,.NONE}, 0xF3B60300, 0xFFB30FD0, .NEON, .A32, {} }, { .VCLS, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B00400, 0xFFB30FD0, .NEON, .A32, {} }, - { .VCLS, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B40440, 0xFFB30FD0, .NEON, .A32, {} }, - { .VCLS, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B80440, 0xFFB30FD0, .NEON, .A32, {} }, - { .VCLS, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B00440, 0xFFB30FD0, .NEON, .A32, {} }, - { .VCLS, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B40400, 0xFFB30FD0, .NEON, .A32, {} }, { .VCLS, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B80400, 0xFFB30FD0, .NEON, .A32, {} }, - { .VCLZ, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B40480, 0xFFB30FD0, .NEON, .A32, {} }, - { .VCLZ, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B80480, 0xFFB30FD0, .NEON, .A32, {} }, + { .VCLS, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B40400, 0xFFB30FD0, .NEON, .A32, {} }, + { .VCLS, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B00440, 0xFFB30FD0, .NEON, .A32, {} }, + { .VCLS, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B80440, 0xFFB30FD0, .NEON, .A32, {} }, + { .VCLS, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B40440, 0xFFB30FD0, .NEON, .A32, {} }, + { .VCLZ, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B804C0, 0xFFB30FD0, .NEON, .A32, {} }, + { .VCLZ, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B004C0, 0xFFB30FD0, .NEON, .A32, {} }, { .VCLZ, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B404C0, 0xFFB30FD0, .NEON, .A32, {} }, { .VCLZ, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B00480, 0xFFB30FD0, .NEON, .A32, {} }, - { .VCLZ, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B004C0, 0xFFB30FD0, .NEON, .A32, {} }, - { .VCLZ, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B804C0, 0xFFB30FD0, .NEON, .A32, {} }, + { .VCLZ, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B40480, 0xFFB30FD0, .NEON, .A32, {} }, + { .VCLZ, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B80480, 0xFFB30FD0, .NEON, .A32, {} }, { .VCNT, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B00540, 0xFFB30FD0, .NEON, .A32, {} }, { .VCNT, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B00500, 0xFFB30FD0, .NEON, .A32, {} }, { .VREV16, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B00140, 0xFFB30FD0, .NEON, .A32, {} }, { .VREV16, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B00100, 0xFFB30FD0, .NEON, .A32, {} }, - { .VREV32, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B00080, 0xFFB30FD0, .NEON, .A32, {} }, - { .VREV32, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B000C0, 0xFFB30FD0, .NEON, .A32, {} }, - { .VREV32, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B40080, 0xFFB30FD0, .NEON, .A32, {} }, { .VREV32, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B400C0, 0xFFB30FD0, .NEON, .A32, {} }, + { .VREV32, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B00080, 0xFFB30FD0, .NEON, .A32, {} }, + { .VREV32, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B40080, 0xFFB30FD0, .NEON, .A32, {} }, + { .VREV32, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B000C0, 0xFFB30FD0, .NEON, .A32, {} }, + { .VREV64, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B40000, 0xFFB30FD0, .NEON, .A32, {} }, + { .VREV64, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B00000, 0xFFB30FD0, .NEON, .A32, {} }, + { .VREV64, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B80040, 0xFFB30FD0, .NEON, .A32, {} }, + { .VREV64, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B80000, 0xFFB30FD0, .NEON, .A32, {} }, { .VREV64, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B40040, 0xFFB30FD0, .NEON, .A32, {} }, { .VREV64, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B00040, 0xFFB30FD0, .NEON, .A32, {} }, - { .VREV64, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B80000, 0xFFB30FD0, .NEON, .A32, {} }, - { .VREV64, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B40000, 0xFFB30FD0, .NEON, .A32, {} }, - { .VREV64, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B80040, 0xFFB30FD0, .NEON, .A32, {} }, - { .VREV64, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B00000, 0xFFB30FD0, .NEON, .A32, {} }, { .VTRN, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B20080, 0xFFB30FD0, .NEON, .A32, {} }, { .VTRN, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B600C0, 0xFFB30FD0, .NEON, .A32, {} }, - { .VTRN, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3BA00C0, 0xFFB30FD0, .NEON, .A32, {} }, { .VTRN, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B60080, 0xFFB30FD0, .NEON, .A32, {} }, { .VTRN, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B200C0, 0xFFB30FD0, .NEON, .A32, {} }, { .VTRN, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3BA0080, 0xFFB30FD0, .NEON, .A32, {} }, - { .VUZP, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B60100, 0xFFB30FD0, .NEON, .A32, {} }, - { .VUZP, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B20100, 0xFFB30FD0, .NEON, .A32, {} }, + { .VTRN, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3BA00C0, 0xFFB30FD0, .NEON, .A32, {} }, { .VUZP, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B60140, 0xFFB30FD0, .NEON, .A32, {} }, + { .VUZP, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B60100, 0xFFB30FD0, .NEON, .A32, {} }, { .VUZP, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B20140, 0xFFB30FD0, .NEON, .A32, {} }, + { .VUZP, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B20100, 0xFFB30FD0, .NEON, .A32, {} }, { .VUZP, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3BA0140, 0xFFB30FD0, .NEON, .A32, {} }, - { .VZIP, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B601C0, 0xFFB30FD0, .NEON, .A32, {} }, { .VZIP, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B20180, 0xFFB30FD0, .NEON, .A32, {} }, { .VZIP, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B201C0, 0xFFB30FD0, .NEON, .A32, {} }, - { .VZIP, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B60180, 0xFFB30FD0, .NEON, .A32, {} }, + { .VZIP, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B601C0, 0xFFB30FD0, .NEON, .A32, {} }, { .VZIP, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3BA01C0, 0xFFB30FD0, .NEON, .A32, {} }, + { .VZIP, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B60180, 0xFFB30FD0, .NEON, .A32, {} }, { .VSWP, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B20000, 0xFFB30FD0, .NEON, .A32, {} }, { .VSWP, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B20040, 0xFFB30FD0, .NEON, .A32, {} }, { .AESE, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B00300, 0xFFB30FD0, .CRYPTO, .A32, {} }, { .AESD, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B00340, 0xFFB30FD0, .CRYPTO, .A32, {} }, { .AESMC, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B00380, 0xFFB30FD0, .CRYPTO, .A32, {} }, { .AESIMC, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B003C0, 0xFFB30FD0, .CRYPTO, .A32, {} }, - { .VCEQ_Z, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B10100, 0xFFB30FD0, .NEON, .A32, {} }, { .VCEQ_Z, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B10140, 0xFFB30FD0, .NEON, .A32, {} }, - { .VCEQ_Z, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B90500, 0xFFB30FD0, .NEON, .A32, {} }, + { .VCEQ_Z, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B10100, 0xFFB30FD0, .NEON, .A32, {} }, { .VCEQ_Z, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B90540, 0xFFB30FD0, .NEON, .A32, {} }, + { .VCEQ_Z, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B90500, 0xFFB30FD0, .NEON, .A32, {} }, + { .VCGE_Z, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B90480, 0xFFB30FD0, .NEON, .A32, {} }, + { .VCGE_Z, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B904C0, 0xFFB30FD0, .NEON, .A32, {} }, { .VCGE_Z, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B10080, 0xFFB30FD0, .NEON, .A32, {} }, { .VCGE_Z, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B100C0, 0xFFB30FD0, .NEON, .A32, {} }, - { .VCGE_Z, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B904C0, 0xFFB30FD0, .NEON, .A32, {} }, - { .VCGE_Z, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B90480, 0xFFB30FD0, .NEON, .A32, {} }, - { .VCGT_Z, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B10040, 0xFFB30FD0, .NEON, .A32, {} }, - { .VCGT_Z, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B90400, 0xFFB30FD0, .NEON, .A32, {} }, { .VCGT_Z, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B90440, 0xFFB30FD0, .NEON, .A32, {} }, + { .VCGT_Z, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B90400, 0xFFB30FD0, .NEON, .A32, {} }, { .VCGT_Z, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B10000, 0xFFB30FD0, .NEON, .A32, {} }, - { .VCLE_Z, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B90580, 0xFFB30FD0, .NEON, .A32, {} }, + { .VCGT_Z, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B10040, 0xFFB30FD0, .NEON, .A32, {} }, + { .VCLE_Z, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B10180, 0xFFB30FD0, .NEON, .A32, {} }, { .VCLE_Z, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B905C0, 0xFFB30FD0, .NEON, .A32, {} }, { .VCLE_Z, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B101C0, 0xFFB30FD0, .NEON, .A32, {} }, - { .VCLE_Z, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B10180, 0xFFB30FD0, .NEON, .A32, {} }, - { .VCLT_Z, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B10240, 0xFFB30FD0, .NEON, .A32, {} }, + { .VCLE_Z, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B90580, 0xFFB30FD0, .NEON, .A32, {} }, { .VCLT_Z, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B10200, 0xFFB30FD0, .NEON, .A32, {} }, { .VCLT_Z, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B90640, 0xFFB30FD0, .NEON, .A32, {} }, { .VCLT_Z, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B90600, 0xFFB30FD0, .NEON, .A32, {} }, - { .VTBL, {.DPR,.DPR_LIST,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3B00A00, 0xFFB00F70, .NEON, .A32, {} }, - { .VTBL, {.DPR,.DPR_LIST,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3B00B00, 0xFFB00F70, .NEON, .A32, {} }, - { .VTBL, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3B00800, 0xFFB00F70, .NEON, .A32, {} }, + { .VCLT_Z, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xF3B10240, 0xFFB30FD0, .NEON, .A32, {} }, { .VTBL, {.DPR,.DPR_LIST,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3B00900, 0xFFB00F70, .NEON, .A32, {} }, - { .VTBX, {.DPR,.DPR_LIST,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3B00B40, 0xFFB00F70, .NEON, .A32, {} }, - { .VTBX, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3B00840, 0xFFB00F70, .NEON, .A32, {} }, + { .VTBL, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3B00800, 0xFFB00F70, .NEON, .A32, {} }, + { .VTBL, {.DPR,.DPR_LIST,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3B00B00, 0xFFB00F70, .NEON, .A32, {} }, + { .VTBL, {.DPR,.DPR_LIST,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3B00A00, 0xFFB00F70, .NEON, .A32, {} }, { .VTBX, {.DPR,.DPR_LIST,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3B00940, 0xFFB00F70, .NEON, .A32, {} }, { .VTBX, {.DPR,.DPR_LIST,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3B00A40, 0xFFB00F70, .NEON, .A32, {} }, - { .VDUP, {.QPR,.DPR_ELEM,.NONE,.NONE}, {.VD_Q,.VM_D,.NONE,.NONE}, 0xF3B00C40, 0xFFB00FD0, .NEON, .A32, {} }, + { .VTBX, {.DPR,.DPR_LIST,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3B00B40, 0xFFB00F70, .NEON, .A32, {} }, + { .VTBX, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xF3B00840, 0xFFB00F70, .NEON, .A32, {} }, { .VDUP, {.DPR,.DPR_ELEM,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xF3B00C00, 0xFFB00FD0, .NEON, .A32, {} }, + { .VDUP, {.QPR,.DPR_ELEM,.NONE,.NONE}, {.VD_Q,.VM_D,.NONE,.NONE}, 0xF3B00C40, 0xFFB00FD0, .NEON, .A32, {} }, { .MOV, {.GPR,.IMM_MOD,.NONE,.NONE}, {.RD,.A32_IMM_MOD,.NONE,.NONE}, 0x03B00000, 0x0FFF0000, .BASE, .A32, {sets_flags=true} }, { .BIC, {.GPR,.GPR,.IMM_MOD,.NONE}, {.RD,.RN_A32,.A32_IMM_MOD,.NONE}, 0x03C00000, 0x0FE00000, .BASE, .A32, {} }, { .BIC, {.GPR,.GPR,.IMM_MOD,.NONE}, {.RD,.RN_A32,.A32_IMM_MOD,.NONE}, 0x03D00000, 0x0FF00000, .BASE, .A32, {sets_flags=true} }, { .MVN, {.GPR,.IMM_MOD,.NONE,.NONE}, {.RD,.A32_IMM_MOD,.NONE,.NONE}, 0x03E00000, 0x0FEF0000, .BASE, .A32, {} }, { .MVN, {.GPR,.IMM_MOD,.NONE,.NONE}, {.RD,.A32_IMM_MOD,.NONE,.NONE}, 0x03F00000, 0x0FFF0000, .BASE, .A32, {sets_flags=true} }, - { .VST1, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4000200, 0xFFF00F00, .NEON, .A32, {} }, - { .VST1, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4000A00, 0xFFF00F00, .NEON, .A32, {} }, - { .VST1, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4000700, 0xFFF00F00, .NEON, .A32, {} }, { .VST1, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4000600, 0xFFF00F00, .NEON, .A32, {} }, - { .VST2, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4000900, 0xFFF00F00, .NEON, .A32, {} }, + { .VST1, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4000A00, 0xFFF00F00, .NEON, .A32, {} }, + { .VST1, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4000200, 0xFFF00F00, .NEON, .A32, {} }, + { .VST1, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4000700, 0xFFF00F00, .NEON, .A32, {} }, { .VST2, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4000300, 0xFFF00F00, .NEON, .A32, {} }, + { .VST2, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4000900, 0xFFF00F00, .NEON, .A32, {} }, { .VST2, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4000800, 0xFFF00F00, .NEON, .A32, {} }, { .VST3, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4000400, 0xFFF00F00, .NEON, .A32, {} }, { .VST3, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4000500, 0xFFF00F00, .NEON, .A32, {} }, - { .VST4, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4000100, 0xFFF00F00, .NEON, .A32, {} }, { .VST4, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4000000, 0xFFF00F00, .NEON, .A32, {} }, - { .VLD1, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4200200, 0xFFF00F00, .NEON, .A32, {} }, + { .VST4, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4000100, 0xFFF00F00, .NEON, .A32, {} }, { .VLD1, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4200600, 0xFFF00F00, .NEON, .A32, {} }, + { .VLD1, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4200200, 0xFFF00F00, .NEON, .A32, {} }, { .VLD1, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4200700, 0xFFF00F00, .NEON, .A32, {} }, { .VLD1, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4200A00, 0xFFF00F00, .NEON, .A32, {} }, { .VLD2, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4200800, 0xFFF00F00, .NEON, .A32, {} }, - { .VLD2, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4200900, 0xFFF00F00, .NEON, .A32, {} }, { .VLD2, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4200300, 0xFFF00F00, .NEON, .A32, {} }, + { .VLD2, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4200900, 0xFFF00F00, .NEON, .A32, {} }, { .VLD3, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4200500, 0xFFF00F00, .NEON, .A32, {} }, { .VLD3, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4200400, 0xFFF00F00, .NEON, .A32, {} }, { .VLD4, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4200100, 0xFFF00F00, .NEON, .A32, {} }, { .VLD4, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4200000, 0xFFF00F00, .NEON, .A32, {} }, { .VST1, {.DPR_ELEM,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800800, 0xFFB00F00, .NEON, .A32, {} }, - { .VST1, {.DPR_ELEM,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800000, 0xFFB00F00, .NEON, .A32, {} }, { .VST1, {.DPR_ELEM,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800400, 0xFFB00F00, .NEON, .A32, {} }, + { .VST1, {.DPR_ELEM,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800000, 0xFFB00F00, .NEON, .A32, {} }, { .VST2_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800100, 0xFFB00D00, .NEON, .A32, {} }, { .VST2_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800500, 0xFFB00D00, .NEON, .A32, {} }, { .VST2_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800900, 0xFFB00D00, .NEON, .A32, {} }, - { .VST3_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800600, 0xFFB00D00, .NEON, .A32, {} }, { .VST3_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800200, 0xFFB00D00, .NEON, .A32, {} }, + { .VST3_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800600, 0xFFB00D00, .NEON, .A32, {} }, { .VST3_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800A00, 0xFFB00D00, .NEON, .A32, {} }, + { .VST4_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800300, 0xFFB00D00, .NEON, .A32, {} }, { .VST4_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800700, 0xFFB00D00, .NEON, .A32, {} }, { .VST4_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800B00, 0xFFB00D00, .NEON, .A32, {} }, - { .VST4_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800300, 0xFFB00D00, .NEON, .A32, {} }, - { .VST1_LANE, {.DPR_ELEM,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800800, 0xFFB00C00, .NEON, .A32, {} }, - { .VST1_LANE, {.DPR_ELEM,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800400, 0xFFB00C00, .NEON, .A32, {} }, { .VST1_LANE, {.DPR_ELEM,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800000, 0xFFB00C00, .NEON, .A32, {} }, + { .VST1_LANE, {.DPR_ELEM,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800400, 0xFFB00C00, .NEON, .A32, {} }, + { .VST1_LANE, {.DPR_ELEM,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4800800, 0xFFB00C00, .NEON, .A32, {} }, { .STR, {.GPR,.MEM,.NONE,.NONE}, {.RT_A32,.MEM_POST_INDEX,.NONE,.NONE}, 0x04800000, 0x0F700000, .BASE, .A32, {} }, { .LDR, {.GPR,.MEM,.NONE,.NONE}, {.RT_A32,.MEM_POST_INDEX,.NONE,.NONE}, 0x04900000, 0x0F700000, .BASE, .A32, {} }, { .VLD2R, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00D0F, 0xFFB00F0F, .NEON, .A32, {} }, { .VLD3R, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00E0F, 0xFFB00F0F, .NEON, .A32, {} }, { .VLD4R, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00F0F, 0xFFB00F0F, .NEON, .A32, {} }, - { .VLD1, {.DPR_ELEM,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00800, 0xFFB00F00, .NEON, .A32, {} }, - { .VLD1, {.DPR_ELEM,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00000, 0xFFB00F00, .NEON, .A32, {} }, { .VLD1, {.DPR_ELEM,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00400, 0xFFB00F00, .NEON, .A32, {} }, { .VLD1, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VFP_D_LIST,.RN_A32,.NONE,.NONE}, 0xF4A00C00, 0xFFB00F00, .NEON, .A32, {} }, - { .VLD2_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00100, 0xFFB00D00, .NEON, .A32, {} }, + { .VLD1, {.DPR_ELEM,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00000, 0xFFB00F00, .NEON, .A32, {} }, + { .VLD1, {.DPR_ELEM,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00800, 0xFFB00F00, .NEON, .A32, {} }, { .VLD2_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00900, 0xFFB00D00, .NEON, .A32, {} }, { .VLD2_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00500, 0xFFB00D00, .NEON, .A32, {} }, - { .VLD3_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00A00, 0xFFB00D00, .NEON, .A32, {} }, + { .VLD2_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00100, 0xFFB00D00, .NEON, .A32, {} }, { .VLD3_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00600, 0xFFB00D00, .NEON, .A32, {} }, + { .VLD3_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00A00, 0xFFB00D00, .NEON, .A32, {} }, { .VLD3_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00200, 0xFFB00D00, .NEON, .A32, {} }, - { .VLD4_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00700, 0xFFB00D00, .NEON, .A32, {} }, { .VLD4_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00300, 0xFFB00D00, .NEON, .A32, {} }, + { .VLD4_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00700, 0xFFB00D00, .NEON, .A32, {} }, { .VLD4_LANE, {.DPR_LIST,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00B00, 0xFFB00D00, .NEON, .A32, {} }, { .VLD1_LANE, {.DPR_ELEM,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00000, 0xFFB00C00, .NEON, .A32, {} }, { .VLD1_LANE, {.DPR_ELEM,.MEM,.NONE,.NONE}, {.VD_D,.RN_A32,.NONE,.NONE}, 0xF4A00800, 0xFFB00C00, .NEON, .A32, {} }, @@ -1053,8 +1053,8 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VCADD, {.DPR,.DPR,.DPR,.IMM}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xFC800800, 0xFE800F10, .FCMA, .A32, {} }, { .VSTM, {.GPR,.SPR_LIST,.NONE,.NONE}, {.RN_A32,.VFP_S_LIST,.NONE,.NONE}, 0x0C800A00, 0x0F900F00, .VFPV2, .A32, {} }, { .VSTM, {.GPR,.DPR_LIST,.NONE,.NONE}, {.RN_A32,.VFP_D_LIST,.NONE,.NONE}, 0x0C800B00, 0x0F900F00, .VFPV2, .A32, {} }, - { .VLDM, {.GPR,.DPR_LIST,.NONE,.NONE}, {.RN_A32,.VFP_D_LIST,.NONE,.NONE}, 0x0C900B00, 0x0F900F00, .VFPV2, .A32, {} }, { .VLDM, {.GPR,.SPR_LIST,.NONE,.NONE}, {.RN_A32,.VFP_S_LIST,.NONE,.NONE}, 0x0C900A00, 0x0F900F00, .VFPV2, .A32, {} }, + { .VLDM, {.GPR,.DPR_LIST,.NONE,.NONE}, {.RN_A32,.VFP_D_LIST,.NONE,.NONE}, 0x0C900B00, 0x0F900F00, .VFPV2, .A32, {} }, { .VFMSL, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xFCA00850, 0xFFB00F50, .FHM, .A32, {} }, { .VUSMMLA, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xFCA00C40, 0xFFB00F50, .V8, .A32, {} }, { .VSUDOT, {.QPR,.QPR,.QPR,.NONE}, {.VD_Q,.VN_Q,.VM_Q,.NONE}, 0xFCA00D50, 0xFFB00F50, .V8, .A32, {} }, @@ -1065,22 +1065,22 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VPOP, {.SPR_LIST,.NONE,.NONE,.NONE}, {.VFP_S_LIST,.NONE,.NONE,.NONE}, 0x0CBD0A00, 0x0FFF0F00, .VFPV2, .A32, {} }, { .VSTR, {.DPR,.MEM,.NONE,.NONE}, {.VD_D,.MEM_IMM8_OFFSET,.NONE,.NONE}, 0x0D000B00, 0x0F300F00, .VFPV2, .A32, {} }, { .VSTR, {.SPR,.MEM,.NONE,.NONE}, {.VD_S,.MEM_IMM8_OFFSET,.NONE,.NONE}, 0x0D000A00, 0x0F300F00, .VFPV2, .A32, {} }, - { .VLDR, {.DPR,.MEM,.NONE,.NONE}, {.VD_D,.MEM_IMM8_OFFSET,.NONE,.NONE}, 0x0D100B00, 0x0F300F00, .VFPV2, .A32, {} }, { .VLDR, {.SPR,.MEM,.NONE,.NONE}, {.VD_S,.MEM_IMM8_OFFSET,.NONE,.NONE}, 0x0D100A00, 0x0F300F00, .VFPV2, .A32, {} }, - { .VPUSH, {.SPR_LIST,.NONE,.NONE,.NONE}, {.VFP_S_LIST,.NONE,.NONE,.NONE}, 0x0D2D0A00, 0x0FFF0F00, .VFPV2, .A32, {} }, + { .VLDR, {.DPR,.MEM,.NONE,.NONE}, {.VD_D,.MEM_IMM8_OFFSET,.NONE,.NONE}, 0x0D100B00, 0x0F300F00, .VFPV2, .A32, {} }, { .VPUSH, {.DPR_LIST,.NONE,.NONE,.NONE}, {.VFP_D_LIST,.NONE,.NONE,.NONE}, 0x0D2D0B00, 0x0FFF0F00, .VFPV2, .A32, {} }, + { .VPUSH, {.SPR_LIST,.NONE,.NONE,.NONE}, {.VFP_S_LIST,.NONE,.NONE,.NONE}, 0x0D2D0A00, 0x0FFF0F00, .VFPV2, .A32, {} }, { .VMOV, {.SPR,.GPR,.NONE,.NONE}, {.VN_S,.RT_A32,.NONE,.NONE}, 0x0E000A10, 0x0FF00F7F, .VFPV2, .A32, {} }, { .VCMLA_LANE, {.QPR,.QPR,.DPR_ELEM,.IMM}, {.VD_Q,.VN_Q,.VM_D,.NONE}, 0xFE000840, 0xFFB00F50, .FCMA, .A32, {} }, { .VCMLA_LANE, {.DPR,.DPR,.DPR_ELEM,.IMM}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xFE000800, 0xFFB00F10, .FCMA, .A32, {} }, - { .VSEL, {.SPR,.SPR,.SPR,.COND}, {.VD_S,.VN_S,.VM_S,.NONE}, 0xFE000A00, 0xFF800F50, .V8, .A32, {} }, { .VSEL, {.DPR,.DPR,.DPR,.COND}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xFE000B00, 0xFF800F50, .V8, .A32, {} }, + { .VSEL, {.SPR,.SPR,.SPR,.COND}, {.VD_S,.VN_S,.VM_S,.NONE}, 0xFE000A00, 0xFF800F50, .V8, .A32, {} }, { .VMOV, {.DPR_ELEM,.GPR,.NONE,.NONE}, {.VN_D,.RT_A32,.NONE,.NONE}, 0x0E000B10, 0x0F100F1F, .NEON, .A32, {} }, { .VMLA, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E000900, 0x0FB00F50, .HALF_FP, .A32, {} }, { .VMLS, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E000940, 0x0FB00F50, .HALF_FP, .A32, {} }, { .VMLA, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0x0E000B00, 0x0FB00B50, .VFPV2, .A32, {} }, { .VMLA, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E000A00, 0x0FB00B50, .VFPV2, .A32, {} }, - { .VMLS, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0x0E000B40, 0x0FB00B50, .VFPV2, .A32, {} }, { .VMLS, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E000A40, 0x0FB00B50, .VFPV2, .A32, {} }, + { .VMLS, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0x0E000B40, 0x0FB00B50, .VFPV2, .A32, {} }, { .MCR2, {.COPROC_NUM,.IMM_COPROC_OP,.GPR,.COPROC_REG}, {.COPROC_NUM_FIELD,.COPROC_OPC1_FIELD,.RT_A32,.COPROC_CRM_FIELD}, 0xFE000010, 0xFF100010, .V5T, .A32, {} }, { .CDP2, {.COPROC_NUM,.IMM_COPROC_OP,.COPROC_REG,.COPROC_REG}, {.COPROC_NUM_FIELD,.COPROC_OPC1_FIELD,.COPROC_CRN_FIELD,.COPROC_CRM_FIELD}, 0xFE000000, 0xFF000010, .V5T, .A32, {} }, { .MCR, {.COPROC_NUM,.IMM_COPROC_OP,.GPR,.COPROC_REG}, {.COPROC_NUM_FIELD,.COPROC_OPC1_FIELD,.RT_A32,.COPROC_CRM_FIELD}, 0x0E000010, 0x0F100010, .BASE, .A32, {} }, @@ -1100,14 +1100,14 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VMUL, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E200900, 0x0FB00F50, .HALF_FP, .A32, {} }, { .VMUL, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E200A00, 0x0FB00B50, .VFPV2, .A32, {} }, { .VMUL, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0x0E200B00, 0x0FB00B50, .VFPV2, .A32, {} }, - { .VNMUL, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E200A40, 0x0FB00B50, .VFPV2, .A32, {} }, { .VNMUL, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0x0E200B40, 0x0FB00B50, .VFPV2, .A32, {} }, + { .VNMUL, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E200A40, 0x0FB00B50, .VFPV2, .A32, {} }, { .VADD, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E300900, 0x0FB00F50, .HALF_FP, .A32, {} }, { .VSUB, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E300940, 0x0FB00F50, .HALF_FP, .A32, {} }, { .VADD, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E300A00, 0x0FB00B50, .VFPV2, .A32, {} }, { .VADD, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0x0E300B00, 0x0FB00B50, .VFPV2, .A32, {} }, - { .VSUB, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E300A40, 0x0FB00B50, .VFPV2, .A32, {} }, { .VSUB, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0x0E300B40, 0x0FB00B50, .VFPV2, .A32, {} }, + { .VSUB, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E300A40, 0x0FB00B50, .VFPV2, .A32, {} }, { .VSUDOT_LANE, {.QPR,.QPR,.DPR_ELEM,.NONE}, {.VD_Q,.VN_Q,.VM_D,.NONE}, 0xFE800D50, 0xFFB00F50, .V8, .A32, {} }, { .VUSDOT_LANE, {.QPR,.QPR,.DPR_ELEM,.NONE}, {.VD_Q,.VN_Q,.VM_D,.NONE}, 0xFE800D40, 0xFFB00F50, .V8, .A32, {} }, { .VMAXNM, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0xFE800A00, 0xFFB00B50, .V8, .A32, {} }, @@ -1116,8 +1116,8 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VMINNM, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0xFE800A40, 0xFFB00B50, .V8, .A32, {} }, { .VUSDOT_LANE, {.DPR,.DPR,.DPR_ELEM,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0xFE800D00, 0xFFB00F10, .V8, .A32, {} }, { .VDIV, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E800900, 0x0FB00F50, .HALF_FP, .A32, {} }, - { .VDIV, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E800A00, 0x0FB00B50, .VFPV2, .A32, {} }, { .VDIV, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0x0E800B00, 0x0FB00B50, .VFPV2, .A32, {} }, + { .VDIV, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E800A00, 0x0FB00B50, .VFPV2, .A32, {} }, { .VFNMA, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E900940, 0x0FB00F50, .HALF_FP, .A32, {} }, { .VFNMS, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E900900, 0x0FB00F50, .HALF_FP, .A32, {} }, { .VFNMA, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0x0E900B40, 0x0FB00B50, .VFPV4, .A32, {} }, @@ -1126,31 +1126,31 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VFNMS, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0E900A00, 0x0FB00B50, .VFPV4, .A32, {} }, { .VFMA, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0EA00900, 0x0FB00F50, .HALF_FP, .A32, {} }, { .VFMS, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0EA00940, 0x0FB00F50, .HALF_FP, .A32, {} }, - { .VFMA, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0EA00A00, 0x0FB00B50, .VFPV4, .A32, {} }, { .VFMA, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0x0EA00B00, 0x0FB00B50, .VFPV4, .A32, {} }, + { .VFMA, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0EA00A00, 0x0FB00B50, .VFPV4, .A32, {} }, { .VFMS, {.DPR,.DPR,.DPR,.NONE}, {.VD_D,.VN_D,.VM_D,.NONE}, 0x0EA00B40, 0x0FB00B50, .VFPV4, .A32, {} }, { .VFMS, {.SPR,.SPR,.SPR,.NONE}, {.VD_S,.VN_S,.VM_S,.NONE}, 0x0EA00A40, 0x0FB00B50, .VFPV4, .A32, {} }, - { .VCMP, {.SPR,.NONE,.NONE,.NONE}, {.VD_S,.NONE,.NONE,.NONE}, 0x0EB50940, 0x0FBF0FFF, .HALF_FP, .A32, {} }, - { .VCMP, {.DPR,.NONE,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0x0EB50B40, 0x0FBF0FFF, .VFPV2, .A32, {} }, { .VCMP, {.SPR,.NONE,.NONE,.NONE}, {.VD_S,.NONE,.NONE,.NONE}, 0x0EB50A40, 0x0FBF0FFF, .VFPV2, .A32, {} }, + { .VCMP, {.DPR,.NONE,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0x0EB50B40, 0x0FBF0FFF, .VFPV2, .A32, {} }, + { .VCMP, {.SPR,.NONE,.NONE,.NONE}, {.VD_S,.NONE,.NONE,.NONE}, 0x0EB50940, 0x0FBF0FFF, .HALF_FP, .A32, {} }, { .VCMPE, {.SPR,.NONE,.NONE,.NONE}, {.VD_S,.NONE,.NONE,.NONE}, 0x0EB50AC0, 0x0FBF0FFF, .VFPV2, .A32, {} }, { .VCMPE, {.DPR,.NONE,.NONE,.NONE}, {.VD_D,.NONE,.NONE,.NONE}, 0x0EB50BC0, 0x0FBF0FFF, .VFPV2, .A32, {} }, { .VCVTA, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xFEBC0B40, 0xFFBF0FD0, .V8, .A32, {} }, { .VCVTA, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0xFEBC0A40, 0xFFBF0FD0, .V8, .A32, {} }, - { .VCVTN, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0xFEBD0A40, 0xFFBF0FD0, .V8, .A32, {} }, { .VCVTN, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xFEBD0B40, 0xFFBF0FD0, .V8, .A32, {} }, + { .VCVTN, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0xFEBD0A40, 0xFFBF0FD0, .V8, .A32, {} }, { .VCVTP, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0xFEBE0A40, 0xFFBF0FD0, .V8, .A32, {} }, { .VCVTP, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xFEBE0B40, 0xFFBF0FD0, .V8, .A32, {} }, - { .VCVTM, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xFEBF0B40, 0xFFBF0FD0, .V8, .A32, {} }, { .VCVTM, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0xFEBF0A40, 0xFFBF0FD0, .V8, .A32, {} }, + { .VCVTM, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xFEBF0B40, 0xFFBF0FD0, .V8, .A32, {} }, { .VRINTA, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0xFEB80A40, 0xFFBF0FD0, .V8, .A32, {} }, { .VRINTA, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xFEB80B40, 0xFFBF0FD0, .V8, .A32, {} }, { .VRINTN, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0xFEB90A40, 0xFFBF0FD0, .V8, .A32, {} }, { .VRINTN, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xFEB90B40, 0xFFBF0FD0, .V8, .A32, {} }, { .VRINTP, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0xFEBA0A40, 0xFFBF0FD0, .V8, .A32, {} }, { .VRINTP, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xFEBA0B40, 0xFFBF0FD0, .V8, .A32, {} }, - { .VRINTM, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0xFEBB0A40, 0xFFBF0FD0, .V8, .A32, {} }, { .VRINTM, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0xFEBB0B40, 0xFFBF0FD0, .V8, .A32, {} }, + { .VRINTM, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0xFEBB0A40, 0xFFBF0FD0, .V8, .A32, {} }, { .VABS, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0x0EB00BC0, 0x0FBF0FD0, .VFPV2, .A32, {} }, { .VABS, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB00AC0, 0x0FBF0FD0, .VFPV2, .A32, {} }, { .VNEG, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0x0EB10B40, 0x0FBF0FD0, .VFPV2, .A32, {} }, @@ -1159,47 +1159,47 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VSQRT, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0x0EB10BC0, 0x0FBF0FD0, .VFPV2, .A32, {} }, { .VSQRT, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB10AC0, 0x0FBF0FD0, .VFPV2, .A32, {} }, { .VCVT, {.DPR,.SPR,.NONE,.NONE}, {.VD_D,.VM_S,.NONE,.NONE}, 0x0EB80B40, 0x0FBF0FD0, .VFPV2, .A32, {} }, - { .VCVT, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB80AC0, 0x0FBF0FD0, .VFPV2, .A32, {} }, - { .VCVT, {.SPR,.DPR,.NONE,.NONE}, {.VD_S,.VM_D,.NONE,.NONE}, 0x0EBC0BC0, 0x0FBF0FD0, .VFPV2, .A32, {} }, { .VCVT, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB80A40, 0x0FBF0FD0, .VFPV2, .A32, {} }, + { .VCVT, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB80AC0, 0x0FBF0FD0, .VFPV2, .A32, {} }, + { .VCVT, {.DPR,.SPR,.NONE,.NONE}, {.VD_D,.VM_S,.NONE,.NONE}, 0x0EB80BC0, 0x0FBF0FD0, .VFPV2, .A32, {} }, { .VCVT, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBC0AC0, 0x0FBF0FD0, .VFPV2, .A32, {} }, - { .VCVT, {.SPR,.DPR,.NONE,.NONE}, {.VD_S,.VM_D,.NONE,.NONE}, 0x0EB70BC0, 0x0FBF0FD0, .VFPV2, .A32, {} }, - { .VCVT, {.DPR,.SPR,.NONE,.NONE}, {.VD_D,.VM_S,.NONE,.NONE}, 0x0EB70AC0, 0x0FBF0FD0, .VFPV2, .A32, {} }, { .VCVT, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBD0AC0, 0x0FBF0FD0, .VFPV2, .A32, {} }, { .VCVT, {.SPR,.DPR,.NONE,.NONE}, {.VD_S,.VM_D,.NONE,.NONE}, 0x0EBD0BC0, 0x0FBF0FD0, .VFPV2, .A32, {} }, - { .VCVT, {.DPR,.SPR,.NONE,.NONE}, {.VD_D,.VM_S,.NONE,.NONE}, 0x0EB80BC0, 0x0FBF0FD0, .VFPV2, .A32, {} }, + { .VCVT, {.DPR,.SPR,.NONE,.NONE}, {.VD_D,.VM_S,.NONE,.NONE}, 0x0EB70AC0, 0x0FBF0FD0, .VFPV2, .A32, {} }, + { .VCVT, {.SPR,.DPR,.NONE,.NONE}, {.VD_S,.VM_D,.NONE,.NONE}, 0x0EB70BC0, 0x0FBF0FD0, .VFPV2, .A32, {} }, + { .VCVT, {.SPR,.DPR,.NONE,.NONE}, {.VD_S,.VM_D,.NONE,.NONE}, 0x0EBC0BC0, 0x0FBF0FD0, .VFPV2, .A32, {} }, { .VCVTB, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB20A40, 0x0FBF0FD0, .VFPV3, .A32, {} }, { .VCVTB, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB30A40, 0x0FBF0FD0, .VFPV3, .A32, {} }, - { .VCVTT, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB20AC0, 0x0FBF0FD0, .VFPV3, .A32, {} }, { .VCVTT, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB30AC0, 0x0FBF0FD0, .VFPV3, .A32, {} }, + { .VCVTT, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB20AC0, 0x0FBF0FD0, .VFPV3, .A32, {} }, { .VCVTR, {.SPR,.DPR,.NONE,.NONE}, {.VD_S,.VM_D,.NONE,.NONE}, 0x0EBC0B40, 0x0FBF0FD0, .VFPV2, .A32, {} }, - { .VCVTR, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBD0A40, 0x0FBF0FD0, .VFPV2, .A32, {} }, { .VCVTR, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBC0A40, 0x0FBF0FD0, .VFPV2, .A32, {} }, + { .VCVTR, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBD0A40, 0x0FBF0FD0, .VFPV2, .A32, {} }, { .VCVTR, {.SPR,.DPR,.NONE,.NONE}, {.VD_S,.VM_D,.NONE,.NONE}, 0x0EBD0B40, 0x0FBF0FD0, .VFPV2, .A32, {} }, - { .VMOV, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB00A40, 0x0FBF0FD0, .VFPV2, .A32, {} }, { .VMOV, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0x0EB00B40, 0x0FBF0FD0, .VFPV2, .A32, {} }, - { .VRINTR, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0x0EB60B40, 0x0FBF0FD0, .V8, .A32, {} }, + { .VMOV, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB00A40, 0x0FBF0FD0, .VFPV2, .A32, {} }, { .VRINTR, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB60A40, 0x0FBF0FD0, .V8, .A32, {} }, - { .VRINTZ, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB60AC0, 0x0FBF0FD0, .V8, .A32, {} }, + { .VRINTR, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0x0EB60B40, 0x0FBF0FD0, .V8, .A32, {} }, { .VRINTZ, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0x0EB60BC0, 0x0FBF0FD0, .V8, .A32, {} }, + { .VRINTZ, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB60AC0, 0x0FBF0FD0, .V8, .A32, {} }, { .VRINTX, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0x0EB70B40, 0x0FBF0FD0, .V8, .A32, {} }, { .VRINTX, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB70A40, 0x0FBF0FD0, .V8, .A32, {} }, { .VJCVT, {.SPR,.DPR,.NONE,.NONE}, {.VD_S,.VM_D,.NONE,.NONE}, 0x0EB90BC0, 0x0FBF0FD0, .V8, .A32, {} }, { .VCVT_FIXED, {.DPR,.DPR,.IMM,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0x0EBA0B40, 0x0FBF0FD0, .VFPV3, .A32, {} }, - { .VCVT_FIXED, {.SPR,.SPR,.IMM,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBF0A40, 0x0FBF0FD0, .VFPV3, .A32, {} }, - { .VCVT_FIXED, {.SPR,.SPR,.IMM,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBE0A40, 0x0FBF0FD0, .VFPV3, .A32, {} }, - { .VCVT_FIXED, {.SPR,.SPR,.IMM,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBB0A40, 0x0FBF0FD0, .VFPV3, .A32, {} }, - { .VCVT_FIXED, {.DPR,.DPR,.IMM,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0x0EBE0B40, 0x0FBF0FD0, .VFPV3, .A32, {} }, - { .VCVT_FIXED, {.SPR,.SPR,.IMM,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBA0940, 0x0FBF0FD0, .HALF_FP, .A32, {} }, { .VCVT_FIXED, {.SPR,.SPR,.IMM,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBE0940, 0x0FBF0FD0, .HALF_FP, .A32, {} }, { .VCVT_FIXED, {.SPR,.SPR,.IMM,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBA0A40, 0x0FBF0FD0, .VFPV3, .A32, {} }, - { .VCMP, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB40940, 0x0FBF0F50, .HALF_FP, .A32, {} }, + { .VCVT_FIXED, {.SPR,.SPR,.IMM,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBB0A40, 0x0FBF0FD0, .VFPV3, .A32, {} }, + { .VCVT_FIXED, {.SPR,.SPR,.IMM,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBE0A40, 0x0FBF0FD0, .VFPV3, .A32, {} }, + { .VCVT_FIXED, {.SPR,.SPR,.IMM,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBF0A40, 0x0FBF0FD0, .VFPV3, .A32, {} }, + { .VCVT_FIXED, {.DPR,.DPR,.IMM,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0x0EBE0B40, 0x0FBF0FD0, .VFPV3, .A32, {} }, + { .VCVT_FIXED, {.SPR,.SPR,.IMM,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBA0940, 0x0FBF0FD0, .HALF_FP, .A32, {} }, { .VCMP, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB40A40, 0x0FBF0F50, .VFPV2, .A32, {} }, { .VCMP, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0x0EB40B40, 0x0FBF0F50, .VFPV2, .A32, {} }, + { .VCMP, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB40940, 0x0FBF0F50, .HALF_FP, .A32, {} }, { .VCMPE, {.SPR,.SPR,.NONE,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EB40AC0, 0x0FBF0F50, .VFPV2, .A32, {} }, { .VCMPE, {.DPR,.DPR,.NONE,.NONE}, {.VD_D,.VM_D,.NONE,.NONE}, 0x0EB40BC0, 0x0FBF0F50, .VFPV2, .A32, {} }, - { .VCVT_FIXED, {.SPR,.SPR,.IMM,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBA0A40, 0x0FBF0FC0, .VFPV3, .A32, {} }, { .VCVT_FIXED, {.SPR,.SPR,.IMM,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBE0A40, 0x0FBF0FC0, .VFPV3, .A32, {} }, + { .VCVT_FIXED, {.SPR,.SPR,.IMM,.NONE}, {.VD_S,.VM_S,.NONE,.NONE}, 0x0EBA0A40, 0x0FBF0FC0, .VFPV3, .A32, {} }, { .VMOV, {.SPR,.IMM8,.NONE,.NONE}, {.VD_S,.VFP_IMM8,.NONE,.NONE}, 0x0EB00A00, 0x0FB00FF0, .VFPV3, .A32, {} }, { .VMOV, {.DPR,.IMM8,.NONE,.NONE}, {.VD_D,.VFP_IMM8,.NONE,.NONE}, 0x0EB00B00, 0x0FB00FF0, .VFPV3, .A32, {} }, { .VDUP, {.DPR,.GPR,.NONE,.NONE}, {.VD_D,.RT_A32,.NONE,.NONE}, 0x0EC00B10, 0x0FF00FD0, .NEON, .A32, {} }, @@ -1262,12 +1262,12 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VMOV_2GPR_Q, {.QPR_ELEM,.QPR_ELEM,.GPR,.GPR}, {.VD_Q,.VD_Q,.RT_T32,.RT2_T32}, 0xEC000F00, 0xFF900F11, .MVE_INT, .T32, {thumb32=true} }, { .VLDRB, {.QPR,.MEM,.NONE,.NONE}, {.VD_Q,.MEM_IMM12_OFFSET,.NONE,.NONE}, 0xED901E00, 0xFFB01F00, .MVE_INT, .T32, {thumb32=true} }, { .VSTRB, {.QPR,.MEM,.NONE,.NONE}, {.VD_Q,.MEM_IMM12_OFFSET,.NONE,.NONE}, 0xED801E00, 0xFFB01F00, .MVE_INT, .T32, {thumb32=true} }, - { .VCX1, {.IMM_COPROC,.SPR,.IMM,.NONE}, {.CDE_COPROC_FIELD,.VD_S,.CDE_IMM_FIELD,.NONE}, 0xEC200000, 0xFF300000, .CDE, .T32, {thumb32=true} }, { .VCX1, {.IMM_COPROC,.DPR,.IMM,.NONE}, {.CDE_COPROC_FIELD,.VD_D,.CDE_IMM_FIELD,.NONE}, 0xEC300000, 0xFF300000, .CDE, .T32, {thumb32=true} }, - { .VCX2, {.IMM_COPROC,.DPR,.DPR,.IMM}, {.CDE_COPROC_FIELD,.VD_D,.VM_D,.CDE_IMM_FIELD}, 0xEC700000, 0xFF300000, .CDE, .T32, {thumb32=true} }, + { .VCX1, {.IMM_COPROC,.SPR,.IMM,.NONE}, {.CDE_COPROC_FIELD,.VD_S,.CDE_IMM_FIELD,.NONE}, 0xEC200000, 0xFF300000, .CDE, .T32, {thumb32=true} }, { .VCX2, {.IMM_COPROC,.SPR,.SPR,.IMM}, {.CDE_COPROC_FIELD,.VD_S,.VM_S,.CDE_IMM_FIELD}, 0xEC600000, 0xFF300000, .CDE, .T32, {thumb32=true} }, - { .VCX3, {.IMM_COPROC,.SPR,.SPR,.SPR}, {.CDE_COPROC_FIELD,.VD_S,.VN_S,.VM_S}, 0xEC800000, 0xFF300000, .CDE, .T32, {thumb32=true} }, + { .VCX2, {.IMM_COPROC,.DPR,.DPR,.IMM}, {.CDE_COPROC_FIELD,.VD_D,.VM_D,.CDE_IMM_FIELD}, 0xEC700000, 0xFF300000, .CDE, .T32, {thumb32=true} }, { .VCX3, {.IMM_COPROC,.DPR,.DPR,.DPR}, {.CDE_COPROC_FIELD,.VD_D,.VN_D,.VM_D}, 0xEC900000, 0xFF300000, .CDE, .T32, {thumb32=true} }, + { .VCX3, {.IMM_COPROC,.SPR,.SPR,.SPR}, {.CDE_COPROC_FIELD,.VD_S,.VN_S,.VM_S}, 0xEC800000, 0xFF300000, .CDE, .T32, {thumb32=true} }, { .VADDLV, {.GPR,.GPR,.QPR,.NONE}, {.RD_T32,.RN_T32,.VM_Q,.NONE}, 0xEE890F00, 0xEFFF0FD1, .MVE_INT, .T32, {thumb32=true} }, { .VADDLVA, {.GPR,.GPR,.QPR,.NONE}, {.RD_T32,.RN_T32,.VM_Q,.NONE}, 0xEE890F20, 0xEFFF0FD1, .MVE_INT, .T32, {thumb32=true} }, { .VMAXNMV, {.GPR,.QPR,.NONE,.NONE}, {.RD_T32,.VM_Q,.NONE,.NONE}, 0xEEEE0F00, 0xEFFF0FD1, .MVE_FP, .T32, {thumb32=true} }, @@ -1425,6 +1425,9 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .USAT, {.GPR,.IMM4_SAT,.GPR_SHIFTED,.NONE}, {.RD_T32,.SAT_IMM5_T32,.RN_T32,.NONE}, 0xF3800000, 0xFFD08020, .V6T2, .T32, {thumb32=true} }, { .MOVW, {.GPR,.IMM16_LO_HI,.NONE,.NONE}, {.RD_T32,.NONE,.NONE,.NONE}, 0xF2400000, 0xFBF08000, .V6T2, .T32, {thumb32=true} }, { .MOVT, {.GPR,.IMM16_LO_HI,.NONE,.NONE}, {.RD_T32,.NONE,.NONE,.NONE}, 0xF2C00000, 0xFBF08000, .V6T2, .T32, {thumb32=true} }, + { .DCPS1, {.NONE,.NONE,.NONE,.NONE}, {.NONE,.NONE,.NONE,.NONE}, 0xF78F8001, 0xFFFFFFFF, .V8, .T32, {thumb32=true} }, + { .DCPS2, {.NONE,.NONE,.NONE,.NONE}, {.NONE,.NONE,.NONE,.NONE}, 0xF78F8002, 0xFFFFFFFF, .V8, .T32, {thumb32=true} }, + { .DCPS3, {.NONE,.NONE,.NONE,.NONE}, {.NONE,.NONE,.NONE,.NONE}, 0xF78F8003, 0xFFFFFFFF, .V8, .T32, {thumb32=true} }, { .UDF, {.IMM,.NONE,.NONE,.NONE}, {.NONE,.NONE,.NONE,.NONE}, 0xF7F0A000, 0xFFF0F000, .V6T2, .T32, {thumb32=true} }, { .LDR, {.GPR,.MEM,.NONE,.NONE}, {.RT_T32,.MEM_REG_OFFSET,.NONE,.NONE}, 0xF8500000, 0xFFF00FC0, .V6T2, .T32, {thumb32=true} }, { .STR, {.GPR,.MEM,.NONE,.NONE}, {.RT_T32,.MEM_REG_OFFSET,.NONE,.NONE}, 0xF8400000, 0xFFF00FC0, .V6T2, .T32, {thumb32=true} }, @@ -1537,8 +1540,8 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ { .VCX1A, {.IMM_COPROC,.DPR,.IMM,.NONE}, {.CDE_COPROC_FIELD,.VD_D,.CDE_IMM_FIELD,.NONE}, 0xFC300000, 0xFF300000, .CDE, .T32, {thumb32=true} }, { .VCX2A, {.IMM_COPROC,.SPR,.SPR,.IMM}, {.CDE_COPROC_FIELD,.VD_S,.VM_S,.CDE_IMM_FIELD}, 0xFC600000, 0xFF300000, .CDE, .T32, {thumb32=true} }, { .VCX2A, {.IMM_COPROC,.DPR,.DPR,.IMM}, {.CDE_COPROC_FIELD,.VD_D,.VM_D,.CDE_IMM_FIELD}, 0xFC700000, 0xFF300000, .CDE, .T32, {thumb32=true} }, - { .VCX3A, {.IMM_COPROC,.DPR,.DPR,.DPR}, {.CDE_COPROC_FIELD,.VD_D,.VN_D,.VM_D}, 0xFC900000, 0xFF300000, .CDE, .T32, {thumb32=true} }, { .VCX3A, {.IMM_COPROC,.SPR,.SPR,.SPR}, {.CDE_COPROC_FIELD,.VD_S,.VN_S,.VM_S}, 0xFC800000, 0xFF300000, .CDE, .T32, {thumb32=true} }, + { .VCX3A, {.IMM_COPROC,.DPR,.DPR,.DPR}, {.CDE_COPROC_FIELD,.VD_D,.VN_D,.VM_D}, 0xFC900000, 0xFF300000, .CDE, .T32, {thumb32=true} }, { .VPST, {.MVE_VPT_MASK,.NONE,.NONE,.NONE}, {.MVE_VPT_MASK_FIELD,.NONE,.NONE,.NONE}, 0xFE710F4D, 0xFFFFFFFF, .MVE_INT, .T32, {thumb32=true} }, { .VPNOT, {.NONE,.NONE,.NONE,.NONE}, {.NONE,.NONE,.NONE,.NONE}, 0xFE310F4D, 0xFFFFFFFF, .MVE_INT, .T32, {thumb32=true} }, { .VRINTA, {.QPR,.QPR,.NONE,.NONE}, {.VD_Q,.VM_Q,.NONE,.NONE}, 0xFFBA0540, 0xFFBB0FD1, .MVE_FP, .T32, {thumb32=true} }, @@ -1669,7 +1672,7 @@ DECODE_ENTRIES := [1657]lib.Decode_Entry{ } @(rodata) -DECODE_FORM_IDX := [1657]u16{ +DECODE_FORM_IDX := [1660]u16{ 0, 2, 1, 1, 5, 4, 0, 2, 1, 1, 5, 4, 0, 2, 1, 5, 4, 0, 2, 1, 5, 4, 0, 2, 1, 1, 5, 4, 0, 2, 1, 1, 5, 4, 0, 2, 2, 2, 2, 1, 1, 2, 2, 2, 5, 4, 0, 0, @@ -1681,51 +1684,51 @@ DECODE_FORM_IDX := [1657]u16{ 0, 0, 0, 0, 0, 2, 1, 0, 0, 5, 4, 0, 0, 0, 0, 0, 0, 2, 1, 0, 0, 0, 0, 0, 0, 5, 4, 0, 0, 0, 2, 1, 1, 1, 1, 0, 0, 0, 5, 4, 1, 1, 1, 1, 1, 1, 9, 14, - 8, 10, 6, 4, 3, 3, 1, 4, 4, 3, 3, 1, 3, 7, 3, 3, - 0, 0, 3, 9, 3, 1, 4, 1, 1, 0, 0, 13, 5, 5, 9, 3, + 8, 6, 10, 4, 3, 3, 1, 4, 4, 3, 3, 1, 3, 7, 3, 3, + 0, 0, 3, 9, 3, 1, 4, 1, 1, 0, 0, 5, 13, 5, 3, 9, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 6, 0, 0, 8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 3, 3, 4, 10, 9, 7, 4, 4, 5, 5, 2, 4, 4, 1, 4, 9, 4, 4, 2, 2, 4, 11, 4, - 2, 0, 6, 3, 6, 4, 1, 1, 1, 1, 0, 1, 1, 0, 1, 8, - 1, 1, 1, 10, 1, 1, 1, 1, 1, 3, 5, 5, 5, 11, 14, 10, + 2, 0, 3, 6, 6, 4, 1, 1, 1, 1, 0, 1, 1, 0, 1, 8, + 1, 1, 10, 1, 1, 1, 1, 1, 1, 3, 5, 5, 5, 11, 14, 10, 8, 10, 4, 5, 5, 6, 6, 3, 5, 5, 1, 5, 5, 5, 4, 4, - 5, 9, 5, 1, 4, 0, 7, 13, 7, 5, 9, 3, 2, 2, 2, 2, - 1, 2, 2, 0, 2, 2, 2, 2, 2, 8, 2, 2, 2, 0, 2, 0, + 5, 5, 9, 1, 4, 0, 7, 13, 7, 5, 9, 3, 2, 2, 2, 2, + 1, 2, 2, 0, 2, 2, 2, 2, 8, 2, 2, 2, 2, 0, 2, 0, 7, 12, 4, 7, 7, 1, 11, 5, 6, 0, 8, 3, 3, 3, 0, 10, - 3, 3, 0, 3, 0, 3, 0, 0, 0, 22, 25, 24, 23, 21, 0, 0, - 0, 0, 11, 10, 13, 12, 15, 18, 17, 11, 20, 14, 19, 10, 16, 0, - 6, 0, 0, 5, 8, 2, 9, 3, 4, 7, 6, 0, 0, 0, 0, 0, + 3, 3, 0, 3, 0, 3, 0, 0, 0, 24, 23, 21, 25, 22, 0, 0, + 0, 0, 11, 10, 14, 12, 17, 19, 15, 16, 20, 18, 13, 11, 10, 6, + 0, 0, 0, 8, 9, 7, 4, 2, 6, 3, 5, 0, 0, 0, 0, 0, 1, 1, 1, 1, 5, 0, 0, 0, 0, 4, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, - 1, 1, 4, 1, 4, 1, 4, 1, 1, 1, 1, 1, 1, 0, 0, 1, - 1, 0, 1, 0, 3, 0, 3, 0, 3, 13, 7, 7, 1, 9, 9, 12, - 14, 6, 7, 7, 9, 9, 7, 7, 1, 3, 7, 9, 7, 12, 6, 6, + 1, 1, 4, 4, 1, 4, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, + 1, 0, 1, 0, 3, 0, 3, 0, 3, 7, 13, 7, 1, 9, 9, 12, + 14, 6, 7, 7, 9, 9, 7, 7, 1, 3, 7, 9, 7, 6, 12, 6, 1, 0, 7, 7, 7, 3, 3, 8, 0, 5, 11, 13, 3, 6, 6, 8, - 8, 6, 6, 0, 0, 8, 6, 6, 0, 6, 6, 4, 3, 3, 3, 6, + 8, 6, 6, 0, 0, 6, 8, 6, 0, 6, 6, 4, 3, 3, 3, 6, 2, 2, 0, 0, 9, 9, 11, 10, 4, 7, 2, 2, 2, 1, 4, 11, 8, 8, 10, 0, 6, 3, 4, 0, 0, 0, 0, 1, 10, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 11, 11, 13, 1, 13, - 11, 8, 3, 3, 3, 9, 1, 5, 9, 10, 10, 12, 1, 0, 12, 0, + 11, 8, 3, 3, 3, 9, 1, 5, 9, 10, 12, 10, 1, 0, 12, 0, 7, 5, 1, 1, 1, 8, 0, 2, 8, 0, 4, 0, 15, 12, 1, 11, 14, 8, 0, 10, 0, 0, 0, 0, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 0, 0, 1, 1, 1, 3, 3, 3, 1, 1, 2, 2, 2, 0, 0, 0, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 2, 2, 2, 2, 2, 2, 2, 2, 3, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 3, - 5, 3, 5, 5, 3, 3, 3, 3, 1, 1, 3, 3, 0, 0, 2, 1, - 3, 0, 3, 1, 2, 0, 1, 1, 0, 0, 0, 0, 0, 2, 8, 7, - 3, 9, 6, 4, 5, 2, 9, 8, 7, 3, 4, 6, 5, 1, 0, 0, - 2, 1, 5, 4, 2, 3, 0, 1, 1, 2, 0, 1, 2, 4, 0, 3, - 5, 3, 1, 0, 2, 3, 4, 2, 0, 4, 5, 3, 1, 2, 1, 2, - 4, 0, 3, 5, 1, 0, 1, 0, 0, 2, 1, 3, 4, 3, 2, 1, - 5, 0, 0, 4, 5, 1, 3, 2, 1, 0, 3, 2, 4, 3, 0, 2, - 1, 4, 0, 1, 0, 0, 0, 0, 0, 1, 2, 3, 0, 1, 3, 2, - 1, 2, 3, 0, 2, 3, 1, 0, 1, 0, 3, 2, 2, 3, 0, 1, - 3, 0, 1, 2, 3, 2, 3, 0, 3, 0, 3, 3, 1, 0, 2, 1, - 2, 0, 0, 1, 1, 0, 3, 2, 0, 1, 0, 1, 2, 1, 0, 1, - 0, 6, 4, 5, 0, 1, 2, 1, 0, 2, 1, 2, 0, 2, 1, 0, - 2, 2, 0, 0, 0, 7, 5, 6, 4, 0, 2, 1, 2, 1, 0, 1, - 0, 2, 0, 2, 1, 0, 0, 2, 0, 2, 0, 0, 0, 0, 0, 0, + 5, 3, 5, 3, 5, 3, 3, 3, 1, 1, 3, 3, 0, 1, 2, 0, + 3, 0, 1, 3, 2, 0, 1, 0, 1, 0, 0, 0, 0, 9, 7, 3, + 6, 5, 2, 8, 4, 4, 9, 7, 6, 8, 3, 2, 5, 1, 0, 2, + 0, 1, 2, 4, 1, 3, 5, 0, 1, 0, 2, 1, 5, 4, 2, 3, + 0, 2, 1, 0, 3, 4, 2, 3, 0, 2, 1, 3, 5, 4, 5, 3, + 4, 0, 1, 2, 1, 0, 1, 0, 3, 0, 1, 2, 1, 0, 5, 2, + 4, 3, 0, 4, 1, 3, 2, 5, 3, 1, 2, 0, 4, 0, 2, 3, + 4, 1, 0, 1, 0, 0, 0, 0, 1, 0, 3, 2, 2, 3, 0, 1, + 3, 2, 0, 1, 0, 3, 1, 2, 0, 3, 2, 1, 1, 0, 3, 2, + 1, 2, 3, 0, 2, 3, 3, 0, 3, 0, 3, 2, 1, 3, 0, 2, + 1, 0, 0, 1, 0, 1, 2, 3, 0, 1, 0, 2, 1, 1, 0, 1, + 0, 6, 5, 4, 0, 1, 2, 0, 1, 2, 0, 1, 2, 0, 1, 2, + 2, 2, 0, 0, 0, 6, 4, 5, 7, 2, 1, 0, 1, 2, 0, 0, + 1, 2, 0, 2, 1, 0, 0, 2, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, @@ -1735,20 +1738,20 @@ DECODE_FORM_IDX := [1657]u16{ 0, 3, 3, 0, 0, 3, 0, 3, 0, 0, 0, 1, 0, 1, 4, 4, 0, 2, 2, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 9, 7, 0, 0, 6, 8, 0, 0, - 1, 0, 0, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, - 1, 0, 0, 1, 4, 1, 0, 0, 1, 27, 2, 2, 1, 0, 1, 0, + 1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, + 0, 1, 1, 0, 4, 1, 0, 1, 0, 27, 2, 2, 1, 0, 0, 1, 0, 0, 0, 0, 5, 26, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, - 2, 0, 1, 0, 1, 2, 2, 0, 1, 0, 1, 0, 1, 0, 1, 1, - 0, 0, 2, 0, 1, 2, 2, 1, 0, 1, 0, 2, 2, 0, 1, 1, - 0, 5, 3, 2, 2, 3, 1, 0, 0, 1, 0, 1, 1, 0, 0, 1, - 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 2, 1, 0, 9, 6, 5, - 7, 3, 1, 0, 2, 4, 8, 0, 1, 0, 1, 3, 0, 1, 2, 0, - 1, 1, 0, 0, 1, 1, 0, 0, 7, 1, 0, 3, 6, 9, 8, 2, - 4, 0, 1, 0, 1, 5, 4, 2, 3, 0, 0, 1, 0, 0, 0, 0, + 2, 0, 1, 1, 0, 2, 2, 0, 1, 1, 0, 0, 1, 0, 1, 1, + 0, 0, 2, 1, 0, 2, 2, 1, 0, 1, 0, 2, 2, 1, 0, 1, + 0, 2, 3, 5, 2, 3, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, + 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 2, 1, 0, 9, 7, 6, + 8, 3, 2, 4, 0, 1, 5, 0, 1, 1, 0, 3, 1, 0, 2, 1, + 0, 0, 1, 1, 0, 1, 0, 0, 7, 8, 2, 3, 0, 1, 6, 9, + 0, 1, 4, 0, 1, 4, 5, 2, 3, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 2, 2, 1, 6, 7, 6, 7, 4, 4, 4, 4, 4, 3, 5, 4, 7, 5, 11, 10, 8, 10, 9, 8, 7, 8, 8, 8, 8, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 4, 0, 0, 0, 0, 7, 2, 2, 2, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 17, 17, 17, 6, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 16, 16, 11, @@ -1758,26 +1761,26 @@ DECODE_FORM_IDX := [1657]u16{ 0, 0, 0, 0, 0, 0, 0, 4, 3, 6, 4, 8, 9, 7, 0, 7, 8, 7, 6, 7, 7, 7, 7, 4, 3, 1, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 2, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 2, 9, 8, 7, 7, 7, 7, 6, - 6, 1, 1, 1, 10, 8, 7, 6, 6, 6, 6, 5, 5, 2, 1, 2, - 2, 1, 2, 1, 1, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 2, 9, 8, 7, 7, + 7, 7, 6, 6, 1, 1, 1, 10, 8, 7, 6, 6, 6, 6, 5, 5, + 2, 1, 2, 2, 1, 2, 1, 1, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 3, 1, 1, 0, 5, 5, 5, 4, 1, 1, 1, 1, 1, 1, 2, 1, - 2, 2, 2, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 0, 2, 2, 2, 2, - 2, 2, 0, 0, 0, 0, 11, 11, 0, 0, 0, 10, 10, 12, 2, 16, - 6, 0, 0, 0, 0, 0, 0, 0, 0, 15, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 2, 2, 6, 6, 7, 7, - 6, 3, 8, 8, 6, 6, 6, 6, 3, 4, 3, 6, 6, 6, 3, 3, - 3, 2, 0, 2, 1, 2, 0, 0, 9, 5, 7, 4, 4, 4, 4, 4, - 5, 4, 4, 4, 5, 6, 5, 5, 5, 5, 6, 7, 0, 10, 1, 1, - 1, 1, 9, 11, 0, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, - 1, 0, 1, 5, 5, 1, 1, 1, 2, + 1, 1, 1, 3, 1, 1, 0, 5, 5, 5, 4, 1, 1, 1, 1, 1, + 1, 2, 1, 2, 2, 2, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 0, 2, + 2, 2, 2, 2, 2, 0, 0, 0, 0, 11, 11, 0, 0, 0, 10, 10, + 12, 2, 16, 6, 0, 0, 0, 0, 0, 0, 0, 0, 15, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 2, 2, 6, + 6, 7, 7, 6, 3, 8, 8, 6, 6, 6, 6, 3, 4, 3, 6, 6, + 6, 3, 3, 3, 2, 0, 2, 1, 2, 0, 0, 9, 5, 7, 4, 4, + 4, 4, 4, 5, 4, 4, 4, 5, 6, 5, 5, 5, 5, 6, 7, 0, + 10, 1, 1, 1, 1, 9, 11, 0, 1, 1, 1, 1, 1, 0, 1, 1, + 1, 1, 1, 1, 0, 1, 5, 5, 1, 1, 1, 2, } @(rodata) -DECODE_BUCKET_LIST := [5377]u16{ +DECODE_BUCKET_LIST := [5383]u16{ 0, 1, 2, 3, 0, 4, 1, 5, 2, 6, 7, 8, 9, 6, 10, 7, 11, 8, 12, 35, 36, 37, 13, 14, 41, 42, 43, 15, 13, 16, 14, 17, 47, 18, 19, 51, 52, 53, 20, 21, 18, 19, 22, 23, 24, 25, 22, 26, @@ -1968,153 +1971,153 @@ DECODE_BUCKET_LIST := [5377]u16{ 1312, 1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322, 1323, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1332, 1333, 1334, 1335, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, 1348, 1349, 1350, 1351, 1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, - 1360, 1361, 1362, 1363, 1364, 1365, 1366, 1367, 1368, 1369, 1370, 1371, 1372, 1373, 1374, 1376, + 1360, 1361, 1362, 1363, 1364, 1365, 1366, 1367, 1368, 1369, 1370, 1372, 1371, 1373, 1374, 1376, 1375, 1377, 1378, 1379, 1380, 1381, 1382, 1383, 1384, 1385, 1386, 1387, 1388, 1389, 1390, 1391, 1392, 1393, 1394, 1395, 1396, 1397, 1398, 1399, 1400, 1401, 1402, 1403, 1404, 1405, 1406, 1407, - 1408, 1409, 1410, 1411, 1412, 1413, 1414, 1415, 1383, 1384, 1385, 1367, 1368, 1369, 1370, 1372, - 1371, 1373, 1376, 1375, 1377, 1378, 1379, 1380, 1381, 1382, 1383, 1384, 1385, 1416, 1414, 1415, - 1383, 1384, 1385, 1417, 1418, 1419, 1420, 1421, 1422, 1423, 1424, 1425, 1426, 1427, 1428, 1429, + 1408, 1409, 1410, 1411, 1412, 1413, 1414, 1415, 1384, 1383, 1385, 1367, 1368, 1369, 1370, 1372, + 1371, 1373, 1376, 1375, 1377, 1378, 1379, 1380, 1381, 1382, 1383, 1384, 1385, 1416, 1417, 1418, + 1419, 1414, 1415, 1383, 1384, 1385, 1420, 1421, 1422, 1423, 1424, 1425, 1426, 1427, 1428, 1429, 1430, 1431, 1432, 1433, 1434, 1435, 1436, 1437, 1438, 1439, 1440, 1441, 1442, 1443, 1444, 1445, 1446, 1447, 1448, 1449, 1450, 1451, 1452, 1453, 1454, 1455, 1456, 1457, 1458, 1459, 1460, 1461, 1462, 1463, 1464, 1465, 1466, 1467, 1468, 1469, 1470, 1471, 1472, 1473, 1474, 1475, 1476, 1477, 1478, 1479, 1480, 1481, 1482, 1483, 1484, 1485, 1486, 1487, 1488, 1489, 1490, 1491, 1492, 1493, 1494, 1495, 1496, 1497, 1498, 1499, 1500, 1501, 1502, 1503, 1504, 1505, 1506, 1507, 1508, 1509, 1510, 1511, 1512, 1513, 1514, 1515, 1516, 1517, 1518, 1519, 1520, 1521, 1522, 1523, 1524, 1525, - 1527, 1526, 1529, 1528, 1530, 1531, 1259, 1260, 1261, 1262, 1263, 1264, 1532, 1533, 1534, 1535, - 1536, 1537, 1538, 1539, 1540, 1541, 1542, 1543, 1544, 1545, 1546, 1269, 1270, 1271, 1272, 1273, - 1274, 1547, 1548, 1549, 1278, 1279, 1280, 1550, 1285, 1286, 1287, 1288, 1289, 1290, 1294, 1295, - 1551, 1296, 1297, 1552, 1298, 1299, 1300, 1301, 1302, 1303, 1304, 1305, 1306, 1307, 1308, 1553, - 1554, 1555, 1556, 1557, 1558, 1559, 1560, 1309, 1561, 1310, 1311, 1312, 1313, 1562, 1314, 1315, - 1316, 1317, 1318, 1319, 1320, 1321, 1322, 1323, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, - 1332, 1333, 1334, 1335, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, - 1563, 1564, 1565, 1566, 1567, 1568, 1569, 1570, 1350, 1351, 1352, 1353, 1571, 1572, 1573, 1574, - 1575, 1576, 1577, 1577, 1578, 1578, 1579, 1579, 1580, 1581, 1582, 1583, 1584, 1584, 1585, 1585, - 1586, 1586, 1587, 1587, 1588, 1589, 1590, 1591, 1592, 1593, 1594, 1595, 1596, 1597, 1598, 1599, - 1600, 1601, 1602, 1603, 1604, 1605, 1606, 1607, 1608, 1609, 1610, 1611, 1611, 1612, 1613, 1614, - 1615, 1616, 1617, 1618, 1619, 1620, 1620, 1621, 1621, 1622, 1622, 1623, 1623, 1624, 1624, 1625, - 1625, 1626, 1626, 1627, 1627, 1628, 1628, 1629, 1629, 1630, 1631, 1632, 1633, 1634, 1635, 1636, - 1637, 1638, 1639, 1640, 1641, 1642, 1643, 1644, 1645, 1646, 1647, 1648, 1649, 1650, 1651, 1651, - 1652, 1652, 1653, 1653, 1653, 1654, 1655, 1653, 1656, 1656, 1206, 1207, 1208, 1209, 1214, 1220, - 1210, 1219, 1220, 1219, 1217, 1215, 1217, 1213, 1215, 1203, 1204, 1211, 1220, 1199, 1200, 1201, - 1202, 1205, 1219, 1220, 1219, 1218, 1216, 1212, 1218, 1216, 1220, 1219, 1220, 1198, 1219, 1220, - 1219, 1220, 1219, 1233, 1232, 1225, 1233, 1232, 1239, 1239, 1221, 1222, 1223, 1224, 1230, 1229, - 1238, 1221, 1222, 1223, 1224, 1229, 1230, 1238, 1231, 1231, 1234, 1226, 1234, 1228, 1236, 1236, - 1237, 1237, 1227, 1235, 1235, 1250, 1257, 1258, 1250, 1253, 1256, 1254, 1255, 1250, 1257, 1258, - 1240, 1241, 1242, 1243, 1250, 1253, 1256, 1254, 1255, 1257, 1258, 1253, 1256, 1254, 1255, 1257, - 1258, 1253, 1256, 1254, 1255, 1240, 1241, 1242, 1243, 1247, 1248, 1249, 1252, 1244, 1245, 1246, - 1251, 1247, 1248, 1249, 1252, 1244, 1245, 1246, 1251, 1278, 1279, 1291, 1292, 1294, 1295, 1296, - 1307, 1308, 1311, 1314, 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1358, - 1278, 1279, 1291, 1293, 1294, 1295, 1296, 1308, 1311, 1314, 1315, 1318, 1319, 1320, 1321, 1322, - 1323, 1332, 1333, 1334, 1335, 1358, 1278, 1279, 1291, 1292, 1294, 1295, 1296, 1308, 1311, 1314, - 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1358, 1265, 1266, 1267, 1268, - 1278, 1279, 1280, 1291, 1293, 1294, 1295, 1296, 1297, 1306, 1308, 1311, 1314, 1315, 1318, 1319, - 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1358, 1278, 1279, 1292, 1294, 1295, 1296, 1307, - 1308, 1311, 1314, 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1354, 1358, - 1278, 1279, 1293, 1294, 1295, 1296, 1308, 1311, 1314, 1315, 1318, 1319, 1320, 1321, 1322, 1323, - 1332, 1333, 1334, 1335, 1354, 1358, 1278, 1279, 1292, 1294, 1295, 1296, 1308, 1311, 1314, 1315, - 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1354, 1358, 1265, 1266, 1267, 1268, - 1278, 1279, 1280, 1293, 1294, 1295, 1296, 1297, 1306, 1308, 1311, 1314, 1315, 1318, 1319, 1320, - 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1354, 1358, 1259, 1260, 1275, 1276, 1277, 1287, 1288, - 1289, 1290, 1300, 1301, 1302, 1303, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, - 1348, 1349, 1353, 1356, 1359, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1356, - 1359, 1275, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1356, 1359, 1285, 1286, - 1298, 1299, 1304, 1305, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1356, 1359, - 1275, 1276, 1277, 1287, 1288, 1289, 1290, 1300, 1301, 1302, 1303, 1316, 1317, 1324, 1325, 1326, - 1327, 1328, 1329, 1330, 1331, 1348, 1349, 1353, 1355, 1357, 1359, 1316, 1317, 1324, 1325, 1326, - 1327, 1328, 1329, 1330, 1331, 1355, 1357, 1359, 1261, 1262, 1263, 1264, 1271, 1272, 1273, 1274, - 1275, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1355, 1357, 1359, 1269, 1270, - 1285, 1286, 1298, 1299, 1304, 1305, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, - 1355, 1357, 1359, 1281, 1309, 1312, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, - 1346, 1347, 1282, 1309, 1312, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, - 1347, 1283, 1310, 1313, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, - 1284, 1310, 1313, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, 1281, - 1309, 1312, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, 1282, 1309, - 1312, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, 1283, 1310, 1313, - 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, 1284, 1310, 1313, 1336, - 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, 1350, 1351, 1352, 1350, 1351, + 1526, 1528, 1527, 1529, 1530, 1531, 1532, 1533, 1534, 1259, 1260, 1261, 1262, 1263, 1264, 1535, + 1536, 1537, 1538, 1539, 1540, 1541, 1542, 1543, 1544, 1545, 1546, 1547, 1548, 1549, 1269, 1270, + 1271, 1272, 1273, 1274, 1550, 1551, 1552, 1278, 1279, 1280, 1553, 1285, 1286, 1287, 1288, 1289, + 1290, 1294, 1295, 1554, 1296, 1297, 1555, 1298, 1299, 1300, 1301, 1302, 1303, 1304, 1305, 1306, + 1307, 1308, 1556, 1557, 1558, 1559, 1560, 1561, 1562, 1563, 1309, 1564, 1310, 1311, 1312, 1313, + 1565, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322, 1323, 1324, 1325, 1326, 1327, 1328, + 1329, 1330, 1331, 1332, 1333, 1334, 1335, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, + 1345, 1346, 1347, 1566, 1567, 1568, 1569, 1570, 1571, 1572, 1573, 1350, 1351, 1352, 1353, 1574, + 1575, 1576, 1577, 1578, 1579, 1580, 1580, 1581, 1581, 1582, 1582, 1583, 1584, 1585, 1586, 1587, + 1587, 1588, 1588, 1589, 1589, 1590, 1590, 1591, 1592, 1593, 1594, 1595, 1596, 1597, 1598, 1599, + 1600, 1601, 1602, 1603, 1604, 1605, 1606, 1607, 1608, 1609, 1610, 1611, 1612, 1613, 1614, 1614, + 1615, 1616, 1617, 1618, 1619, 1620, 1621, 1622, 1623, 1623, 1624, 1624, 1625, 1625, 1626, 1626, + 1627, 1627, 1628, 1628, 1629, 1629, 1630, 1630, 1631, 1631, 1632, 1632, 1633, 1634, 1635, 1636, + 1637, 1638, 1639, 1640, 1641, 1642, 1643, 1644, 1645, 1646, 1647, 1648, 1649, 1650, 1651, 1652, + 1653, 1654, 1654, 1655, 1655, 1656, 1656, 1656, 1657, 1658, 1656, 1659, 1659, 1206, 1207, 1208, + 1209, 1214, 1220, 1210, 1219, 1220, 1219, 1217, 1215, 1217, 1213, 1215, 1203, 1204, 1211, 1220, + 1199, 1200, 1201, 1202, 1205, 1219, 1220, 1219, 1218, 1216, 1212, 1218, 1216, 1220, 1219, 1220, + 1198, 1219, 1220, 1219, 1220, 1219, 1233, 1232, 1225, 1233, 1232, 1239, 1239, 1221, 1222, 1223, + 1224, 1230, 1229, 1238, 1221, 1222, 1223, 1224, 1229, 1230, 1238, 1231, 1231, 1234, 1226, 1234, + 1228, 1236, 1236, 1237, 1237, 1227, 1235, 1235, 1250, 1258, 1257, 1250, 1254, 1255, 1253, 1256, + 1250, 1258, 1257, 1240, 1241, 1242, 1243, 1250, 1254, 1255, 1253, 1256, 1258, 1257, 1254, 1255, + 1253, 1256, 1258, 1257, 1254, 1255, 1253, 1256, 1240, 1241, 1242, 1243, 1247, 1248, 1249, 1252, + 1244, 1245, 1246, 1251, 1247, 1248, 1249, 1252, 1244, 1245, 1246, 1251, 1278, 1279, 1291, 1292, + 1294, 1295, 1296, 1307, 1308, 1311, 1314, 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, + 1334, 1335, 1358, 1278, 1279, 1291, 1293, 1294, 1295, 1296, 1308, 1311, 1314, 1315, 1318, 1319, + 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1358, 1278, 1279, 1291, 1292, 1294, 1295, 1296, + 1308, 1311, 1314, 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1358, 1265, + 1266, 1267, 1268, 1278, 1279, 1280, 1291, 1293, 1294, 1295, 1296, 1297, 1306, 1308, 1311, 1314, + 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1358, 1278, 1279, 1292, 1294, + 1295, 1296, 1307, 1308, 1311, 1314, 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, + 1335, 1354, 1358, 1278, 1279, 1293, 1294, 1295, 1296, 1308, 1311, 1314, 1315, 1318, 1319, 1320, + 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1354, 1358, 1278, 1279, 1292, 1294, 1295, 1296, 1308, + 1311, 1314, 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1354, 1358, 1265, + 1266, 1267, 1268, 1278, 1279, 1280, 1293, 1294, 1295, 1296, 1297, 1306, 1308, 1311, 1314, 1315, + 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1354, 1358, 1259, 1260, 1275, 1276, + 1277, 1287, 1288, 1289, 1290, 1300, 1301, 1302, 1303, 1316, 1317, 1324, 1325, 1326, 1327, 1328, + 1329, 1330, 1331, 1348, 1349, 1353, 1356, 1359, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, + 1330, 1331, 1356, 1359, 1275, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1356, + 1359, 1285, 1286, 1298, 1299, 1304, 1305, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, 1330, + 1331, 1356, 1359, 1275, 1276, 1277, 1287, 1288, 1289, 1290, 1300, 1301, 1302, 1303, 1316, 1317, + 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1348, 1349, 1353, 1355, 1357, 1359, 1316, 1317, + 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1355, 1357, 1359, 1261, 1262, 1263, 1264, 1271, + 1272, 1273, 1274, 1275, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1355, 1357, + 1359, 1269, 1270, 1285, 1286, 1298, 1299, 1304, 1305, 1316, 1317, 1324, 1325, 1326, 1327, 1328, + 1329, 1330, 1331, 1355, 1357, 1359, 1281, 1309, 1312, 1336, 1337, 1338, 1339, 1340, 1341, 1342, + 1343, 1344, 1345, 1346, 1347, 1282, 1309, 1312, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, + 1344, 1345, 1346, 1347, 1283, 1310, 1313, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, + 1345, 1346, 1347, 1284, 1310, 1313, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, + 1346, 1347, 1281, 1309, 1312, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, + 1347, 1282, 1309, 1312, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, + 1283, 1310, 1313, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, 1284, + 1310, 1313, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, 1350, 1351, 1352, 1350, 1351, 1352, 1350, 1351, 1352, 1350, 1351, 1352, 1350, 1351, 1352, 1350, 1351, 1352, - 1350, 1351, 1352, 1360, 1362, 1363, 1364, 1374, 1376, 1375, 1384, 1383, 1385, 1362, 1363, 1365, - 1367, 1374, 1376, 1375, 1384, 1383, 1385, 1362, 1363, 1374, 1382, 1384, 1383, 1385, 1362, 1363, - 1374, 1382, 1383, 1384, 1385, 1361, 1363, 1366, 1372, 1371, 1374, 1381, 1383, 1384, 1385, 1363, - 1372, 1371, 1374, 1381, 1384, 1383, 1385, 1363, 1373, 1374, 1384, 1383, 1385, 1363, 1373, 1374, - 1384, 1383, 1385, 1377, 1384, 1383, 1385, 1368, 1377, 1383, 1384, 1385, 1384, 1383, 1385, 1384, - 1383, 1385, 1383, 1384, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1384, 1383, 1385, 1363, 1374, - 1383, 1384, 1385, 1363, 1370, 1374, 1384, 1383, 1385, 1363, 1374, 1383, 1384, 1385, 1363, 1374, - 1384, 1383, 1385, 1363, 1374, 1379, 1383, 1384, 1385, 1363, 1374, 1379, 1384, 1383, 1385, 1363, - 1374, 1380, 1384, 1383, 1385, 1363, 1374, 1380, 1383, 1384, 1385, 1383, 1384, 1385, 1383, 1384, - 1385, 1384, 1383, 1385, 1369, 1383, 1384, 1385, 1378, 1383, 1384, 1385, 1378, 1383, 1384, 1385, - 1383, 1384, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1383, 1384, 1385, 1384, - 1383, 1385, 1414, 1383, 1384, 1385, 1383, 1384, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1383, - 1384, 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1383, 1384, 1385, 1415, 1384, 1383, 1385, 1384, - 1383, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1412, 1384, 1383, 1385, 1383, 1384, 1385, 1406, - 1412, 1384, 1383, 1385, 1384, 1383, 1385, 1410, 1384, 1383, 1385, 1384, 1383, 1385, 1408, 1409, - 1383, 1384, 1385, 1384, 1383, 1385, 1405, 1413, 1384, 1383, 1385, 1383, 1384, 1385, 1386, 1387, - 1388, 1389, 1390, 1392, 1393, 1394, 1395, 1397, 1398, 1399, 1400, 1407, 1413, 1383, 1384, 1385, - 1391, 1396, 1402, 1403, 1404, 1383, 1384, 1385, 1411, 1384, 1383, 1385, 1383, 1384, 1385, 1401, - 1384, 1383, 1385, 1384, 1383, 1385, 1376, 1375, 1384, 1383, 1385, 1367, 1376, 1375, 1384, 1383, - 1385, 1382, 1383, 1384, 1385, 1382, 1384, 1383, 1385, 1372, 1371, 1381, 1384, 1383, 1385, 1372, - 1371, 1381, 1384, 1383, 1385, 1373, 1384, 1383, 1385, 1373, 1384, 1383, 1385, 1377, 1384, 1383, - 1385, 1368, 1377, 1384, 1383, 1385, 1384, 1383, 1385, 1384, 1383, 1385, 1384, 1383, 1385, 1384, - 1383, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1370, 1384, 1383, 1385, 1383, - 1384, 1385, 1384, 1383, 1385, 1379, 1384, 1383, 1385, 1379, 1384, 1383, 1385, 1380, 1384, 1383, - 1385, 1380, 1384, 1383, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1369, 1384, - 1383, 1385, 1378, 1383, 1384, 1385, 1378, 1383, 1384, 1385, 1383, 1384, 1385, 1384, 1383, 1385, - 1384, 1383, 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1414, 1384, 1383, 1385, - 1383, 1384, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1384, 1383, 1385, 1384, 1383, 1385, 1384, - 1383, 1385, 1384, 1383, 1385, 1415, 1384, 1383, 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1384, - 1383, 1385, 1384, 1383, 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1384, 1383, - 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1383, 1384, 1385, - 1383, 1384, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1416, - 1383, 1384, 1385, 1420, 1419, 1422, 1421, 1426, 1418, 1417, 1428, 1432, 1425, 1431, 1434, 1433, - 1430, 1428, 1429, 1423, 1424, 1427, 1435, 1436, 1439, 1492, 1498, 1442, 1492, 1501, 1438, 1493, - 1497, 1441, 1493, 1500, 1437, 1494, 1496, 1440, 1494, 1499, 1495, 1495, 1448, 1449, 1450, 1451, - 1452, 1458, 1464, 1470, 1476, 1482, 1444, 1445, 1446, 1447, 1453, 1459, 1465, 1471, 1477, 1483, - 1454, 1460, 1466, 1472, 1478, 1484, 1443, 1456, 1462, 1468, 1474, 1480, 1486, 1457, 1463, 1469, - 1475, 1481, 1487, 1455, 1461, 1467, 1473, 1479, 1485, 1488, 1502, 1503, 1491, 1506, 1489, 1504, - 1490, 1507, 1505, 1529, 1528, 1524, 1526, 1525, 1527, 1529, 1528, 1524, 1526, 1525, 1527, 1514, - 1515, 1516, 1517, 1518, 1519, 1529, 1508, 1509, 1510, 1511, 1512, 1513, 1520, 1521, 1522, 1523, - 1528, 1524, 1526, 1525, 1527, 1514, 1515, 1516, 1517, 1518, 1519, 1529, 1508, 1509, 1510, 1511, - 1512, 1513, 1528, 1524, 1526, 1525, 1527, 1520, 1521, 1522, 1523, 1546, 1278, 1279, 1294, 1295, - 1296, 1552, 1307, 1308, 1557, 1558, 1559, 1560, 1311, 1562, 1314, 1315, 1318, 1319, 1320, 1321, - 1322, 1323, 1332, 1333, 1334, 1335, 1575, 1278, 1279, 1294, 1295, 1296, 1552, 1308, 1557, 1558, - 1559, 1560, 1311, 1562, 1314, 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, - 1575, 1278, 1279, 1294, 1295, 1296, 1552, 1308, 1557, 1558, 1559, 1560, 1311, 1562, 1314, 1315, - 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1575, 1531, 1540, 1541, 1278, 1279, - 1280, 1294, 1295, 1296, 1297, 1552, 1306, 1308, 1557, 1558, 1559, 1560, 1311, 1562, 1314, 1315, - 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1575, 1546, 1278, 1279, 1294, 1295, - 1296, 1552, 1307, 1308, 1557, 1558, 1559, 1560, 1311, 1562, 1314, 1315, 1318, 1319, 1320, 1321, - 1322, 1323, 1332, 1333, 1334, 1335, 1571, 1575, 1278, 1279, 1294, 1295, 1296, 1552, 1308, 1557, - 1558, 1559, 1560, 1311, 1562, 1314, 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, - 1335, 1571, 1575, 1278, 1279, 1294, 1295, 1296, 1552, 1308, 1557, 1558, 1559, 1560, 1311, 1562, - 1314, 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1571, 1575, 1530, 1540, - 1541, 1278, 1279, 1280, 1294, 1295, 1296, 1297, 1552, 1306, 1308, 1557, 1558, 1559, 1560, 1311, - 1562, 1314, 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1571, 1575, 1259, - 1260, 1287, 1288, 1289, 1290, 1300, 1301, 1302, 1303, 1553, 1554, 1555, 1556, 1562, 1316, 1317, - 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1567, 1568, 1569, 1570, 1353, 1573, 1576, 1553, - 1554, 1555, 1556, 1562, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1573, 1576, - 1553, 1554, 1555, 1556, 1562, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1573, - 1576, 1538, 1539, 1285, 1286, 1298, 1299, 1304, 1305, 1553, 1554, 1555, 1556, 1562, 1316, 1317, - 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1563, 1564, 1565, 1566, 1573, 1576, 1287, 1288, - 1289, 1290, 1300, 1301, 1302, 1303, 1553, 1554, 1555, 1556, 1562, 1316, 1317, 1324, 1325, 1326, - 1327, 1328, 1329, 1330, 1331, 1567, 1568, 1569, 1570, 1353, 1572, 1574, 1576, 1553, 1554, 1555, - 1556, 1562, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1572, 1574, 1576, 1261, - 1262, 1263, 1264, 1271, 1272, 1273, 1274, 1553, 1554, 1555, 1556, 1562, 1316, 1317, 1324, 1325, - 1326, 1327, 1328, 1329, 1330, 1331, 1572, 1574, 1576, 1538, 1539, 1269, 1270, 1285, 1286, 1298, - 1299, 1304, 1305, 1553, 1554, 1555, 1556, 1562, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, - 1330, 1331, 1563, 1564, 1565, 1566, 1572, 1574, 1576, 1550, 1551, 1552, 1309, 1561, 1312, 1562, - 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, 1551, 1552, 1309, 1561, - 1312, 1562, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, 1552, 1561, - 1310, 1313, 1562, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, 1552, - 1561, 1310, 1313, 1562, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, - 1550, 1551, 1552, 1309, 1561, 1312, 1562, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, - 1345, 1346, 1347, 1551, 1552, 1309, 1561, 1312, 1562, 1336, 1337, 1338, 1339, 1340, 1341, 1342, - 1343, 1344, 1345, 1346, 1347, 1552, 1561, 1310, 1313, 1562, 1336, 1337, 1338, 1339, 1340, 1341, - 1342, 1343, 1344, 1345, 1346, 1347, 1552, 1561, 1310, 1313, 1562, 1336, 1337, 1338, 1339, 1340, - 1341, 1342, 1343, 1344, 1345, 1346, 1347, 1562, 1350, 1351, 1352, 1562, 1350, 1351, 1352, 1562, - 1350, 1351, 1352, 1532, 1533, 1534, 1535, 1536, 1537, 1542, 1543, 1544, 1545, 1547, 1548, 1549, - 1562, 1350, 1351, 1352, 1562, 1350, 1351, 1352, 1562, 1350, 1351, 1352, 1562, 1350, 1351, 1352, - 1532, 1533, 1534, 1535, 1536, 1537, 1542, 1543, 1544, 1545, 1547, 1548, 1549, 1562, 1350, 1351, - 1352, + 1350, 1351, 1352, 1350, 1351, 1352, 1360, 1362, 1363, 1364, 1374, 1375, 1376, 1384, 1383, 1385, + 1362, 1363, 1365, 1367, 1374, 1375, 1376, 1384, 1383, 1385, 1362, 1363, 1374, 1382, 1383, 1384, + 1385, 1362, 1363, 1374, 1382, 1384, 1383, 1385, 1361, 1363, 1366, 1372, 1371, 1374, 1381, 1384, + 1383, 1385, 1363, 1372, 1371, 1374, 1381, 1384, 1383, 1385, 1363, 1373, 1374, 1383, 1384, 1385, + 1363, 1373, 1374, 1384, 1383, 1385, 1377, 1383, 1384, 1385, 1368, 1377, 1383, 1384, 1385, 1384, + 1383, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1383, 1384, 1385, 1384, 1383, + 1385, 1363, 1374, 1384, 1383, 1385, 1363, 1370, 1374, 1384, 1383, 1385, 1363, 1374, 1383, 1384, + 1385, 1363, 1374, 1383, 1384, 1385, 1363, 1374, 1379, 1384, 1383, 1385, 1363, 1374, 1379, 1384, + 1383, 1385, 1363, 1374, 1380, 1383, 1384, 1385, 1363, 1374, 1380, 1384, 1383, 1385, 1384, 1383, + 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1369, 1384, 1383, 1385, 1378, 1383, 1384, 1385, 1378, + 1384, 1383, 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1383, 1384, 1385, 1383, 1384, 1385, 1383, + 1384, 1385, 1383, 1384, 1385, 1414, 1383, 1384, 1385, 1383, 1384, 1385, 1383, 1384, 1385, 1383, + 1384, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1383, 1384, 1385, 1415, 1383, + 1384, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1412, 1384, 1383, 1385, 1384, + 1383, 1385, 1406, 1412, 1384, 1383, 1385, 1384, 1383, 1385, 1410, 1383, 1384, 1385, 1383, 1384, + 1385, 1408, 1409, 1383, 1384, 1385, 1384, 1383, 1385, 1405, 1413, 1384, 1383, 1385, 1383, 1384, + 1385, 1386, 1387, 1388, 1389, 1390, 1392, 1393, 1394, 1395, 1397, 1398, 1399, 1400, 1407, 1413, + 1384, 1383, 1385, 1391, 1396, 1402, 1403, 1404, 1383, 1384, 1385, 1411, 1384, 1383, 1385, 1384, + 1383, 1385, 1401, 1383, 1384, 1385, 1383, 1384, 1385, 1376, 1375, 1383, 1384, 1385, 1367, 1375, + 1376, 1384, 1383, 1385, 1382, 1383, 1384, 1385, 1382, 1383, 1384, 1385, 1372, 1371, 1381, 1383, + 1384, 1385, 1371, 1372, 1381, 1383, 1384, 1385, 1373, 1383, 1384, 1385, 1373, 1383, 1384, 1385, + 1377, 1383, 1384, 1385, 1368, 1377, 1383, 1384, 1385, 1384, 1383, 1385, 1384, 1383, 1385, 1384, + 1383, 1385, 1384, 1383, 1385, 1384, 1383, 1385, 1384, 1383, 1385, 1384, 1383, 1385, 1370, 1384, + 1383, 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1379, 1384, 1383, 1385, 1379, 1384, 1383, 1385, + 1380, 1384, 1383, 1385, 1380, 1383, 1384, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1383, 1384, + 1385, 1369, 1383, 1384, 1385, 1378, 1383, 1384, 1385, 1378, 1383, 1384, 1385, 1383, 1384, 1385, + 1383, 1384, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1414, + 1383, 1384, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1384, 1383, 1385, 1384, 1383, 1385, 1383, + 1384, 1385, 1384, 1383, 1385, 1384, 1383, 1385, 1415, 1384, 1383, 1385, 1384, 1383, 1385, 1384, + 1383, 1385, 1384, 1383, 1385, 1384, 1383, 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1384, 1383, + 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1383, 1384, 1385, 1416, 1417, 1418, + 1383, 1384, 1385, 1383, 1384, 1385, 1383, 1384, 1385, 1383, 1384, 1385, 1384, 1383, 1385, 1384, + 1383, 1385, 1383, 1384, 1385, 1419, 1383, 1384, 1385, 1423, 1422, 1425, 1424, 1429, 1421, 1420, + 1431, 1435, 1428, 1434, 1437, 1436, 1433, 1431, 1432, 1426, 1427, 1430, 1438, 1439, 1442, 1495, + 1501, 1445, 1495, 1504, 1441, 1496, 1500, 1444, 1496, 1503, 1440, 1497, 1499, 1443, 1497, 1502, + 1498, 1498, 1451, 1452, 1453, 1454, 1455, 1461, 1467, 1473, 1479, 1485, 1447, 1448, 1449, 1450, + 1456, 1462, 1468, 1474, 1480, 1486, 1457, 1463, 1469, 1475, 1481, 1487, 1446, 1459, 1465, 1471, + 1477, 1483, 1489, 1460, 1466, 1472, 1478, 1484, 1490, 1458, 1464, 1470, 1476, 1482, 1488, 1491, + 1505, 1506, 1494, 1509, 1492, 1507, 1493, 1510, 1508, 1531, 1532, 1527, 1529, 1528, 1530, 1531, + 1532, 1527, 1529, 1528, 1530, 1517, 1518, 1519, 1520, 1521, 1522, 1531, 1511, 1512, 1513, 1514, + 1515, 1516, 1523, 1524, 1525, 1526, 1532, 1527, 1529, 1528, 1530, 1517, 1518, 1519, 1520, 1521, + 1522, 1531, 1511, 1512, 1513, 1514, 1515, 1516, 1532, 1527, 1529, 1528, 1530, 1523, 1524, 1525, + 1526, 1549, 1278, 1279, 1294, 1295, 1296, 1555, 1307, 1308, 1560, 1561, 1562, 1563, 1311, 1565, + 1314, 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1578, 1278, 1279, 1294, + 1295, 1296, 1555, 1308, 1560, 1561, 1562, 1563, 1311, 1565, 1314, 1315, 1318, 1319, 1320, 1321, + 1322, 1323, 1332, 1333, 1334, 1335, 1578, 1278, 1279, 1294, 1295, 1296, 1555, 1308, 1560, 1561, + 1562, 1563, 1311, 1565, 1314, 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, + 1578, 1534, 1543, 1544, 1278, 1279, 1280, 1294, 1295, 1296, 1297, 1555, 1306, 1308, 1560, 1561, + 1562, 1563, 1311, 1565, 1314, 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, + 1578, 1549, 1278, 1279, 1294, 1295, 1296, 1555, 1307, 1308, 1560, 1561, 1562, 1563, 1311, 1565, + 1314, 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1574, 1578, 1278, 1279, + 1294, 1295, 1296, 1555, 1308, 1560, 1561, 1562, 1563, 1311, 1565, 1314, 1315, 1318, 1319, 1320, + 1321, 1322, 1323, 1332, 1333, 1334, 1335, 1574, 1578, 1278, 1279, 1294, 1295, 1296, 1555, 1308, + 1560, 1561, 1562, 1563, 1311, 1565, 1314, 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, 1333, + 1334, 1335, 1574, 1578, 1533, 1543, 1544, 1278, 1279, 1280, 1294, 1295, 1296, 1297, 1555, 1306, + 1308, 1560, 1561, 1562, 1563, 1311, 1565, 1314, 1315, 1318, 1319, 1320, 1321, 1322, 1323, 1332, + 1333, 1334, 1335, 1574, 1578, 1259, 1260, 1287, 1288, 1289, 1290, 1300, 1301, 1302, 1303, 1556, + 1557, 1558, 1559, 1565, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1570, 1571, + 1572, 1573, 1353, 1576, 1579, 1556, 1557, 1558, 1559, 1565, 1316, 1317, 1324, 1325, 1326, 1327, + 1328, 1329, 1330, 1331, 1576, 1579, 1556, 1557, 1558, 1559, 1565, 1316, 1317, 1324, 1325, 1326, + 1327, 1328, 1329, 1330, 1331, 1576, 1579, 1541, 1542, 1285, 1286, 1298, 1299, 1304, 1305, 1556, + 1557, 1558, 1559, 1565, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1566, 1567, + 1568, 1569, 1576, 1579, 1287, 1288, 1289, 1290, 1300, 1301, 1302, 1303, 1556, 1557, 1558, 1559, + 1565, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1570, 1571, 1572, 1573, 1353, + 1575, 1577, 1579, 1556, 1557, 1558, 1559, 1565, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, + 1330, 1331, 1575, 1577, 1579, 1261, 1262, 1263, 1264, 1271, 1272, 1273, 1274, 1556, 1557, 1558, + 1559, 1565, 1316, 1317, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1575, 1577, 1579, 1541, + 1542, 1269, 1270, 1285, 1286, 1298, 1299, 1304, 1305, 1556, 1557, 1558, 1559, 1565, 1316, 1317, + 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1566, 1567, 1568, 1569, 1575, 1577, 1579, 1553, + 1554, 1555, 1309, 1564, 1312, 1565, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, + 1346, 1347, 1554, 1555, 1309, 1564, 1312, 1565, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, + 1344, 1345, 1346, 1347, 1555, 1564, 1310, 1313, 1565, 1336, 1337, 1338, 1339, 1340, 1341, 1342, + 1343, 1344, 1345, 1346, 1347, 1555, 1310, 1564, 1313, 1565, 1336, 1337, 1338, 1339, 1340, 1341, + 1342, 1343, 1344, 1345, 1346, 1347, 1553, 1554, 1555, 1309, 1564, 1312, 1565, 1336, 1337, 1338, + 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, 1554, 1555, 1309, 1564, 1312, 1565, 1336, + 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, 1555, 1564, 1310, 1313, 1565, + 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, 1555, 1564, 1310, 1313, + 1565, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, 1344, 1345, 1346, 1347, 1565, 1350, 1351, + 1352, 1565, 1350, 1351, 1352, 1565, 1350, 1351, 1352, 1535, 1536, 1537, 1538, 1539, 1540, 1545, + 1546, 1547, 1548, 1550, 1551, 1552, 1565, 1350, 1351, 1352, 1565, 1350, 1351, 1352, 1565, 1350, + 1351, 1352, 1565, 1350, 1351, 1352, 1535, 1536, 1537, 1538, 1539, 1540, 1545, 1546, 1547, 1548, + 1550, 1551, 1552, 1565, 1350, 1351, 1352, } DECODE_INDEX_A32 := [256]lib.Decode_Index{ @@ -2377,385 +2380,385 @@ DECODE_INDEX_T32 := [128]lib.Decode_Index{ 0x78 = { 3040, 26}, 0x79 = { 3066, 33}, 0x7A = { 3099, 18}, - 0x7B = { 3117, 6}, - 0x7C = { 3123, 20}, - 0x7D = { 3143, 71}, - 0x7E = { 3214, 22}, - 0x7F = { 3236, 126}, + 0x7B = { 3117, 9}, + 0x7C = { 3126, 20}, + 0x7D = { 3146, 71}, + 0x7E = { 3217, 22}, + 0x7F = { 3239, 126}, } DECODE_INDEX_T16 := [64]lib.Decode_Index{ - 0x00 = { 3362, 1}, - 0x01 = { 3363, 1}, - 0x02 = { 3364, 1}, - 0x03 = { 3365, 1}, - 0x04 = { 3366, 1}, - 0x05 = { 3367, 1}, - 0x06 = { 3368, 2}, - 0x07 = { 3370, 2}, - 0x08 = { 3372, 1}, - 0x09 = { 3373, 1}, - 0x0A = { 3374, 1}, - 0x0B = { 3375, 1}, - 0x0C = { 3376, 1}, - 0x0D = { 3377, 1}, - 0x0E = { 3378, 1}, - 0x0F = { 3379, 1}, - 0x10 = { 3380, 16}, - 0x11 = { 3396, 7}, - 0x12 = { 3403, 1}, - 0x13 = { 3404, 1}, - 0x14 = { 3405, 2}, - 0x15 = { 3407, 2}, - 0x16 = { 3409, 2}, - 0x17 = { 3411, 2}, - 0x18 = { 3413, 1}, - 0x19 = { 3414, 1}, - 0x1A = { 3415, 1}, - 0x1B = { 3416, 1}, - 0x1C = { 3417, 1}, - 0x1D = { 3418, 1}, - 0x1E = { 3419, 1}, - 0x1F = { 3420, 1}, - 0x20 = { 3421, 1}, - 0x21 = { 3422, 1}, - 0x22 = { 3423, 1}, - 0x23 = { 3424, 1}, - 0x24 = { 3425, 1}, - 0x25 = { 3426, 1}, - 0x26 = { 3427, 1}, - 0x27 = { 3428, 1}, - 0x28 = { 3429, 1}, - 0x29 = { 3430, 1}, - 0x2A = { 3431, 1}, - 0x2B = { 3432, 1}, - 0x2C = { 3433, 7}, - 0x2D = { 3440, 2}, - 0x2E = { 3442, 4}, - 0x2F = { 3446, 8}, - 0x30 = { 3454, 1}, - 0x31 = { 3455, 1}, - 0x32 = { 3456, 1}, - 0x33 = { 3457, 1}, - 0x34 = { 3458, 1}, - 0x35 = { 3459, 1}, - 0x36 = { 3460, 1}, - 0x37 = { 3461, 3}, - 0x38 = { 3464, 1}, - 0x39 = { 3465, 1}, + 0x00 = { 3365, 1}, + 0x01 = { 3366, 1}, + 0x02 = { 3367, 1}, + 0x03 = { 3368, 1}, + 0x04 = { 3369, 1}, + 0x05 = { 3370, 1}, + 0x06 = { 3371, 2}, + 0x07 = { 3373, 2}, + 0x08 = { 3375, 1}, + 0x09 = { 3376, 1}, + 0x0A = { 3377, 1}, + 0x0B = { 3378, 1}, + 0x0C = { 3379, 1}, + 0x0D = { 3380, 1}, + 0x0E = { 3381, 1}, + 0x0F = { 3382, 1}, + 0x10 = { 3383, 16}, + 0x11 = { 3399, 7}, + 0x12 = { 3406, 1}, + 0x13 = { 3407, 1}, + 0x14 = { 3408, 2}, + 0x15 = { 3410, 2}, + 0x16 = { 3412, 2}, + 0x17 = { 3414, 2}, + 0x18 = { 3416, 1}, + 0x19 = { 3417, 1}, + 0x1A = { 3418, 1}, + 0x1B = { 3419, 1}, + 0x1C = { 3420, 1}, + 0x1D = { 3421, 1}, + 0x1E = { 3422, 1}, + 0x1F = { 3423, 1}, + 0x20 = { 3424, 1}, + 0x21 = { 3425, 1}, + 0x22 = { 3426, 1}, + 0x23 = { 3427, 1}, + 0x24 = { 3428, 1}, + 0x25 = { 3429, 1}, + 0x26 = { 3430, 1}, + 0x27 = { 3431, 1}, + 0x28 = { 3432, 1}, + 0x29 = { 3433, 1}, + 0x2A = { 3434, 1}, + 0x2B = { 3435, 1}, + 0x2C = { 3436, 7}, + 0x2D = { 3443, 2}, + 0x2E = { 3445, 4}, + 0x2F = { 3449, 8}, + 0x30 = { 3457, 1}, + 0x31 = { 3458, 1}, + 0x32 = { 3459, 1}, + 0x33 = { 3460, 1}, + 0x34 = { 3461, 1}, + 0x35 = { 3462, 1}, + 0x36 = { 3463, 1}, + 0x37 = { 3464, 3}, + 0x38 = { 3467, 1}, + 0x39 = { 3468, 1}, } DECODE_INDEX_T32_SUB := [4096]lib.Decode_Index{ - 0xE84 = { 3466, 6}, - 0xE85 = { 3472, 2}, - 0xE86 = { 3474, 1}, - 0xE87 = { 3475, 1}, - 0xE88 = { 3476, 1}, - 0xE89 = { 3477, 1}, - 0xE8A = { 3478, 1}, - 0xE8B = { 3479, 2}, - 0xE8C = { 3481, 4}, - 0xE8D = { 3485, 6}, - 0xE8E = { 3491, 1}, - 0xE8F = { 3492, 1}, - 0xE90 = { 3493, 1}, - 0xE91 = { 3494, 1}, - 0xE92 = { 3495, 2}, - 0xE93 = { 3497, 1}, - 0xE94 = { 3498, 1}, - 0xE95 = { 3499, 1}, - 0xE96 = { 3500, 1}, - 0xE97 = { 3501, 2}, - 0xE9C = { 3503, 1}, - 0xE9D = { 3504, 1}, - 0xE9E = { 3505, 1}, - 0xE9F = { 3506, 1}, - 0xEA0 = { 3507, 2}, - 0xEA1 = { 3509, 3}, - 0xEA2 = { 3512, 1}, - 0xEA3 = { 3513, 1}, - 0xEA4 = { 3514, 7}, - 0xEA5 = { 3521, 7}, - 0xEA6 = { 3528, 1}, - 0xEA7 = { 3529, 1}, - 0xEA8 = { 3530, 1}, - 0xEA9 = { 3531, 2}, - 0xEB1 = { 3533, 1}, - 0xEB4 = { 3534, 1}, - 0xEB5 = { 3535, 1}, - 0xEB6 = { 3536, 1}, - 0xEB7 = { 3537, 1}, - 0xEBB = { 3538, 1}, - 0xEBC = { 3539, 1}, - 0xEBD = { 3540, 1}, - 0xEC0 = { 3541, 2}, - 0xEC1 = { 3543, 1}, - 0xEC2 = { 3544, 3}, - 0xEC3 = { 3547, 2}, - 0xEC4 = { 3549, 2}, - 0xEC5 = { 3551, 1}, - 0xEC6 = { 3552, 7}, - 0xEC7 = { 3559, 2}, - 0xEC8 = { 3561, 1}, - 0xEC9 = { 3562, 1}, - 0xECA = { 3563, 2}, - 0xECB = { 3565, 2}, - 0xECC = { 3567, 1}, - 0xECD = { 3568, 1}, - 0xECE = { 3569, 2}, - 0xECF = { 3571, 2}, - 0xED6 = { 3573, 4}, - 0xED8 = { 3577, 4}, - 0xED9 = { 3581, 4}, - 0xEDC = { 3585, 4}, - 0xEDD = { 3589, 4}, - 0xEE0 = { 3593, 23}, - 0xEE1 = { 3616, 22}, - 0xEE2 = { 3638, 22}, - 0xEE3 = { 3660, 29}, - 0xEE4 = { 3689, 23}, - 0xEE5 = { 3712, 22}, - 0xEE6 = { 3734, 22}, - 0xEE7 = { 3756, 29}, - 0xEE8 = { 3785, 28}, - 0xEE9 = { 3813, 12}, - 0xEEA = { 3825, 13}, - 0xEEB = { 3838, 18}, - 0xEEC = { 3856, 27}, - 0xEED = { 3883, 13}, - 0xEEE = { 3896, 22}, - 0xEEF = { 3918, 21}, - 0xEF0 = { 3939, 15}, - 0xEF1 = { 3954, 15}, - 0xEF2 = { 3969, 15}, - 0xEF3 = { 3984, 15}, - 0xEF4 = { 3999, 15}, - 0xEF5 = { 4014, 15}, - 0xEF6 = { 4029, 15}, - 0xEF7 = { 4044, 15}, - 0xEF8 = { 4059, 3}, - 0xEF9 = { 4062, 3}, - 0xEFA = { 4065, 3}, - 0xEFB = { 4068, 3}, - 0xEFC = { 4071, 3}, - 0xEFD = { 4074, 3}, - 0xEFE = { 4077, 3}, - 0xEFF = { 4080, 3}, - 0xF00 = { 4083, 10}, - 0xF01 = { 4093, 10}, - 0xF02 = { 4103, 7}, - 0xF03 = { 4110, 7}, - 0xF04 = { 4117, 10}, - 0xF05 = { 4127, 8}, - 0xF06 = { 4135, 6}, - 0xF07 = { 4141, 6}, - 0xF08 = { 4147, 4}, - 0xF09 = { 4151, 5}, - 0xF0A = { 4156, 3}, - 0xF0B = { 4159, 3}, - 0xF0C = { 4162, 3}, - 0xF0D = { 4165, 3}, - 0xF0E = { 4168, 3}, - 0xF0F = { 4171, 3}, - 0xF10 = { 4174, 5}, - 0xF11 = { 4179, 6}, - 0xF12 = { 4185, 5}, - 0xF13 = { 4190, 5}, - 0xF14 = { 4195, 6}, - 0xF15 = { 4201, 6}, - 0xF16 = { 4207, 6}, - 0xF17 = { 4213, 6}, - 0xF18 = { 4219, 3}, - 0xF19 = { 4222, 3}, - 0xF1A = { 4225, 3}, - 0xF1B = { 4228, 4}, - 0xF1C = { 4232, 4}, - 0xF1D = { 4236, 4}, - 0xF1E = { 4240, 3}, - 0xF1F = { 4243, 3}, - 0xF20 = { 4246, 3}, - 0xF21 = { 4249, 3}, - 0xF22 = { 4252, 3}, - 0xF23 = { 4255, 3}, - 0xF24 = { 4258, 4}, - 0xF25 = { 4262, 3}, - 0xF26 = { 4265, 3}, - 0xF27 = { 4268, 3}, - 0xF28 = { 4271, 3}, - 0xF29 = { 4274, 3}, - 0xF2A = { 4277, 3}, - 0xF2B = { 4280, 3}, - 0xF2C = { 4283, 4}, - 0xF2D = { 4287, 3}, - 0xF2E = { 4290, 3}, - 0xF2F = { 4293, 3}, - 0xF30 = { 4296, 4}, - 0xF31 = { 4300, 3}, - 0xF32 = { 4303, 5}, - 0xF33 = { 4308, 3}, - 0xF34 = { 4311, 4}, - 0xF35 = { 4315, 3}, - 0xF36 = { 4318, 5}, - 0xF37 = { 4323, 3}, - 0xF38 = { 4326, 5}, - 0xF39 = { 4331, 3}, - 0xF3A = { 4334, 18}, - 0xF3B = { 4352, 8}, - 0xF3C = { 4360, 4}, - 0xF3D = { 4364, 3}, - 0xF3E = { 4367, 4}, - 0xF3F = { 4371, 3}, - 0xF40 = { 4374, 5}, - 0xF41 = { 4379, 6}, - 0xF42 = { 4385, 4}, - 0xF43 = { 4389, 4}, - 0xF44 = { 4393, 6}, - 0xF45 = { 4399, 6}, - 0xF46 = { 4405, 4}, - 0xF47 = { 4409, 4}, - 0xF48 = { 4413, 4}, - 0xF49 = { 4417, 5}, - 0xF4A = { 4422, 3}, - 0xF4B = { 4425, 3}, - 0xF4C = { 4428, 3}, - 0xF4D = { 4431, 3}, - 0xF4E = { 4434, 3}, - 0xF4F = { 4437, 3}, - 0xF50 = { 4440, 3}, - 0xF51 = { 4443, 4}, - 0xF52 = { 4447, 3}, - 0xF53 = { 4450, 3}, - 0xF54 = { 4453, 4}, - 0xF55 = { 4457, 4}, - 0xF56 = { 4461, 4}, - 0xF57 = { 4465, 4}, - 0xF58 = { 4469, 3}, - 0xF59 = { 4472, 3}, - 0xF5A = { 4475, 3}, - 0xF5B = { 4478, 4}, - 0xF5C = { 4482, 4}, - 0xF5D = { 4486, 4}, - 0xF5E = { 4490, 3}, - 0xF5F = { 4493, 3}, - 0xF60 = { 4496, 3}, - 0xF61 = { 4499, 3}, - 0xF62 = { 4502, 3}, - 0xF63 = { 4505, 3}, - 0xF64 = { 4508, 4}, - 0xF65 = { 4512, 3}, - 0xF66 = { 4515, 3}, - 0xF67 = { 4518, 3}, - 0xF68 = { 4521, 3}, - 0xF69 = { 4524, 3}, - 0xF6A = { 4527, 3}, - 0xF6B = { 4530, 3}, - 0xF6C = { 4533, 4}, - 0xF6D = { 4537, 3}, - 0xF6E = { 4540, 3}, - 0xF6F = { 4543, 3}, - 0xF70 = { 4546, 3}, - 0xF71 = { 4549, 3}, - 0xF72 = { 4552, 3}, - 0xF73 = { 4555, 3}, - 0xF74 = { 4558, 3}, - 0xF75 = { 4561, 3}, - 0xF76 = { 4564, 3}, - 0xF77 = { 4567, 3}, - 0xF78 = { 4570, 3}, - 0xF79 = { 4573, 3}, - 0xF7A = { 4576, 3}, - 0xF7B = { 4579, 3}, - 0xF7C = { 4582, 3}, - 0xF7D = { 4585, 3}, - 0xF7E = { 4588, 3}, - 0xF7F = { 4591, 4}, - 0xF80 = { 4595, 1}, - 0xF81 = { 4596, 1}, - 0xF82 = { 4597, 1}, - 0xF83 = { 4598, 2}, - 0xF84 = { 4600, 1}, - 0xF85 = { 4601, 2}, - 0xF88 = { 4603, 1}, - 0xF89 = { 4604, 2}, - 0xF8A = { 4606, 1}, - 0xF8B = { 4607, 1}, - 0xF8C = { 4608, 1}, - 0xF8D = { 4609, 2}, - 0xF91 = { 4611, 1}, - 0xF93 = { 4612, 1}, - 0xF99 = { 4613, 2}, - 0xF9B = { 4615, 1}, - 0xFA0 = { 4616, 3}, - 0xFA1 = { 4619, 3}, - 0xFA2 = { 4622, 3}, - 0xFA3 = { 4625, 3}, - 0xFA4 = { 4628, 3}, - 0xFA5 = { 4631, 3}, - 0xFA6 = { 4634, 1}, - 0xFA7 = { 4635, 1}, - 0xFA8 = { 4636, 10}, - 0xFA9 = { 4646, 10}, - 0xFAA = { 4656, 6}, - 0xFAB = { 4662, 1}, - 0xFAC = { 4663, 6}, - 0xFAD = { 4669, 6}, - 0xFAE = { 4675, 6}, - 0xFB0 = { 4681, 3}, - 0xFB5 = { 4684, 1}, - 0xFB8 = { 4685, 1}, - 0xFB9 = { 4686, 1}, - 0xFBA = { 4687, 1}, - 0xFBB = { 4688, 1}, - 0xFBC = { 4689, 1}, - 0xFBE = { 4690, 1}, - 0xFC0 = { 4691, 1}, - 0xFC1 = { 4692, 1}, - 0xFC2 = { 4693, 2}, - 0xFC3 = { 4695, 2}, - 0xFC4 = { 4697, 1}, - 0xFC5 = { 4698, 1}, - 0xFC6 = { 4699, 2}, - 0xFC7 = { 4701, 2}, - 0xFC8 = { 4703, 7}, - 0xFC9 = { 4710, 11}, - 0xFCA = { 4721, 2}, - 0xFCB = { 4723, 2}, - 0xFCC = { 4725, 7}, - 0xFCD = { 4732, 7}, - 0xFCE = { 4739, 2}, - 0xFCF = { 4741, 2}, - 0xFD9 = { 4743, 4}, - 0xFE0 = { 4747, 28}, - 0xFE1 = { 4775, 26}, - 0xFE2 = { 4801, 26}, - 0xFE3 = { 4827, 32}, - 0xFE4 = { 4859, 29}, - 0xFE5 = { 4888, 27}, - 0xFE6 = { 4915, 27}, - 0xFE7 = { 4942, 33}, - 0xFE8 = { 4975, 32}, - 0xFE9 = { 5007, 17}, - 0xFEA = { 5024, 17}, - 0xFEB = { 5041, 29}, - 0xFEC = { 5070, 31}, - 0xFED = { 5101, 18}, - 0xFEE = { 5119, 26}, - 0xFEF = { 5145, 32}, - 0xFF0 = { 5177, 19}, - 0xFF1 = { 5196, 18}, - 0xFF2 = { 5214, 17}, - 0xFF3 = { 5231, 17}, - 0xFF4 = { 5248, 19}, - 0xFF5 = { 5267, 18}, - 0xFF6 = { 5285, 17}, - 0xFF7 = { 5302, 17}, - 0xFF8 = { 5319, 4}, - 0xFF9 = { 5323, 4}, - 0xFFA = { 5327, 4}, - 0xFFB = { 5331, 17}, - 0xFFC = { 5348, 4}, - 0xFFD = { 5352, 4}, - 0xFFE = { 5356, 4}, - 0xFFF = { 5360, 17}, + 0xE84 = { 3469, 6}, + 0xE85 = { 3475, 2}, + 0xE86 = { 3477, 1}, + 0xE87 = { 3478, 1}, + 0xE88 = { 3479, 1}, + 0xE89 = { 3480, 1}, + 0xE8A = { 3481, 1}, + 0xE8B = { 3482, 2}, + 0xE8C = { 3484, 4}, + 0xE8D = { 3488, 6}, + 0xE8E = { 3494, 1}, + 0xE8F = { 3495, 1}, + 0xE90 = { 3496, 1}, + 0xE91 = { 3497, 1}, + 0xE92 = { 3498, 2}, + 0xE93 = { 3500, 1}, + 0xE94 = { 3501, 1}, + 0xE95 = { 3502, 1}, + 0xE96 = { 3503, 1}, + 0xE97 = { 3504, 2}, + 0xE9C = { 3506, 1}, + 0xE9D = { 3507, 1}, + 0xE9E = { 3508, 1}, + 0xE9F = { 3509, 1}, + 0xEA0 = { 3510, 2}, + 0xEA1 = { 3512, 3}, + 0xEA2 = { 3515, 1}, + 0xEA3 = { 3516, 1}, + 0xEA4 = { 3517, 7}, + 0xEA5 = { 3524, 7}, + 0xEA6 = { 3531, 1}, + 0xEA7 = { 3532, 1}, + 0xEA8 = { 3533, 1}, + 0xEA9 = { 3534, 2}, + 0xEB1 = { 3536, 1}, + 0xEB4 = { 3537, 1}, + 0xEB5 = { 3538, 1}, + 0xEB6 = { 3539, 1}, + 0xEB7 = { 3540, 1}, + 0xEBB = { 3541, 1}, + 0xEBC = { 3542, 1}, + 0xEBD = { 3543, 1}, + 0xEC0 = { 3544, 2}, + 0xEC1 = { 3546, 1}, + 0xEC2 = { 3547, 3}, + 0xEC3 = { 3550, 2}, + 0xEC4 = { 3552, 2}, + 0xEC5 = { 3554, 1}, + 0xEC6 = { 3555, 7}, + 0xEC7 = { 3562, 2}, + 0xEC8 = { 3564, 1}, + 0xEC9 = { 3565, 1}, + 0xECA = { 3566, 2}, + 0xECB = { 3568, 2}, + 0xECC = { 3570, 1}, + 0xECD = { 3571, 1}, + 0xECE = { 3572, 2}, + 0xECF = { 3574, 2}, + 0xED6 = { 3576, 4}, + 0xED8 = { 3580, 4}, + 0xED9 = { 3584, 4}, + 0xEDC = { 3588, 4}, + 0xEDD = { 3592, 4}, + 0xEE0 = { 3596, 23}, + 0xEE1 = { 3619, 22}, + 0xEE2 = { 3641, 22}, + 0xEE3 = { 3663, 29}, + 0xEE4 = { 3692, 23}, + 0xEE5 = { 3715, 22}, + 0xEE6 = { 3737, 22}, + 0xEE7 = { 3759, 29}, + 0xEE8 = { 3788, 28}, + 0xEE9 = { 3816, 12}, + 0xEEA = { 3828, 13}, + 0xEEB = { 3841, 18}, + 0xEEC = { 3859, 27}, + 0xEED = { 3886, 13}, + 0xEEE = { 3899, 22}, + 0xEEF = { 3921, 21}, + 0xEF0 = { 3942, 15}, + 0xEF1 = { 3957, 15}, + 0xEF2 = { 3972, 15}, + 0xEF3 = { 3987, 15}, + 0xEF4 = { 4002, 15}, + 0xEF5 = { 4017, 15}, + 0xEF6 = { 4032, 15}, + 0xEF7 = { 4047, 15}, + 0xEF8 = { 4062, 3}, + 0xEF9 = { 4065, 3}, + 0xEFA = { 4068, 3}, + 0xEFB = { 4071, 3}, + 0xEFC = { 4074, 3}, + 0xEFD = { 4077, 3}, + 0xEFE = { 4080, 3}, + 0xEFF = { 4083, 3}, + 0xF00 = { 4086, 10}, + 0xF01 = { 4096, 10}, + 0xF02 = { 4106, 7}, + 0xF03 = { 4113, 7}, + 0xF04 = { 4120, 10}, + 0xF05 = { 4130, 8}, + 0xF06 = { 4138, 6}, + 0xF07 = { 4144, 6}, + 0xF08 = { 4150, 4}, + 0xF09 = { 4154, 5}, + 0xF0A = { 4159, 3}, + 0xF0B = { 4162, 3}, + 0xF0C = { 4165, 3}, + 0xF0D = { 4168, 3}, + 0xF0E = { 4171, 3}, + 0xF0F = { 4174, 3}, + 0xF10 = { 4177, 5}, + 0xF11 = { 4182, 6}, + 0xF12 = { 4188, 5}, + 0xF13 = { 4193, 5}, + 0xF14 = { 4198, 6}, + 0xF15 = { 4204, 6}, + 0xF16 = { 4210, 6}, + 0xF17 = { 4216, 6}, + 0xF18 = { 4222, 3}, + 0xF19 = { 4225, 3}, + 0xF1A = { 4228, 3}, + 0xF1B = { 4231, 4}, + 0xF1C = { 4235, 4}, + 0xF1D = { 4239, 4}, + 0xF1E = { 4243, 3}, + 0xF1F = { 4246, 3}, + 0xF20 = { 4249, 3}, + 0xF21 = { 4252, 3}, + 0xF22 = { 4255, 3}, + 0xF23 = { 4258, 3}, + 0xF24 = { 4261, 4}, + 0xF25 = { 4265, 3}, + 0xF26 = { 4268, 3}, + 0xF27 = { 4271, 3}, + 0xF28 = { 4274, 3}, + 0xF29 = { 4277, 3}, + 0xF2A = { 4280, 3}, + 0xF2B = { 4283, 3}, + 0xF2C = { 4286, 4}, + 0xF2D = { 4290, 3}, + 0xF2E = { 4293, 3}, + 0xF2F = { 4296, 3}, + 0xF30 = { 4299, 4}, + 0xF31 = { 4303, 3}, + 0xF32 = { 4306, 5}, + 0xF33 = { 4311, 3}, + 0xF34 = { 4314, 4}, + 0xF35 = { 4318, 3}, + 0xF36 = { 4321, 5}, + 0xF37 = { 4326, 3}, + 0xF38 = { 4329, 5}, + 0xF39 = { 4334, 3}, + 0xF3A = { 4337, 18}, + 0xF3B = { 4355, 8}, + 0xF3C = { 4363, 4}, + 0xF3D = { 4367, 3}, + 0xF3E = { 4370, 4}, + 0xF3F = { 4374, 3}, + 0xF40 = { 4377, 5}, + 0xF41 = { 4382, 6}, + 0xF42 = { 4388, 4}, + 0xF43 = { 4392, 4}, + 0xF44 = { 4396, 6}, + 0xF45 = { 4402, 6}, + 0xF46 = { 4408, 4}, + 0xF47 = { 4412, 4}, + 0xF48 = { 4416, 4}, + 0xF49 = { 4420, 5}, + 0xF4A = { 4425, 3}, + 0xF4B = { 4428, 3}, + 0xF4C = { 4431, 3}, + 0xF4D = { 4434, 3}, + 0xF4E = { 4437, 3}, + 0xF4F = { 4440, 3}, + 0xF50 = { 4443, 3}, + 0xF51 = { 4446, 4}, + 0xF52 = { 4450, 3}, + 0xF53 = { 4453, 3}, + 0xF54 = { 4456, 4}, + 0xF55 = { 4460, 4}, + 0xF56 = { 4464, 4}, + 0xF57 = { 4468, 4}, + 0xF58 = { 4472, 3}, + 0xF59 = { 4475, 3}, + 0xF5A = { 4478, 3}, + 0xF5B = { 4481, 4}, + 0xF5C = { 4485, 4}, + 0xF5D = { 4489, 4}, + 0xF5E = { 4493, 3}, + 0xF5F = { 4496, 3}, + 0xF60 = { 4499, 3}, + 0xF61 = { 4502, 3}, + 0xF62 = { 4505, 3}, + 0xF63 = { 4508, 3}, + 0xF64 = { 4511, 4}, + 0xF65 = { 4515, 3}, + 0xF66 = { 4518, 3}, + 0xF67 = { 4521, 3}, + 0xF68 = { 4524, 3}, + 0xF69 = { 4527, 3}, + 0xF6A = { 4530, 3}, + 0xF6B = { 4533, 3}, + 0xF6C = { 4536, 4}, + 0xF6D = { 4540, 3}, + 0xF6E = { 4543, 3}, + 0xF6F = { 4546, 3}, + 0xF70 = { 4549, 3}, + 0xF71 = { 4552, 3}, + 0xF72 = { 4555, 3}, + 0xF73 = { 4558, 3}, + 0xF74 = { 4561, 3}, + 0xF75 = { 4564, 3}, + 0xF76 = { 4567, 3}, + 0xF77 = { 4570, 3}, + 0xF78 = { 4573, 6}, + 0xF79 = { 4579, 3}, + 0xF7A = { 4582, 3}, + 0xF7B = { 4585, 3}, + 0xF7C = { 4588, 3}, + 0xF7D = { 4591, 3}, + 0xF7E = { 4594, 3}, + 0xF7F = { 4597, 4}, + 0xF80 = { 4601, 1}, + 0xF81 = { 4602, 1}, + 0xF82 = { 4603, 1}, + 0xF83 = { 4604, 2}, + 0xF84 = { 4606, 1}, + 0xF85 = { 4607, 2}, + 0xF88 = { 4609, 1}, + 0xF89 = { 4610, 2}, + 0xF8A = { 4612, 1}, + 0xF8B = { 4613, 1}, + 0xF8C = { 4614, 1}, + 0xF8D = { 4615, 2}, + 0xF91 = { 4617, 1}, + 0xF93 = { 4618, 1}, + 0xF99 = { 4619, 2}, + 0xF9B = { 4621, 1}, + 0xFA0 = { 4622, 3}, + 0xFA1 = { 4625, 3}, + 0xFA2 = { 4628, 3}, + 0xFA3 = { 4631, 3}, + 0xFA4 = { 4634, 3}, + 0xFA5 = { 4637, 3}, + 0xFA6 = { 4640, 1}, + 0xFA7 = { 4641, 1}, + 0xFA8 = { 4642, 10}, + 0xFA9 = { 4652, 10}, + 0xFAA = { 4662, 6}, + 0xFAB = { 4668, 1}, + 0xFAC = { 4669, 6}, + 0xFAD = { 4675, 6}, + 0xFAE = { 4681, 6}, + 0xFB0 = { 4687, 3}, + 0xFB5 = { 4690, 1}, + 0xFB8 = { 4691, 1}, + 0xFB9 = { 4692, 1}, + 0xFBA = { 4693, 1}, + 0xFBB = { 4694, 1}, + 0xFBC = { 4695, 1}, + 0xFBE = { 4696, 1}, + 0xFC0 = { 4697, 1}, + 0xFC1 = { 4698, 1}, + 0xFC2 = { 4699, 2}, + 0xFC3 = { 4701, 2}, + 0xFC4 = { 4703, 1}, + 0xFC5 = { 4704, 1}, + 0xFC6 = { 4705, 2}, + 0xFC7 = { 4707, 2}, + 0xFC8 = { 4709, 7}, + 0xFC9 = { 4716, 11}, + 0xFCA = { 4727, 2}, + 0xFCB = { 4729, 2}, + 0xFCC = { 4731, 7}, + 0xFCD = { 4738, 7}, + 0xFCE = { 4745, 2}, + 0xFCF = { 4747, 2}, + 0xFD9 = { 4749, 4}, + 0xFE0 = { 4753, 28}, + 0xFE1 = { 4781, 26}, + 0xFE2 = { 4807, 26}, + 0xFE3 = { 4833, 32}, + 0xFE4 = { 4865, 29}, + 0xFE5 = { 4894, 27}, + 0xFE6 = { 4921, 27}, + 0xFE7 = { 4948, 33}, + 0xFE8 = { 4981, 32}, + 0xFE9 = { 5013, 17}, + 0xFEA = { 5030, 17}, + 0xFEB = { 5047, 29}, + 0xFEC = { 5076, 31}, + 0xFED = { 5107, 18}, + 0xFEE = { 5125, 26}, + 0xFEF = { 5151, 32}, + 0xFF0 = { 5183, 19}, + 0xFF1 = { 5202, 18}, + 0xFF2 = { 5220, 17}, + 0xFF3 = { 5237, 17}, + 0xFF4 = { 5254, 19}, + 0xFF5 = { 5273, 18}, + 0xFF6 = { 5291, 17}, + 0xFF7 = { 5308, 17}, + 0xFF8 = { 5325, 4}, + 0xFF9 = { 5329, 4}, + 0xFFA = { 5333, 4}, + 0xFFB = { 5337, 17}, + 0xFFC = { 5354, 4}, + 0xFFD = { 5358, 4}, + 0xFFE = { 5362, 4}, + 0xFFF = { 5366, 17}, } diff --git a/core/rexcode/arm32/tablegen/generated/encode_tables.odin b/core/rexcode/arm32/tablegen/generated/encode_tables.odin index 3baf32998..9c0e5af20 100644 --- a/core/rexcode/arm32/tablegen/generated/encode_tables.odin +++ b/core/rexcode/arm32/tablegen/generated/encode_tables.odin @@ -8,7 +8,7 @@ package rexcode_arm32_generated import lib "../.." @(rodata) -ENCODE_FORMS := [1657]lib.Encoding{ +ENCODE_FORMS := [1660]lib.Encoding{ // .AND { .AND, {.GPR,.GPR,.IMM_MOD,.NONE}, {.RD,.RN_A32,.A32_IMM_MOD,.NONE}, 0x02000000, 0x0FE00000, .BASE, .A32, {} }, { .AND, {.GPR,.GPR,.GPR_SHIFTED,.NONE}, {.RD,.RN_A32,.RM_A32,.NONE}, 0x00000000, 0x0FE00010, .BASE, .A32, {} }, @@ -604,6 +604,12 @@ ENCODE_FORMS := [1657]lib.Encoding{ { .PLI, {.MEM,.NONE,.NONE,.NONE}, {.MEM_IMM12_OFFSET,.NONE,.NONE,.NONE}, 0xF990F000, 0xFFF0F000, .V7, .T32, {thumb32=true} }, // .HLT { .HLT, {.IMM,.NONE,.NONE,.NONE}, {.NONE,.NONE,.NONE,.NONE}, 0xE1000070, 0xFFF000F0, .V8, .A32, {} }, + // .DCPS1 + { .DCPS1, {.NONE,.NONE,.NONE,.NONE}, {.NONE,.NONE,.NONE,.NONE}, 0xF78F8001, 0xFFFFFFFF, .V8, .T32, {thumb32=true} }, + // .DCPS2 + { .DCPS2, {.NONE,.NONE,.NONE,.NONE}, {.NONE,.NONE,.NONE,.NONE}, 0xF78F8002, 0xFFFFFFFF, .V8, .T32, {thumb32=true} }, + // .DCPS3 + { .DCPS3, {.NONE,.NONE,.NONE,.NONE}, {.NONE,.NONE,.NONE,.NONE}, 0xF78F8003, 0xFFFFFFFF, .V8, .T32, {thumb32=true} }, // .ERET { .ERET, {.NONE,.NONE,.NONE,.NONE}, {.NONE,.NONE,.NONE,.NONE}, 0x0160006E, 0x0FFFFFFF, .V7VE, .A32, {writes_pc=true} }, // .ESB @@ -2454,471 +2460,471 @@ ENCODE_RUNS := [lib.Mnemonic]lib.Encode_Run{ .PLDW = { 422, 2}, .PLI = { 424, 2}, .HLT = { 426, 1}, - .DCPS1 = { 427, 0}, - .DCPS2 = { 427, 0}, - .DCPS3 = { 427, 0}, - .ERET = { 427, 1}, - .ESB = { 428, 2}, - .PSB_CSYNC = { 430, 2}, - .TSB_CSYNC = { 432, 2}, - .CSDB = { 434, 2}, - .SB = { 436, 2}, - .SETPAN = { 438, 2}, - .SVC = { 440, 2}, - .BKPT = { 442, 2}, - .HVC = { 444, 1}, - .SMC = { 445, 1}, - .UDF = { 446, 3}, - .LDR = { 449, 11}, - .STR = { 460, 9}, - .LDRB = { 469, 8}, - .STRB = { 477, 8}, - .LDRH = { 485, 8}, - .STRH = { 493, 8}, - .LDRSB = { 501, 7}, - .LDRSH = { 508, 7}, - .LDRD = { 515, 5}, - .STRD = { 520, 5}, - .LDRT = { 525, 1}, - .STRT = { 526, 1}, - .LDRBT = { 527, 1}, - .STRBT = { 528, 1}, - .LDRHT = { 529, 1}, - .STRHT = { 530, 1}, - .LDRSBT = { 531, 1}, - .LDRSHT = { 532, 1}, - .LDA = { 533, 1}, - .STL = { 534, 1}, - .LDAB = { 535, 1}, - .STLB = { 536, 1}, - .LDAH = { 537, 1}, - .STLH = { 538, 1}, - .LDREX = { 539, 2}, - .STREX = { 541, 2}, - .LDREXB = { 543, 2}, - .STREXB = { 545, 2}, - .LDREXH = { 547, 2}, - .STREXH = { 549, 2}, - .LDREXD = { 551, 2}, - .STREXD = { 553, 2}, - .LDAEX = { 555, 1}, - .STLEX = { 556, 1}, - .LDAEXB = { 557, 1}, - .STLEXB = { 558, 1}, - .LDAEXH = { 559, 1}, - .STLEXH = { 560, 1}, - .LDAEXD = { 561, 1}, - .STLEXD = { 562, 1}, - .LDM = { 563, 8}, - .STM = { 571, 8}, - .PUSH = { 579, 3}, - .POP = { 582, 3}, - .SWP = { 585, 1}, - .SWPB = { 586, 1}, - .RFE = { 587, 1}, - .SRS = { 588, 1}, - .CDP = { 589, 1}, - .CDP2 = { 590, 1}, - .MCR = { 591, 1}, - .MCR2 = { 592, 1}, - .MRC = { 593, 1}, - .MRC2 = { 594, 1}, - .MCRR = { 595, 1}, - .MCRR2 = { 596, 1}, - .MRRC = { 597, 1}, - .MRRC2 = { 598, 1}, - .LDC = { 599, 1}, - .LDC2 = { 600, 1}, - .STC = { 601, 1}, - .STC2 = { 602, 1}, - .CRC32B = { 603, 1}, - .CRC32H = { 604, 1}, - .CRC32W = { 605, 1}, - .CRC32CB = { 606, 1}, - .CRC32CH = { 607, 1}, - .CRC32CW = { 608, 1}, - .VADD = { 609, 18}, - .VSUB = { 627, 18}, - .VMUL = { 645, 18}, - .VDIV = { 663, 3}, - .VMLA = { 666, 12}, - .VMLS = { 678, 11}, - .VNMUL = { 689, 2}, - .VNMLA = { 691, 2}, - .VNMLS = { 693, 2}, - .VFMA = { 695, 7}, - .VFMS = { 702, 6}, - .VFNMA = { 708, 3}, - .VFNMS = { 711, 3}, - .VABS = { 714, 12}, - .VNEG = { 726, 12}, - .VSQRT = { 738, 3}, - .VCMP = { 741, 8}, - .VCMPE = { 749, 4}, - .VCVT = { 753, 10}, - .VCVTB = { 763, 2}, - .VCVTT = { 765, 2}, - .VCVTA = { 767, 2}, - .VCVTN = { 769, 2}, - .VCVTP = { 771, 2}, - .VCVTM = { 773, 2}, - .VCVTR = { 775, 4}, - .VMOV = { 779, 28}, - .VMRS = { 807, 1}, - .VMSR = { 808, 1}, - .VLDR = { 809, 2}, - .VSTR = { 811, 2}, - .VLDM = { 813, 2}, - .VSTM = { 815, 2}, - .VPUSH = { 817, 2}, - .VPOP = { 819, 2}, - .VSEL = { 821, 2}, - .VMAXNM = { 823, 2}, - .VMINNM = { 825, 2}, - .VRINTA = { 827, 3}, - .VRINTN = { 830, 3}, - .VRINTP = { 833, 3}, - .VRINTM = { 836, 3}, - .VRINTR = { 839, 2}, - .VRINTZ = { 841, 3}, - .VRINTX = { 844, 3}, - .VADDL = { 847, 6}, - .VADDW = { 853, 6}, - .VSUBL = { 859, 6}, - .VSUBW = { 865, 6}, - .VHADD = { 871, 9}, - .VHSUB = { 880, 9}, - .VRHADD = { 889, 3}, - .VQADD = { 892, 11}, - .VQSUB = { 903, 11}, - .VMULL = { 914, 7}, - .VMLAL = { 921, 6}, - .VMLSL = { 927, 6}, - .VQDMULL = { 933, 2}, - .VQDMLAL = { 935, 2}, - .VQDMLSL = { 937, 2}, - .VQDMULH = { 939, 4}, - .VQRDMULH = { 943, 4}, - .VQDMULH_LANE = { 947, 0}, - .VQRDMULH_LANE = { 947, 0}, - .VQRDMLAH = { 947, 4}, - .VQRDMLSH = { 951, 4}, - .VABA = { 955, 8}, - .VABAL = { 963, 6}, - .VABD = { 969, 10}, - .VABDL = { 979, 6}, - .VAND = { 985, 3}, - .VBIC = { 988, 3}, - .VORR = { 991, 3}, - .VORN = { 994, 3}, - .VEOR = { 997, 3}, - .VBSL = { 1000, 2}, - .VBIT = { 1002, 2}, - .VBIF = { 1004, 2}, - .VMVN = { 1006, 13}, - .VMOVN = { 1019, 3}, - .VQMOVN = { 1022, 6}, - .VQMOVUN = { 1028, 3}, - .VMOVL = { 1031, 6}, - .VTST = { 1037, 6}, - .VCEQ = { 1043, 10}, - .VCGE = { 1053, 12}, - .VCGT = { 1065, 12}, - .VCLE = { 1077, 14}, - .VCLT = { 1091, 14}, - .VACGE = { 1105, 2}, - .VACGT = { 1107, 2}, - .VACLE = { 1109, 2}, - .VACLT = { 1111, 2}, - .VMAX = { 1113, 13}, - .VMIN = { 1126, 13}, - .VPMAX = { 1139, 5}, - .VPMIN = { 1144, 5}, - .VPADD = { 1149, 4}, - .VPADDL = { 1153, 6}, - .VPADAL = { 1159, 4}, - .VRECPE = { 1163, 4}, - .VRECPS = { 1167, 2}, - .VRSQRTE = { 1169, 4}, - .VRSQRTS = { 1173, 2}, - .VSHL = { 1175, 9}, - .VSHR = { 1184, 5}, - .VSRA = { 1189, 5}, - .VRSHL = { 1194, 5}, - .VRSHR = { 1199, 5}, - .VRSRA = { 1204, 2}, - .VSLI = { 1206, 2}, - .VSRI = { 1208, 2}, - .VQSHL = { 1210, 7}, - .VQSHRN = { 1217, 2}, - .VQSHRUN = { 1219, 1}, - .VQRSHL = { 1220, 16}, - .VQRSHRN = { 1236, 2}, - .VQRSHRUN = { 1238, 1}, - .VSHRN = { 1239, 1}, - .VRSHRN = { 1240, 1}, - .VSHLL = { 1241, 5}, - .VCLS = { 1246, 6}, - .VCLZ = { 1252, 6}, - .VCNT = { 1258, 2}, - .VPADD_F = { 1260, 2}, - .VRECPE_F = { 1262, 2}, - .VRSQRTE_F = { 1264, 2}, - .VREV16 = { 1266, 2}, - .VREV32 = { 1268, 4}, - .VREV64 = { 1272, 6}, - .VEXT = { 1278, 2}, - .VTBL = { 1280, 4}, - .VTBX = { 1284, 4}, - .VTRN = { 1288, 6}, - .VUZP = { 1294, 5}, - .VZIP = { 1299, 5}, - .VDUP = { 1304, 5}, - .VSWP = { 1309, 2}, - .VMOV_LANE = { 1311, 0}, - .VLD1 = { 1311, 8}, - .VLD2 = { 1319, 3}, - .VLD3 = { 1322, 2}, - .VLD4 = { 1324, 2}, - .VST1 = { 1326, 7}, - .VST2 = { 1333, 3}, - .VST3 = { 1336, 2}, - .VST4 = { 1338, 2}, - .AESE = { 1340, 1}, - .AESD = { 1341, 1}, - .AESMC = { 1342, 1}, - .AESIMC = { 1343, 1}, - .SHA1H = { 1344, 1}, - .SHA1SU0 = { 1345, 1}, - .SHA1SU1 = { 1346, 1}, - .SHA1C = { 1347, 1}, - .SHA1M = { 1348, 1}, - .SHA1P = { 1349, 1}, - .SHA256H = { 1350, 1}, - .SHA256H2 = { 1351, 1}, - .SHA256SU0 = { 1352, 1}, - .SHA256SU1 = { 1353, 1}, - .VRINT = { 1354, 0}, - .VJCVT = { 1354, 1}, - .VSDOT = { 1355, 2}, - .VUDOT = { 1357, 2}, - .VSDOT_LANE = { 1359, 2}, - .VUDOT_LANE = { 1361, 2}, - .VCVT_BF16 = { 1363, 1}, - .VDOT_BF16 = { 1364, 2}, - .VFMA_BF16 = { 1366, 1}, - .VMMLA_BF16 = { 1367, 1}, - .VFMAL = { 1368, 2}, - .VFMSL = { 1370, 2}, - .VCMLA = { 1372, 2}, - .VCADD = { 1374, 2}, - .VCMLA_LANE = { 1376, 2}, - .VSMMLA = { 1378, 1}, - .VUMMLA = { 1379, 1}, - .VUSMMLA = { 1380, 1}, - .VSUDOT = { 1381, 1}, - .VUSDOT = { 1382, 2}, - .VSUDOT_LANE = { 1384, 1}, - .VUSDOT_LANE = { 1385, 2}, - .VMUL_LANE = { 1387, 6}, - .VMLA_LANE = { 1393, 6}, - .VMLS_LANE = { 1399, 6}, - .VMULL_LANE = { 1405, 4}, - .VMLAL_LANE = { 1409, 4}, - .VMLSL_LANE = { 1413, 4}, - .VQDMULL_LANE = { 1417, 2}, - .VQDMLAL_LANE = { 1419, 2}, - .VQDMLSL_LANE = { 1421, 2}, - .VFMA_LANE = { 1423, 2}, - .VFMS_LANE = { 1425, 2}, - .VQRDMLAH_LANE = { 1427, 4}, - .VQRDMLSH_LANE = { 1431, 4}, - .VQABS = { 1435, 1}, - .VQNEG = { 1436, 1}, - .VMOVX = { 1437, 1}, - .VINS = { 1438, 1}, - .VLDRB_GATHER = { 1439, 1}, - .VLDRH_GATHER = { 1440, 1}, - .VLDRW_GATHER = { 1441, 1}, - .VLDRD_GATHER = { 1442, 1}, - .VSTRB_SCATTER = { 1443, 1}, - .VSTRH_SCATTER = { 1444, 1}, - .VSTRW_SCATTER = { 1445, 1}, - .VSTRD_SCATTER = { 1446, 1}, - .VCEQ_Z = { 1447, 4}, - .VCGE_Z = { 1451, 4}, - .VCGT_Z = { 1455, 4}, - .VCLE_Z = { 1459, 4}, - .VCLT_Z = { 1463, 4}, - .VLD2R = { 1467, 1}, - .VLD3R = { 1468, 1}, - .VLD4R = { 1469, 1}, - .VLD1_LANE = { 1470, 3}, - .VLD2_LANE = { 1473, 3}, - .VLD3_LANE = { 1476, 3}, - .VLD4_LANE = { 1479, 3}, - .VST1_LANE = { 1482, 3}, - .VST2_LANE = { 1485, 3}, - .VST3_LANE = { 1488, 3}, - .VST4_LANE = { 1491, 3}, - .VCVT_FIXED = { 1494, 10}, - .IT = { 1504, 1}, - .TT = { 1505, 1}, - .TTT = { 1506, 1}, - .TTA = { 1507, 1}, - .TTAT = { 1508, 1}, - .SG = { 1509, 1}, - .BXNS = { 1510, 1}, - .BLXNS = { 1511, 1}, - .PAC = { 1512, 1}, - .PACBTI = { 1513, 1}, - .AUT = { 1514, 1}, - .AUTG = { 1515, 1}, - .BTI = { 1516, 1}, - .WLS = { 1517, 1}, - .WLSTP = { 1518, 1}, - .DLS = { 1519, 1}, - .DLSTP = { 1520, 1}, - .LE = { 1521, 1}, - .LETP = { 1522, 1}, - .LCTP = { 1523, 1}, - .BF = { 1524, 0}, - .BFI_BR = { 1524, 0}, - .BFL = { 1524, 0}, - .BFLX = { 1524, 0}, - .BFCSEL = { 1524, 0}, - .CX1 = { 1524, 1}, - .CX1A = { 1525, 1}, - .CX1D = { 1526, 1}, - .CX1DA = { 1527, 1}, - .CX2 = { 1528, 1}, - .CX2A = { 1529, 1}, - .CX2D = { 1530, 1}, - .CX2DA = { 1531, 1}, - .CX3 = { 1532, 1}, - .CX3A = { 1533, 1}, - .CX3D = { 1534, 1}, - .CX3DA = { 1535, 1}, - .VCX1 = { 1536, 2}, - .VCX1A = { 1538, 2}, - .VCX2 = { 1540, 2}, - .VCX2A = { 1542, 2}, - .VCX3 = { 1544, 2}, - .VCX3A = { 1546, 2}, - .VPT = { 1548, 1}, - .VPST = { 1549, 1}, - .VPSEL = { 1550, 1}, - .VPNOT = { 1551, 1}, - .VCTP = { 1552, 1}, - .VADDV = { 1553, 1}, - .VADDVA = { 1554, 1}, - .VADDLV = { 1555, 1}, - .VADDLVA = { 1556, 1}, - .VMAXV = { 1557, 1}, - .VMAXAV = { 1558, 1}, - .VMINV = { 1559, 1}, - .VMINAV = { 1560, 1}, - .VMAXNMV = { 1561, 1}, - .VMAXNMAV = { 1562, 1}, - .VMINNMV = { 1563, 1}, - .VMINNMAV = { 1564, 1}, - .VABAV = { 1565, 1}, - .VMLADAV = { 1566, 1}, - .VMLADAVA = { 1567, 1}, - .VMLADAVX = { 1568, 1}, - .VMLADAVAX = { 1569, 1}, - .VMLALDAV = { 1570, 1}, - .VMLALDAVA = { 1571, 1}, - .VMLALDAVX = { 1572, 1}, - .VMLALDAVAX = { 1573, 1}, - .VMLSDAV = { 1574, 1}, - .VMLSDAVA = { 1575, 1}, - .VMLSDAVX = { 1576, 1}, - .VMLSDAVAX = { 1577, 1}, - .VMLSLDAV = { 1578, 1}, - .VMLSLDAVA = { 1579, 1}, - .VMLSLDAVX = { 1580, 1}, - .VMLSLDAVAX = { 1581, 1}, - .VRMLALDAVH = { 1582, 1}, - .VRMLALDAVHA = { 1583, 1}, - .VRMLALDAVHX = { 1584, 1}, - .VRMLALDAVHAX = { 1585, 1}, - .VRMLSLDAVH = { 1586, 1}, - .VRMLSLDAVHA = { 1587, 1}, - .VRMLSLDAVHX = { 1588, 1}, - .VRMLSLDAVHAX = { 1589, 1}, - .VMLAV = { 1590, 1}, - .VMLAVA = { 1591, 1}, - .VMLSV = { 1592, 0}, - .VMLSVA = { 1592, 0}, - .VCMUL = { 1592, 1}, - .VHCADD = { 1593, 1}, - .VBRSR = { 1594, 1}, - .VSHLC = { 1595, 1}, - .VRSHL_MVE = { 1596, 0}, - .VDDUP = { 1596, 1}, - .VIDUP = { 1597, 1}, - .VDWDUP = { 1598, 1}, - .VIWDUP = { 1599, 1}, - .VMOVNB = { 1600, 1}, - .VMOVNT = { 1601, 1}, - .VQMOVNB = { 1602, 1}, - .VQMOVNT = { 1603, 1}, - .VQMOVUNB = { 1604, 1}, - .VQMOVUNT = { 1605, 1}, - .VSHLLB = { 1606, 1}, - .VSHLLT = { 1607, 1}, - .VMULLB = { 1608, 1}, - .VMULLT = { 1609, 1}, - .VMLALB = { 1610, 1}, - .VMLALT = { 1611, 1}, - .VMLSLB = { 1612, 1}, - .VMLSLT = { 1613, 1}, - .VSHRNB = { 1614, 1}, - .VSHRNT = { 1615, 1}, - .VRSHRNB = { 1616, 1}, - .VRSHRNT = { 1617, 1}, - .VQSHRNB = { 1618, 1}, - .VQSHRNT = { 1619, 1}, - .VQRSHRNB = { 1620, 1}, - .VQRSHRNT = { 1621, 1}, - .VQSHRUNB = { 1622, 1}, - .VQSHRUNT = { 1623, 1}, - .VQRSHRUNB = { 1624, 1}, - .VQRSHRUNT = { 1625, 1}, - .VMOV_Q_R = { 1626, 1}, - .VMOV_R_Q = { 1627, 1}, - .VMOV_2GPR_Q = { 1628, 1}, - .VQDMLADH = { 1629, 1}, - .VQDMLADHX = { 1630, 1}, - .VQDMLSDH = { 1631, 1}, - .VQDMLSDHX = { 1632, 1}, - .VQRDMLADH = { 1633, 1}, - .VQRDMLADHX = { 1634, 1}, - .VQRDMLSDH = { 1635, 1}, - .VQRDMLSDHX = { 1636, 1}, - .VPRINT = { 1637, 0}, - .VHCADD_SAT = { 1637, 0}, - .VCMLA_MVE = { 1637, 0}, - .VLDRB = { 1637, 1}, - .VLDRH = { 1638, 1}, - .VLDRW = { 1639, 1}, - .VLDRD = { 1640, 1}, - .VSTRB = { 1641, 1}, - .VSTRH = { 1642, 1}, - .VSTRW = { 1643, 1}, - .VSTRD = { 1644, 1}, - .VLD20 = { 1645, 1}, - .VLD21 = { 1646, 1}, - .VLD40 = { 1647, 1}, - .VLD41 = { 1648, 1}, - .VLD42 = { 1649, 1}, - .VLD43 = { 1650, 1}, - .VST20 = { 1651, 1}, - .VST21 = { 1652, 1}, - .VST40 = { 1653, 1}, - .VST41 = { 1654, 1}, - .VST42 = { 1655, 1}, - .VST43 = { 1656, 1}, - ._COUNT = { 1657, 0}, + .DCPS1 = { 427, 1}, + .DCPS2 = { 428, 1}, + .DCPS3 = { 429, 1}, + .ERET = { 430, 1}, + .ESB = { 431, 2}, + .PSB_CSYNC = { 433, 2}, + .TSB_CSYNC = { 435, 2}, + .CSDB = { 437, 2}, + .SB = { 439, 2}, + .SETPAN = { 441, 2}, + .SVC = { 443, 2}, + .BKPT = { 445, 2}, + .HVC = { 447, 1}, + .SMC = { 448, 1}, + .UDF = { 449, 3}, + .LDR = { 452, 11}, + .STR = { 463, 9}, + .LDRB = { 472, 8}, + .STRB = { 480, 8}, + .LDRH = { 488, 8}, + .STRH = { 496, 8}, + .LDRSB = { 504, 7}, + .LDRSH = { 511, 7}, + .LDRD = { 518, 5}, + .STRD = { 523, 5}, + .LDRT = { 528, 1}, + .STRT = { 529, 1}, + .LDRBT = { 530, 1}, + .STRBT = { 531, 1}, + .LDRHT = { 532, 1}, + .STRHT = { 533, 1}, + .LDRSBT = { 534, 1}, + .LDRSHT = { 535, 1}, + .LDA = { 536, 1}, + .STL = { 537, 1}, + .LDAB = { 538, 1}, + .STLB = { 539, 1}, + .LDAH = { 540, 1}, + .STLH = { 541, 1}, + .LDREX = { 542, 2}, + .STREX = { 544, 2}, + .LDREXB = { 546, 2}, + .STREXB = { 548, 2}, + .LDREXH = { 550, 2}, + .STREXH = { 552, 2}, + .LDREXD = { 554, 2}, + .STREXD = { 556, 2}, + .LDAEX = { 558, 1}, + .STLEX = { 559, 1}, + .LDAEXB = { 560, 1}, + .STLEXB = { 561, 1}, + .LDAEXH = { 562, 1}, + .STLEXH = { 563, 1}, + .LDAEXD = { 564, 1}, + .STLEXD = { 565, 1}, + .LDM = { 566, 8}, + .STM = { 574, 8}, + .PUSH = { 582, 3}, + .POP = { 585, 3}, + .SWP = { 588, 1}, + .SWPB = { 589, 1}, + .RFE = { 590, 1}, + .SRS = { 591, 1}, + .CDP = { 592, 1}, + .CDP2 = { 593, 1}, + .MCR = { 594, 1}, + .MCR2 = { 595, 1}, + .MRC = { 596, 1}, + .MRC2 = { 597, 1}, + .MCRR = { 598, 1}, + .MCRR2 = { 599, 1}, + .MRRC = { 600, 1}, + .MRRC2 = { 601, 1}, + .LDC = { 602, 1}, + .LDC2 = { 603, 1}, + .STC = { 604, 1}, + .STC2 = { 605, 1}, + .CRC32B = { 606, 1}, + .CRC32H = { 607, 1}, + .CRC32W = { 608, 1}, + .CRC32CB = { 609, 1}, + .CRC32CH = { 610, 1}, + .CRC32CW = { 611, 1}, + .VADD = { 612, 18}, + .VSUB = { 630, 18}, + .VMUL = { 648, 18}, + .VDIV = { 666, 3}, + .VMLA = { 669, 12}, + .VMLS = { 681, 11}, + .VNMUL = { 692, 2}, + .VNMLA = { 694, 2}, + .VNMLS = { 696, 2}, + .VFMA = { 698, 7}, + .VFMS = { 705, 6}, + .VFNMA = { 711, 3}, + .VFNMS = { 714, 3}, + .VABS = { 717, 12}, + .VNEG = { 729, 12}, + .VSQRT = { 741, 3}, + .VCMP = { 744, 8}, + .VCMPE = { 752, 4}, + .VCVT = { 756, 10}, + .VCVTB = { 766, 2}, + .VCVTT = { 768, 2}, + .VCVTA = { 770, 2}, + .VCVTN = { 772, 2}, + .VCVTP = { 774, 2}, + .VCVTM = { 776, 2}, + .VCVTR = { 778, 4}, + .VMOV = { 782, 28}, + .VMRS = { 810, 1}, + .VMSR = { 811, 1}, + .VLDR = { 812, 2}, + .VSTR = { 814, 2}, + .VLDM = { 816, 2}, + .VSTM = { 818, 2}, + .VPUSH = { 820, 2}, + .VPOP = { 822, 2}, + .VSEL = { 824, 2}, + .VMAXNM = { 826, 2}, + .VMINNM = { 828, 2}, + .VRINTA = { 830, 3}, + .VRINTN = { 833, 3}, + .VRINTP = { 836, 3}, + .VRINTM = { 839, 3}, + .VRINTR = { 842, 2}, + .VRINTZ = { 844, 3}, + .VRINTX = { 847, 3}, + .VADDL = { 850, 6}, + .VADDW = { 856, 6}, + .VSUBL = { 862, 6}, + .VSUBW = { 868, 6}, + .VHADD = { 874, 9}, + .VHSUB = { 883, 9}, + .VRHADD = { 892, 3}, + .VQADD = { 895, 11}, + .VQSUB = { 906, 11}, + .VMULL = { 917, 7}, + .VMLAL = { 924, 6}, + .VMLSL = { 930, 6}, + .VQDMULL = { 936, 2}, + .VQDMLAL = { 938, 2}, + .VQDMLSL = { 940, 2}, + .VQDMULH = { 942, 4}, + .VQRDMULH = { 946, 4}, + .VQDMULH_LANE = { 950, 0}, + .VQRDMULH_LANE = { 950, 0}, + .VQRDMLAH = { 950, 4}, + .VQRDMLSH = { 954, 4}, + .VABA = { 958, 8}, + .VABAL = { 966, 6}, + .VABD = { 972, 10}, + .VABDL = { 982, 6}, + .VAND = { 988, 3}, + .VBIC = { 991, 3}, + .VORR = { 994, 3}, + .VORN = { 997, 3}, + .VEOR = { 1000, 3}, + .VBSL = { 1003, 2}, + .VBIT = { 1005, 2}, + .VBIF = { 1007, 2}, + .VMVN = { 1009, 13}, + .VMOVN = { 1022, 3}, + .VQMOVN = { 1025, 6}, + .VQMOVUN = { 1031, 3}, + .VMOVL = { 1034, 6}, + .VTST = { 1040, 6}, + .VCEQ = { 1046, 10}, + .VCGE = { 1056, 12}, + .VCGT = { 1068, 12}, + .VCLE = { 1080, 14}, + .VCLT = { 1094, 14}, + .VACGE = { 1108, 2}, + .VACGT = { 1110, 2}, + .VACLE = { 1112, 2}, + .VACLT = { 1114, 2}, + .VMAX = { 1116, 13}, + .VMIN = { 1129, 13}, + .VPMAX = { 1142, 5}, + .VPMIN = { 1147, 5}, + .VPADD = { 1152, 4}, + .VPADDL = { 1156, 6}, + .VPADAL = { 1162, 4}, + .VRECPE = { 1166, 4}, + .VRECPS = { 1170, 2}, + .VRSQRTE = { 1172, 4}, + .VRSQRTS = { 1176, 2}, + .VSHL = { 1178, 9}, + .VSHR = { 1187, 5}, + .VSRA = { 1192, 5}, + .VRSHL = { 1197, 5}, + .VRSHR = { 1202, 5}, + .VRSRA = { 1207, 2}, + .VSLI = { 1209, 2}, + .VSRI = { 1211, 2}, + .VQSHL = { 1213, 7}, + .VQSHRN = { 1220, 2}, + .VQSHRUN = { 1222, 1}, + .VQRSHL = { 1223, 16}, + .VQRSHRN = { 1239, 2}, + .VQRSHRUN = { 1241, 1}, + .VSHRN = { 1242, 1}, + .VRSHRN = { 1243, 1}, + .VSHLL = { 1244, 5}, + .VCLS = { 1249, 6}, + .VCLZ = { 1255, 6}, + .VCNT = { 1261, 2}, + .VPADD_F = { 1263, 2}, + .VRECPE_F = { 1265, 2}, + .VRSQRTE_F = { 1267, 2}, + .VREV16 = { 1269, 2}, + .VREV32 = { 1271, 4}, + .VREV64 = { 1275, 6}, + .VEXT = { 1281, 2}, + .VTBL = { 1283, 4}, + .VTBX = { 1287, 4}, + .VTRN = { 1291, 6}, + .VUZP = { 1297, 5}, + .VZIP = { 1302, 5}, + .VDUP = { 1307, 5}, + .VSWP = { 1312, 2}, + .VMOV_LANE = { 1314, 0}, + .VLD1 = { 1314, 8}, + .VLD2 = { 1322, 3}, + .VLD3 = { 1325, 2}, + .VLD4 = { 1327, 2}, + .VST1 = { 1329, 7}, + .VST2 = { 1336, 3}, + .VST3 = { 1339, 2}, + .VST4 = { 1341, 2}, + .AESE = { 1343, 1}, + .AESD = { 1344, 1}, + .AESMC = { 1345, 1}, + .AESIMC = { 1346, 1}, + .SHA1H = { 1347, 1}, + .SHA1SU0 = { 1348, 1}, + .SHA1SU1 = { 1349, 1}, + .SHA1C = { 1350, 1}, + .SHA1M = { 1351, 1}, + .SHA1P = { 1352, 1}, + .SHA256H = { 1353, 1}, + .SHA256H2 = { 1354, 1}, + .SHA256SU0 = { 1355, 1}, + .SHA256SU1 = { 1356, 1}, + .VRINT = { 1357, 0}, + .VJCVT = { 1357, 1}, + .VSDOT = { 1358, 2}, + .VUDOT = { 1360, 2}, + .VSDOT_LANE = { 1362, 2}, + .VUDOT_LANE = { 1364, 2}, + .VCVT_BF16 = { 1366, 1}, + .VDOT_BF16 = { 1367, 2}, + .VFMA_BF16 = { 1369, 1}, + .VMMLA_BF16 = { 1370, 1}, + .VFMAL = { 1371, 2}, + .VFMSL = { 1373, 2}, + .VCMLA = { 1375, 2}, + .VCADD = { 1377, 2}, + .VCMLA_LANE = { 1379, 2}, + .VSMMLA = { 1381, 1}, + .VUMMLA = { 1382, 1}, + .VUSMMLA = { 1383, 1}, + .VSUDOT = { 1384, 1}, + .VUSDOT = { 1385, 2}, + .VSUDOT_LANE = { 1387, 1}, + .VUSDOT_LANE = { 1388, 2}, + .VMUL_LANE = { 1390, 6}, + .VMLA_LANE = { 1396, 6}, + .VMLS_LANE = { 1402, 6}, + .VMULL_LANE = { 1408, 4}, + .VMLAL_LANE = { 1412, 4}, + .VMLSL_LANE = { 1416, 4}, + .VQDMULL_LANE = { 1420, 2}, + .VQDMLAL_LANE = { 1422, 2}, + .VQDMLSL_LANE = { 1424, 2}, + .VFMA_LANE = { 1426, 2}, + .VFMS_LANE = { 1428, 2}, + .VQRDMLAH_LANE = { 1430, 4}, + .VQRDMLSH_LANE = { 1434, 4}, + .VQABS = { 1438, 1}, + .VQNEG = { 1439, 1}, + .VMOVX = { 1440, 1}, + .VINS = { 1441, 1}, + .VLDRB_GATHER = { 1442, 1}, + .VLDRH_GATHER = { 1443, 1}, + .VLDRW_GATHER = { 1444, 1}, + .VLDRD_GATHER = { 1445, 1}, + .VSTRB_SCATTER = { 1446, 1}, + .VSTRH_SCATTER = { 1447, 1}, + .VSTRW_SCATTER = { 1448, 1}, + .VSTRD_SCATTER = { 1449, 1}, + .VCEQ_Z = { 1450, 4}, + .VCGE_Z = { 1454, 4}, + .VCGT_Z = { 1458, 4}, + .VCLE_Z = { 1462, 4}, + .VCLT_Z = { 1466, 4}, + .VLD2R = { 1470, 1}, + .VLD3R = { 1471, 1}, + .VLD4R = { 1472, 1}, + .VLD1_LANE = { 1473, 3}, + .VLD2_LANE = { 1476, 3}, + .VLD3_LANE = { 1479, 3}, + .VLD4_LANE = { 1482, 3}, + .VST1_LANE = { 1485, 3}, + .VST2_LANE = { 1488, 3}, + .VST3_LANE = { 1491, 3}, + .VST4_LANE = { 1494, 3}, + .VCVT_FIXED = { 1497, 10}, + .IT = { 1507, 1}, + .TT = { 1508, 1}, + .TTT = { 1509, 1}, + .TTA = { 1510, 1}, + .TTAT = { 1511, 1}, + .SG = { 1512, 1}, + .BXNS = { 1513, 1}, + .BLXNS = { 1514, 1}, + .PAC = { 1515, 1}, + .PACBTI = { 1516, 1}, + .AUT = { 1517, 1}, + .AUTG = { 1518, 1}, + .BTI = { 1519, 1}, + .WLS = { 1520, 1}, + .WLSTP = { 1521, 1}, + .DLS = { 1522, 1}, + .DLSTP = { 1523, 1}, + .LE = { 1524, 1}, + .LETP = { 1525, 1}, + .LCTP = { 1526, 1}, + .BF = { 1527, 0}, + .BFI_BR = { 1527, 0}, + .BFL = { 1527, 0}, + .BFLX = { 1527, 0}, + .BFCSEL = { 1527, 0}, + .CX1 = { 1527, 1}, + .CX1A = { 1528, 1}, + .CX1D = { 1529, 1}, + .CX1DA = { 1530, 1}, + .CX2 = { 1531, 1}, + .CX2A = { 1532, 1}, + .CX2D = { 1533, 1}, + .CX2DA = { 1534, 1}, + .CX3 = { 1535, 1}, + .CX3A = { 1536, 1}, + .CX3D = { 1537, 1}, + .CX3DA = { 1538, 1}, + .VCX1 = { 1539, 2}, + .VCX1A = { 1541, 2}, + .VCX2 = { 1543, 2}, + .VCX2A = { 1545, 2}, + .VCX3 = { 1547, 2}, + .VCX3A = { 1549, 2}, + .VPT = { 1551, 1}, + .VPST = { 1552, 1}, + .VPSEL = { 1553, 1}, + .VPNOT = { 1554, 1}, + .VCTP = { 1555, 1}, + .VADDV = { 1556, 1}, + .VADDVA = { 1557, 1}, + .VADDLV = { 1558, 1}, + .VADDLVA = { 1559, 1}, + .VMAXV = { 1560, 1}, + .VMAXAV = { 1561, 1}, + .VMINV = { 1562, 1}, + .VMINAV = { 1563, 1}, + .VMAXNMV = { 1564, 1}, + .VMAXNMAV = { 1565, 1}, + .VMINNMV = { 1566, 1}, + .VMINNMAV = { 1567, 1}, + .VABAV = { 1568, 1}, + .VMLADAV = { 1569, 1}, + .VMLADAVA = { 1570, 1}, + .VMLADAVX = { 1571, 1}, + .VMLADAVAX = { 1572, 1}, + .VMLALDAV = { 1573, 1}, + .VMLALDAVA = { 1574, 1}, + .VMLALDAVX = { 1575, 1}, + .VMLALDAVAX = { 1576, 1}, + .VMLSDAV = { 1577, 1}, + .VMLSDAVA = { 1578, 1}, + .VMLSDAVX = { 1579, 1}, + .VMLSDAVAX = { 1580, 1}, + .VMLSLDAV = { 1581, 1}, + .VMLSLDAVA = { 1582, 1}, + .VMLSLDAVX = { 1583, 1}, + .VMLSLDAVAX = { 1584, 1}, + .VRMLALDAVH = { 1585, 1}, + .VRMLALDAVHA = { 1586, 1}, + .VRMLALDAVHX = { 1587, 1}, + .VRMLALDAVHAX = { 1588, 1}, + .VRMLSLDAVH = { 1589, 1}, + .VRMLSLDAVHA = { 1590, 1}, + .VRMLSLDAVHX = { 1591, 1}, + .VRMLSLDAVHAX = { 1592, 1}, + .VMLAV = { 1593, 1}, + .VMLAVA = { 1594, 1}, + .VMLSV = { 1595, 0}, + .VMLSVA = { 1595, 0}, + .VCMUL = { 1595, 1}, + .VHCADD = { 1596, 1}, + .VBRSR = { 1597, 1}, + .VSHLC = { 1598, 1}, + .VRSHL_MVE = { 1599, 0}, + .VDDUP = { 1599, 1}, + .VIDUP = { 1600, 1}, + .VDWDUP = { 1601, 1}, + .VIWDUP = { 1602, 1}, + .VMOVNB = { 1603, 1}, + .VMOVNT = { 1604, 1}, + .VQMOVNB = { 1605, 1}, + .VQMOVNT = { 1606, 1}, + .VQMOVUNB = { 1607, 1}, + .VQMOVUNT = { 1608, 1}, + .VSHLLB = { 1609, 1}, + .VSHLLT = { 1610, 1}, + .VMULLB = { 1611, 1}, + .VMULLT = { 1612, 1}, + .VMLALB = { 1613, 1}, + .VMLALT = { 1614, 1}, + .VMLSLB = { 1615, 1}, + .VMLSLT = { 1616, 1}, + .VSHRNB = { 1617, 1}, + .VSHRNT = { 1618, 1}, + .VRSHRNB = { 1619, 1}, + .VRSHRNT = { 1620, 1}, + .VQSHRNB = { 1621, 1}, + .VQSHRNT = { 1622, 1}, + .VQRSHRNB = { 1623, 1}, + .VQRSHRNT = { 1624, 1}, + .VQSHRUNB = { 1625, 1}, + .VQSHRUNT = { 1626, 1}, + .VQRSHRUNB = { 1627, 1}, + .VQRSHRUNT = { 1628, 1}, + .VMOV_Q_R = { 1629, 1}, + .VMOV_R_Q = { 1630, 1}, + .VMOV_2GPR_Q = { 1631, 1}, + .VQDMLADH = { 1632, 1}, + .VQDMLADHX = { 1633, 1}, + .VQDMLSDH = { 1634, 1}, + .VQDMLSDHX = { 1635, 1}, + .VQRDMLADH = { 1636, 1}, + .VQRDMLADHX = { 1637, 1}, + .VQRDMLSDH = { 1638, 1}, + .VQRDMLSDHX = { 1639, 1}, + .VPRINT = { 1640, 0}, + .VHCADD_SAT = { 1640, 0}, + .VCMLA_MVE = { 1640, 0}, + .VLDRB = { 1640, 1}, + .VLDRH = { 1641, 1}, + .VLDRW = { 1642, 1}, + .VLDRD = { 1643, 1}, + .VSTRB = { 1644, 1}, + .VSTRH = { 1645, 1}, + .VSTRW = { 1646, 1}, + .VSTRD = { 1647, 1}, + .VLD20 = { 1648, 1}, + .VLD21 = { 1649, 1}, + .VLD40 = { 1650, 1}, + .VLD41 = { 1651, 1}, + .VLD42 = { 1652, 1}, + .VLD43 = { 1653, 1}, + .VST20 = { 1654, 1}, + .VST21 = { 1655, 1}, + .VST40 = { 1656, 1}, + .VST41 = { 1657, 1}, + .VST42 = { 1658, 1}, + .VST43 = { 1659, 1}, + ._COUNT = { 1660, 0}, } diff --git a/core/rexcode/arm32/tables/arm32.bucket_list.bin b/core/rexcode/arm32/tables/arm32.bucket_list.bin index d5d9acb0c..6dbfa9705 100644 Binary files a/core/rexcode/arm32/tables/arm32.bucket_list.bin and b/core/rexcode/arm32/tables/arm32.bucket_list.bin differ diff --git a/core/rexcode/arm32/tables/arm32.encode_forms.bin b/core/rexcode/arm32/tables/arm32.encode_forms.bin index 86153f470..b58d2aa81 100644 Binary files a/core/rexcode/arm32/tables/arm32.encode_forms.bin and b/core/rexcode/arm32/tables/arm32.encode_forms.bin differ diff --git a/core/rexcode/arm32/tables/arm32.encode_runs.bin b/core/rexcode/arm32/tables/arm32.encode_runs.bin index c58625f9b..e05531c4e 100644 Binary files a/core/rexcode/arm32/tables/arm32.encode_runs.bin and b/core/rexcode/arm32/tables/arm32.encode_runs.bin differ diff --git a/core/rexcode/arm32/tables/arm32.entries.bin b/core/rexcode/arm32/tables/arm32.entries.bin index 83994f52b..40bbc34be 100644 Binary files a/core/rexcode/arm32/tables/arm32.entries.bin and b/core/rexcode/arm32/tables/arm32.entries.bin differ diff --git a/core/rexcode/arm32/tables/arm32.form_idx.bin b/core/rexcode/arm32/tables/arm32.form_idx.bin index 8035d344d..baeca385f 100644 Binary files a/core/rexcode/arm32/tables/arm32.form_idx.bin and b/core/rexcode/arm32/tables/arm32.form_idx.bin differ diff --git a/core/rexcode/arm32/tables/arm32.idx_t16.bin b/core/rexcode/arm32/tables/arm32.idx_t16.bin index 7a7f41090..287a5b81d 100644 Binary files a/core/rexcode/arm32/tables/arm32.idx_t16.bin and b/core/rexcode/arm32/tables/arm32.idx_t16.bin differ diff --git a/core/rexcode/arm32/tables/arm32.idx_t32.bin b/core/rexcode/arm32/tables/arm32.idx_t32.bin index 2596d707d..209e42015 100644 Binary files a/core/rexcode/arm32/tables/arm32.idx_t32.bin and b/core/rexcode/arm32/tables/arm32.idx_t32.bin differ diff --git a/core/rexcode/arm32/tables/arm32.idx_t32_sub.bin b/core/rexcode/arm32/tables/arm32.idx_t32_sub.bin index 7305e8ac7..00c5b7bfe 100644 Binary files a/core/rexcode/arm32/tables/arm32.idx_t32_sub.bin and b/core/rexcode/arm32/tables/arm32.idx_t32_sub.bin differ