test_cases: - input: bytes: [ 0x01, 0xd4, 0x20, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z0.q, z1.q }, z0.q, z0.q" - input: bytes: [ 0x55, 0xd5, 0x35, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z20.q, z21.q }, z10.q, z21.q" - input: bytes: [ 0xb7, 0xd5, 0x28, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z22.q, z23.q }, z13.q, z8.q" - input: bytes: [ 0xff, 0xd7, 0x3f, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z30.q, z31.q }, z31.q, z31.q" - input: bytes: [ 0x01, 0xd0, 0x60, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z0.h, z1.h }, z0.h, z0.h" - input: bytes: [ 0x55, 0xd1, 0x75, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z20.h, z21.h }, z10.h, z21.h" - input: bytes: [ 0xb7, 0xd1, 0x68, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z22.h, z23.h }, z13.h, z8.h" - input: bytes: [ 0xff, 0xd3, 0x7f, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z30.h, z31.h }, z31.h, z31.h" - input: bytes: [ 0x01, 0xd0, 0xa0, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z0.s, z1.s }, z0.s, z0.s" - input: bytes: [ 0x55, 0xd1, 0xb5, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z20.s, z21.s }, z10.s, z21.s" - input: bytes: [ 0xb7, 0xd1, 0xa8, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z22.s, z23.s }, z13.s, z8.s" - input: bytes: [ 0xff, 0xd3, 0xbf, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z30.s, z31.s }, z31.s, z31.s" - input: bytes: [ 0x01, 0xd0, 0xe0, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z0.d, z1.d }, z0.d, z0.d" - input: bytes: [ 0x55, 0xd1, 0xf5, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z20.d, z21.d }, z10.d, z21.d" - input: bytes: [ 0xb7, 0xd1, 0xe8, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z22.d, z23.d }, z13.d, z8.d" - input: bytes: [ 0xff, 0xd3, 0xff, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z30.d, z31.d }, z31.d, z31.d" - input: bytes: [ 0x01, 0xd0, 0x20, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z0.b, z1.b }, z0.b, z0.b" - input: bytes: [ 0x55, 0xd1, 0x35, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z20.b, z21.b }, z10.b, z21.b" - input: bytes: [ 0xb7, 0xd1, 0x28, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z22.b, z23.b }, z13.b, z8.b" - input: bytes: [ 0xff, 0xd3, 0x3f, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z30.b, z31.b }, z31.b, z31.b" - input: bytes: [ 0x02, 0xe0, 0x37, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z0.q - z3.q }, { z0.q - z3.q }" - input: bytes: [ 0x16, 0xe1, 0x37, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z20.q - z23.q }, { z8.q - z11.q }" - input: bytes: [ 0x96, 0xe1, 0x37, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z20.q - z23.q }, { z12.q - z15.q }" - input: bytes: [ 0x9e, 0xe3, 0x37, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z28.q - z31.q }, { z28.q - z31.q }" - input: bytes: [ 0x02, 0xe0, 0x76, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z0.h - z3.h }, { z0.h - z3.h }" - input: bytes: [ 0x16, 0xe1, 0x76, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z20.h - z23.h }, { z8.h - z11.h }" - input: bytes: [ 0x96, 0xe1, 0x76, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z20.h - z23.h }, { z12.h - z15.h }" - input: bytes: [ 0x9e, 0xe3, 0x76, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z28.h - z31.h }, { z28.h - z31.h }" - input: bytes: [ 0x02, 0xe0, 0xb6, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z0.s - z3.s }, { z0.s - z3.s }" - input: bytes: [ 0x16, 0xe1, 0xb6, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z20.s - z23.s }, { z8.s - z11.s }" - input: bytes: [ 0x96, 0xe1, 0xb6, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z20.s - z23.s }, { z12.s - z15.s }" - input: bytes: [ 0x9e, 0xe3, 0xb6, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z28.s - z31.s }, { z28.s - z31.s }" - input: bytes: [ 0x02, 0xe0, 0xf6, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z0.d - z3.d }, { z0.d - z3.d }" - input: bytes: [ 0x16, 0xe1, 0xf6, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z20.d - z23.d }, { z8.d - z11.d }" - input: bytes: [ 0x96, 0xe1, 0xf6, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z20.d - z23.d }, { z12.d - z15.d }" - input: bytes: [ 0x9e, 0xe3, 0xf6, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z28.d - z31.d }, { z28.d - z31.d }" - input: bytes: [ 0x02, 0xe0, 0x36, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z0.b - z3.b }, { z0.b - z3.b }" - input: bytes: [ 0x16, 0xe1, 0x36, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z20.b - z23.b }, { z8.b - z11.b }" - input: bytes: [ 0x96, 0xe1, 0x36, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z20.b - z23.b }, { z12.b - z15.b }" - input: bytes: [ 0x9e, 0xe3, 0x36, 0xc1 ] arch: "CS_ARCH_AARCH64" options: [ "CS_OPT_NO_BRANCH_OFFSET", "aarch64", "sme2" ] expected: insns: - asm_text: "uzp { z28.b - z31.b }, { z28.b - z31.b }"