r336933 - [Hexagon] Diagnose intrinsics not supported by selected CPU/HVX

Reid Kleckner via cfe-commits cfe-commits at lists.llvm.org
Wed Oct 24 17:02:37 PDT 2018


These static std::maps that you are using are causing compile-time problems
in clang. They generate the enormous basic blocks I was studying in
https://llvm.org/PR38829. I'm going to try to simplify this code to avoid
these dynamically initialized globals.

Please do not use this pattern again in the future.

On Thu, Jul 12, 2018 at 11:58 AM Krzysztof Parzyszek via cfe-commits <
cfe-commits at lists.llvm.org> wrote:

> Author: kparzysz
> Date: Thu Jul 12 11:54:04 2018
> New Revision: 336933
>
> URL: http://llvm.org/viewvc/llvm-project?rev=336933&view=rev
> Log:
> [Hexagon] Diagnose intrinsics not supported by selected CPU/HVX
>
> Added:
>     cfe/trunk/test/Sema/builtins-hexagon-v55.c
>     cfe/trunk/test/Sema/builtins-hexagon-v60.c
>     cfe/trunk/test/Sema/builtins-hexagon-v62.c
>     cfe/trunk/test/Sema/builtins-hexagon-v65.c
>     cfe/trunk/test/Sema/builtins-hvx-none.c
>     cfe/trunk/test/Sema/builtins-hvx-v60.c
>     cfe/trunk/test/Sema/builtins-hvx-v62.c
>     cfe/trunk/test/Sema/builtins-hvx-v65.c
> Modified:
>     cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td
>     cfe/trunk/include/clang/Sema/Sema.h
>     cfe/trunk/lib/Basic/Targets/Hexagon.cpp
>     cfe/trunk/lib/Sema/SemaChecking.cpp
>
> Modified: cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td?rev=336933&r1=336932&r2=336933&view=diff
>
> ==============================================================================
> --- cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td (original)
> +++ cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td Thu Jul 12
> 11:54:04 2018
> @@ -8181,9 +8181,15 @@ def err_x86_builtin_invalid_rounding : E
>    "invalid rounding argument">;
>  def err_x86_builtin_invalid_scale : Error<
>    "scale argument must be 1, 2, 4, or 8">;
> +def err_hexagon_builtin_unsupported_cpu : Error<
> +  "builtin is not supported on this CPU">;
> +def err_hexagon_builtin_requires_hvx : Error<
> +  "builtin requires HVX">;
> +def err_hexagon_builtin_unsupported_hvx : Error<
> +  "builtin is not supported on this version of HVX">;
> +
>  def err_builtin_target_unsupported : Error<
>    "builtin is not supported on this target">;
> -
>  def err_builtin_longjmp_unsupported : Error<
>    "__builtin_longjmp is not supported for the current target">;
>  def err_builtin_setjmp_unsupported : Error<
>
> Modified: cfe/trunk/include/clang/Sema/Sema.h
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Sema/Sema.h?rev=336933&r1=336932&r2=336933&view=diff
>
> ==============================================================================
> --- cfe/trunk/include/clang/Sema/Sema.h (original)
> +++ cfe/trunk/include/clang/Sema/Sema.h Thu Jul 12 11:54:04 2018
> @@ -10418,6 +10418,8 @@ private:
>
>    bool CheckAArch64BuiltinFunctionCall(unsigned BuiltinID, CallExpr
> *TheCall);
>    bool CheckHexagonBuiltinFunctionCall(unsigned BuiltinID, CallExpr
> *TheCall);
> +  bool CheckHexagonBuiltinCpu(unsigned BuiltinID, CallExpr *TheCall);
> +  bool CheckHexagonBuiltinArgument(unsigned BuiltinID, CallExpr *TheCall);
>    bool CheckMipsBuiltinFunctionCall(unsigned BuiltinID, CallExpr
> *TheCall);
>    bool CheckSystemZBuiltinFunctionCall(unsigned BuiltinID, CallExpr
> *TheCall);
>    bool CheckX86BuiltinRoundingOrSAE(unsigned BuiltinID, CallExpr
> *TheCall);
>
> Modified: cfe/trunk/lib/Basic/Targets/Hexagon.cpp
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Basic/Targets/Hexagon.cpp?rev=336933&r1=336932&r2=336933&view=diff
>
> ==============================================================================
> --- cfe/trunk/lib/Basic/Targets/Hexagon.cpp (original)
> +++ cfe/trunk/lib/Basic/Targets/Hexagon.cpp Thu Jul 12 11:54:04 2018
> @@ -131,6 +131,10 @@ const Builtin::Info HexagonTargetInfo::B
>  };
>
>  bool HexagonTargetInfo::hasFeature(StringRef Feature) const {
> +  std::string VS = "hvxv" + HVXVersion;
> +  if (Feature == VS)
> +    return true;
> +
>    return llvm::StringSwitch<bool>(Feature)
>        .Case("hexagon", true)
>        .Case("hvx", HasHVX)
>
> Modified: cfe/trunk/lib/Sema/SemaChecking.cpp
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaChecking.cpp?rev=336933&r1=336932&r2=336933&view=diff
>
> ==============================================================================
> --- cfe/trunk/lib/Sema/SemaChecking.cpp (original)
> +++ cfe/trunk/lib/Sema/SemaChecking.cpp Thu Jul 12 11:54:04 2018
> @@ -1731,8 +1731,791 @@ bool Sema::CheckAArch64BuiltinFunctionCa
>    return SemaBuiltinConstantArgRange(TheCall, i, l, u + l);
>  }
>
> -bool Sema::CheckHexagonBuiltinFunctionCall(unsigned BuiltinID,
> -                                           CallExpr *TheCall) {
> +bool Sema::CheckHexagonBuiltinCpu(unsigned BuiltinID, CallExpr *TheCall) {
> +  static const std::map<unsigned, std::vector<StringRef>> ValidCPU = {
> +    { Hexagon::BI__builtin_HEXAGON_A6_vcmpbeq_notany, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_A6_vminub_RdP, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_M6_vabsdiffb, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_M6_vabsdiffub, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_S6_rol_i_p_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_S6_rol_i_p_and, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_S6_rol_i_p_nac, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_S6_rol_i_p_or, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_S6_rol_i_p, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_S6_rol_i_p_xacc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_S6_rol_i_r_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_S6_rol_i_r_and, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_S6_rol_i_r_nac, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_S6_rol_i_r_or, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_S6_rol_i_r, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_S6_rol_i_r_xacc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_S6_vsplatrbp, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_S6_vtrunehb_ppp, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_S6_vtrunohb_ppp, {"v62", "v65"} },
> +  };
> +
> +  static const std::map<unsigned, std::vector<StringRef>> ValidHVX = {
> +    { Hexagon::BI__builtin_HEXAGON_V6_extractw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_extractw_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_hi, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_hi_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_lo, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_lo_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_lvsplatb, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_lvsplatb_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_lvsplath, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_lvsplath_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_lvsplatw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_lvsplatw_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_pred_and, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_pred_and_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_pred_and_n, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_pred_and_n_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_pred_not, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_pred_not_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_pred_or, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_pred_or_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_pred_or_n, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_pred_or_n_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_pred_scalar2, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_pred_scalar2_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_pred_scalar2v2, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_pred_scalar2v2_128B, {"v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_pred_xor, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_pred_xor_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_shuffeqh, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_shuffeqh_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_shuffeqw, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_shuffeqw_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsb, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsb_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsb_sat, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsb_sat_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsdiffh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsdiffh_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsdiffub, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsdiffub_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsdiffuh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsdiffuh_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsdiffw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsdiffw_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsh_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsh_sat, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsh_sat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsw_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsw_sat, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vabsw_sat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddb_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddb_dv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddb_dv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddbsat, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddbsat_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddbsat_dv, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddbsat_dv_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddcarry, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddcarry_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddclbh, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddclbh_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddclbw, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddclbw_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddh_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddh_dv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddh_dv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddhsat, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddhsat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddhsat_dv, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddhsat_dv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddhw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddhw_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddhw_acc, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddhw_acc_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddubh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddubh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddubh_acc, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddubh_acc_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddubsat, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddubsat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddubsat_dv, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddubsat_dv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddububb_sat, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddububb_sat_128B, {"v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vadduhsat, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vadduhsat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vadduhsat_dv, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vadduhsat_dv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vadduhw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vadduhw_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vadduhw_acc, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vadduhw_acc_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vadduwsat, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vadduwsat_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vadduwsat_dv, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vadduwsat_dv_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddw_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddw_dv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddw_dv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddwsat, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddwsat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddwsat_dv, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaddwsat_dv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_valignb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_valignb_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_valignbi, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_valignbi_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vand, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vand_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vandnqrt, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vandnqrt_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vandnqrt_acc, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vandnqrt_acc_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vandqrt, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vandqrt_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vandqrt_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vandqrt_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vandvnqv, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vandvnqv_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vandvqv, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vandvqv_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vandvrt, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vandvrt_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vandvrt_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vandvrt_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaslh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaslh_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaslh_acc, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaslh_acc_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaslhv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaslhv_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaslw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaslw_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaslw_acc, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaslw_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaslwv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vaslwv_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrh_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrh_acc, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrh_acc_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrhbrndsat, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrhbrndsat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrhbsat, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrhbsat_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrhubrndsat, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrhubrndsat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrhubsat, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrhubsat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrhv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrhv_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasruhubrndsat, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasruhubrndsat_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasruhubsat, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasruhubsat_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasruwuhrndsat, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasruwuhrndsat_128B, {"v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasruwuhsat, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasruwuhsat_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrw_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrw_acc, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrw_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrwh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrwh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrwhrndsat, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrwhrndsat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrwhsat, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrwhsat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrwuhrndsat, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrwuhrndsat_128B, {"v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrwuhsat, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrwuhsat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrwv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vasrwv_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vassign, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vassign_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vassignp, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vassignp_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavgb, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavgb_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavgbrnd, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavgbrnd_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavgh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavgh_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavghrnd, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavghrnd_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavgub, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavgub_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavgubrnd, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavgubrnd_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavguh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavguh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavguhrnd, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavguhrnd_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavguw, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavguw_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavguwrnd, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavguwrnd_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavgw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavgw_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavgwrnd, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vavgwrnd_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vcl0h, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vcl0h_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vcl0w, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vcl0w_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vcombine, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vcombine_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vd0, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vd0_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdd0, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdd0_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdealb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdealb_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdealb4w, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdealb4w_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdealh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdealh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdealvdd, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdealvdd_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdelta, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdelta_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpybus, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpybus_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpybus_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpybus_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpybus_dv, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpybus_dv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpybus_dv_acc, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpybus_dv_acc_128B, {"v60",
> "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhb_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhb_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhb_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhb_dv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhb_dv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhb_dv_acc, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhb_dv_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhisat, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhisat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhisat_acc, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhisat_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhsat, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhsat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhsat_acc, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhsat_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhsuisat, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhsuisat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhsuisat_acc, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhsuisat_acc_128B, {"v60",
> "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhsusat, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhsusat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhsusat_acc, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhsusat_acc_128B, {"v60",
> "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhvsat, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhvsat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhvsat_acc, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdmpyhvsat_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdsaduh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdsaduh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdsaduh_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vdsaduh_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqb_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqb_and, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqb_and_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqb_or, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqb_or_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqb_xor, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqb_xor_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqh_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqh_and, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqh_and_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqh_or, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqh_or_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqh_xor, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqh_xor_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqw_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqw_and, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqw_and_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqw_or, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqw_or_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqw_xor, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_veqw_xor_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtb_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtb_and, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtb_and_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtb_or, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtb_or_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtb_xor, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtb_xor_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgth, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgth_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgth_and, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgth_and_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgth_or, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgth_or_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgth_xor, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgth_xor_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtub, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtub_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtub_and, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtub_and_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtub_or, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtub_or_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtub_xor, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtub_xor_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtuh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtuh_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtuh_and, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtuh_and_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtuh_or, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtuh_or_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtuh_xor, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtuh_xor_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtuw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtuw_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtuw_and, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtuw_and_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtuw_or, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtuw_or_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtuw_xor, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtuw_xor_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtw_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtw_and, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtw_and_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtw_or, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtw_or_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtw_xor, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vgtw_xor_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vinsertwr, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vinsertwr_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlalignb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlalignb_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlalignbi, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlalignbi_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlsrb, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlsrb_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlsrh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlsrh_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlsrhv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlsrhv_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlsrw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlsrw_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlsrwv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlsrwv_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlut4, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlut4_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvvb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvvb_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvvbi, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvvbi_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvvb_nm, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvvb_nm_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvvb_oracc, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvvb_oracc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvvb_oracci, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvvb_oracci_128B, {"v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvwh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvwh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvwhi, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvwhi_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvwh_nm, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvwh_nm_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvwh_oracc, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvwh_oracc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvwh_oracci, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vlutvwh_oracci_128B, {"v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmaxb, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmaxb_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmaxh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmaxh_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmaxub, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmaxub_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmaxuh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmaxuh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmaxw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmaxw_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vminb, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vminb_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vminh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vminh_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vminub, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vminub_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vminuh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vminuh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vminw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vminw_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpabus, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpabus_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpabus_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpabus_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpabusv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpabusv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpabuu, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpabuu_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpabuu_acc, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpabuu_acc_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpabuuv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpabuuv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpahb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpahb_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpahb_acc, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpahb_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpahhsat, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpahhsat_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpauhb, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpauhb_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpauhb_acc, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpauhb_acc_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpauhuhsat, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpauhuhsat_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpsuhuhsat, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpsuhuhsat_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpybus, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpybus_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpybus_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpybus_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpybusv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpybusv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpybusv_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpybusv_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpybv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpybv_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpybv_acc, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpybv_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyewuh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyewuh_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyewuh_64, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyewuh_64_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyh_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyh_acc, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyh_acc_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyhsat_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyhsat_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyhsrs, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyhsrs_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyhss, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyhss_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyhus, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyhus_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyhus_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyhus_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyhv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyhv_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyhv_acc, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyhv_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyhvsrs, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyhvsrs_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyieoh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyieoh_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiewh_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiewh_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiewuh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiewuh_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiewuh_acc, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiewuh_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyih, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyih_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyih_acc, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyih_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyihb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyihb_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyihb_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyihb_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiowh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiowh_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiwb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiwb_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiwb_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiwb_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiwh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiwh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiwh_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiwh_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiwub, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiwub_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiwub_acc, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyiwub_acc_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyowh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyowh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyowh_64_acc, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyowh_64_acc_128B, {"v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyowh_rnd, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyowh_rnd_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyowh_rnd_sacc, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyowh_rnd_sacc_128B, {"v60",
> "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyowh_sacc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyowh_sacc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyub, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyub_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyub_acc, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyub_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyubv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyubv_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyubv_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyubv_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyuh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyuh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyuh_acc, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyuh_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyuhe, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyuhe_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyuhe_acc, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyuhe_acc_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyuhv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyuhv_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyuhv_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmpyuhv_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmux, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vmux_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vnavgb, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vnavgb_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vnavgh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vnavgh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vnavgub, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vnavgub_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vnavgw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vnavgw_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vnormamth, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vnormamth_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vnormamtw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vnormamtw_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vnot, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vnot_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vor, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vor_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpackeb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpackeb_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpackeh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpackeh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpackhb_sat, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpackhb_sat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpackhub_sat, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpackhub_sat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpackob, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpackob_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpackoh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpackoh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpackwh_sat, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpackwh_sat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpackwuh_sat, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpackwuh_sat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpopcounth, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vpopcounth_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vprefixqb, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vprefixqb_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vprefixqh, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vprefixqh_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vprefixqw, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vprefixqw_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrdelta, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrdelta_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybub_rtt, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybub_rtt_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybub_rtt_acc, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybub_rtt_acc_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybus, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybus_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybus_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybus_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybusi, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybusi_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybusi_acc, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybusi_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybusv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybusv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybusv_acc, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybusv_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybv_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybv_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpybv_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpyub, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpyub_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpyub_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpyub_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpyubi, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpyubi_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpyubi_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpyubi_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpyub_rtt, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpyub_rtt_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpyub_rtt_acc, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpyub_rtt_acc_128B, {"v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpyubv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpyubv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpyubv_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrmpyubv_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vror, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vror_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vroundhb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vroundhb_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vroundhub, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vroundhub_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrounduhub, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrounduhub_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrounduwuh, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrounduwuh_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vroundwh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vroundwh_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vroundwuh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vroundwuh_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrsadubi, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrsadubi_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrsadubi_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vrsadubi_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsathub, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsathub_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsatuwuh, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsatuwuh_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsatwh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsatwh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsb_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsh_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshufeh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshufeh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshuffb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshuffb_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshuffeb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshuffeb_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshuffh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshuffh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshuffob, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshuffob_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshuffvdd, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshuffvdd_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshufoeb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshufoeb_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshufoeh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshufoeh_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshufoh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vshufoh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubb_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubb_dv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubb_dv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubbsat, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubbsat_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubbsat_dv, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubbsat_dv_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubcarry, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubcarry_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubh_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubh_dv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubh_dv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubhsat, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubhsat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubhsat_dv, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubhsat_dv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubhw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubhw_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsububh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsububh_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsububsat, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsububsat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsububsat_dv, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsububsat_dv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubububb_sat, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubububb_sat_128B, {"v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubuhsat, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubuhsat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubuhsat_dv, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubuhsat_dv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubuhw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubuhw_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubuwsat, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubuwsat_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubuwsat_dv, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubuwsat_dv_128B, {"v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubw, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubw_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubw_dv, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubw_dv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubwsat, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubwsat_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubwsat_dv, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vsubwsat_dv_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vswap, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vswap_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vtmpyb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vtmpyb_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vtmpyb_acc, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vtmpyb_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vtmpybus, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vtmpybus_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vtmpybus_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vtmpybus_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vtmpyhb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vtmpyhb_128B, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vtmpyhb_acc, {"v60", "v62", "v65"}
> },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vtmpyhb_acc_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vunpackb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vunpackb_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vunpackh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vunpackh_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vunpackob, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vunpackob_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vunpackoh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vunpackoh_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vunpackub, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vunpackub_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vunpackuh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vunpackuh_128B, {"v60", "v62",
> "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vxor, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vxor_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vzb, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vzb_128B, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vzh, {"v60", "v62", "v65"} },
> +    { Hexagon::BI__builtin_HEXAGON_V6_vzh_128B, {"v60", "v62", "v65"} },
> +  };
> +
> +  const TargetInfo &TI = Context.getTargetInfo();
> +
> +  auto FC = ValidCPU.find(BuiltinID);
> +  if (FC != ValidCPU.end()) {
> +    const TargetOptions &Opts = TI.getTargetOpts();
> +    StringRef CPU = Opts.CPU;
> +    if (!CPU.empty()) {
> +      assert(CPU.startswith("hexagon") && "Unexpected CPU name");
> +      CPU.consume_front("hexagon");
> +      if (llvm::none_of(FC->second, [CPU](StringRef S) { return S == CPU;
> }))
> +        return Diag(TheCall->getLocStart(),
> +                    diag::err_hexagon_builtin_unsupported_cpu);
> +    }
> +  }
> +
> +  auto FH = ValidHVX.find(BuiltinID);
> +  if (FH != ValidHVX.end()) {
> +    if (!TI.hasFeature("hvx"))
> +      return Diag(TheCall->getLocStart(),
> +                  diag::err_hexagon_builtin_requires_hvx);
> +
> +    bool IsValid = llvm::any_of(FH->second,
> +                                [&TI] (StringRef V) {
> +                                  std::string F = "hvx" + V.str();
> +                                  return TI.hasFeature(F);
> +                                });
> +    if (!IsValid)
> +      return Diag(TheCall->getLocStart(),
> +                  diag::err_hexagon_builtin_unsupported_hvx);
> +  }
> +
> +  return false;
> +}
> +
> +bool Sema::CheckHexagonBuiltinArgument(unsigned BuiltinID, CallExpr
> *TheCall) {
>    struct ArgInfo {
>      ArgInfo(unsigned O, bool S, unsigned W, unsigned A)
>        : OpNum(O), IsSigned(S), BitWidth(W), Align(A) {}
> @@ -1950,6 +2733,13 @@ bool Sema::CheckHexagonBuiltinFunctionCa
>    return Error;
>  }
>
> +bool Sema::CheckHexagonBuiltinFunctionCall(unsigned BuiltinID,
> +                                           CallExpr *TheCall) {
> +  return CheckHexagonBuiltinCpu(BuiltinID, TheCall) ||
> +         CheckHexagonBuiltinArgument(BuiltinID, TheCall);
> +}
> +
> +
>  // CheckMipsBuiltinFunctionCall - Checks the constant value passed to the
>  // intrinsic is correct. The switch statement is ordered by DSP, MSA. The
>  // ordering for DSP is unspecified. MSA is ordered by the data format used
>
> Added: cfe/trunk/test/Sema/builtins-hexagon-v55.c
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Sema/builtins-hexagon-v55.c?rev=336933&view=auto
>
> ==============================================================================
> --- cfe/trunk/test/Sema/builtins-hexagon-v55.c (added)
> +++ cfe/trunk/test/Sema/builtins-hexagon-v55.c Thu Jul 12 11:54:04 2018
> @@ -0,0 +1,17 @@
> +// REQUIRES: hexagon-registered-target
> +// RUN: %clang_cc1 %s -triple hexagon -fsyntax-only -verify -target-cpu
> hexagonv55
> +
> +unsigned builtin_needs_v60(unsigned Rs) {
> +  // expected-error at +1 {{builtin is not supported on this CPU}}
> +  return __builtin_HEXAGON_S6_rol_i_r(Rs, 3);
> +}
> +
> +unsigned long long builtin_needs_v62(unsigned Rs) {
> +  // expected-error at +1 {{builtin is not supported on this CPU}}
> +  return __builtin_HEXAGON_S6_vsplatrbp(Rs);
> +}
> +
> +unsigned builtin_needs_v65(unsigned long long Rss, unsigned long long
> Rtt) {
> +  // expected-error at +1 {{builtin is not supported on this CPU}}
> +  return __builtin_HEXAGON_A6_vcmpbeq_notany(Rss, Rtt);
> +}
>
> Added: cfe/trunk/test/Sema/builtins-hexagon-v60.c
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Sema/builtins-hexagon-v60.c?rev=336933&view=auto
>
> ==============================================================================
> --- cfe/trunk/test/Sema/builtins-hexagon-v60.c (added)
> +++ cfe/trunk/test/Sema/builtins-hexagon-v60.c Thu Jul 12 11:54:04 2018
> @@ -0,0 +1,16 @@
> +// REQUIRES: hexagon-registered-target
> +// RUN: %clang_cc1 %s -triple hexagon -fsyntax-only -verify -target-cpu
> hexagonv60
> +
> +unsigned builtin_needs_v60(unsigned Rs) {
> +  return __builtin_HEXAGON_S6_rol_i_r(Rs, 3);
> +}
> +
> +unsigned long long builtin_needs_v62(unsigned Rs) {
> +  // expected-error at +1 {{builtin is not supported on this CPU}}
> +  return __builtin_HEXAGON_S6_vsplatrbp(Rs);
> +}
> +
> +unsigned builtin_needs_v65(unsigned long long Rss, unsigned long long
> Rtt) {
> +  // expected-error at +1 {{builtin is not supported on this CPU}}
> +  return __builtin_HEXAGON_A6_vcmpbeq_notany(Rss, Rtt);
> +}
>
> Added: cfe/trunk/test/Sema/builtins-hexagon-v62.c
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Sema/builtins-hexagon-v62.c?rev=336933&view=auto
>
> ==============================================================================
> --- cfe/trunk/test/Sema/builtins-hexagon-v62.c (added)
> +++ cfe/trunk/test/Sema/builtins-hexagon-v62.c Thu Jul 12 11:54:04 2018
> @@ -0,0 +1,15 @@
> +// REQUIRES: hexagon-registered-target
> +// RUN: %clang_cc1 %s -triple hexagon -fsyntax-only -verify -target-cpu
> hexagonv62
> +
> +unsigned builtin_needs_v60(unsigned Rs) {
> +  return __builtin_HEXAGON_S6_rol_i_r(Rs, 3);
> +}
> +
> +unsigned long long builtin_needs_v62(unsigned Rs) {
> +  return __builtin_HEXAGON_S6_vsplatrbp(Rs);
> +}
> +
> +unsigned builtin_needs_v65(unsigned long long Rss, unsigned long long
> Rtt) {
> +  // expected-error at +1 {{builtin is not supported on this CPU}}
> +  return __builtin_HEXAGON_A6_vcmpbeq_notany(Rss, Rtt);
> +}
>
> Added: cfe/trunk/test/Sema/builtins-hexagon-v65.c
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Sema/builtins-hexagon-v65.c?rev=336933&view=auto
>
> ==============================================================================
> --- cfe/trunk/test/Sema/builtins-hexagon-v65.c (added)
> +++ cfe/trunk/test/Sema/builtins-hexagon-v65.c Thu Jul 12 11:54:04 2018
> @@ -0,0 +1,15 @@
> +// REQUIRES: hexagon-registered-target
> +// RUN: %clang_cc1 %s -triple hexagon -fsyntax-only -verify -target-cpu
> hexagonv65
> +
> +// expected-no-diagnostics
> +unsigned builtin_needs_v60(unsigned Rs) {
> +  return __builtin_HEXAGON_S6_rol_i_r(Rs, 3);
> +}
> +
> +unsigned long long builtin_needs_v62(unsigned Rs) {
> +  return __builtin_HEXAGON_S6_vsplatrbp(Rs);
> +}
> +
> +unsigned builtin_needs_v65(unsigned long long Rss, unsigned long long
> Rtt) {
> +  return __builtin_HEXAGON_A6_vcmpbeq_notany(Rss, Rtt);
> +}
>
> Added: cfe/trunk/test/Sema/builtins-hvx-none.c
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Sema/builtins-hvx-none.c?rev=336933&view=auto
>
> ==============================================================================
> --- cfe/trunk/test/Sema/builtins-hvx-none.c (added)
> +++ cfe/trunk/test/Sema/builtins-hvx-none.c Thu Jul 12 11:54:04 2018
> @@ -0,0 +1,26 @@
> +// REQUIRES: hexagon-registered-target
> +// RUN: %clang_cc1 -triple hexagon %s -fsyntax-only -verify
> +
> +typedef long Vect1024 __attribute__((__vector_size__(128)))
> +    __attribute__((aligned(128)));
> +typedef long Vect2048 __attribute__((__vector_size__(256)))
> +    __attribute__((aligned(128)));
> +
> +typedef Vect1024 HVX_Vector;
> +typedef Vect2048 HVX_VectorPair;
> +
> +
> +HVX_Vector builtin_needs_v60(HVX_VectorPair a) {
> +  // expected-error at +1 {{builtin requires HVX}}
> +  return __builtin_HEXAGON_V6_hi_128B(a);
> +}
> +
> +HVX_Vector builtin_needs_v62(char a) {
> +  // expected-error at +1 {{builtin requires HVX}}
> +  return __builtin_HEXAGON_V6_lvsplatb_128B(a);
> +}
> +
> +HVX_VectorPair builtin_needs_v65() {
> +  // expected-error at +1 {{builtin requires HVX}}
> +  return __builtin_HEXAGON_V6_vdd0_128B();
> +}
>
> Added: cfe/trunk/test/Sema/builtins-hvx-v60.c
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Sema/builtins-hvx-v60.c?rev=336933&view=auto
>
> ==============================================================================
> --- cfe/trunk/test/Sema/builtins-hvx-v60.c (added)
> +++ cfe/trunk/test/Sema/builtins-hvx-v60.c Thu Jul 12 11:54:04 2018
> @@ -0,0 +1,25 @@
> +// REQUIRES: hexagon-registered-target
> +// RUN: %clang_cc1 -triple hexagon %s -target-feature +hvx-length128b
> -target-feature +hvxv60 -target-cpu hexagonv60 -fsyntax-only -verify
> +
> +typedef long Vect1024 __attribute__((__vector_size__(128)))
> +    __attribute__((aligned(128)));
> +typedef long Vect2048 __attribute__((__vector_size__(256)))
> +    __attribute__((aligned(128)));
> +
> +typedef Vect1024 HVX_Vector;
> +typedef Vect2048 HVX_VectorPair;
> +
> +
> +HVX_Vector builtin_needs_v60(HVX_VectorPair a) {
> +  return __builtin_HEXAGON_V6_hi_128B(a);
> +}
> +
> +HVX_Vector builtin_needs_v62(char a) {
> +  // expected-error at +1 {{builtin is not supported on this version of
> HVX}}
> +  return __builtin_HEXAGON_V6_lvsplatb_128B(a);
> +}
> +
> +HVX_VectorPair builtin_needs_v65() {
> +  // expected-error at +1 {{builtin is not supported on this version of
> HVX}}
> +  return __builtin_HEXAGON_V6_vdd0_128B();
> +}
>
> Added: cfe/trunk/test/Sema/builtins-hvx-v62.c
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Sema/builtins-hvx-v62.c?rev=336933&view=auto
>
> ==============================================================================
> --- cfe/trunk/test/Sema/builtins-hvx-v62.c (added)
> +++ cfe/trunk/test/Sema/builtins-hvx-v62.c Thu Jul 12 11:54:04 2018
> @@ -0,0 +1,24 @@
> +// REQUIRES: hexagon-registered-target
> +// RUN: %clang_cc1 -triple hexagon %s -target-feature +hvx-length128b
> -target-feature +hvxv62 -target-cpu hexagonv62 -fsyntax-only -verify
> +
> +typedef long Vect1024 __attribute__((__vector_size__(128)))
> +    __attribute__((aligned(128)));
> +typedef long Vect2048 __attribute__((__vector_size__(256)))
> +    __attribute__((aligned(128)));
> +
> +typedef Vect1024 HVX_Vector;
> +typedef Vect2048 HVX_VectorPair;
> +
> +
> +HVX_Vector builtin_needs_v60(HVX_VectorPair a) {
> +  return __builtin_HEXAGON_V6_hi_128B(a);
> +}
> +
> +HVX_Vector builtin_needs_v62(char a) {
> +  return __builtin_HEXAGON_V6_lvsplatb_128B(a);
> +}
> +
> +HVX_VectorPair builtin_needs_v65() {
> +  // expected-error at +1 {{builtin is not supported on this version of
> HVX}}
> +  return __builtin_HEXAGON_V6_vdd0_128B();
> +}
>
> Added: cfe/trunk/test/Sema/builtins-hvx-v65.c
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Sema/builtins-hvx-v65.c?rev=336933&view=auto
>
> ==============================================================================
> --- cfe/trunk/test/Sema/builtins-hvx-v65.c (added)
> +++ cfe/trunk/test/Sema/builtins-hvx-v65.c Thu Jul 12 11:54:04 2018
> @@ -0,0 +1,23 @@
> +// REQUIRES: hexagon-registered-target
> +// RUN: %clang_cc1 -triple hexagon %s -target-feature +hvx-length128b
> -target-feature +hvxv65 -target-cpu hexagonv65 -fsyntax-only -verify
> +
> +typedef long Vect1024 __attribute__((__vector_size__(128)))
> +    __attribute__((aligned(128)));
> +typedef long Vect2048 __attribute__((__vector_size__(256)))
> +    __attribute__((aligned(128)));
> +
> +typedef Vect1024 HVX_Vector;
> +typedef Vect2048 HVX_VectorPair;
> +
> +// expected-no-diagnostics
> +HVX_Vector builtin_needs_v60(HVX_VectorPair a) {
> +  return __builtin_HEXAGON_V6_hi_128B(a);
> +}
> +
> +HVX_Vector builtin_needs_v62(char a) {
> +  return __builtin_HEXAGON_V6_lvsplatb_128B(a);
> +}
> +
> +HVX_VectorPair builtin_needs_v65() {
> +  return __builtin_HEXAGON_V6_vdd0_128B();
> +}
>
>
> _______________________________________________
> cfe-commits mailing list
> cfe-commits at lists.llvm.org
> http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20181024/08e7f5e3/attachment-0001.html>


More information about the cfe-commits mailing list