{"sve2-sha3", AARCH64_FEATURE (SVE2_SHA3),
AARCH64_FEATURES (2, SVE2, SHA3)},
{"sve2-bitperm", AARCH64_FEATURE (SVE2_BITPERM),
- AARCH64_FEATURE (SVE2)},
+ AARCH64_FEATURES (2, SVE2, SVE_BITPERM)},
{"sme", AARCH64_FEATURE (SME),
AARCH64_FEATURES (3, BFLOAT16, F16, COMPNUM)},
{"sme-f64", AARCH64_FEATURE (SME_F64F64), AARCH64_FEATURE (SME)},
{"f8f16mm", AARCH64_FEATURE (F8F16MM), AARCH64_FEATURES (2, SIMD, FP8)},
{"sve-aes", AARCH64_FEATURE (SVE_AES), AARCH64_FEATURE (AES)},
{"sve-aes2", AARCH64_FEATURE (SVE_AES2), AARCH64_NO_FEATURES},
- {"ssve-aes", AARCH64_FEATURE (SSVE_AES), AARCH64_FEATURES (2, SME2, SVE_AES)},
+ {"ssve-aes", AARCH64_FEATURE (SSVE_AES),
+ AARCH64_FEATURES (2, SME2, SVE_AES)},
+ {"sve-bitperm", AARCH64_FEATURE (SVE_BITPERM), AARCH64_NO_FEATURES},
+ {"ssve-bitperm", AARCH64_FEATURE (SSVE_BITPERM),
+ AARCH64_FEATURES (2, SME2, SVE_BITPERM)},
{"rcpc3", AARCH64_FEATURE (RCPC3), AARCH64_FEATURE (RCPC2)},
{"cpa", AARCH64_FEATURE (CPA), AARCH64_NO_FEATURES},
{"faminmax", AARCH64_FEATURE (FAMINMAX), AARCH64_FEATURE (SIMD)},
@tab Enable Speculative Store Bypassing Safe state read and write.
@item @code{ssve-aes} @tab @code{sme2}, @code{sve-aes}
@tab Enable SVE AES instructions in streaming mode.
+@item @code{ssve-bitperm} @tab @code{sme2}, @code{sve-bitperm}
+ @tab Enable SVE AES instructions in streaming mode.
@item @code{ssve-fexpa} @tab @code{sme2}
@tab Enable the SVE FEXPA instruction in streaming mode.
@item @code{ssve-fp8dot2} @tab @code{sme2}, @code{fp8}
@tab Enable the SVE2 AES and PMULL Extensions.
@item @code{sve-aes2} @tab
@tab Enable the SVE-AES2 extension.
+@item @code{sve-bitperm} @tab
+ @tab Enable the SVE2 BITPERM Extension.
@item @code{sve-b16b16} @tab
@tab Enable the SVE B16B16 extension. These instructions also require either @code{+sve2} or @code{+sme2}.
@item @code{sve-bfscale} @tab
@tab Enable SVE2.
@item @code{sve2-aes} @tab @code{sve2}, @code{sve-aes}
@tab Enable the SVE2 AES and PMULL Extensions.
-@item @code{sve2-bitperm} @tab @code{sve2}
+@item @code{sve2-bitperm} @tab @code{sve2}, @code{sve-bitperm}
@tab Enable the SVE2 BITPERM Extension.
@item @code{sve2-sha3} @tab @code{sve2}, @code{sha3}
@tab Enable the SVE2 SHA3 Extension.
--- /dev/null
+#as: -march=armv8-a+sve2+sve-bitperm
+#as: -march=armv8-a+ssve-bitperm
+#objdump: -dr
+
+.*: file format .*
+
+
+Disassembly of section \.text:
+
+0+ <\.text>:
+ *[0-9a-f]+: 4500b400 bdep z0\.b, z0\.b, z0\.b
+ *[0-9a-f]+: 4500b41f bdep z31\.b, z0\.b, z0\.b
+ *[0-9a-f]+: 4500b7e0 bdep z0\.b, z31\.b, z0\.b
+ *[0-9a-f]+: 451fb400 bdep z0\.b, z0\.b, z31\.b
+ *[0-9a-f]+: 4540b400 bdep z0\.h, z0\.h, z0\.h
+ *[0-9a-f]+: 4540b41f bdep z31\.h, z0\.h, z0\.h
+ *[0-9a-f]+: 4540b7e0 bdep z0\.h, z31\.h, z0\.h
+ *[0-9a-f]+: 455fb400 bdep z0\.h, z0\.h, z31\.h
+ *[0-9a-f]+: 4580b400 bdep z0\.s, z0\.s, z0\.s
+ *[0-9a-f]+: 4580b41f bdep z31\.s, z0\.s, z0\.s
+ *[0-9a-f]+: 4580b7e0 bdep z0\.s, z31\.s, z0\.s
+ *[0-9a-f]+: 459fb400 bdep z0\.s, z0\.s, z31\.s
+ *[0-9a-f]+: 45c0b400 bdep z0\.d, z0\.d, z0\.d
+ *[0-9a-f]+: 45c0b41f bdep z31\.d, z0\.d, z0\.d
+ *[0-9a-f]+: 45c0b7e0 bdep z0\.d, z31\.d, z0\.d
+ *[0-9a-f]+: 45dfb400 bdep z0\.d, z0\.d, z31\.d
+ *[0-9a-f]+: 4500b000 bext z0\.b, z0\.b, z0\.b
+ *[0-9a-f]+: 4500b01f bext z31\.b, z0\.b, z0\.b
+ *[0-9a-f]+: 4500b3e0 bext z0\.b, z31\.b, z0\.b
+ *[0-9a-f]+: 451fb000 bext z0\.b, z0\.b, z31\.b
+ *[0-9a-f]+: 4540b000 bext z0\.h, z0\.h, z0\.h
+ *[0-9a-f]+: 4540b01f bext z31\.h, z0\.h, z0\.h
+ *[0-9a-f]+: 4540b3e0 bext z0\.h, z31\.h, z0\.h
+ *[0-9a-f]+: 455fb000 bext z0\.h, z0\.h, z31\.h
+ *[0-9a-f]+: 4580b000 bext z0\.s, z0\.s, z0\.s
+ *[0-9a-f]+: 4580b01f bext z31\.s, z0\.s, z0\.s
+ *[0-9a-f]+: 4580b3e0 bext z0\.s, z31\.s, z0\.s
+ *[0-9a-f]+: 459fb000 bext z0\.s, z0\.s, z31\.s
+ *[0-9a-f]+: 45c0b000 bext z0\.d, z0\.d, z0\.d
+ *[0-9a-f]+: 45c0b01f bext z31\.d, z0\.d, z0\.d
+ *[0-9a-f]+: 45c0b3e0 bext z0\.d, z31\.d, z0\.d
+ *[0-9a-f]+: 45dfb000 bext z0\.d, z0\.d, z31\.d
+ *[0-9a-f]+: 4500b800 bgrp z0\.b, z0\.b, z0\.b
+ *[0-9a-f]+: 4500b81f bgrp z31\.b, z0\.b, z0\.b
+ *[0-9a-f]+: 4500bbe0 bgrp z0\.b, z31\.b, z0\.b
+ *[0-9a-f]+: 451fb800 bgrp z0\.b, z0\.b, z31\.b
+ *[0-9a-f]+: 4540b800 bgrp z0\.h, z0\.h, z0\.h
+ *[0-9a-f]+: 4540b81f bgrp z31\.h, z0\.h, z0\.h
+ *[0-9a-f]+: 4540bbe0 bgrp z0\.h, z31\.h, z0\.h
+ *[0-9a-f]+: 455fb800 bgrp z0\.h, z0\.h, z31\.h
+ *[0-9a-f]+: 4580b800 bgrp z0\.s, z0\.s, z0\.s
+ *[0-9a-f]+: 4580b81f bgrp z31\.s, z0\.s, z0\.s
+ *[0-9a-f]+: 4580bbe0 bgrp z0\.s, z31\.s, z0\.s
+ *[0-9a-f]+: 459fb800 bgrp z0\.s, z0\.s, z31\.s
+ *[0-9a-f]+: 45c0b800 bgrp z0\.d, z0\.d, z0\.d
+ *[0-9a-f]+: 45c0b81f bgrp z31\.d, z0\.d, z0\.d
+ *[0-9a-f]+: 45c0bbe0 bgrp z0\.d, z31\.d, z0\.d
+ *[0-9a-f]+: 45dfb800 bgrp z0\.d, z0\.d, z31\.d