- /* Do not replace the first two entries - i386_target_format()
- relies on them being there in this order. */
- { STRING_COMMA_LEN ("generic32"), PROCESSOR_GENERIC32,
- CPU_GENERIC32_FLAGS, 0 },
- { STRING_COMMA_LEN ("generic64"), PROCESSOR_GENERIC64,
- CPU_GENERIC64_FLAGS, 0 },
- { STRING_COMMA_LEN ("i8086"), PROCESSOR_UNKNOWN,
- CPU_NONE_FLAGS, 0 },
- { STRING_COMMA_LEN ("i186"), PROCESSOR_UNKNOWN,
- CPU_I186_FLAGS, 0 },
- { STRING_COMMA_LEN ("i286"), PROCESSOR_UNKNOWN,
- CPU_I286_FLAGS, 0 },
- { STRING_COMMA_LEN ("i386"), PROCESSOR_I386,
- CPU_I386_FLAGS, 0 },
- { STRING_COMMA_LEN ("i486"), PROCESSOR_I486,
- CPU_I486_FLAGS, 0 },
- { STRING_COMMA_LEN ("i586"), PROCESSOR_PENTIUM,
- CPU_I586_FLAGS, 0 },
- { STRING_COMMA_LEN ("i686"), PROCESSOR_PENTIUMPRO,
- CPU_I686_FLAGS, 0 },
- { STRING_COMMA_LEN ("pentium"), PROCESSOR_PENTIUM,
- CPU_I586_FLAGS, 0 },
- { STRING_COMMA_LEN ("pentiumpro"), PROCESSOR_PENTIUMPRO,
- CPU_PENTIUMPRO_FLAGS, 0 },
- { STRING_COMMA_LEN ("pentiumii"), PROCESSOR_PENTIUMPRO,
- CPU_P2_FLAGS, 0 },
- { STRING_COMMA_LEN ("pentiumiii"),PROCESSOR_PENTIUMPRO,
- CPU_P3_FLAGS, 0 },
- { STRING_COMMA_LEN ("pentium4"), PROCESSOR_PENTIUM4,
- CPU_P4_FLAGS, 0 },
- { STRING_COMMA_LEN ("prescott"), PROCESSOR_NOCONA,
- CPU_CORE_FLAGS, 0 },
- { STRING_COMMA_LEN ("nocona"), PROCESSOR_NOCONA,
- CPU_NOCONA_FLAGS, 0 },
- { STRING_COMMA_LEN ("yonah"), PROCESSOR_CORE,
- CPU_CORE_FLAGS, 1 },
- { STRING_COMMA_LEN ("core"), PROCESSOR_CORE,
- CPU_CORE_FLAGS, 0 },
- { STRING_COMMA_LEN ("merom"), PROCESSOR_CORE2,
- CPU_CORE2_FLAGS, 1 },
- { STRING_COMMA_LEN ("core2"), PROCESSOR_CORE2,
- CPU_CORE2_FLAGS, 0 },
- { STRING_COMMA_LEN ("corei7"), PROCESSOR_COREI7,
- CPU_COREI7_FLAGS, 0 },
- { STRING_COMMA_LEN ("iamcu"), PROCESSOR_IAMCU,
- CPU_IAMCU_FLAGS, 0 },
- { STRING_COMMA_LEN ("k6"), PROCESSOR_K6,
- CPU_K6_FLAGS, 0 },
- { STRING_COMMA_LEN ("k6_2"), PROCESSOR_K6,
- CPU_K6_2_FLAGS, 0 },
- { STRING_COMMA_LEN ("athlon"), PROCESSOR_ATHLON,
- CPU_ATHLON_FLAGS, 0 },
- { STRING_COMMA_LEN ("sledgehammer"), PROCESSOR_K8,
- CPU_K8_FLAGS, 1 },
- { STRING_COMMA_LEN ("opteron"), PROCESSOR_K8,
- CPU_K8_FLAGS, 0 },
- { STRING_COMMA_LEN ("k8"), PROCESSOR_K8,
- CPU_K8_FLAGS, 0 },
- { STRING_COMMA_LEN ("amdfam10"), PROCESSOR_AMDFAM10,
- CPU_AMDFAM10_FLAGS, 0 },
- { STRING_COMMA_LEN ("bdver1"), PROCESSOR_BD,
- CPU_BDVER1_FLAGS, 0 },
- { STRING_COMMA_LEN ("bdver2"), PROCESSOR_BD,
- CPU_BDVER2_FLAGS, 0 },
- { STRING_COMMA_LEN ("bdver3"), PROCESSOR_BD,
- CPU_BDVER3_FLAGS, 0 },
- { STRING_COMMA_LEN ("bdver4"), PROCESSOR_BD,
- CPU_BDVER4_FLAGS, 0 },
- { STRING_COMMA_LEN ("znver1"), PROCESSOR_ZNVER,
- CPU_ZNVER1_FLAGS, 0 },
- { STRING_COMMA_LEN ("znver2"), PROCESSOR_ZNVER,
- CPU_ZNVER2_FLAGS, 0 },
- { STRING_COMMA_LEN ("znver3"), PROCESSOR_ZNVER,
- CPU_ZNVER3_FLAGS, 0 },
- { STRING_COMMA_LEN ("btver1"), PROCESSOR_BT,
- CPU_BTVER1_FLAGS, 0 },
- { STRING_COMMA_LEN ("btver2"), PROCESSOR_BT,
- CPU_BTVER2_FLAGS, 0 },
- { STRING_COMMA_LEN (".8087"), PROCESSOR_UNKNOWN,
- CPU_8087_FLAGS, 0 },
- { STRING_COMMA_LEN (".287"), PROCESSOR_UNKNOWN,
- CPU_287_FLAGS, 0 },
- { STRING_COMMA_LEN (".387"), PROCESSOR_UNKNOWN,
- CPU_387_FLAGS, 0 },
- { STRING_COMMA_LEN (".687"), PROCESSOR_UNKNOWN,
- CPU_687_FLAGS, 0 },
- { STRING_COMMA_LEN (".cmov"), PROCESSOR_UNKNOWN,
- CPU_CMOV_FLAGS, 0 },
- { STRING_COMMA_LEN (".fxsr"), PROCESSOR_UNKNOWN,
- CPU_FXSR_FLAGS, 0 },
- { STRING_COMMA_LEN (".mmx"), PROCESSOR_UNKNOWN,
- CPU_MMX_FLAGS, 0 },
- { STRING_COMMA_LEN (".sse"), PROCESSOR_UNKNOWN,
- CPU_SSE_FLAGS, 0 },
- { STRING_COMMA_LEN (".sse2"), PROCESSOR_UNKNOWN,
- CPU_SSE2_FLAGS, 0 },
- { STRING_COMMA_LEN (".sse3"), PROCESSOR_UNKNOWN,
- CPU_SSE3_FLAGS, 0 },
- { STRING_COMMA_LEN (".sse4a"), PROCESSOR_UNKNOWN,
- CPU_SSE4A_FLAGS, 0 },
- { STRING_COMMA_LEN (".ssse3"), PROCESSOR_UNKNOWN,
- CPU_SSSE3_FLAGS, 0 },
- { STRING_COMMA_LEN (".sse4.1"), PROCESSOR_UNKNOWN,
- CPU_SSE4_1_FLAGS, 0 },
- { STRING_COMMA_LEN (".sse4.2"), PROCESSOR_UNKNOWN,
- CPU_SSE4_2_FLAGS, 0 },
- { STRING_COMMA_LEN (".sse4"), PROCESSOR_UNKNOWN,
- CPU_SSE4_2_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx"), PROCESSOR_UNKNOWN,
- CPU_AVX_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx2"), PROCESSOR_UNKNOWN,
- CPU_AVX2_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512f"), PROCESSOR_UNKNOWN,
- CPU_AVX512F_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512cd"), PROCESSOR_UNKNOWN,
- CPU_AVX512CD_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512er"), PROCESSOR_UNKNOWN,
- CPU_AVX512ER_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512pf"), PROCESSOR_UNKNOWN,
- CPU_AVX512PF_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512dq"), PROCESSOR_UNKNOWN,
- CPU_AVX512DQ_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512bw"), PROCESSOR_UNKNOWN,
- CPU_AVX512BW_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512vl"), PROCESSOR_UNKNOWN,
- CPU_AVX512VL_FLAGS, 0 },
- { STRING_COMMA_LEN (".vmx"), PROCESSOR_UNKNOWN,
- CPU_VMX_FLAGS, 0 },
- { STRING_COMMA_LEN (".vmfunc"), PROCESSOR_UNKNOWN,
- CPU_VMFUNC_FLAGS, 0 },
- { STRING_COMMA_LEN (".smx"), PROCESSOR_UNKNOWN,
- CPU_SMX_FLAGS, 0 },
- { STRING_COMMA_LEN (".xsave"), PROCESSOR_UNKNOWN,
- CPU_XSAVE_FLAGS, 0 },
- { STRING_COMMA_LEN (".xsaveopt"), PROCESSOR_UNKNOWN,
- CPU_XSAVEOPT_FLAGS, 0 },
- { STRING_COMMA_LEN (".xsavec"), PROCESSOR_UNKNOWN,
- CPU_XSAVEC_FLAGS, 0 },
- { STRING_COMMA_LEN (".xsaves"), PROCESSOR_UNKNOWN,
- CPU_XSAVES_FLAGS, 0 },
- { STRING_COMMA_LEN (".aes"), PROCESSOR_UNKNOWN,
- CPU_AES_FLAGS, 0 },
- { STRING_COMMA_LEN (".pclmul"), PROCESSOR_UNKNOWN,
- CPU_PCLMUL_FLAGS, 0 },
- { STRING_COMMA_LEN (".clmul"), PROCESSOR_UNKNOWN,
- CPU_PCLMUL_FLAGS, 1 },
- { STRING_COMMA_LEN (".fsgsbase"), PROCESSOR_UNKNOWN,
- CPU_FSGSBASE_FLAGS, 0 },
- { STRING_COMMA_LEN (".rdrnd"), PROCESSOR_UNKNOWN,
- CPU_RDRND_FLAGS, 0 },
- { STRING_COMMA_LEN (".f16c"), PROCESSOR_UNKNOWN,
- CPU_F16C_FLAGS, 0 },
- { STRING_COMMA_LEN (".bmi2"), PROCESSOR_UNKNOWN,
- CPU_BMI2_FLAGS, 0 },
- { STRING_COMMA_LEN (".fma"), PROCESSOR_UNKNOWN,
- CPU_FMA_FLAGS, 0 },
- { STRING_COMMA_LEN (".fma4"), PROCESSOR_UNKNOWN,
- CPU_FMA4_FLAGS, 0 },
- { STRING_COMMA_LEN (".xop"), PROCESSOR_UNKNOWN,
- CPU_XOP_FLAGS, 0 },
- { STRING_COMMA_LEN (".lwp"), PROCESSOR_UNKNOWN,
- CPU_LWP_FLAGS, 0 },
- { STRING_COMMA_LEN (".movbe"), PROCESSOR_UNKNOWN,
- CPU_MOVBE_FLAGS, 0 },
- { STRING_COMMA_LEN (".cx16"), PROCESSOR_UNKNOWN,
- CPU_CX16_FLAGS, 0 },
- { STRING_COMMA_LEN (".ept"), PROCESSOR_UNKNOWN,
- CPU_EPT_FLAGS, 0 },
- { STRING_COMMA_LEN (".lzcnt"), PROCESSOR_UNKNOWN,
- CPU_LZCNT_FLAGS, 0 },
- { STRING_COMMA_LEN (".popcnt"), PROCESSOR_UNKNOWN,
- CPU_POPCNT_FLAGS, 0 },
- { STRING_COMMA_LEN (".hle"), PROCESSOR_UNKNOWN,
- CPU_HLE_FLAGS, 0 },
- { STRING_COMMA_LEN (".rtm"), PROCESSOR_UNKNOWN,
- CPU_RTM_FLAGS, 0 },
- { STRING_COMMA_LEN (".invpcid"), PROCESSOR_UNKNOWN,
- CPU_INVPCID_FLAGS, 0 },
- { STRING_COMMA_LEN (".clflush"), PROCESSOR_UNKNOWN,
- CPU_CLFLUSH_FLAGS, 0 },
- { STRING_COMMA_LEN (".nop"), PROCESSOR_UNKNOWN,
- CPU_NOP_FLAGS, 0 },
- { STRING_COMMA_LEN (".syscall"), PROCESSOR_UNKNOWN,
- CPU_SYSCALL_FLAGS, 0 },
- { STRING_COMMA_LEN (".rdtscp"), PROCESSOR_UNKNOWN,
- CPU_RDTSCP_FLAGS, 0 },
- { STRING_COMMA_LEN (".3dnow"), PROCESSOR_UNKNOWN,
- CPU_3DNOW_FLAGS, 0 },
- { STRING_COMMA_LEN (".3dnowa"), PROCESSOR_UNKNOWN,
- CPU_3DNOWA_FLAGS, 0 },
- { STRING_COMMA_LEN (".padlock"), PROCESSOR_UNKNOWN,
- CPU_PADLOCK_FLAGS, 0 },
- { STRING_COMMA_LEN (".pacifica"), PROCESSOR_UNKNOWN,
- CPU_SVME_FLAGS, 1 },
- { STRING_COMMA_LEN (".svme"), PROCESSOR_UNKNOWN,
- CPU_SVME_FLAGS, 0 },
- { STRING_COMMA_LEN (".sse4a"), PROCESSOR_UNKNOWN,
- CPU_SSE4A_FLAGS, 0 },
- { STRING_COMMA_LEN (".abm"), PROCESSOR_UNKNOWN,
- CPU_ABM_FLAGS, 0 },
- { STRING_COMMA_LEN (".bmi"), PROCESSOR_UNKNOWN,
- CPU_BMI_FLAGS, 0 },
- { STRING_COMMA_LEN (".tbm"), PROCESSOR_UNKNOWN,
- CPU_TBM_FLAGS, 0 },
- { STRING_COMMA_LEN (".adx"), PROCESSOR_UNKNOWN,
- CPU_ADX_FLAGS, 0 },
- { STRING_COMMA_LEN (".rdseed"), PROCESSOR_UNKNOWN,
- CPU_RDSEED_FLAGS, 0 },
- { STRING_COMMA_LEN (".prfchw"), PROCESSOR_UNKNOWN,
- CPU_PRFCHW_FLAGS, 0 },
- { STRING_COMMA_LEN (".smap"), PROCESSOR_UNKNOWN,
- CPU_SMAP_FLAGS, 0 },
- { STRING_COMMA_LEN (".mpx"), PROCESSOR_UNKNOWN,
- CPU_MPX_FLAGS, 0 },
- { STRING_COMMA_LEN (".sha"), PROCESSOR_UNKNOWN,
- CPU_SHA_FLAGS, 0 },
- { STRING_COMMA_LEN (".clflushopt"), PROCESSOR_UNKNOWN,
- CPU_CLFLUSHOPT_FLAGS, 0 },
- { STRING_COMMA_LEN (".prefetchwt1"), PROCESSOR_UNKNOWN,
- CPU_PREFETCHWT1_FLAGS, 0 },
- { STRING_COMMA_LEN (".se1"), PROCESSOR_UNKNOWN,
- CPU_SE1_FLAGS, 0 },
- { STRING_COMMA_LEN (".clwb"), PROCESSOR_UNKNOWN,
- CPU_CLWB_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512ifma"), PROCESSOR_UNKNOWN,
- CPU_AVX512IFMA_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512vbmi"), PROCESSOR_UNKNOWN,
- CPU_AVX512VBMI_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512_4fmaps"), PROCESSOR_UNKNOWN,
- CPU_AVX512_4FMAPS_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512_4vnniw"), PROCESSOR_UNKNOWN,
- CPU_AVX512_4VNNIW_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512_vpopcntdq"), PROCESSOR_UNKNOWN,
- CPU_AVX512_VPOPCNTDQ_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512_vbmi2"), PROCESSOR_UNKNOWN,
- CPU_AVX512_VBMI2_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512_vnni"), PROCESSOR_UNKNOWN,
- CPU_AVX512_VNNI_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512_bitalg"), PROCESSOR_UNKNOWN,
- CPU_AVX512_BITALG_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx_vnni"), PROCESSOR_UNKNOWN,
- CPU_AVX_VNNI_FLAGS, 0 },
- { STRING_COMMA_LEN (".clzero"), PROCESSOR_UNKNOWN,
- CPU_CLZERO_FLAGS, 0 },
- { STRING_COMMA_LEN (".mwaitx"), PROCESSOR_UNKNOWN,
- CPU_MWAITX_FLAGS, 0 },
- { STRING_COMMA_LEN (".ospke"), PROCESSOR_UNKNOWN,
- CPU_OSPKE_FLAGS, 0 },
- { STRING_COMMA_LEN (".rdpid"), PROCESSOR_UNKNOWN,
- CPU_RDPID_FLAGS, 0 },
- { STRING_COMMA_LEN (".ptwrite"), PROCESSOR_UNKNOWN,
- CPU_PTWRITE_FLAGS, 0 },
- { STRING_COMMA_LEN (".ibt"), PROCESSOR_UNKNOWN,
- CPU_IBT_FLAGS, 0 },
- { STRING_COMMA_LEN (".shstk"), PROCESSOR_UNKNOWN,
- CPU_SHSTK_FLAGS, 0 },
- { STRING_COMMA_LEN (".gfni"), PROCESSOR_UNKNOWN,
- CPU_GFNI_FLAGS, 0 },
- { STRING_COMMA_LEN (".vaes"), PROCESSOR_UNKNOWN,
- CPU_VAES_FLAGS, 0 },
- { STRING_COMMA_LEN (".vpclmulqdq"), PROCESSOR_UNKNOWN,
- CPU_VPCLMULQDQ_FLAGS, 0 },
- { STRING_COMMA_LEN (".wbnoinvd"), PROCESSOR_UNKNOWN,
- CPU_WBNOINVD_FLAGS, 0 },
- { STRING_COMMA_LEN (".pconfig"), PROCESSOR_UNKNOWN,
- CPU_PCONFIG_FLAGS, 0 },
- { STRING_COMMA_LEN (".waitpkg"), PROCESSOR_UNKNOWN,
- CPU_WAITPKG_FLAGS, 0 },
- { STRING_COMMA_LEN (".cldemote"), PROCESSOR_UNKNOWN,
- CPU_CLDEMOTE_FLAGS, 0 },
- { STRING_COMMA_LEN (".amx_int8"), PROCESSOR_UNKNOWN,
- CPU_AMX_INT8_FLAGS, 0 },
- { STRING_COMMA_LEN (".amx_bf16"), PROCESSOR_UNKNOWN,
- CPU_AMX_BF16_FLAGS, 0 },
- { STRING_COMMA_LEN (".amx_tile"), PROCESSOR_UNKNOWN,
- CPU_AMX_TILE_FLAGS, 0 },
- { STRING_COMMA_LEN (".movdiri"), PROCESSOR_UNKNOWN,
- CPU_MOVDIRI_FLAGS, 0 },
- { STRING_COMMA_LEN (".movdir64b"), PROCESSOR_UNKNOWN,
- CPU_MOVDIR64B_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512_bf16"), PROCESSOR_UNKNOWN,
- CPU_AVX512_BF16_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512_vp2intersect"), PROCESSOR_UNKNOWN,
- CPU_AVX512_VP2INTERSECT_FLAGS, 0 },
- { STRING_COMMA_LEN (".tdx"), PROCESSOR_UNKNOWN,
- CPU_TDX_FLAGS, 0 },
- { STRING_COMMA_LEN (".enqcmd"), PROCESSOR_UNKNOWN,
- CPU_ENQCMD_FLAGS, 0 },
- { STRING_COMMA_LEN (".serialize"), PROCESSOR_UNKNOWN,
- CPU_SERIALIZE_FLAGS, 0 },
- { STRING_COMMA_LEN (".rdpru"), PROCESSOR_UNKNOWN,
- CPU_RDPRU_FLAGS, 0 },
- { STRING_COMMA_LEN (".mcommit"), PROCESSOR_UNKNOWN,
- CPU_MCOMMIT_FLAGS, 0 },
- { STRING_COMMA_LEN (".sev_es"), PROCESSOR_UNKNOWN,
- CPU_SEV_ES_FLAGS, 0 },
- { STRING_COMMA_LEN (".tsxldtrk"), PROCESSOR_UNKNOWN,
- CPU_TSXLDTRK_FLAGS, 0 },
- { STRING_COMMA_LEN (".kl"), PROCESSOR_UNKNOWN,
- CPU_KL_FLAGS, 0 },
- { STRING_COMMA_LEN (".widekl"), PROCESSOR_UNKNOWN,
- CPU_WIDEKL_FLAGS, 0 },
- { STRING_COMMA_LEN (".uintr"), PROCESSOR_UNKNOWN,
- CPU_UINTR_FLAGS, 0 },
- { STRING_COMMA_LEN (".hreset"), PROCESSOR_UNKNOWN,
- CPU_HRESET_FLAGS, 0 },
- { STRING_COMMA_LEN (".avx512_fp16"), PROCESSOR_UNKNOWN,
- CPU_AVX512_FP16_FLAGS, 0 },
+ /* Do not replace the first two entries - i386_target_format() and
+ set_cpu_arch() rely on them being there in this order. */
+ ARCH (generic32, GENERIC32, GENERIC32, false),
+ ARCH (generic64, GENERIC64, GENERIC64, false),
+ ARCH (i8086, UNKNOWN, NONE, false),
+ ARCH (i186, UNKNOWN, 186, false),
+ ARCH (i286, UNKNOWN, 286, false),
+ ARCH (i386, I386, 386, false),
+ ARCH (i486, I486, 486, false),
+ ARCH (i586, PENTIUM, 586, false),
+ ARCH (i686, PENTIUMPRO, 686, false),
+ ARCH (pentium, PENTIUM, 586, false),
+ ARCH (pentiumpro, PENTIUMPRO, PENTIUMPRO, false),
+ ARCH (pentiumii, PENTIUMPRO, P2, false),
+ ARCH (pentiumiii, PENTIUMPRO, P3, false),
+ ARCH (pentium4, PENTIUM4, P4, false),
+ ARCH (prescott, NOCONA, CORE, false),
+ ARCH (nocona, NOCONA, NOCONA, false),
+ ARCH (yonah, CORE, CORE, true),
+ ARCH (core, CORE, CORE, false),
+ ARCH (merom, CORE2, CORE2, true),
+ ARCH (core2, CORE2, CORE2, false),
+ ARCH (corei7, COREI7, COREI7, false),
+ ARCH (iamcu, IAMCU, IAMCU, false),
+ ARCH (k6, K6, K6, false),
+ ARCH (k6_2, K6, K6_2, false),
+ ARCH (athlon, ATHLON, ATHLON, false),
+ ARCH (sledgehammer, K8, K8, true),
+ ARCH (opteron, K8, K8, false),
+ ARCH (k8, K8, K8, false),
+ ARCH (amdfam10, AMDFAM10, AMDFAM10, false),
+ ARCH (bdver1, BD, BDVER1, false),
+ ARCH (bdver2, BD, BDVER2, false),
+ ARCH (bdver3, BD, BDVER3, false),
+ ARCH (bdver4, BD, BDVER4, false),
+ ARCH (znver1, ZNVER, ZNVER1, false),
+ ARCH (znver2, ZNVER, ZNVER2, false),
+ ARCH (znver3, ZNVER, ZNVER3, false),
+ ARCH (znver4, ZNVER, ZNVER4, false),
+ ARCH (btver1, BT, BTVER1, false),
+ ARCH (btver2, BT, BTVER2, false),
+
+ SUBARCH (8087, 8087, ANY_8087, false),
+ SUBARCH (87, NONE, ANY_8087, false), /* Disable only! */
+ SUBARCH (287, 287, ANY_287, false),
+ SUBARCH (387, 387, ANY_387, false),
+ SUBARCH (687, 687, ANY_687, false),
+ SUBARCH (cmov, CMOV, CMOV, false),
+ SUBARCH (fxsr, FXSR, ANY_FXSR, false),
+ SUBARCH (mmx, MMX, ANY_MMX, false),
+ SUBARCH (sse, SSE, ANY_SSE, false),
+ SUBARCH (sse2, SSE2, ANY_SSE2, false),
+ SUBARCH (sse3, SSE3, ANY_SSE3, false),
+ SUBARCH (sse4a, SSE4A, ANY_SSE4A, false),
+ SUBARCH (ssse3, SSSE3, ANY_SSSE3, false),
+ SUBARCH (sse4.1, SSE4_1, ANY_SSE4_1, false),
+ SUBARCH (sse4.2, SSE4_2, ANY_SSE4_2, false),
+ SUBARCH (sse4, SSE4_2, ANY_SSE4_1, false),
+ SUBARCH (avx, AVX, ANY_AVX, false),
+ SUBARCH (avx2, AVX2, ANY_AVX2, false),
+ SUBARCH (avx512f, AVX512F, ANY_AVX512F, false),
+ SUBARCH (avx512cd, AVX512CD, ANY_AVX512CD, false),
+ SUBARCH (avx512er, AVX512ER, ANY_AVX512ER, false),
+ SUBARCH (avx512pf, AVX512PF, ANY_AVX512PF, false),
+ SUBARCH (avx512dq, AVX512DQ, ANY_AVX512DQ, false),
+ SUBARCH (avx512bw, AVX512BW, ANY_AVX512BW, false),
+ SUBARCH (avx512vl, AVX512VL, ANY_AVX512VL, false),
+ SUBARCH (vmx, VMX, ANY_VMX, false),
+ SUBARCH (vmfunc, VMFUNC, ANY_VMFUNC, false),
+ SUBARCH (smx, SMX, SMX, false),
+ SUBARCH (xsave, XSAVE, ANY_XSAVE, false),
+ SUBARCH (xsaveopt, XSAVEOPT, ANY_XSAVEOPT, false),
+ SUBARCH (xsavec, XSAVEC, ANY_XSAVEC, false),
+ SUBARCH (xsaves, XSAVES, ANY_XSAVES, false),
+ SUBARCH (aes, AES, ANY_AES, false),
+ SUBARCH (pclmul, PCLMUL, ANY_PCLMUL, false),
+ SUBARCH (clmul, PCLMUL, ANY_PCLMUL, true),
+ SUBARCH (fsgsbase, FSGSBASE, FSGSBASE, false),
+ SUBARCH (rdrnd, RDRND, RDRND, false),
+ SUBARCH (f16c, F16C, ANY_F16C, false),
+ SUBARCH (bmi2, BMI2, BMI2, false),
+ SUBARCH (fma, FMA, ANY_FMA, false),
+ SUBARCH (fma4, FMA4, ANY_FMA4, false),
+ SUBARCH (xop, XOP, ANY_XOP, false),
+ SUBARCH (lwp, LWP, ANY_LWP, false),
+ SUBARCH (movbe, MOVBE, MOVBE, false),
+ SUBARCH (cx16, CX16, CX16, false),
+ SUBARCH (ept, EPT, ANY_EPT, false),
+ SUBARCH (lzcnt, LZCNT, LZCNT, false),
+ SUBARCH (popcnt, POPCNT, POPCNT, false),
+ SUBARCH (hle, HLE, HLE, false),
+ SUBARCH (rtm, RTM, ANY_RTM, false),
+ SUBARCH (tsx, TSX, TSX, false),
+ SUBARCH (invpcid, INVPCID, INVPCID, false),
+ SUBARCH (clflush, CLFLUSH, CLFLUSH, false),
+ SUBARCH (nop, NOP, NOP, false),
+ SUBARCH (syscall, SYSCALL, SYSCALL, false),
+ SUBARCH (rdtscp, RDTSCP, RDTSCP, false),
+ SUBARCH (3dnow, 3DNOW, ANY_3DNOW, false),
+ SUBARCH (3dnowa, 3DNOWA, ANY_3DNOWA, false),
+ SUBARCH (padlock, PADLOCK, PADLOCK, false),
+ SUBARCH (pacifica, SVME, ANY_SVME, true),
+ SUBARCH (svme, SVME, ANY_SVME, false),
+ SUBARCH (abm, ABM, ABM, false),
+ SUBARCH (bmi, BMI, BMI, false),
+ SUBARCH (tbm, TBM, TBM, false),
+ SUBARCH (adx, ADX, ADX, false),
+ SUBARCH (rdseed, RDSEED, RDSEED, false),
+ SUBARCH (prfchw, PRFCHW, PRFCHW, false),
+ SUBARCH (smap, SMAP, SMAP, false),
+ SUBARCH (mpx, MPX, ANY_MPX, false),
+ SUBARCH (sha, SHA, ANY_SHA, false),
+ SUBARCH (clflushopt, CLFLUSHOPT, CLFLUSHOPT, false),
+ SUBARCH (prefetchwt1, PREFETCHWT1, PREFETCHWT1, false),
+ SUBARCH (se1, SE1, SE1, false),
+ SUBARCH (clwb, CLWB, CLWB, false),
+ SUBARCH (avx512ifma, AVX512IFMA, ANY_AVX512IFMA, false),
+ SUBARCH (avx512vbmi, AVX512VBMI, ANY_AVX512VBMI, false),
+ SUBARCH (avx512_4fmaps, AVX512_4FMAPS, ANY_AVX512_4FMAPS, false),
+ SUBARCH (avx512_4vnniw, AVX512_4VNNIW, ANY_AVX512_4VNNIW, false),
+ SUBARCH (avx512_vpopcntdq, AVX512_VPOPCNTDQ, ANY_AVX512_VPOPCNTDQ, false),
+ SUBARCH (avx512_vbmi2, AVX512_VBMI2, ANY_AVX512_VBMI2, false),
+ SUBARCH (avx512_vnni, AVX512_VNNI, ANY_AVX512_VNNI, false),
+ SUBARCH (avx512_bitalg, AVX512_BITALG, ANY_AVX512_BITALG, false),
+ SUBARCH (avx_vnni, AVX_VNNI, ANY_AVX_VNNI, false),
+ SUBARCH (clzero, CLZERO, CLZERO, false),
+ SUBARCH (mwaitx, MWAITX, MWAITX, false),
+ SUBARCH (ospke, OSPKE, ANY_OSPKE, false),
+ SUBARCH (rdpid, RDPID, RDPID, false),
+ SUBARCH (ptwrite, PTWRITE, PTWRITE, false),
+ SUBARCH (ibt, IBT, IBT, false),
+ SUBARCH (shstk, SHSTK, SHSTK, false),
+ SUBARCH (gfni, GFNI, ANY_GFNI, false),
+ SUBARCH (vaes, VAES, ANY_VAES, false),
+ SUBARCH (vpclmulqdq, VPCLMULQDQ, ANY_VPCLMULQDQ, false),
+ SUBARCH (wbnoinvd, WBNOINVD, WBNOINVD, false),
+ SUBARCH (pconfig, PCONFIG, PCONFIG, false),
+ SUBARCH (waitpkg, WAITPKG, WAITPKG, false),
+ SUBARCH (cldemote, CLDEMOTE, CLDEMOTE, false),
+ SUBARCH (amx_int8, AMX_INT8, ANY_AMX_INT8, false),
+ SUBARCH (amx_bf16, AMX_BF16, ANY_AMX_BF16, false),
+ SUBARCH (amx_fp16, AMX_FP16, ANY_AMX_FP16, false),
+ SUBARCH (amx_tile, AMX_TILE, ANY_AMX_TILE, false),
+ SUBARCH (movdiri, MOVDIRI, MOVDIRI, false),
+ SUBARCH (movdir64b, MOVDIR64B, MOVDIR64B, false),
+ SUBARCH (avx512_bf16, AVX512_BF16, ANY_AVX512_BF16, false),
+ SUBARCH (avx512_vp2intersect, AVX512_VP2INTERSECT,
+ ANY_AVX512_VP2INTERSECT, false),
+ SUBARCH (tdx, TDX, TDX, false),
+ SUBARCH (enqcmd, ENQCMD, ENQCMD, false),
+ SUBARCH (serialize, SERIALIZE, SERIALIZE, false),
+ SUBARCH (rdpru, RDPRU, RDPRU, false),
+ SUBARCH (mcommit, MCOMMIT, MCOMMIT, false),
+ SUBARCH (sev_es, SEV_ES, ANY_SEV_ES, false),
+ SUBARCH (tsxldtrk, TSXLDTRK, ANY_TSXLDTRK, false),
+ SUBARCH (kl, KL, ANY_KL, false),
+ SUBARCH (widekl, WIDEKL, ANY_WIDEKL, false),
+ SUBARCH (uintr, UINTR, UINTR, false),
+ SUBARCH (hreset, HRESET, HRESET, false),
+ SUBARCH (avx512_fp16, AVX512_FP16, ANY_AVX512_FP16, false),
+ SUBARCH (prefetchi, PREFETCHI, PREFETCHI, false),
+ SUBARCH (avx_ifma, AVX_IFMA, ANY_AVX_IFMA, false),
+ SUBARCH (avx_vnni_int8, AVX_VNNI_INT8, ANY_AVX_VNNI_INT8, false),
+ SUBARCH (cmpccxadd, CMPCCXADD, CMPCCXADD, false),
+ SUBARCH (wrmsrns, WRMSRNS, WRMSRNS, false),
+ SUBARCH (msrlist, MSRLIST, MSRLIST, false),
+ SUBARCH (avx_ne_convert, AVX_NE_CONVERT, ANY_AVX_NE_CONVERT, false),
+ SUBARCH (rao_int, RAO_INT, RAO_INT, false),
+ SUBARCH (rmpquery, RMPQUERY, ANY_RMPQUERY, false),