mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-22 10:42:39 +01:00
[Hexagon] Introduce Hexagon V62
llvm-svn: 294805
This commit is contained in:
parent
306e44c0af
commit
5f0b4b1ff0
@ -5658,22 +5658,6 @@ class Hexagon_v2048v2048v1024v1024i_Intrinsic<string GCCIntSuffix>
|
||||
[llvm_v64i32_ty], [llvm_v64i32_ty,llvm_v32i32_ty,llvm_v32i32_ty,llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_LLiLLiLLi_Intrinsic<string GCCIntSuffix>
|
||||
// tag : M6_vabsdiffb
|
||||
class Hexagon_LLiLLiLLi_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_i64_ty], [llvm_i64_ty,llvm_i64_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_LLii_Intrinsic<string GCCIntSuffix>
|
||||
// tag : S6_vsplatrbp
|
||||
class Hexagon_LLii_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_i64_ty], [llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.S6_rol_i_r,SI_ftype_SISI,2)
|
||||
// tag : S6_rol_i_r
|
||||
@ -9342,6 +9326,274 @@ Hexagon_v1024v1024v512v512i_Intrinsic<"HEXAGON_V6_vlutvwh_oracc">;
|
||||
def int_hexagon_V6_vlutvwh_oracc_128B :
|
||||
Hexagon_v2048v2048v1024v1024i_Intrinsic<"HEXAGON_V6_vlutvwh_oracc_128B">;
|
||||
|
||||
///
|
||||
/// HexagonV62 intrinsics
|
||||
///
|
||||
|
||||
//
|
||||
// Hexagon_LLiLLiLLi_Intrinsic<string GCCIntSuffix>
|
||||
// tag : M6_vabsdiffb
|
||||
class Hexagon_LLiLLiLLi_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_i64_ty], [llvm_i64_ty,llvm_i64_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_LLii_Intrinsic<string GCCIntSuffix>
|
||||
// tag : S6_vsplatrbp
|
||||
class Hexagon_LLii_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_i64_ty], [llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v512v512i_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vlsrb
|
||||
class Hexagon_V62_v512v512i_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v16i32_ty], [llvm_v16i32_ty,llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v1024v1024i_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vlsrb_128B
|
||||
class Hexagon_V62_v1024v1024i_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v32i32_ty,llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v512v512v512i_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vasrwuhrndsat
|
||||
class Hexagon_V62_v512v512v512i_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v16i32_ty], [llvm_v16i32_ty,llvm_v16i32_ty,llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v1024v1024v1024i_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vasrwuhrndsat_128B
|
||||
class Hexagon_V62_v1024v1024v1024i_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v32i32_ty,llvm_v32i32_ty,llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v512v512v512_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vrounduwuh
|
||||
class Hexagon_V62_v512v512v512_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v16i32_ty], [llvm_v16i32_ty,llvm_v16i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v1024v1024v1024_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vrounduwuh_128B
|
||||
class Hexagon_V62_v1024v1024v1024_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v32i32_ty,llvm_v32i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v2048v2048v2048_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vadduwsat_dv_128B
|
||||
class Hexagon_V62_v2048v2048v2048_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v64i32_ty], [llvm_v64i32_ty,llvm_v64i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v1024v1024v512v512_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vaddhw_acc
|
||||
class Hexagon_V62_v1024v1024v512v512_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v32i32_ty,llvm_v16i32_ty,llvm_v16i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v2048v2048v1024v1024_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vaddhw_acc_128B
|
||||
class Hexagon_V62_v2048v2048v1024v1024_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v64i32_ty], [llvm_v64i32_ty,llvm_v32i32_ty,llvm_v32i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v1024v512v512_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vmpyewuh_64
|
||||
class Hexagon_V62_v1024v512v512_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v16i32_ty,llvm_v16i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v2048v1024v1024_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vmpyewuh_64_128B
|
||||
class Hexagon_V62_v2048v1024v1024_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v64i32_ty], [llvm_v32i32_ty,llvm_v32i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v2048v2048i_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vmpauhb_128B
|
||||
class Hexagon_V62_v2048v2048i_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v64i32_ty], [llvm_v64i32_ty,llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v2048v2048v2048i_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vmpauhb_acc_128B
|
||||
class Hexagon_V62_v2048v2048v2048i_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v64i32_ty], [llvm_v64i32_ty,llvm_v64i32_ty,llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v512v64ii_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vandnqrt
|
||||
class Hexagon_V62_v512v64ii_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v16i32_ty], [llvm_v512i1_ty,llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v1024v128ii_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vandnqrt_128B
|
||||
class Hexagon_V62_v1024v128ii_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v1024i1_ty,llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v512v512v64ii_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vandnqrt_acc
|
||||
class Hexagon_V62_v512v512v64ii_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v16i32_ty], [llvm_v16i32_ty,llvm_v512i1_ty,llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v1024v1024v128ii_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vandnqrt_acc_128B
|
||||
class Hexagon_V62_v1024v1024v128ii_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v32i32_ty,llvm_v1024i1_ty,llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v512v64iv512_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vandvqv
|
||||
class Hexagon_V62_v512v64iv512_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v16i32_ty], [llvm_v512i1_ty,llvm_v16i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v1024v128iv1024_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vandvqv_128B
|
||||
class Hexagon_V62_v1024v128iv1024_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v1024i1_ty,llvm_v32i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v64ii_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_pred_scalar2v2
|
||||
class Hexagon_V62_v64ii_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v512i1_ty], [llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v128ii_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_pred_scalar2v2_128B
|
||||
class Hexagon_V62_v128ii_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v1024i1_ty], [llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v64iv64iv64i_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_shuffeqw
|
||||
class Hexagon_V62_v64iv64iv64i_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v512i1_ty], [llvm_v512i1_ty,llvm_v512i1_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v128iv128iv128i_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_shuffeqw_128B
|
||||
class Hexagon_V62_v128iv128iv128i_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v1024i1_ty], [llvm_v1024i1_ty,llvm_v1024i1_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v512i_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_lvsplath
|
||||
class Hexagon_V62_v512i_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v16i32_ty], [llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v1024i_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_lvsplath_128B
|
||||
class Hexagon_V62_v1024i_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v512v512v512v512i_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vlutvvb_oracci
|
||||
class Hexagon_V62_v512v512v512v512i_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v16i32_ty], [llvm_v16i32_ty,llvm_v16i32_ty,llvm_v16i32_ty,llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v1024v1024v1024v1024i_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vlutvvb_oracci_128B
|
||||
class Hexagon_V62_v1024v1024v1024v1024i_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v32i32_ty,llvm_v32i32_ty,llvm_v32i32_ty,llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v1024v512v512i_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vlutvwhi
|
||||
class Hexagon_V62_v1024v512v512i_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v16i32_ty,llvm_v16i32_ty,llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v2048v1024v1024i_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vlutvwhi_128B
|
||||
class Hexagon_V62_v2048v1024v1024i_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v64i32_ty], [llvm_v32i32_ty,llvm_v32i32_ty,llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v1024v1024v512v512i_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vlutvwh_oracci
|
||||
class Hexagon_V62_v1024v1024v512v512i_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v32i32_ty,llvm_v16i32_ty,llvm_v16i32_ty,llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// Hexagon_V62_v2048v2048v1024v1024i_Intrinsic<string GCCIntSuffix>
|
||||
// tag : V6_vlutvwh_oracci_128B
|
||||
class Hexagon_V62_v2048v2048v1024v1024i_Intrinsic<string GCCIntSuffix>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v64i32_ty], [llvm_v64i32_ty,llvm_v32i32_ty,llvm_v32i32_ty,llvm_i32_ty],
|
||||
[IntrNoMem]>;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.M6_vabsdiffb,DI_ftype_DIDI,2)
|
||||
// tag : M6_vabsdiffb
|
||||
@ -9354,12 +9606,6 @@ Hexagon_LLiLLiLLi_Intrinsic<"HEXAGON_M6_vabsdiffb">;
|
||||
def int_hexagon_M6_vabsdiffub :
|
||||
Hexagon_LLiLLiLLi_Intrinsic<"HEXAGON_M6_vabsdiffub">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.S6_vsplatrbp,DI_ftype_SI,1)
|
||||
// tag : S6_vsplatrbp
|
||||
def int_hexagon_S6_vsplatrbp :
|
||||
Hexagon_LLii_Intrinsic<"HEXAGON_S6_vsplatrbp">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.S6_vtrunehb_ppp,DI_ftype_DIDI,2)
|
||||
// tag : S6_vtrunehb_ppp
|
||||
@ -9371,3 +9617,550 @@ Hexagon_LLiLLiLLi_Intrinsic<"HEXAGON_S6_vtrunehb_ppp">;
|
||||
// tag : S6_vtrunohb_ppp
|
||||
def int_hexagon_S6_vtrunohb_ppp :
|
||||
Hexagon_LLiLLiLLi_Intrinsic<"HEXAGON_S6_vtrunohb_ppp">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.S6_vsplatrbp,DI_ftype_SI,1)
|
||||
// tag : S6_vsplatrbp
|
||||
def int_hexagon_S6_vsplatrbp :
|
||||
Hexagon_LLii_Intrinsic<"HEXAGON_S6_vsplatrbp">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vlsrb,VI_ftype_VISI,2)
|
||||
// tag : V6_vlsrb
|
||||
def int_hexagon_V6_vlsrb :
|
||||
Hexagon_V62_v512v512i_Intrinsic<"HEXAGON_V6_vlsrb">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vlsrb_128B,VI_ftype_VISI,2)
|
||||
// tag : V6_vlsrb_128B
|
||||
def int_hexagon_V6_vlsrb_128B :
|
||||
Hexagon_V62_v1024v1024i_Intrinsic<"HEXAGON_V6_vlsrb_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vasrwuhrndsat,VI_ftype_VIVISI,3)
|
||||
// tag : V6_vasrwuhrndsat
|
||||
def int_hexagon_V6_vasrwuhrndsat :
|
||||
Hexagon_V62_v512v512v512i_Intrinsic<"HEXAGON_V6_vasrwuhrndsat">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vasrwuhrndsat_128B,VI_ftype_VIVISI,3)
|
||||
// tag : V6_vasrwuhrndsat_128B
|
||||
def int_hexagon_V6_vasrwuhrndsat_128B :
|
||||
Hexagon_V62_v1024v1024v1024i_Intrinsic<"HEXAGON_V6_vasrwuhrndsat_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vasruwuhrndsat,VI_ftype_VIVISI,3)
|
||||
// tag : V6_vasruwuhrndsat
|
||||
def int_hexagon_V6_vasruwuhrndsat :
|
||||
Hexagon_V62_v512v512v512i_Intrinsic<"HEXAGON_V6_vasruwuhrndsat">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vasruwuhrndsat_128B,VI_ftype_VIVISI,3)
|
||||
// tag : V6_vasruwuhrndsat_128B
|
||||
def int_hexagon_V6_vasruwuhrndsat_128B :
|
||||
Hexagon_V62_v1024v1024v1024i_Intrinsic<"HEXAGON_V6_vasruwuhrndsat_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vasrhbsat,VI_ftype_VIVISI,3)
|
||||
// tag : V6_vasrhbsat
|
||||
def int_hexagon_V6_vasrhbsat :
|
||||
Hexagon_V62_v512v512v512i_Intrinsic<"HEXAGON_V6_vasrhbsat">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vasrhbsat_128B,VI_ftype_VIVISI,3)
|
||||
// tag : V6_vasrhbsat_128B
|
||||
def int_hexagon_V6_vasrhbsat_128B :
|
||||
Hexagon_V62_v1024v1024v1024i_Intrinsic<"HEXAGON_V6_vasrhbsat_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vrounduwuh,VI_ftype_VIVI,2)
|
||||
// tag : V6_vrounduwuh
|
||||
def int_hexagon_V6_vrounduwuh :
|
||||
Hexagon_V62_v512v512v512_Intrinsic<"HEXAGON_V6_vrounduwuh">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vrounduwuh_128B,VI_ftype_VIVI,2)
|
||||
// tag : V6_vrounduwuh_128B
|
||||
def int_hexagon_V6_vrounduwuh_128B :
|
||||
Hexagon_V62_v1024v1024v1024_Intrinsic<"HEXAGON_V6_vrounduwuh_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vrounduhub,VI_ftype_VIVI,2)
|
||||
// tag : V6_vrounduhub
|
||||
def int_hexagon_V6_vrounduhub :
|
||||
Hexagon_V62_v512v512v512_Intrinsic<"HEXAGON_V6_vrounduhub">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vrounduhub_128B,VI_ftype_VIVI,2)
|
||||
// tag : V6_vrounduhub_128B
|
||||
def int_hexagon_V6_vrounduhub_128B :
|
||||
Hexagon_V62_v1024v1024v1024_Intrinsic<"HEXAGON_V6_vrounduhub_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vadduwsat,VI_ftype_VIVI,2)
|
||||
// tag : V6_vadduwsat
|
||||
def int_hexagon_V6_vadduwsat :
|
||||
Hexagon_V62_v512v512v512_Intrinsic<"HEXAGON_V6_vadduwsat">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vadduwsat_128B,VI_ftype_VIVI,2)
|
||||
// tag : V6_vadduwsat_128B
|
||||
def int_hexagon_V6_vadduwsat_128B :
|
||||
Hexagon_V62_v1024v1024v1024_Intrinsic<"HEXAGON_V6_vadduwsat_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vadduwsat_dv,VD_ftype_VDVD,2)
|
||||
// tag : V6_vadduwsat_dv
|
||||
def int_hexagon_V6_vadduwsat_dv :
|
||||
Hexagon_V62_v1024v1024v1024_Intrinsic<"HEXAGON_V6_vadduwsat_dv">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vadduwsat_dv_128B,VD_ftype_VDVD,2)
|
||||
// tag : V6_vadduwsat_dv_128B
|
||||
def int_hexagon_V6_vadduwsat_dv_128B :
|
||||
Hexagon_V62_v2048v2048v2048_Intrinsic<"HEXAGON_V6_vadduwsat_dv_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vsubuwsat,VI_ftype_VIVI,2)
|
||||
// tag : V6_vsubuwsat
|
||||
def int_hexagon_V6_vsubuwsat :
|
||||
Hexagon_V62_v512v512v512_Intrinsic<"HEXAGON_V6_vsubuwsat">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vsubuwsat_128B,VI_ftype_VIVI,2)
|
||||
// tag : V6_vsubuwsat_128B
|
||||
def int_hexagon_V6_vsubuwsat_128B :
|
||||
Hexagon_V62_v1024v1024v1024_Intrinsic<"HEXAGON_V6_vsubuwsat_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vsubuwsat_dv,VD_ftype_VDVD,2)
|
||||
// tag : V6_vsubuwsat_dv
|
||||
def int_hexagon_V6_vsubuwsat_dv :
|
||||
Hexagon_V62_v1024v1024v1024_Intrinsic<"HEXAGON_V6_vsubuwsat_dv">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vsubuwsat_dv_128B,VD_ftype_VDVD,2)
|
||||
// tag : V6_vsubuwsat_dv_128B
|
||||
def int_hexagon_V6_vsubuwsat_dv_128B :
|
||||
Hexagon_V62_v2048v2048v2048_Intrinsic<"HEXAGON_V6_vsubuwsat_dv_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vaddbsat,VI_ftype_VIVI,2)
|
||||
// tag : V6_vaddbsat
|
||||
def int_hexagon_V6_vaddbsat :
|
||||
Hexagon_V62_v512v512v512_Intrinsic<"HEXAGON_V6_vaddbsat">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vaddbsat_128B,VI_ftype_VIVI,2)
|
||||
// tag : V6_vaddbsat_128B
|
||||
def int_hexagon_V6_vaddbsat_128B :
|
||||
Hexagon_V62_v1024v1024v1024_Intrinsic<"HEXAGON_V6_vaddbsat_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vaddbsat_dv,VD_ftype_VDVD,2)
|
||||
// tag : V6_vaddbsat_dv
|
||||
def int_hexagon_V6_vaddbsat_dv :
|
||||
Hexagon_V62_v1024v1024v1024_Intrinsic<"HEXAGON_V6_vaddbsat_dv">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vaddbsat_dv_128B,VD_ftype_VDVD,2)
|
||||
// tag : V6_vaddbsat_dv_128B
|
||||
def int_hexagon_V6_vaddbsat_dv_128B :
|
||||
Hexagon_V62_v2048v2048v2048_Intrinsic<"HEXAGON_V6_vaddbsat_dv_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vsubbsat,VI_ftype_VIVI,2)
|
||||
// tag : V6_vsubbsat
|
||||
def int_hexagon_V6_vsubbsat :
|
||||
Hexagon_V62_v512v512v512_Intrinsic<"HEXAGON_V6_vsubbsat">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vsubbsat_128B,VI_ftype_VIVI,2)
|
||||
// tag : V6_vsubbsat_128B
|
||||
def int_hexagon_V6_vsubbsat_128B :
|
||||
Hexagon_V62_v1024v1024v1024_Intrinsic<"HEXAGON_V6_vsubbsat_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vsubbsat_dv,VD_ftype_VDVD,2)
|
||||
// tag : V6_vsubbsat_dv
|
||||
def int_hexagon_V6_vsubbsat_dv :
|
||||
Hexagon_V62_v1024v1024v1024_Intrinsic<"HEXAGON_V6_vsubbsat_dv">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vsubbsat_dv_128B,VD_ftype_VDVD,2)
|
||||
// tag : V6_vsubbsat_dv_128B
|
||||
def int_hexagon_V6_vsubbsat_dv_128B :
|
||||
Hexagon_V62_v2048v2048v2048_Intrinsic<"HEXAGON_V6_vsubbsat_dv_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vaddububb_sat,VI_ftype_VIVI,2)
|
||||
// tag : V6_vaddububb_sat
|
||||
def int_hexagon_V6_vaddububb_sat :
|
||||
Hexagon_V62_v512v512v512_Intrinsic<"HEXAGON_V6_vaddububb_sat">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vaddububb_sat_128B,VI_ftype_VIVI,2)
|
||||
// tag : V6_vaddububb_sat_128B
|
||||
def int_hexagon_V6_vaddububb_sat_128B :
|
||||
Hexagon_V62_v1024v1024v1024_Intrinsic<"HEXAGON_V6_vaddububb_sat_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vsubububb_sat,VI_ftype_VIVI,2)
|
||||
// tag : V6_vsubububb_sat
|
||||
def int_hexagon_V6_vsubububb_sat :
|
||||
Hexagon_V62_v512v512v512_Intrinsic<"HEXAGON_V6_vsubububb_sat">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vsubububb_sat_128B,VI_ftype_VIVI,2)
|
||||
// tag : V6_vsubububb_sat_128B
|
||||
def int_hexagon_V6_vsubububb_sat_128B :
|
||||
Hexagon_V62_v1024v1024v1024_Intrinsic<"HEXAGON_V6_vsubububb_sat_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vaddhw_acc,VD_ftype_VDVIVI,3)
|
||||
// tag : V6_vaddhw_acc
|
||||
def int_hexagon_V6_vaddhw_acc :
|
||||
Hexagon_V62_v1024v1024v512v512_Intrinsic<"HEXAGON_V6_vaddhw_acc">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vaddhw_acc_128B,VD_ftype_VDVIVI,3)
|
||||
// tag : V6_vaddhw_acc_128B
|
||||
def int_hexagon_V6_vaddhw_acc_128B :
|
||||
Hexagon_V62_v2048v2048v1024v1024_Intrinsic<"HEXAGON_V6_vaddhw_acc_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vadduhw_acc,VD_ftype_VDVIVI,3)
|
||||
// tag : V6_vadduhw_acc
|
||||
def int_hexagon_V6_vadduhw_acc :
|
||||
Hexagon_V62_v1024v1024v512v512_Intrinsic<"HEXAGON_V6_vadduhw_acc">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vadduhw_acc_128B,VD_ftype_VDVIVI,3)
|
||||
// tag : V6_vadduhw_acc_128B
|
||||
def int_hexagon_V6_vadduhw_acc_128B :
|
||||
Hexagon_V62_v2048v2048v1024v1024_Intrinsic<"HEXAGON_V6_vadduhw_acc_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vaddubh_acc,VD_ftype_VDVIVI,3)
|
||||
// tag : V6_vaddubh_acc
|
||||
def int_hexagon_V6_vaddubh_acc :
|
||||
Hexagon_V62_v1024v1024v512v512_Intrinsic<"HEXAGON_V6_vaddubh_acc">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vaddubh_acc_128B,VD_ftype_VDVIVI,3)
|
||||
// tag : V6_vaddubh_acc_128B
|
||||
def int_hexagon_V6_vaddubh_acc_128B :
|
||||
Hexagon_V62_v2048v2048v1024v1024_Intrinsic<"HEXAGON_V6_vaddubh_acc_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vmpyewuh_64,VD_ftype_VIVI,2)
|
||||
// tag : V6_vmpyewuh_64
|
||||
def int_hexagon_V6_vmpyewuh_64 :
|
||||
Hexagon_V62_v1024v512v512_Intrinsic<"HEXAGON_V6_vmpyewuh_64">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vmpyewuh_64_128B,VD_ftype_VIVI,2)
|
||||
// tag : V6_vmpyewuh_64_128B
|
||||
def int_hexagon_V6_vmpyewuh_64_128B :
|
||||
Hexagon_V62_v2048v1024v1024_Intrinsic<"HEXAGON_V6_vmpyewuh_64_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vmpyowh_64_acc,VD_ftype_VDVIVI,3)
|
||||
// tag : V6_vmpyowh_64_acc
|
||||
def int_hexagon_V6_vmpyowh_64_acc :
|
||||
Hexagon_V62_v1024v1024v512v512_Intrinsic<"HEXAGON_V6_vmpyowh_64_acc">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vmpyowh_64_acc_128B,VD_ftype_VDVIVI,3)
|
||||
// tag : V6_vmpyowh_64_acc_128B
|
||||
def int_hexagon_V6_vmpyowh_64_acc_128B :
|
||||
Hexagon_V62_v2048v2048v1024v1024_Intrinsic<"HEXAGON_V6_vmpyowh_64_acc_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vmpauhb,VD_ftype_VDSI,2)
|
||||
// tag : V6_vmpauhb
|
||||
def int_hexagon_V6_vmpauhb :
|
||||
Hexagon_V62_v1024v1024i_Intrinsic<"HEXAGON_V6_vmpauhb">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vmpauhb_128B,VD_ftype_VDSI,2)
|
||||
// tag : V6_vmpauhb_128B
|
||||
def int_hexagon_V6_vmpauhb_128B :
|
||||
Hexagon_V62_v2048v2048i_Intrinsic<"HEXAGON_V6_vmpauhb_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vmpauhb_acc,VD_ftype_VDVDSI,3)
|
||||
// tag : V6_vmpauhb_acc
|
||||
def int_hexagon_V6_vmpauhb_acc :
|
||||
Hexagon_V62_v1024v1024v1024i_Intrinsic<"HEXAGON_V6_vmpauhb_acc">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vmpauhb_acc_128B,VD_ftype_VDVDSI,3)
|
||||
// tag : V6_vmpauhb_acc_128B
|
||||
def int_hexagon_V6_vmpauhb_acc_128B :
|
||||
Hexagon_V62_v2048v2048v2048i_Intrinsic<"HEXAGON_V6_vmpauhb_acc_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vmpyiwub,VI_ftype_VISI,2)
|
||||
// tag : V6_vmpyiwub
|
||||
def int_hexagon_V6_vmpyiwub :
|
||||
Hexagon_V62_v512v512i_Intrinsic<"HEXAGON_V6_vmpyiwub">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vmpyiwub_128B,VI_ftype_VISI,2)
|
||||
// tag : V6_vmpyiwub_128B
|
||||
def int_hexagon_V6_vmpyiwub_128B :
|
||||
Hexagon_V62_v1024v1024i_Intrinsic<"HEXAGON_V6_vmpyiwub_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vmpyiwub_acc,VI_ftype_VIVISI,3)
|
||||
// tag : V6_vmpyiwub_acc
|
||||
def int_hexagon_V6_vmpyiwub_acc :
|
||||
Hexagon_V62_v512v512v512i_Intrinsic<"HEXAGON_V6_vmpyiwub_acc">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vmpyiwub_acc_128B,VI_ftype_VIVISI,3)
|
||||
// tag : V6_vmpyiwub_acc_128B
|
||||
def int_hexagon_V6_vmpyiwub_acc_128B :
|
||||
Hexagon_V62_v1024v1024v1024i_Intrinsic<"HEXAGON_V6_vmpyiwub_acc_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vandnqrt,VI_ftype_QVSI,2)
|
||||
// tag : V6_vandnqrt
|
||||
def int_hexagon_V6_vandnqrt :
|
||||
Hexagon_V62_v512v64ii_Intrinsic<"HEXAGON_V6_vandnqrt">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vandnqrt_128B,VI_ftype_QVSI,2)
|
||||
// tag : V6_vandnqrt_128B
|
||||
def int_hexagon_V6_vandnqrt_128B :
|
||||
Hexagon_V62_v1024v128ii_Intrinsic<"HEXAGON_V6_vandnqrt_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vandnqrt_acc,VI_ftype_VIQVSI,3)
|
||||
// tag : V6_vandnqrt_acc
|
||||
def int_hexagon_V6_vandnqrt_acc :
|
||||
Hexagon_V62_v512v512v64ii_Intrinsic<"HEXAGON_V6_vandnqrt_acc">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vandnqrt_acc_128B,VI_ftype_VIQVSI,3)
|
||||
// tag : V6_vandnqrt_acc_128B
|
||||
def int_hexagon_V6_vandnqrt_acc_128B :
|
||||
Hexagon_V62_v1024v1024v128ii_Intrinsic<"HEXAGON_V6_vandnqrt_acc_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vandvqv,VI_ftype_QVVI,2)
|
||||
// tag : V6_vandvqv
|
||||
def int_hexagon_V6_vandvqv :
|
||||
Hexagon_V62_v512v64iv512_Intrinsic<"HEXAGON_V6_vandvqv">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vandvqv_128B,VI_ftype_QVVI,2)
|
||||
// tag : V6_vandvqv_128B
|
||||
def int_hexagon_V6_vandvqv_128B :
|
||||
Hexagon_V62_v1024v128iv1024_Intrinsic<"HEXAGON_V6_vandvqv_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vandvnqv,VI_ftype_QVVI,2)
|
||||
// tag : V6_vandvnqv
|
||||
def int_hexagon_V6_vandvnqv :
|
||||
Hexagon_V62_v512v64iv512_Intrinsic<"HEXAGON_V6_vandvnqv">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vandvnqv_128B,VI_ftype_QVVI,2)
|
||||
// tag : V6_vandvnqv_128B
|
||||
def int_hexagon_V6_vandvnqv_128B :
|
||||
Hexagon_V62_v1024v128iv1024_Intrinsic<"HEXAGON_V6_vandvnqv_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_pred_scalar2v2,QV_ftype_SI,1)
|
||||
// tag : V6_pred_scalar2v2
|
||||
def int_hexagon_V6_pred_scalar2v2 :
|
||||
Hexagon_V62_v64ii_Intrinsic<"HEXAGON_V6_pred_scalar2v2">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_pred_scalar2v2_128B,QV_ftype_SI,1)
|
||||
// tag : V6_pred_scalar2v2_128B
|
||||
def int_hexagon_V6_pred_scalar2v2_128B :
|
||||
Hexagon_V62_v128ii_Intrinsic<"HEXAGON_V6_pred_scalar2v2_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_shuffeqw,QV_ftype_QVQV,2)
|
||||
// tag : V6_shuffeqw
|
||||
def int_hexagon_V6_shuffeqw :
|
||||
Hexagon_V62_v64iv64iv64i_Intrinsic<"HEXAGON_V6_shuffeqw">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_shuffeqw_128B,QV_ftype_QVQV,2)
|
||||
// tag : V6_shuffeqw_128B
|
||||
def int_hexagon_V6_shuffeqw_128B :
|
||||
Hexagon_V62_v128iv128iv128i_Intrinsic<"HEXAGON_V6_shuffeqw_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_shuffeqh,QV_ftype_QVQV,2)
|
||||
// tag : V6_shuffeqh
|
||||
def int_hexagon_V6_shuffeqh :
|
||||
Hexagon_V62_v64iv64iv64i_Intrinsic<"HEXAGON_V6_shuffeqh">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_shuffeqh_128B,QV_ftype_QVQV,2)
|
||||
// tag : V6_shuffeqh_128B
|
||||
def int_hexagon_V6_shuffeqh_128B :
|
||||
Hexagon_V62_v128iv128iv128i_Intrinsic<"HEXAGON_V6_shuffeqh_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vmaxb,VI_ftype_VIVI,2)
|
||||
// tag : V6_vmaxb
|
||||
def int_hexagon_V6_vmaxb :
|
||||
Hexagon_V62_v512v512v512_Intrinsic<"HEXAGON_V6_vmaxb">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vmaxb_128B,VI_ftype_VIVI,2)
|
||||
// tag : V6_vmaxb_128B
|
||||
def int_hexagon_V6_vmaxb_128B :
|
||||
Hexagon_V62_v1024v1024v1024_Intrinsic<"HEXAGON_V6_vmaxb_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vminb,VI_ftype_VIVI,2)
|
||||
// tag : V6_vminb
|
||||
def int_hexagon_V6_vminb :
|
||||
Hexagon_V62_v512v512v512_Intrinsic<"HEXAGON_V6_vminb">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vminb_128B,VI_ftype_VIVI,2)
|
||||
// tag : V6_vminb_128B
|
||||
def int_hexagon_V6_vminb_128B :
|
||||
Hexagon_V62_v1024v1024v1024_Intrinsic<"HEXAGON_V6_vminb_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vsatuwuh,VI_ftype_VIVI,2)
|
||||
// tag : V6_vsatuwuh
|
||||
def int_hexagon_V6_vsatuwuh :
|
||||
Hexagon_V62_v512v512v512_Intrinsic<"HEXAGON_V6_vsatuwuh">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vsatuwuh_128B,VI_ftype_VIVI,2)
|
||||
// tag : V6_vsatuwuh_128B
|
||||
def int_hexagon_V6_vsatuwuh_128B :
|
||||
Hexagon_V62_v1024v1024v1024_Intrinsic<"HEXAGON_V6_vsatuwuh_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_lvsplath,VI_ftype_SI,1)
|
||||
// tag : V6_lvsplath
|
||||
def int_hexagon_V6_lvsplath :
|
||||
Hexagon_V62_v512i_Intrinsic<"HEXAGON_V6_lvsplath">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_lvsplath_128B,VI_ftype_SI,1)
|
||||
// tag : V6_lvsplath_128B
|
||||
def int_hexagon_V6_lvsplath_128B :
|
||||
Hexagon_V62_v1024i_Intrinsic<"HEXAGON_V6_lvsplath_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_lvsplatb,VI_ftype_SI,1)
|
||||
// tag : V6_lvsplatb
|
||||
def int_hexagon_V6_lvsplatb :
|
||||
Hexagon_V62_v512i_Intrinsic<"HEXAGON_V6_lvsplatb">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_lvsplatb_128B,VI_ftype_SI,1)
|
||||
// tag : V6_lvsplatb_128B
|
||||
def int_hexagon_V6_lvsplatb_128B :
|
||||
Hexagon_V62_v1024i_Intrinsic<"HEXAGON_V6_lvsplatb_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vaddclbw,VI_ftype_VIVI,2)
|
||||
// tag : V6_vaddclbw
|
||||
def int_hexagon_V6_vaddclbw :
|
||||
Hexagon_V62_v512v512v512_Intrinsic<"HEXAGON_V6_vaddclbw">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vaddclbw_128B,VI_ftype_VIVI,2)
|
||||
// tag : V6_vaddclbw_128B
|
||||
def int_hexagon_V6_vaddclbw_128B :
|
||||
Hexagon_V62_v1024v1024v1024_Intrinsic<"HEXAGON_V6_vaddclbw_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vaddclbh,VI_ftype_VIVI,2)
|
||||
// tag : V6_vaddclbh
|
||||
def int_hexagon_V6_vaddclbh :
|
||||
Hexagon_V62_v512v512v512_Intrinsic<"HEXAGON_V6_vaddclbh">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vaddclbh_128B,VI_ftype_VIVI,2)
|
||||
// tag : V6_vaddclbh_128B
|
||||
def int_hexagon_V6_vaddclbh_128B :
|
||||
Hexagon_V62_v1024v1024v1024_Intrinsic<"HEXAGON_V6_vaddclbh_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vlutvvbi,VI_ftype_VIVISI,3)
|
||||
// tag : V6_vlutvvbi
|
||||
def int_hexagon_V6_vlutvvbi :
|
||||
Hexagon_V62_v512v512v512i_Intrinsic<"HEXAGON_V6_vlutvvbi">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vlutvvbi_128B,VI_ftype_VIVISI,3)
|
||||
// tag : V6_vlutvvbi_128B
|
||||
def int_hexagon_V6_vlutvvbi_128B :
|
||||
Hexagon_V62_v1024v1024v1024i_Intrinsic<"HEXAGON_V6_vlutvvbi_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vlutvvb_oracci,VI_ftype_VIVIVISI,4)
|
||||
// tag : V6_vlutvvb_oracci
|
||||
def int_hexagon_V6_vlutvvb_oracci :
|
||||
Hexagon_V62_v512v512v512v512i_Intrinsic<"HEXAGON_V6_vlutvvb_oracci">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vlutvvb_oracci_128B,VI_ftype_VIVIVISI,4)
|
||||
// tag : V6_vlutvvb_oracci_128B
|
||||
def int_hexagon_V6_vlutvvb_oracci_128B :
|
||||
Hexagon_V62_v1024v1024v1024v1024i_Intrinsic<"HEXAGON_V6_vlutvvb_oracci_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vlutvwhi,VD_ftype_VIVISI,3)
|
||||
// tag : V6_vlutvwhi
|
||||
def int_hexagon_V6_vlutvwhi :
|
||||
Hexagon_V62_v1024v512v512i_Intrinsic<"HEXAGON_V6_vlutvwhi">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vlutvwhi_128B,VD_ftype_VIVISI,3)
|
||||
// tag : V6_vlutvwhi_128B
|
||||
def int_hexagon_V6_vlutvwhi_128B :
|
||||
Hexagon_V62_v2048v1024v1024i_Intrinsic<"HEXAGON_V6_vlutvwhi_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vlutvwh_oracci,VD_ftype_VDVIVISI,4)
|
||||
// tag : V6_vlutvwh_oracci
|
||||
def int_hexagon_V6_vlutvwh_oracci :
|
||||
Hexagon_V62_v1024v1024v512v512i_Intrinsic<"HEXAGON_V6_vlutvwh_oracci">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vlutvwh_oracci_128B,VD_ftype_VDVIVISI,4)
|
||||
// tag : V6_vlutvwh_oracci_128B
|
||||
def int_hexagon_V6_vlutvwh_oracci_128B :
|
||||
Hexagon_V62_v2048v2048v1024v1024i_Intrinsic<"HEXAGON_V6_vlutvwh_oracci_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vlutvvb_nm,VI_ftype_VIVISI,3)
|
||||
// tag : V6_vlutvvb_nm
|
||||
def int_hexagon_V6_vlutvvb_nm :
|
||||
Hexagon_V62_v512v512v512i_Intrinsic<"HEXAGON_V6_vlutvvb_nm">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vlutvvb_nm_128B,VI_ftype_VIVISI,3)
|
||||
// tag : V6_vlutvvb_nm_128B
|
||||
def int_hexagon_V6_vlutvvb_nm_128B :
|
||||
Hexagon_V62_v1024v1024v1024i_Intrinsic<"HEXAGON_V6_vlutvvb_nm_128B">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vlutvwh_nm,VD_ftype_VIVISI,3)
|
||||
// tag : V6_vlutvwh_nm
|
||||
def int_hexagon_V6_vlutvwh_nm :
|
||||
Hexagon_V62_v1024v512v512i_Intrinsic<"HEXAGON_V6_vlutvwh_nm">;
|
||||
|
||||
//
|
||||
// BUILTIN_INFO(HEXAGON.V6_vlutvwh_nm_128B,VD_ftype_VIVISI,3)
|
||||
// tag : V6_vlutvwh_nm_128B
|
||||
def int_hexagon_V6_vlutvwh_nm_128B :
|
||||
Hexagon_V62_v2048v1024v1024i_Intrinsic<"HEXAGON_V6_vlutvwh_nm_128B">;
|
||||
|
||||
|
@ -556,6 +556,7 @@ enum {
|
||||
EF_HEXAGON_MACH_V5 = 0x00000004, // Hexagon V5
|
||||
EF_HEXAGON_MACH_V55 = 0x00000005, // Hexagon V55
|
||||
EF_HEXAGON_MACH_V60 = 0x00000060, // Hexagon V60
|
||||
EF_HEXAGON_MACH_V62 = 0x00000062, // Hexagon V62
|
||||
|
||||
// Highest ISA version flags
|
||||
EF_HEXAGON_ISA_MACH = 0x00000000, // Same as specified in bits[11:0]
|
||||
@ -566,6 +567,7 @@ enum {
|
||||
EF_HEXAGON_ISA_V5 = 0x00000040, // Hexagon V5 ISA
|
||||
EF_HEXAGON_ISA_V55 = 0x00000050, // Hexagon V55 ISA
|
||||
EF_HEXAGON_ISA_V60 = 0x00000060, // Hexagon V60 ISA
|
||||
EF_HEXAGON_ISA_V62 = 0x00000062, // Hexagon V62 ISA
|
||||
};
|
||||
|
||||
// Hexagon-specific section indexes for common small data
|
||||
|
@ -907,6 +907,9 @@ bool HexagonAsmParser::ParseDirectiveComm(bool IsLocal, SMLoc Loc) {
|
||||
|
||||
// validate register against architecture
|
||||
bool HexagonAsmParser::RegisterMatchesArch(unsigned MatchNum) const {
|
||||
if (HexagonMCRegisterClasses[Hexagon::V62RegsRegClassID].contains(MatchNum))
|
||||
if (!getSTI().getFeatureBits()[Hexagon::ArchV62])
|
||||
return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
@ -1012,11 +1015,15 @@ bool HexagonAsmParser::parseOperand(OperandVector &Operands) {
|
||||
bool HexagonAsmParser::isLabel(AsmToken &Token) {
|
||||
MCAsmLexer &Lexer = getLexer();
|
||||
AsmToken const &Second = Lexer.getTok();
|
||||
AsmToken Third = Lexer.peekTok();
|
||||
AsmToken Third = Lexer.peekTok();
|
||||
StringRef String = Token.getString();
|
||||
if (Token.is(AsmToken::TokenKind::LCurly) ||
|
||||
Token.is(AsmToken::TokenKind::RCurly))
|
||||
return false;
|
||||
// special case for parsing vwhist256:sat
|
||||
if (String.lower() == "vwhist256" && Second.is(AsmToken::Colon) &&
|
||||
Third.getString().lower() == "sat")
|
||||
return false;
|
||||
if (!Token.is(AsmToken::TokenKind::Identifier))
|
||||
return true;
|
||||
if (!matchRegister(String.lower()))
|
||||
|
@ -551,19 +551,23 @@ static DecodeStatus DecodeVecPredRegsRegisterClass(MCInst &Inst, unsigned RegNo,
|
||||
static DecodeStatus DecodeCtrRegsRegisterClass(MCInst &Inst, unsigned RegNo,
|
||||
uint64_t /*Address*/,
|
||||
const void *Decoder) {
|
||||
using namespace Hexagon;
|
||||
static const MCPhysReg CtrlRegDecoderTable[] = {
|
||||
Hexagon::SA0, Hexagon::LC0, Hexagon::SA1,
|
||||
Hexagon::LC1, Hexagon::P3_0, Hexagon::C5,
|
||||
Hexagon::C6, Hexagon::C7, Hexagon::USR,
|
||||
Hexagon::PC, Hexagon::UGP, Hexagon::GP,
|
||||
Hexagon::CS0, Hexagon::CS1, Hexagon::UPCL,
|
||||
Hexagon::UPC
|
||||
/* 0 */ SA0, LC0, SA1, LC1,
|
||||
/* 4 */ P3_0, C5, C6, C7,
|
||||
/* 8 */ USR, PC, UGP, GP,
|
||||
/* 12 */ CS0, CS1, UPCL, UPCH,
|
||||
/* 16 */ FRAMELIMIT, FRAMEKEY, PKTCOUNTLO, PKTCOUNTHI,
|
||||
/* 20 */ 0, 0, 0, 0,
|
||||
/* 24 */ 0, 0, 0, 0,
|
||||
/* 28 */ 0, 0, UTIMERLO, UTIMERHI
|
||||
};
|
||||
|
||||
if (RegNo >= array_lengthof(CtrlRegDecoderTable))
|
||||
return MCDisassembler::Fail;
|
||||
|
||||
if (CtrlRegDecoderTable[RegNo] == Hexagon::NoRegister)
|
||||
static_assert(NoRegister == 0, "Expecting NoRegister to be 0");
|
||||
if (CtrlRegDecoderTable[RegNo] == NoRegister)
|
||||
return MCDisassembler::Fail;
|
||||
|
||||
unsigned Register = CtrlRegDecoderTable[RegNo];
|
||||
@ -574,19 +578,23 @@ static DecodeStatus DecodeCtrRegsRegisterClass(MCInst &Inst, unsigned RegNo,
|
||||
static DecodeStatus DecodeCtrRegs64RegisterClass(MCInst &Inst, unsigned RegNo,
|
||||
uint64_t /*Address*/,
|
||||
const void *Decoder) {
|
||||
using namespace Hexagon;
|
||||
static const MCPhysReg CtrlReg64DecoderTable[] = {
|
||||
Hexagon::C1_0, Hexagon::NoRegister, Hexagon::C3_2,
|
||||
Hexagon::NoRegister,
|
||||
Hexagon::C7_6, Hexagon::NoRegister, Hexagon::C9_8,
|
||||
Hexagon::NoRegister, Hexagon::C11_10, Hexagon::NoRegister,
|
||||
Hexagon::CS, Hexagon::NoRegister, Hexagon::UPC,
|
||||
Hexagon::NoRegister
|
||||
/* 0 */ C1_0, 0, C3_2, 0,
|
||||
/* 4 */ C5_4, 0, C7_6, 0,
|
||||
/* 8 */ C9_8, 0, C11_10, 0,
|
||||
/* 12 */ CS, 0, UPC, 0,
|
||||
/* 16 */ C17_16, 0, PKTCOUNT, 0,
|
||||
/* 20 */ 0, 0, 0, 0,
|
||||
/* 24 */ 0, 0, 0, 0,
|
||||
/* 28 */ 0, 0, UTIMER, 0
|
||||
};
|
||||
|
||||
if (RegNo >= array_lengthof(CtrlReg64DecoderTable))
|
||||
return MCDisassembler::Fail;
|
||||
|
||||
if (CtrlReg64DecoderTable[RegNo] == Hexagon::NoRegister)
|
||||
static_assert(NoRegister == 0, "Expecting NoRegister to be 0");
|
||||
if (CtrlReg64DecoderTable[RegNo] == NoRegister)
|
||||
return MCDisassembler::Fail;
|
||||
|
||||
unsigned Register = CtrlReg64DecoderTable[RegNo];
|
||||
|
@ -252,6 +252,7 @@ include "HexagonPatterns.td"
|
||||
include "HexagonDepMappings.td"
|
||||
include "HexagonIntrinsics.td"
|
||||
include "HexagonIntrinsicsDerived.td"
|
||||
include "HexagonMapAsm2IntrinV62.gen.td"
|
||||
|
||||
def HexagonInstrInfo : InstrInfo;
|
||||
|
||||
@ -271,6 +272,8 @@ def : Proc<"hexagonv55", HexagonModelV55,
|
||||
[ArchV4, ArchV5, ArchV55]>;
|
||||
def : Proc<"hexagonv60", HexagonModelV60,
|
||||
[ArchV4, ArchV5, ArchV55, ArchV60, ExtensionHVX]>;
|
||||
def : Proc<"hexagonv62", HexagonModelV62,
|
||||
[ArchV4, ArchV5, ArchV55, ArchV60, ArchV62, ExtensionHVX]>;
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// Declare the target which we are implementing
|
||||
|
@ -7,4 +7,4 @@
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
enum HexagonArchEnum { V4,V5,V55,V60 };
|
||||
enum HexagonArchEnum { V4,V5,V55,V60,V62 };
|
||||
|
@ -7,6 +7,8 @@
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
def ArchV62: SubtargetFeature<"v62", "HexagonArchVersion", "V62", "Enable Hexagon V62 architecture">;
|
||||
def HasV62T : Predicate<"HST->hasV62TOps()">, AssemblerPredicate<"ArchV62">;
|
||||
def ArchV60: SubtargetFeature<"v60", "HexagonArchVersion", "V60", "Enable Hexagon V60 architecture">;
|
||||
def HasV60T : Predicate<"HST->hasV60TOps()">, AssemblerPredicate<"ArchV60">;
|
||||
def ArchV55: SubtargetFeature<"v55", "HexagonArchVersion", "V55", "Enable Hexagon V55 architecture">;
|
||||
|
@ -15,6 +15,7 @@ enum Type {
|
||||
TypeALU32_ADDI = 2,
|
||||
TypeALU64 = 3,
|
||||
TypeCJ = 4,
|
||||
TypeCOPROC_VMEM = 5,
|
||||
TypeCR = 7,
|
||||
TypeCVI_HIST = 10,
|
||||
TypeCVI_VA = 16,
|
||||
|
@ -13,6 +13,7 @@ def TypeALU32_3op : IType<1>;
|
||||
def TypeALU32_ADDI : IType<2>;
|
||||
def TypeALU64 : IType<3>;
|
||||
def TypeCJ : IType<4>;
|
||||
def TypeCOPROC_VMEM : IType<5>;
|
||||
def TypeCR : IType<7>;
|
||||
def TypeCVI_HIST : IType<10>;
|
||||
def TypeCVI_VA : IType<16>;
|
||||
|
File diff suppressed because it is too large
Load Diff
102
lib/Target/Hexagon/HexagonIICHVX.td
Normal file
102
lib/Target/Hexagon/HexagonIICHVX.td
Normal file
@ -0,0 +1,102 @@
|
||||
//===--- HexagonIICHVX.td -------------------------------------------------===//
|
||||
//
|
||||
// The LLVM Compiler Infrastructure
|
||||
//
|
||||
// This file is distributed under the University of Illinois Open Source
|
||||
// License. See LICENSE.TXT for details.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
//
|
||||
// Though all these itinerary classes exist for V60 onwards, they are being
|
||||
// listed here as 'HVXV62Itin' because itinerary class description prior to V62
|
||||
// doesn't include operand cycle info. In future, I plan to merge them
|
||||
// together and call it 'HVXItin'.
|
||||
//
|
||||
class HVXV62Itin {
|
||||
list<InstrItinData> HVXV62Itin_list = [
|
||||
InstrItinData<COPROC_VMEM_vtc_long_SLOT01,
|
||||
[InstrStage<1, [SLOT0, SLOT1]>],
|
||||
[3, 1, 1, 1]>,
|
||||
InstrItinData<COPROC_VX_vtc_long_SLOT23,
|
||||
[InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[3, 1, 1, 1]>,
|
||||
InstrItinData<COPROC_VX_vtc_SLOT23,
|
||||
[InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[3, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VA, [InstrStage<1, [SLOT0,SLOT1,SLOT2,SLOT3], 0>,
|
||||
InstrStage<1, [CVI_XLANE,CVI_SHIFT,
|
||||
CVI_MPY0, CVI_MPY1]>],
|
||||
[1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VA_DV, [InstrStage<1, [SLOT0,SLOT1,SLOT2,SLOT3], 0>,
|
||||
InstrStage<1, [CVI_XLSHF, CVI_MPY01]>],
|
||||
[1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VX_LONG, [InstrStage<1, [SLOT2, SLOT3], 0>,
|
||||
InstrStage<1, [CVI_MPY0, CVI_MPY1]>],
|
||||
[1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VX_LATE, [InstrStage<1, [SLOT2, SLOT3], 0>,
|
||||
InstrStage<1, [CVI_MPY0, CVI_MPY1]>],
|
||||
[1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VX, [InstrStage<1, [SLOT2, SLOT3], 0>,
|
||||
InstrStage<1, [CVI_MPY0, CVI_MPY1]>],
|
||||
[1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VX_DV_LONG, [InstrStage<1, [SLOT2, SLOT3], 0>,
|
||||
InstrStage<1, [CVI_MPY01]>], [1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VX_DV, [InstrStage<1, [SLOT2, SLOT3], 0>,
|
||||
InstrStage<1, [CVI_MPY01]>], [1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VX_DV_SLOT2, [InstrStage<1, [SLOT2], 0>,
|
||||
InstrStage<1, [CVI_MPY01]>], [1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VX_DV_SLOT2_LONG_EARLY,
|
||||
[InstrStage<1, [SLOT2], 0>,
|
||||
InstrStage<1, [CVI_MPY01]>], [1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VP, [InstrStage<1, [SLOT0,SLOT1,SLOT2,SLOT3], 0>,
|
||||
InstrStage<1, [CVI_XLANE]>], [1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VP_LONG, [InstrStage<1, [SLOT0,SLOT1,SLOT2,SLOT3], 0>,
|
||||
InstrStage<1, [CVI_XLANE]>], [1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VP_VS_EARLY, [InstrStage<1, [SLOT0,SLOT1,SLOT2,SLOT3], 0>,
|
||||
InstrStage<1, [CVI_XLSHF]>], [1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VP_VS_LONG, [InstrStage<1, [SLOT0,SLOT1,SLOT2,SLOT3], 0>,
|
||||
InstrStage<1, [CVI_XLSHF]>], [1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VP_VS, [InstrStage<1, [SLOT0,SLOT1,SLOT2,SLOT3], 0>,
|
||||
InstrStage<1, [CVI_XLSHF]>], [1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VP_VS_LONG_EARLY,
|
||||
[InstrStage<1, [SLOT0,SLOT1,SLOT2,SLOT3], 0>,
|
||||
InstrStage<1, [CVI_XLSHF]>], [1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VP_DV, [InstrStage<1, [SLOT0,SLOT1,SLOT2,SLOT3], 0>,
|
||||
InstrStage<1, [CVI_XLSHF]>], [1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VS, [InstrStage<1, [SLOT0,SLOT1,SLOT2,SLOT3], 0>,
|
||||
InstrStage<1, [CVI_SHIFT]>], [1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VINLANESAT, [InstrStage<1, [SLOT0,SLOT1,SLOT2,SLOT3], 0>,
|
||||
InstrStage<1, [CVI_XLANE, CVI_SHIFT,
|
||||
CVI_MPY0, CVI_MPY1]>],
|
||||
[1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VM_LD, [InstrStage<1, [SLOT0, SLOT1], 0>,
|
||||
InstrStage<1, [CVI_LD], 0>,
|
||||
InstrStage<1, [CVI_XLANE, CVI_SHIFT,
|
||||
CVI_MPY0, CVI_MPY1]>],
|
||||
[1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VM_TMP_LD, [InstrStage<1,[SLOT0, SLOT1], 0>,
|
||||
InstrStage<1, [CVI_LD]>],[1, 1, 1, 1, 10]>,
|
||||
InstrItinData<CVI_VM_CUR_LD, [InstrStage<1,[SLOT0, SLOT1], 0>,
|
||||
InstrStage<1, [CVI_LD], 0>,
|
||||
InstrStage<1, [CVI_XLANE, CVI_SHIFT,
|
||||
CVI_MPY0, CVI_MPY1]>],
|
||||
[1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VM_VP_LDU, [InstrStage<1,[SLOT0], 0>,
|
||||
InstrStage<1, [SLOT1], 0>,
|
||||
InstrStage<1, [CVI_LD], 0>,
|
||||
InstrStage<1, [CVI_XLANE]>], [1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VM_ST, [InstrStage<1, [SLOT0], 0>,
|
||||
InstrStage<1, [CVI_ST], 0>,
|
||||
InstrStage<1, [CVI_XLANE, CVI_SHIFT,
|
||||
CVI_MPY0, CVI_MPY1]>],
|
||||
[1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VM_NEW_ST, [InstrStage<1,[SLOT0], 0>,
|
||||
InstrStage<1, [CVI_ST]>], [1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_VM_STU, [InstrStage<1, [SLOT0], 0>,
|
||||
InstrStage<1, [SLOT1], 0>,
|
||||
InstrStage<1, [CVI_ST], 0>,
|
||||
InstrStage<1, [CVI_XLANE]>], [1, 1, 1, 1]>,
|
||||
InstrItinData<CVI_HIST, [InstrStage<1, [SLOT0,SLOT1,SLOT2,SLOT3], 0>,
|
||||
InstrStage<1, [CVI_ALL]>], [1, 1, 1, 1]>];
|
||||
}
|
164
lib/Target/Hexagon/HexagonIICScalar.td
Normal file
164
lib/Target/Hexagon/HexagonIICScalar.td
Normal file
@ -0,0 +1,164 @@
|
||||
//===--- HexagonIICScalar.td ----------------------------------------------===//
|
||||
//
|
||||
// The LLVM Compiler Infrastructure
|
||||
//
|
||||
// This file is distributed under the University of Illinois Open Source
|
||||
// License. See LICENSE.TXT for details.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
// These itinerary class descriptions are based on the instruction timing
|
||||
// classes as per V62. Curretnly, they are just extracted from
|
||||
// HexagonScheduleV62.td but will soon be auto-generated by HexagonGen.py.
|
||||
|
||||
class ScalarItin {
|
||||
list<InstrItinData> ScalarItin_list = [
|
||||
InstrItinData<ALU32_2op_tc_1_SLOT0123 ,
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [1, 1, 1]>,
|
||||
InstrItinData<ALU32_2op_tc_2early_SLOT0123,
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [2, 1, 1]>,
|
||||
InstrItinData<ALU32_3op_tc_1_SLOT0123 ,
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [1, 1, 1]>,
|
||||
InstrItinData<ALU32_3op_tc_2_SLOT0123 ,
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [2, 1, 1]>,
|
||||
InstrItinData<ALU32_3op_tc_2early_SLOT0123,
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [2, 1, 1]>,
|
||||
InstrItinData<ALU32_ADDI_tc_1_SLOT0123 ,
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [1, 1, 1]>,
|
||||
|
||||
// ALU64
|
||||
InstrItinData<ALU64_tc_1_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[1, 1, 1]>,
|
||||
InstrItinData<ALU64_tc_2_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[2, 1, 1]>,
|
||||
InstrItinData<ALU64_tc_2early_SLOT23, [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[2, 1, 1]>,
|
||||
InstrItinData<ALU64_tc_3x_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[3, 1, 1]>,
|
||||
|
||||
// CR -> System
|
||||
InstrItinData<CR_tc_2_SLOT3 , [InstrStage<1, [SLOT3]>], [2, 1, 1]>,
|
||||
InstrItinData<CR_tc_2early_SLOT3 , [InstrStage<1, [SLOT3]>], [2, 1, 1]>,
|
||||
InstrItinData<CR_tc_3x_SLOT3 , [InstrStage<1, [SLOT3]>], [3, 1, 1]>,
|
||||
|
||||
// Jump (conditional/unconditional/return etc)
|
||||
InstrItinData<CR_tc_2early_SLOT23, [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[2, 1, 1, 1]>,
|
||||
InstrItinData<CR_tc_3x_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[3, 1, 1, 1]>,
|
||||
InstrItinData<CJ_tc_1_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[1, 1, 1, 1]>,
|
||||
InstrItinData<CJ_tc_2early_SLOT23, [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[2, 1, 1, 1]>,
|
||||
InstrItinData<J_tc_2early_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[2, 1, 1, 1]>,
|
||||
InstrItinData<J_tc_2early_CJUMP_UCJUMP_ARCHDEPSLOT,
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [2, 1, 1, 1]>,
|
||||
|
||||
// JR
|
||||
InstrItinData<J_tc_2early_SLOT2 , [InstrStage<1, [SLOT2]>], [2, 1, 1]>,
|
||||
InstrItinData<J_tc_3stall_SLOT2 , [InstrStage<1, [SLOT2]>], [3, 1, 1]>,
|
||||
|
||||
// Extender
|
||||
InstrItinData<EXTENDER_tc_1_SLOT0123, [InstrStage<1,
|
||||
[SLOT0, SLOT1, SLOT2, SLOT3]>], [2, 1, 1, 1]>,
|
||||
|
||||
// Load
|
||||
InstrItinData<LD_tc_ld_SLOT01 , [InstrStage<1, [SLOT0, SLOT1]>],
|
||||
[3, 1]>,
|
||||
InstrItinData<LD_tc_ld_pi_SLOT01 , [InstrStage<1, [SLOT0, SLOT1]>],
|
||||
[3, 1]>,
|
||||
InstrItinData<LD_tc_3or4stall_SLOT0, [InstrStage<1, [SLOT0]>], [4, 1]>,
|
||||
InstrItinData<LD_tc_ld_SLOT0 , [InstrStage<1, [SLOT0]>], [3, 1]>,
|
||||
|
||||
// M
|
||||
InstrItinData<M_tc_1_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[1, 1, 1]>,
|
||||
InstrItinData<M_tc_2_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[2, 1, 1]>,
|
||||
InstrItinData<M_tc_2_acc_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[2, 1, 1]>,
|
||||
InstrItinData<M_tc_3_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[3, 1, 1]>,
|
||||
InstrItinData<M_tc_3x_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[3, 1, 1]>,
|
||||
InstrItinData<M_tc_3x_acc_SLOT23, [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[3, 1, 1, 1]>,
|
||||
InstrItinData<M_tc_3or4x_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[4, 1, 1]>,
|
||||
InstrItinData<M_tc_3or4x_acc_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[4, 1, 1]>,
|
||||
InstrItinData<M_tc_3stall_SLOT23, [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[3, 1, 1]>,
|
||||
|
||||
// Store
|
||||
InstrItinData<ST_tc_st_SLOT01 , [InstrStage<1, [SLOT0, SLOT1]>],
|
||||
[1, 1, 1]>,
|
||||
InstrItinData<ST_tc_st_pi_SLOT01, [InstrStage<1, [SLOT0, SLOT1]>],
|
||||
[1, 1, 1]>,
|
||||
InstrItinData<ST_tc_3stall_SLOT0, [InstrStage<1, [SLOT0]>], [3, 1, 1]>,
|
||||
InstrItinData<ST_tc_ld_SLOT0 , [InstrStage<1, [SLOT0]>], [3, 1, 1]>,
|
||||
InstrItinData<ST_tc_st_SLOT0 , [InstrStage<1, [SLOT0]>], [1, 1, 1]>,
|
||||
InstrItinData<ST_tc_st_pi_SLOT0 , [InstrStage<1, [SLOT0]>], [1, 1, 1]>,
|
||||
|
||||
// S
|
||||
InstrItinData<S_2op_tc_1_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[1, 1, 1]>,
|
||||
InstrItinData<S_2op_tc_2_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[2, 1, 1]>,
|
||||
InstrItinData<S_2op_tc_2early_SLOT23, [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[2, 1, 1]>,
|
||||
// The S_2op_tc_3x_SLOT23 slots are 4 cycles on v60.
|
||||
InstrItinData<S_2op_tc_3or4x_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[4, 1, 1]>,
|
||||
InstrItinData<S_3op_tc_1_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[1, 1, 1]>,
|
||||
InstrItinData<S_3op_tc_2_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[2, 1, 1]>,
|
||||
InstrItinData<S_3op_tc_2early_SLOT23, [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[2, 1, 1]>,
|
||||
InstrItinData<S_3op_tc_3_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[3, 1, 1]>,
|
||||
InstrItinData<S_3op_tc_3stall_SLOT23, [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[3, 1, 1]>,
|
||||
InstrItinData<S_3op_tc_3x_SLOT23 , [InstrStage<1, [SLOT2, SLOT3]>],
|
||||
[3, 1, 1]>,
|
||||
|
||||
// New Value Compare Jump
|
||||
InstrItinData<NCJ_tc_3or4stall_SLOT0, [InstrStage<1, [SLOT0]>],
|
||||
[3, 1, 1, 1]>,
|
||||
|
||||
// Mem ops
|
||||
InstrItinData<V2LDST_tc_st_SLOT0 , [InstrStage<1, [SLOT0]>],
|
||||
[1, 1, 1, 1]>,
|
||||
InstrItinData<V2LDST_tc_ld_SLOT01 , [InstrStage<1, [SLOT0, SLOT1]>],
|
||||
[2, 1, 1, 1]>,
|
||||
InstrItinData<V2LDST_tc_st_SLOT01 , [InstrStage<1, [SLOT0, SLOT1]>],
|
||||
[1, 1, 1, 1]>,
|
||||
InstrItinData<V4LDST_tc_st_SLOT0 , [InstrStage<1, [SLOT0]>],
|
||||
[1, 1, 1, 1]>,
|
||||
InstrItinData<V4LDST_tc_ld_SLOT01 , [InstrStage<1, [SLOT0, SLOT1]>],
|
||||
[3, 1, 1, 1]>,
|
||||
InstrItinData<V4LDST_tc_st_SLOT01 , [InstrStage<1, [SLOT0, SLOT1]>],
|
||||
[1, 1, 1, 1]>,
|
||||
|
||||
// Endloop
|
||||
InstrItinData<J_tc_2early_SLOT0123, [InstrStage<1, [SLOT_ENDLOOP]>],
|
||||
[2]>,
|
||||
InstrItinData<MAPPING_tc_1_SLOT0123 ,
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>],
|
||||
[1, 1, 1, 1]>,
|
||||
|
||||
// Duplex and Compound
|
||||
InstrItinData<DUPLEX , [InstrStage<1, [SLOT0]>], [1, 1, 1]>,
|
||||
InstrItinData<COMPOUND_CJ_ARCHDEPSLOT,
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [1, 1, 1]>,
|
||||
InstrItinData<COMPOUND , [InstrStage<1, [SLOT2, SLOT3]>], [1, 1, 1]>,
|
||||
// Misc
|
||||
InstrItinData<PREFIX , [InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>],
|
||||
[1, 1, 1]>,
|
||||
InstrItinData<PSEUDO , [InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>],
|
||||
[1, 1, 1]>,
|
||||
InstrItinData<PSEUDOM , [InstrStage<1, [SLOT2, SLOT3], 0>,
|
||||
InstrStage<1, [SLOT2, SLOT3]>], [1, 1, 1]>];
|
||||
}
|
204
lib/Target/Hexagon/HexagonMapAsm2IntrinV62.gen.td
Normal file
204
lib/Target/Hexagon/HexagonMapAsm2IntrinV62.gen.td
Normal file
@ -0,0 +1,204 @@
|
||||
//===--- HexagonMapAsm2IntrinV62.gen.td -----------------------------------===//
|
||||
//
|
||||
// The LLVM Compiler Infrastructure
|
||||
//
|
||||
// This file is distributed under the University of Illinois Open Source
|
||||
// License. See LICENSE.TXT for details.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
multiclass T_VR_HVX_gen_pat <InstHexagon MI, Intrinsic IntID> {
|
||||
def: Pat<(IntID VectorRegs:$src1, IntRegs:$src2),
|
||||
(MI VectorRegs:$src1, IntRegs:$src2)>,
|
||||
Requires<[UseHVXSgl]>;
|
||||
def: Pat<(!cast<Intrinsic>(IntID#"_128B") VectorRegs128B:$src1, IntRegs:$src2),
|
||||
(!cast<InstHexagon>(MI#"_128B") VectorRegs128B:$src1, IntRegs:$src2)>,
|
||||
Requires<[UseHVXDbl]>;
|
||||
}
|
||||
|
||||
multiclass T_VVL_HVX_gen_pat <InstHexagon MI, Intrinsic IntID> {
|
||||
def: Pat<(IntID VectorRegs:$src1, VectorRegs:$src2, IntRegsLow8:$src3),
|
||||
(MI VectorRegs:$src1, VectorRegs:$src2, IntRegsLow8:$src3)>,
|
||||
Requires<[UseHVXSgl]>;
|
||||
def: Pat<(!cast<Intrinsic>(IntID#"_128B") VectorRegs128B:$src1, VectorRegs128B:$src2, IntRegsLow8:$src3),
|
||||
(!cast<InstHexagon>(MI#"_128B") VectorRegs128B:$src1, VectorRegs128B:$src2, IntRegsLow8:$src3)>,
|
||||
Requires<[UseHVXDbl]>;
|
||||
}
|
||||
|
||||
multiclass T_VV_HVX_gen_pat <InstHexagon MI, Intrinsic IntID> {
|
||||
def: Pat<(IntID VectorRegs:$src1, VectorRegs:$src2),
|
||||
(MI VectorRegs:$src1, VectorRegs:$src2)>,
|
||||
Requires<[UseHVXSgl]>;
|
||||
def: Pat<(!cast<Intrinsic>(IntID#"_128B") VectorRegs128B:$src1, VectorRegs128B:$src2),
|
||||
(!cast<InstHexagon>(MI#"_128B") VectorRegs128B:$src1, VectorRegs128B:$src2)>,
|
||||
Requires<[UseHVXDbl]>;
|
||||
}
|
||||
|
||||
multiclass T_WW_HVX_gen_pat <InstHexagon MI, Intrinsic IntID> {
|
||||
def: Pat<(IntID VecDblRegs:$src1, VecDblRegs:$src2),
|
||||
(MI VecDblRegs:$src1, VecDblRegs:$src2)>,
|
||||
Requires<[UseHVXSgl]>;
|
||||
def: Pat<(!cast<Intrinsic>(IntID#"_128B") VecDblRegs128B:$src1, VecDblRegs128B:$src2),
|
||||
(!cast<InstHexagon>(MI#"_128B") VecDblRegs128B:$src1, VecDblRegs128B:$src2)>,
|
||||
Requires<[UseHVXDbl]>;
|
||||
}
|
||||
|
||||
multiclass T_WVV_HVX_gen_pat <InstHexagon MI, Intrinsic IntID> {
|
||||
def: Pat<(IntID VecDblRegs:$src1, VectorRegs:$src2, VectorRegs:$src3),
|
||||
(MI VecDblRegs:$src1, VectorRegs:$src2, VectorRegs:$src3)>,
|
||||
Requires<[UseHVXSgl]>;
|
||||
def: Pat<(!cast<Intrinsic>(IntID#"_128B") VecDblRegs128B:$src1, VectorRegs128B:$src2, VectorRegs128B:$src3),
|
||||
(!cast<InstHexagon>(MI#"_128B") VecDblRegs128B:$src1, VectorRegs128B:$src2, VectorRegs128B:$src3)>,
|
||||
Requires<[UseHVXDbl]>;
|
||||
}
|
||||
|
||||
multiclass T_WR_HVX_gen_pat <InstHexagon MI, Intrinsic IntID> {
|
||||
def: Pat<(IntID VecDblRegs:$src1, IntRegs:$src2),
|
||||
(MI VecDblRegs:$src1, IntRegs:$src2)>,
|
||||
Requires<[UseHVXSgl]>;
|
||||
def: Pat<(!cast<Intrinsic>(IntID#"_128B") VecDblRegs128B:$src1, IntRegs:$src2),
|
||||
(!cast<InstHexagon>(MI#"_128B") VecDblRegs128B:$src1, IntRegs:$src2)>,
|
||||
Requires<[UseHVXDbl]>;
|
||||
}
|
||||
|
||||
multiclass T_WWR_HVX_gen_pat <InstHexagon MI, Intrinsic IntID> {
|
||||
def: Pat<(IntID VecDblRegs:$src1, VecDblRegs:$src2, IntRegs:$src3),
|
||||
(MI VecDblRegs:$src1, VecDblRegs:$src2, IntRegs:$src3)>,
|
||||
Requires<[UseHVXSgl]>;
|
||||
def: Pat<(!cast<Intrinsic>(IntID#"_128B") VecDblRegs128B:$src1, VecDblRegs128B:$src2, IntRegs:$src3),
|
||||
(!cast<InstHexagon>(MI#"_128B") VecDblRegs128B:$src1, VecDblRegs128B:$src2, IntRegs:$src3)>,
|
||||
Requires<[UseHVXDbl]>;
|
||||
}
|
||||
|
||||
multiclass T_VVR_HVX_gen_pat <InstHexagon MI, Intrinsic IntID> {
|
||||
def: Pat<(IntID VectorRegs:$src1, VectorRegs:$src2, IntRegs:$src3),
|
||||
(MI VectorRegs:$src1, VectorRegs:$src2, IntRegs:$src3)>,
|
||||
Requires<[UseHVXSgl]>;
|
||||
def: Pat<(!cast<Intrinsic>(IntID#"_128B") VectorRegs128B:$src1, VectorRegs128B:$src2, IntRegs:$src3),
|
||||
(!cast<InstHexagon>(MI#"_128B") VectorRegs128B:$src1, VectorRegs128B:$src2, IntRegs:$src3)>,
|
||||
Requires<[UseHVXDbl]>;
|
||||
}
|
||||
|
||||
multiclass T_ZR_HVX_gen_pat <InstHexagon MI, Intrinsic IntID> {
|
||||
def: Pat<(IntID VecPredRegs:$src1, IntRegs:$src2),
|
||||
(MI VecPredRegs:$src1, IntRegs:$src2)>,
|
||||
Requires<[UseHVXSgl]>;
|
||||
def: Pat<(!cast<Intrinsic>(IntID#"_128B") VecPredRegs128B:$src1, IntRegs:$src2),
|
||||
(!cast<InstHexagon>(MI#"_128B") VecPredRegs128B:$src1, IntRegs:$src2)>,
|
||||
Requires<[UseHVXDbl]>;
|
||||
}
|
||||
|
||||
multiclass T_VZR_HVX_gen_pat <InstHexagon MI, Intrinsic IntID> {
|
||||
def: Pat<(IntID VectorRegs:$src1, VecPredRegs:$src2, IntRegs:$src3),
|
||||
(MI VectorRegs:$src1, VecPredRegs:$src2, IntRegs:$src3)>,
|
||||
Requires<[UseHVXSgl]>;
|
||||
def: Pat<(!cast<Intrinsic>(IntID#"_128B") VectorRegs128B:$src1, VecPredRegs128B:$src2, IntRegs:$src3),
|
||||
(!cast<InstHexagon>(MI#"_128B") VectorRegs128B:$src1, VecPredRegs128B:$src2, IntRegs:$src3)>,
|
||||
Requires<[UseHVXDbl]>;
|
||||
}
|
||||
|
||||
multiclass T_ZV_HVX_gen_pat <InstHexagon MI, Intrinsic IntID> {
|
||||
def: Pat<(IntID VecPredRegs:$src1, VectorRegs:$src2),
|
||||
(MI VecPredRegs:$src1, VectorRegs:$src2)>,
|
||||
Requires<[UseHVXSgl]>;
|
||||
def: Pat<(!cast<Intrinsic>(IntID#"_128B") VecPredRegs128B:$src1, VectorRegs128B:$src2),
|
||||
(!cast<InstHexagon>(MI#"_128B") VecPredRegs128B:$src1, VectorRegs128B:$src2)>,
|
||||
Requires<[UseHVXDbl]>;
|
||||
}
|
||||
|
||||
multiclass T_R_HVX_gen_pat <InstHexagon MI, Intrinsic IntID> {
|
||||
def: Pat<(IntID IntRegs:$src1),
|
||||
(MI IntRegs:$src1)>,
|
||||
Requires<[UseHVXSgl]>;
|
||||
def: Pat<(!cast<Intrinsic>(IntID#"_128B") IntRegs:$src1),
|
||||
(!cast<InstHexagon>(MI#"_128B") IntRegs:$src1)>,
|
||||
Requires<[UseHVXDbl]>;
|
||||
}
|
||||
|
||||
multiclass T_ZZ_HVX_gen_pat <InstHexagon MI, Intrinsic IntID> {
|
||||
def: Pat<(IntID VecPredRegs:$src1, VecPredRegs:$src2),
|
||||
(MI VecPredRegs:$src1, VecPredRegs:$src2)>,
|
||||
Requires<[UseHVXSgl]>;
|
||||
def: Pat<(!cast<Intrinsic>(IntID#"_128B") VecPredRegs128B:$src1, VecPredRegs128B:$src2),
|
||||
(!cast<InstHexagon>(MI#"_128B") VecPredRegs128B:$src1, VecPredRegs128B:$src2)>,
|
||||
Requires<[UseHVXDbl]>;
|
||||
}
|
||||
|
||||
multiclass T_VVI_HVX_gen_pat <InstHexagon MI, Intrinsic IntID> {
|
||||
def: Pat<(IntID VectorRegs:$src1, VectorRegs:$src2, imm:$src3),
|
||||
(MI VectorRegs:$src1, VectorRegs:$src2, imm:$src3)>,
|
||||
Requires<[UseHVXSgl]>;
|
||||
def: Pat<(!cast<Intrinsic>(IntID#"_128B") VectorRegs128B:$src1, VectorRegs128B:$src2, imm:$src3),
|
||||
(!cast<InstHexagon>(MI#"_128B") VectorRegs128B:$src1, VectorRegs128B:$src2, imm:$src3)>,
|
||||
Requires<[UseHVXDbl]>;
|
||||
}
|
||||
|
||||
multiclass T_VVVI_HVX_gen_pat <InstHexagon MI, Intrinsic IntID> {
|
||||
def: Pat<(IntID VectorRegs:$src1, VectorRegs:$src2, VectorRegs:$src3, imm:$src4),
|
||||
(MI VectorRegs:$src1, VectorRegs:$src2, VectorRegs:$src3, imm:$src4)>,
|
||||
Requires<[UseHVXSgl]>;
|
||||
def: Pat<(!cast<Intrinsic>(IntID#"_128B") VectorRegs128B:$src1, VectorRegs128B:$src2, VectorRegs128B:$src3, imm:$src4),
|
||||
(!cast<InstHexagon>(MI#"_128B") VectorRegs128B:$src1, VectorRegs128B:$src2, VectorRegs128B:$src3, imm:$src4)>,
|
||||
Requires<[UseHVXDbl]>;
|
||||
}
|
||||
|
||||
multiclass T_WVVI_HVX_gen_pat <InstHexagon MI, Intrinsic IntID> {
|
||||
def: Pat<(IntID VecDblRegs:$src1, VectorRegs:$src2, VectorRegs:$src3, imm:$src4),
|
||||
(MI VecDblRegs:$src1, VectorRegs:$src2, VectorRegs:$src3, imm:$src4)>,
|
||||
Requires<[UseHVXSgl]>;
|
||||
def: Pat<(!cast<Intrinsic>(IntID#"_128B") VecDblRegs128B:$src1, VectorRegs128B:$src2, VectorRegs128B:$src3, imm:$src4),
|
||||
(!cast<InstHexagon>(MI#"_128B") VecDblRegs128B:$src1, VectorRegs128B:$src2, VectorRegs128B:$src3, imm:$src4)>,
|
||||
Requires<[UseHVXDbl]>;
|
||||
}
|
||||
|
||||
def : T_R_pat <S6_vsplatrbp, int_hexagon_S6_vsplatrbp>;
|
||||
def : T_PP_pat <M6_vabsdiffb, int_hexagon_M6_vabsdiffb>;
|
||||
def : T_PP_pat <M6_vabsdiffub, int_hexagon_M6_vabsdiffub>;
|
||||
def : T_PP_pat <S6_vtrunehb_ppp, int_hexagon_S6_vtrunehb_ppp>;
|
||||
def : T_PP_pat <S6_vtrunohb_ppp, int_hexagon_S6_vtrunohb_ppp>;
|
||||
|
||||
defm : T_VR_HVX_gen_pat <V6_vlsrb, int_hexagon_V6_vlsrb>;
|
||||
defm : T_VR_HVX_gen_pat <V6_vmpyiwub, int_hexagon_V6_vmpyiwub>;
|
||||
defm : T_VVL_HVX_gen_pat <V6_vasrwuhrndsat, int_hexagon_V6_vasrwuhrndsat>;
|
||||
defm : T_VVL_HVX_gen_pat <V6_vasruwuhrndsat, int_hexagon_V6_vasruwuhrndsat>;
|
||||
defm : T_VVL_HVX_gen_pat <V6_vasrhbsat, int_hexagon_V6_vasrhbsat>;
|
||||
defm : T_VVL_HVX_gen_pat <V6_vlutvvb_nm, int_hexagon_V6_vlutvvb_nm>;
|
||||
defm : T_VVL_HVX_gen_pat <V6_vlutvwh_nm, int_hexagon_V6_vlutvwh_nm>;
|
||||
defm : T_VV_HVX_gen_pat <V6_vrounduwuh, int_hexagon_V6_vrounduwuh>;
|
||||
defm : T_VV_HVX_gen_pat <V6_vrounduhub, int_hexagon_V6_vrounduhub>;
|
||||
defm : T_VV_HVX_gen_pat <V6_vadduwsat, int_hexagon_V6_vadduwsat>;
|
||||
defm : T_VV_HVX_gen_pat <V6_vsubuwsat, int_hexagon_V6_vsubuwsat>;
|
||||
defm : T_VV_HVX_gen_pat <V6_vaddbsat, int_hexagon_V6_vaddbsat>;
|
||||
defm : T_VV_HVX_gen_pat <V6_vsubbsat, int_hexagon_V6_vsubbsat>;
|
||||
defm : T_VV_HVX_gen_pat <V6_vaddububb_sat, int_hexagon_V6_vaddububb_sat>;
|
||||
defm : T_VV_HVX_gen_pat <V6_vsubububb_sat, int_hexagon_V6_vsubububb_sat>;
|
||||
defm : T_VV_HVX_gen_pat <V6_vmpyewuh_64, int_hexagon_V6_vmpyewuh_64>;
|
||||
defm : T_VV_HVX_gen_pat <V6_vmaxb, int_hexagon_V6_vmaxb>;
|
||||
defm : T_VV_HVX_gen_pat <V6_vminb, int_hexagon_V6_vminb>;
|
||||
defm : T_VV_HVX_gen_pat <V6_vsatuwuh, int_hexagon_V6_vsatuwuh>;
|
||||
defm : T_VV_HVX_gen_pat <V6_vaddclbw, int_hexagon_V6_vaddclbw>;
|
||||
defm : T_VV_HVX_gen_pat <V6_vaddclbh, int_hexagon_V6_vaddclbh>;
|
||||
defm : T_WW_HVX_gen_pat <V6_vadduwsat_dv, int_hexagon_V6_vadduwsat_dv>;
|
||||
defm : T_WW_HVX_gen_pat <V6_vsubuwsat_dv, int_hexagon_V6_vsubuwsat_dv>;
|
||||
defm : T_WW_HVX_gen_pat <V6_vaddbsat_dv, int_hexagon_V6_vaddbsat_dv>;
|
||||
defm : T_WW_HVX_gen_pat <V6_vsubbsat_dv, int_hexagon_V6_vsubbsat_dv>;
|
||||
defm : T_WVV_HVX_gen_pat <V6_vaddhw_acc, int_hexagon_V6_vaddhw_acc>;
|
||||
defm : T_WVV_HVX_gen_pat <V6_vadduhw_acc, int_hexagon_V6_vadduhw_acc>;
|
||||
defm : T_WVV_HVX_gen_pat <V6_vaddubh_acc, int_hexagon_V6_vaddubh_acc>;
|
||||
defm : T_WVV_HVX_gen_pat <V6_vmpyowh_64_acc, int_hexagon_V6_vmpyowh_64_acc>;
|
||||
defm : T_WR_HVX_gen_pat <V6_vmpauhb, int_hexagon_V6_vmpauhb>;
|
||||
defm : T_WWR_HVX_gen_pat <V6_vmpauhb_acc, int_hexagon_V6_vmpauhb_acc>;
|
||||
defm : T_VVR_HVX_gen_pat <V6_vmpyiwub_acc, int_hexagon_V6_vmpyiwub_acc>;
|
||||
defm : T_ZR_HVX_gen_pat <V6_vandnqrt, int_hexagon_V6_vandnqrt>;
|
||||
defm : T_VZR_HVX_gen_pat <V6_vandnqrt_acc, int_hexagon_V6_vandnqrt_acc>;
|
||||
defm : T_ZV_HVX_gen_pat <V6_vandvqv, int_hexagon_V6_vandvqv>;
|
||||
defm : T_ZV_HVX_gen_pat <V6_vandvnqv, int_hexagon_V6_vandvnqv>;
|
||||
defm : T_R_HVX_gen_pat <V6_pred_scalar2v2, int_hexagon_V6_pred_scalar2v2>;
|
||||
defm : T_R_HVX_gen_pat <V6_lvsplath, int_hexagon_V6_lvsplath>;
|
||||
defm : T_R_HVX_gen_pat <V6_lvsplatb, int_hexagon_V6_lvsplatb>;
|
||||
defm : T_ZZ_HVX_gen_pat <V6_shuffeqw, int_hexagon_V6_shuffeqw>;
|
||||
defm : T_ZZ_HVX_gen_pat <V6_shuffeqh, int_hexagon_V6_shuffeqh>;
|
||||
defm : T_VVI_HVX_gen_pat <V6_vlutvvbi, int_hexagon_V6_vlutvvbi>;
|
||||
defm : T_VVI_HVX_gen_pat <V6_vlutvwhi, int_hexagon_V6_vlutvwhi>;
|
||||
defm : T_VVVI_HVX_gen_pat <V6_vlutvvb_oracci, int_hexagon_V6_vlutvvb_oracci>;
|
||||
defm : T_WVVI_HVX_gen_pat <V6_vlutvwh_oracci, int_hexagon_V6_vlutvwh_oracci>;
|
@ -125,6 +125,7 @@ HexagonRegisterInfo::getCalleeSavedRegs(const MachineFunction *MF) const {
|
||||
case HexagonSubtarget::V5:
|
||||
case HexagonSubtarget::V55:
|
||||
case HexagonSubtarget::V60:
|
||||
case HexagonSubtarget::V62:
|
||||
return HasEHReturn ? CalleeSavedRegsV3EHReturn : CalleeSavedRegsV3;
|
||||
}
|
||||
|
||||
@ -139,17 +140,26 @@ BitVector HexagonRegisterInfo::getReservedRegs(const MachineFunction &MF)
|
||||
Reserved.set(Hexagon::R29);
|
||||
Reserved.set(Hexagon::R30);
|
||||
Reserved.set(Hexagon::R31);
|
||||
Reserved.set(Hexagon::SA0); // C0
|
||||
Reserved.set(Hexagon::LC0); // C1
|
||||
Reserved.set(Hexagon::SA1); // C2
|
||||
Reserved.set(Hexagon::LC1); // C3
|
||||
Reserved.set(Hexagon::USR); // C8
|
||||
Reserved.set(Hexagon::PC); // C9
|
||||
Reserved.set(Hexagon::UGP); // C10
|
||||
Reserved.set(Hexagon::GP); // C11
|
||||
Reserved.set(Hexagon::CS0); // C12
|
||||
Reserved.set(Hexagon::CS1); // C13
|
||||
|
||||
// Control registers.
|
||||
Reserved.set(Hexagon::SA0); // C0
|
||||
Reserved.set(Hexagon::LC0); // C1
|
||||
Reserved.set(Hexagon::SA1); // C2
|
||||
Reserved.set(Hexagon::LC1); // C3
|
||||
Reserved.set(Hexagon::P3_0); // C4
|
||||
Reserved.set(Hexagon::USR); // C8
|
||||
Reserved.set(Hexagon::PC); // C9
|
||||
Reserved.set(Hexagon::UGP); // C10
|
||||
Reserved.set(Hexagon::GP); // C11
|
||||
Reserved.set(Hexagon::CS0); // C12
|
||||
Reserved.set(Hexagon::CS1); // C13
|
||||
Reserved.set(Hexagon::UPCL); // C14
|
||||
Reserved.set(Hexagon::UPCH); // C15
|
||||
Reserved.set(Hexagon::FRAMELIMIT); // C16
|
||||
Reserved.set(Hexagon::FRAMEKEY); // C17
|
||||
Reserved.set(Hexagon::PKTCOUNTLO); // C18
|
||||
Reserved.set(Hexagon::PKTCOUNTHI); // C19
|
||||
Reserved.set(Hexagon::UTIMERLO); // C30
|
||||
Reserved.set(Hexagon::UTIMERHI); // C31
|
||||
// Out of the control registers, only C8 is explicitly defined in
|
||||
// HexagonRegisterInfo.td. If others are defined, make sure to add
|
||||
// them here as well.
|
||||
|
@ -140,43 +140,54 @@ let Namespace = "Hexagon" in {
|
||||
}
|
||||
|
||||
// Control registers.
|
||||
def SA0 : Rc<0, "sa0", ["c0"]>, DwarfRegNum<[67]>;
|
||||
def LC0 : Rc<1, "lc0", ["c1"]>, DwarfRegNum<[68]>;
|
||||
def SA1 : Rc<2, "sa1", ["c2"]>, DwarfRegNum<[69]>;
|
||||
def LC1 : Rc<3, "lc1", ["c3"]>, DwarfRegNum<[70]>;
|
||||
def P3_0 : Rc<4, "p3:0", ["c4"], [P0, P1, P2, P3]>,
|
||||
DwarfRegNum<[71]>;
|
||||
def SA0: Rc<0, "sa0", ["c0"]>, DwarfRegNum<[67]>;
|
||||
def LC0: Rc<1, "lc0", ["c1"]>, DwarfRegNum<[68]>;
|
||||
def SA1: Rc<2, "sa1", ["c2"]>, DwarfRegNum<[69]>;
|
||||
def LC1: Rc<3, "lc1", ["c3"]>, DwarfRegNum<[70]>;
|
||||
def P3_0: Rc<4, "p3:0", ["c4"], [P0, P1, P2, P3]>,
|
||||
DwarfRegNum<[71]>;
|
||||
// When defining more Cn registers, make sure to explicitly mark them
|
||||
// as reserved in HexagonRegisterInfo.cpp.
|
||||
def C5 : Rc<5, "c5", ["c5"]>, DwarfRegNum<[72]>; // future use
|
||||
def C6 : Rc<6, "c6", [], [M0]>, DwarfRegNum<[73]>;
|
||||
def C7 : Rc<7, "c7", [], [M1]>, DwarfRegNum<[74]>;
|
||||
def C5: Rc<5, "c5", ["c5"]>, DwarfRegNum<[72]>;
|
||||
def C6: Rc<6, "c6", [], [M0]>, DwarfRegNum<[73]>;
|
||||
def C7: Rc<7, "c7", [], [M1]>, DwarfRegNum<[74]>;
|
||||
// Define C8 separately and make it aliased with USR.
|
||||
// The problem is that USR has subregisters (e.g. overflow). If USR was
|
||||
// specified as a subregister of C9_8, it would imply that subreg_overflow
|
||||
// and isub_lo can be composed, which leads to all kinds of issues
|
||||
// with lane masks.
|
||||
def C8 : Rc<8, "c8", [], [USR]>, DwarfRegNum<[75]>;
|
||||
def PC : Rc<9, "pc">, DwarfRegNum<[76]>;
|
||||
def UGP : Rc<10, "ugp", ["c10"]>, DwarfRegNum<[77]>;
|
||||
def GP : Rc<11, "gp", ["c11"]>, DwarfRegNum<[78]>;
|
||||
def CS0 : Rc<12, "cs0", ["c12"]>, DwarfRegNum<[79]>;
|
||||
def CS1 : Rc<13, "cs1", ["c13"]>, DwarfRegNum<[80]>;
|
||||
def UPCL : Rc<14, "upcyclelo", ["c14"]>, DwarfRegNum<[81]>;
|
||||
def UPCH : Rc<15, "upcyclehi", ["c15"]>, DwarfRegNum<[82]>;
|
||||
def C8: Rc<8, "c8", [], [USR]>, DwarfRegNum<[75]>;
|
||||
def PC: Rc<9, "pc">, DwarfRegNum<[76]>;
|
||||
def UGP: Rc<10, "ugp", ["c10"]>, DwarfRegNum<[77]>;
|
||||
def GP: Rc<11, "gp", ["c11"]>, DwarfRegNum<[78]>;
|
||||
def CS0: Rc<12, "cs0", ["c12"]>, DwarfRegNum<[79]>;
|
||||
def CS1: Rc<13, "cs1", ["c13"]>, DwarfRegNum<[80]>;
|
||||
def UPCL: Rc<14, "upcyclelo", ["c14"]>, DwarfRegNum<[81]>;
|
||||
def UPCH: Rc<15, "upcyclehi", ["c15"]>, DwarfRegNum<[82]>;
|
||||
def FRAMELIMIT: Rc<16, "framelimit", ["c16"]>, DwarfRegNum<[83]>;
|
||||
def FRAMEKEY: Rc<17, "framekey", ["c17"]>, DwarfRegNum<[84]>;
|
||||
def PKTCOUNTLO: Rc<18, "pktcountlo", ["c18"]>, DwarfRegNum<[85]>;
|
||||
def PKTCOUNTHI: Rc<19, "pktcounthi", ["c19"]>, DwarfRegNum<[86]>;
|
||||
def UTIMERLO: Rc<30, "utimerlo", ["c30"]>, DwarfRegNum<[97]>;
|
||||
def UTIMERHI: Rc<31, "utimerhi", ["c31"]>, DwarfRegNum<[98]>;
|
||||
}
|
||||
|
||||
// Control registers pairs.
|
||||
let SubRegIndices = [isub_lo, isub_hi], CoveredBySubRegs = 1 in {
|
||||
def C1_0 : Rcc<0, "c1:0", [SA0, LC0], ["lc0:sa0"]>, DwarfRegNum<[67]>;
|
||||
def C3_2 : Rcc<2, "c3:2", [SA1, LC1], ["lc1:sa1"]>, DwarfRegNum<[69]>;
|
||||
def C5_4 : Rcc<4, "c5:4", [P3_0, C5]>, DwarfRegNum<[71]>;
|
||||
def C7_6 : Rcc<6, "c7:6", [C6, C7], ["m1:0"]>, DwarfRegNum<[72]>;
|
||||
def C1_0: Rcc<0, "c1:0", [SA0, LC0], ["lc0:sa0"]>, DwarfRegNum<[67]>;
|
||||
def C3_2: Rcc<2, "c3:2", [SA1, LC1], ["lc1:sa1"]>, DwarfRegNum<[69]>;
|
||||
def C5_4: Rcc<4, "c5:4", [P3_0, C5]>, DwarfRegNum<[71]>;
|
||||
def C7_6: Rcc<6, "c7:6", [C6, C7], ["m1:0"]>, DwarfRegNum<[72]>;
|
||||
// Use C8 instead of USR as a subregister of C9_8.
|
||||
def C9_8 : Rcc<8, "c9:8", [C8, PC]>, DwarfRegNum<[74]>;
|
||||
def C11_10 : Rcc<10, "c11:10", [UGP, GP]>, DwarfRegNum<[76]>;
|
||||
def CS : Rcc<12, "c13:12", [CS0, CS1], ["cs1:0"]>, DwarfRegNum<[78]>;
|
||||
def UPC : Rcc<14, "c15:14", [UPCL, UPCH]>, DwarfRegNum<[80]>;
|
||||
def C9_8: Rcc<8, "c9:8", [C8, PC]>, DwarfRegNum<[74]>;
|
||||
def C11_10: Rcc<10, "c11:10", [UGP, GP]>, DwarfRegNum<[76]>;
|
||||
def CS: Rcc<12, "c13:12", [CS0, CS1], ["cs1:0"]>, DwarfRegNum<[78]>;
|
||||
def UPC: Rcc<14, "c15:14", [UPCL, UPCH]>, DwarfRegNum<[80]>;
|
||||
def C17_16: Rcc<16, "c17:16", [FRAMELIMIT, FRAMEKEY]>, DwarfRegNum<[83]>;
|
||||
def PKTCOUNT: Rcc<18, "c19:18", [PKTCOUNTLO, PKTCOUNTHI], ["pktcount"]>,
|
||||
DwarfRegNum<[85]>;
|
||||
def UTIMER: Rcc<30, "c31:30", [UTIMERLO, UTIMERHI], ["utimer"]>,
|
||||
DwarfRegNum<[97]>;
|
||||
}
|
||||
|
||||
foreach i = 0-31 in {
|
||||
@ -269,17 +280,26 @@ def ModRegs : RegisterClass<"Hexagon", [i32], 32, (add M0, M1)>;
|
||||
|
||||
let Size = 32, isAllocatable = 0 in
|
||||
def CtrRegs : RegisterClass<"Hexagon", [i32], 32,
|
||||
(add LC0, SA0, LC1, SA1,
|
||||
P3_0, C5,
|
||||
M0, M1, C6, C7, C8, CS0, CS1, UPCL, UPCH,
|
||||
USR, UGP, GP, PC)>;
|
||||
(add LC0, SA0, LC1, SA1, P3_0, C5, C6, C7,
|
||||
C8, PC, UGP, GP, CS0, CS1, UPCL, UPCH,
|
||||
FRAMELIMIT, FRAMEKEY, PKTCOUNTLO, PKTCOUNTHI, UTIMERLO, UTIMERHI,
|
||||
M0, M1, USR)>;
|
||||
|
||||
let isAllocatable = 0 in
|
||||
def UsrBits : RegisterClass<"Hexagon", [i1], 0, (add USR_OVF)>;
|
||||
|
||||
let Size = 64, isAllocatable = 0 in
|
||||
def CtrRegs64 : RegisterClass<"Hexagon", [i64], 64,
|
||||
(add C1_0, C3_2, C7_6, C9_8, C11_10, CS, UPC)>;
|
||||
(add C1_0, C3_2, C5_4, C7_6, C9_8, C11_10, CS, UPC, C17_16,
|
||||
PKTCOUNT, UTIMER)>;
|
||||
|
||||
// These registers are new for v62 and onward.
|
||||
// The function RegisterMatchesArch() uses this list for validation.
|
||||
let isAllocatable = 0 in
|
||||
def V62Regs : RegisterClass<"Hexagon", [i32], 32,
|
||||
(add FRAMELIMIT, FRAMEKEY, C17_16,
|
||||
PKTCOUNTLO, PKTCOUNTHI, PKTCOUNT,
|
||||
UTIMERLO, UTIMERHI, UTIMER)>;
|
||||
|
||||
def VolatileV3 {
|
||||
list<Register> Regs = [D0, D1, D2, D3, D4, D5, D6, D7,
|
||||
|
@ -21,3 +21,12 @@ include "HexagonScheduleV55.td"
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
include "HexagonScheduleV60.td"
|
||||
include "HexagonIICScalar.td"
|
||||
include "HexagonIICHVX.td"
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// V62 Machine Info +
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
include "HexagonScheduleV62.td"
|
||||
|
||||
|
129
lib/Target/Hexagon/HexagonScheduleV62.td
Normal file
129
lib/Target/Hexagon/HexagonScheduleV62.td
Normal file
@ -0,0 +1,129 @@
|
||||
//=-HexagonScheduleV62.td - HexagonV62 Scheduling Definitions *- tablegen -*-=//
|
||||
//
|
||||
// The LLVM Compiler Infrastructure
|
||||
//
|
||||
// This file is distributed under the University of Illinois Open Source
|
||||
// License. See LICENSE.TXT for details.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
// V62 follows the same schedule as V60 with following exceptions:
|
||||
// Following instructions are permissible on any slot on V62:
|
||||
// V4_J4_cmpeq_fp0_jump_nt
|
||||
// V4_J4_cmpeq_fp0_jump_t
|
||||
// V4_J4_cmpeq_fp1_jump_nt
|
||||
// V4_J4_cmpeq_fp1_jump_t
|
||||
// V4_J4_cmpeq_tp0_jump_nt
|
||||
// V4_J4_cmpeq_tp0_jump_t
|
||||
// V4_J4_cmpeq_tp1_jump_nt
|
||||
// V4_J4_cmpeq_tp1_jump_t
|
||||
// V4_J4_cmpeqi_fp0_jump_nt
|
||||
// V4_J4_cmpeqi_fp0_jump_t
|
||||
// V4_J4_cmpeqi_fp1_jump_nt
|
||||
// V4_J4_cmpeqi_fp1_jump_t
|
||||
// V4_J4_cmpeqi_tp0_jump_nt
|
||||
// V4_J4_cmpeqi_tp0_jump_t
|
||||
// V4_J4_cmpeqi_tp1_jump_nt
|
||||
// V4_J4_cmpeqi_tp1_jump_t
|
||||
// V4_J4_cmpeqn1_fp0_jump_nt
|
||||
// V4_J4_cmpeqn1_fp0_jump_t
|
||||
// V4_J4_cmpeqn1_fp1_jump_nt
|
||||
// V4_J4_cmpeqn1_fp1_jump_t
|
||||
// V4_J4_cmpeqn1_tp0_jump_nt
|
||||
// V4_J4_cmpeqn1_tp0_jump_t
|
||||
// V4_J4_cmpeqn1_tp1_jump_nt
|
||||
// V4_J4_cmpeqn1_tp1_jump_t
|
||||
// V4_J4_cmpgt_fp0_jump_nt
|
||||
// V4_J4_cmpgt_fp0_jump_t
|
||||
// V4_J4_cmpgt_fp1_jump_nt
|
||||
// V4_J4_cmpgt_fp1_jump_t
|
||||
// V4_J4_cmpgt_tp0_jump_nt
|
||||
// V4_J4_cmpgt_tp0_jump_t
|
||||
// V4_J4_cmpgt_tp1_jump_nt
|
||||
// V4_J4_cmpgt_tp1_jump_t
|
||||
// V4_J4_cmpgti_fp0_jump_nt
|
||||
// V4_J4_cmpgti_fp0_jump_t
|
||||
// V4_J4_cmpgti_fp1_jump_nt
|
||||
// V4_J4_cmpgti_fp1_jump_t
|
||||
// V4_J4_cmpgti_tp0_jump_nt
|
||||
// V4_J4_cmpgti_tp0_jump_t
|
||||
// V4_J4_cmpgti_tp1_jump_nt
|
||||
// V4_J4_cmpgti_tp1_jump_t
|
||||
// V4_J4_cmpgtn1_fp0_jump_nt
|
||||
// V4_J4_cmpgtn1_fp0_jump_t
|
||||
// V4_J4_cmpgtn1_fp1_jump_nt
|
||||
// V4_J4_cmpgtn1_fp1_jump_t
|
||||
// V4_J4_cmpgtn1_tp0_jump_nt
|
||||
// V4_J4_cmpgtn1_tp0_jump_t
|
||||
// V4_J4_cmpgtn1_tp1_jump_nt
|
||||
// V4_J4_cmpgtn1_tp1_jump_t
|
||||
// V4_J4_cmpgtu_fp0_jump_nt
|
||||
// V4_J4_cmpgtu_fp0_jump_t
|
||||
// V4_J4_cmpgtu_fp1_jump_nt
|
||||
// V4_J4_cmpgtu_fp1_jump_t
|
||||
// V4_J4_cmpgtu_tp0_jump_nt
|
||||
// V4_J4_cmpgtu_tp0_jump_t
|
||||
// V4_J4_cmpgtu_tp1_jump_nt
|
||||
// V4_J4_cmpgtu_tp1_jump_t
|
||||
// V4_J4_cmpgtui_fp0_jump_nt
|
||||
// V4_J4_cmpgtui_fp0_jump_t
|
||||
// V4_J4_cmpgtui_fp1_jump_nt
|
||||
// V4_J4_cmpgtui_fp1_jump_t
|
||||
// V4_J4_cmpgtui_tp0_jump_nt
|
||||
// V4_J4_cmpgtui_tp0_jump_t
|
||||
// V4_J4_cmpgtui_tp1_jump_nt
|
||||
// V4_J4_cmpgtui_tp1_jump_t
|
||||
// V4_J4_tstbit0_fp0_jump_nt
|
||||
// V4_J4_tstbit0_fp0_jump_t
|
||||
// V4_J4_tstbit0_fp1_jump_nt
|
||||
// V4_J4_tstbit0_fp1_jump_t
|
||||
// V4_J4_tstbit0_tp0_jump_nt
|
||||
// V4_J4_tstbit0_tp0_jump_t
|
||||
// V4_J4_tstbit0_tp1_jump_nt
|
||||
// V4_J4_tstbit0_tp1_jump_t
|
||||
// JMP
|
||||
// JMPEXT
|
||||
// JMPEXT_f
|
||||
// JMPEXT_fnew_nt
|
||||
// JMPEXT_fnew_t
|
||||
// JMPEXT_t
|
||||
// JMPEXT_tnew_nt
|
||||
// JMPEXT_tnew_t
|
||||
// JMPNOTEXT
|
||||
// JMPNOTEXT_f
|
||||
// JMPNOTEXT_fnew_nt
|
||||
// JMPNOTEXT_fnew_t
|
||||
// JMPNOTEXT_t
|
||||
// JMPNOTEXT_tnew_nt
|
||||
// JMPNOTEXT_tnew_t
|
||||
// JMP_f
|
||||
// JMP_fnew_nt
|
||||
// JMP_fnew_t
|
||||
// JMP_t
|
||||
// JMP_tnew_nt
|
||||
// JMP_tnew_t
|
||||
// RESTORE_DEALLOC_RET_JMP_V4
|
||||
// RESTORE_DEALLOC_RET_JMP_V4_EXT
|
||||
|
||||
def HexagonV62ItinList : ScalarItin, HVXV62Itin {
|
||||
list<InstrItinData> ItinList =
|
||||
!listconcat(ScalarItin_list, HVXV62Itin_list);
|
||||
}
|
||||
|
||||
def HexagonItinerariesV62 :
|
||||
ProcessorItineraries<[SLOT0, SLOT1, SLOT2, SLOT3, SLOT_ENDLOOP,
|
||||
CVI_ST, CVI_XLANE, CVI_SHIFT, CVI_MPY0, CVI_MPY1,
|
||||
CVI_LD, CVI_XLSHF, CVI_MPY01, CVI_ALL],
|
||||
[], HexagonV62ItinList.ItinList>;
|
||||
|
||||
def HexagonModelV62 : SchedMachineModel {
|
||||
// Max issue per cycle == bundle width.
|
||||
let IssueWidth = 4;
|
||||
let Itineraries = HexagonItinerariesV62;
|
||||
let LoadLatency = 1;
|
||||
let CompleteModel = 0;
|
||||
}
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// Hexagon V62 Resource Definitions -
|
||||
//===----------------------------------------------------------------------===//
|
@ -88,6 +88,7 @@ HexagonSubtarget::initializeSubtargetDependencies(StringRef CPU, StringRef FS) {
|
||||
{ "hexagonv5", V5 },
|
||||
{ "hexagonv55", V55 },
|
||||
{ "hexagonv60", V60 },
|
||||
{ "hexagonv62", V62 },
|
||||
};
|
||||
|
||||
auto foundIt = CpuTable.find(CPUString);
|
||||
|
@ -96,6 +96,9 @@ public:
|
||||
bool hasV55TOpsOnly() const { return getHexagonArchVersion() == V55; }
|
||||
bool hasV60TOps() const { return getHexagonArchVersion() >= V60; }
|
||||
bool hasV60TOpsOnly() const { return getHexagonArchVersion() == V60; }
|
||||
bool hasV62TOps() const { return getHexagonArchVersion() >= V62; }
|
||||
bool hasV62TOpsOnly() const { return getHexagonArchVersion() == V62; }
|
||||
|
||||
bool modeIEEERndNear() const { return ModeIEEERndNear; }
|
||||
bool useHVXOps() const { return UseHVXOps; }
|
||||
bool useHVXDblOps() const { return UseHVXOps && UseHVXDblOps; }
|
||||
|
@ -67,6 +67,9 @@ static cl::opt<bool> HexagonV55ArchVariant("mv55", cl::Hidden, cl::init(false),
|
||||
static cl::opt<bool> HexagonV60ArchVariant("mv60", cl::Hidden, cl::init(false),
|
||||
cl::desc("Build for Hexagon V60"));
|
||||
|
||||
static cl::opt<bool> HexagonV62ArchVariant("mv62", cl::Hidden, cl::init(false),
|
||||
cl::desc("Build for Hexagon V62"));
|
||||
|
||||
static StringRef DefaultArch = "hexagonv60";
|
||||
|
||||
static StringRef HexagonGetArchVariant() {
|
||||
@ -78,6 +81,8 @@ static StringRef HexagonGetArchVariant() {
|
||||
return "hexagonv55";
|
||||
if (HexagonV60ArchVariant)
|
||||
return "hexagonv60";
|
||||
if (HexagonV62ArchVariant)
|
||||
return "hexagonv62";
|
||||
return "";
|
||||
}
|
||||
|
||||
@ -247,7 +252,7 @@ static bool LLVM_ATTRIBUTE_UNUSED checkFeature(MCSubtargetInfo* STI, uint64_t F)
|
||||
StringRef Hexagon_MC::ParseHexagonTriple(const Triple &TT, StringRef CPU) {
|
||||
StringRef CPUName = Hexagon_MC::selectHexagonCPU(TT, CPU);
|
||||
StringRef FS = "";
|
||||
if (CPUName.equals_lower("hexagonv60"))
|
||||
if (CPUName.equals_lower("hexagonv60") || CPUName.equals_lower("hexagonv62"))
|
||||
FS = "+hvx";
|
||||
return FS;
|
||||
}
|
||||
@ -260,6 +265,7 @@ static bool isCPUValid(std::string CPU)
|
||||
"hexagonv5",
|
||||
"hexagonv55",
|
||||
"hexagonv60",
|
||||
"hexagonv62",
|
||||
};
|
||||
|
||||
return std::find(table.begin(), table.end(), CPU) != table.end();
|
||||
@ -270,9 +276,9 @@ MCSubtargetInfo *Hexagon_MC::createHexagonMCSubtargetInfo(const Triple &TT,
|
||||
StringRef FS) {
|
||||
StringRef ArchFS = (FS.size()) ? FS : Hexagon_MC::ParseHexagonTriple(TT, CPU);
|
||||
StringRef CPUName = Hexagon_MC::selectHexagonCPU(TT, CPU);
|
||||
if (!isCPUValid(CPUName.str()))
|
||||
{
|
||||
errs() << "error: invalid CPU \"" << CPUName.str().c_str() << "\" specified\n";
|
||||
if (!isCPUValid(CPUName.str())) {
|
||||
errs() << "error: invalid CPU \"" << CPUName.str().c_str()
|
||||
<< "\" specified\n";
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
@ -290,6 +296,7 @@ unsigned Hexagon_MC::GetELFFlags(const MCSubtargetInfo &STI) {
|
||||
{"hexagonv5", ELF::EF_HEXAGON_MACH_V5},
|
||||
{"hexagonv55", ELF::EF_HEXAGON_MACH_V55},
|
||||
{"hexagonv60", ELF::EF_HEXAGON_MACH_V60},
|
||||
{"hexagonv62", ELF::EF_HEXAGON_MACH_V62},
|
||||
};
|
||||
|
||||
auto F = ElfFlags.find(STI.getCPU());
|
||||
|
@ -2,8 +2,10 @@
|
||||
# RUN: llvm-mc -arch=hexagon -mcpu=hexagonv5 --filetype=obj %s -o - | llvm-readobj -file-headers -elf-output-style=GNU | FileCheck --check-prefix=CHECK-V5 %s
|
||||
# RUN: llvm-mc -arch=hexagon -mcpu=hexagonv55 --filetype=obj %s -o - | llvm-readobj -file-headers -elf-output-style=GNU | FileCheck --check-prefix=CHECK-V55 %s
|
||||
# RUN: llvm-mc -arch=hexagon -mcpu=hexagonv60 --filetype=obj %s -o - | llvm-readobj -file-headers -elf-output-style=GNU | FileCheck --check-prefix=CHECK-V60 %s
|
||||
# RUN: llvm-mc -arch=hexagon -mcpu=hexagonv62 --filetype=obj %s -o - | llvm-readobj -file-headers -elf-output-style=GNU | FileCheck --check-prefix=CHECK-V62 %s
|
||||
|
||||
# CHECK-V4: Flags: 0x3
|
||||
# CHECK-V5: Flags: 0x4
|
||||
# CHECK-V55: Flags: 0x5
|
||||
# CHECK-V60: Flags: 0x60
|
||||
# CHECK-V62: Flags: 0x62
|
||||
|
552
test/MC/Hexagon/v62_all.s
Normal file
552
test/MC/Hexagon/v62_all.s
Normal file
@ -0,0 +1,552 @@
|
||||
# RUN: llvm-mc -arch=hexagon -mcpu=hexagonv62 -filetype=obj %s | llvm-objdump -arch=hexagon -mcpu=hexagonv62 -d - | FileCheck %s
|
||||
|
||||
// V6_lvsplatb
|
||||
// Vd32.b=vsplat(Rt32)
|
||||
V0.b=vsplat(R0)
|
||||
# CHECK: 19c0c040 { v0.b = vsplat(r0) }
|
||||
|
||||
// V6_lvsplath
|
||||
// Vd32.h=vsplat(Rt32)
|
||||
V0.h=vsplat(R0)
|
||||
# CHECK: 19c0c020 { v0.h = vsplat(r0) }
|
||||
|
||||
// V6_pred_scalar2v2
|
||||
// Qd4=vsetq2(Rt32)
|
||||
Q0=vsetq2(R0)
|
||||
# CHECK: 19a0c04c { q0 = vsetq2(r0) }
|
||||
|
||||
// V6_shuffeqh
|
||||
// Qd4.b=vshuffe(Qs4.h,Qt4.h)
|
||||
Q0.b=vshuffe(Q0.h,Q0.h)
|
||||
# CHECK: 1e03c018 { q0.b = vshuffe(q0.h,q0.h) }
|
||||
|
||||
// V6_shuffeqw
|
||||
// Qd4.h=vshuffe(Qs4.w,Qt4.w)
|
||||
Q0.h=vshuffe(Q0.w,Q0.w)
|
||||
# CHECK: 1e03c01c { q0.h = vshuffe(q0.w,q0.w) }
|
||||
|
||||
// V6_vaddbsat
|
||||
// Vd32.b=vadd(Vu32.b,Vv32.b):sat
|
||||
V0.b=vadd(V0.b,V0.b):sat
|
||||
# CHECK: 1f00c000 { v0.b = vadd(v0.b,v0.b):sat }
|
||||
|
||||
// V6_vaddbsat_dv
|
||||
// Vdd32.b=vadd(Vuu32.b,Vvv32.b):sat
|
||||
V1:0.b=vadd(V1:0.b,V1:0.b):sat
|
||||
# CHECK: 1ea0c000 { v1:0.b = vadd(v1:0.b,v1:0.b):sat }
|
||||
|
||||
// V6_vaddcarry
|
||||
// Vd32.w=vadd(Vu32.w,Vv32.w,Qx4):carry
|
||||
V0.w=vadd(V0.w,V0.w,Q0):carry
|
||||
# CHECK: 1ca0e000 { v0.w = vadd(v0.w,v0.w,q0):carry }
|
||||
|
||||
// V6_vaddclbh
|
||||
// $Vd.h=vadd(vclb($Vu.h),$Vv.h)
|
||||
V0.h=vadd(vclb(V0.h),V0.h)
|
||||
# CHECK: 1f00e000 { v0.h = vadd(vclb(v0.h),v0.h) }
|
||||
|
||||
// V6_vaddclbw
|
||||
// $Vd.w=vadd(vclb($Vu.w),$Vv.w)
|
||||
V0.w=vadd(vclb(V0.w),V0.w)
|
||||
# CHECK: 1f00e020 { v0.w = vadd(vclb(v0.w),v0.w) }
|
||||
|
||||
// V6_vaddhw_acc
|
||||
// Vxx32.w+=vadd(Vu32.h,Vv32.h)
|
||||
V1:0.w+=vadd(V0.h,V0.h)
|
||||
# CHECK: 1c20e040 { v1:0.w += vadd(v0.h,v0.h) }
|
||||
|
||||
// V6_vaddubh_acc
|
||||
// Vxx32.h+=vadd(Vu32.ub,Vv32.ub)
|
||||
V1:0.h+=vadd(V0.ub,V0.ub)
|
||||
# CHECK: 1c40e0a0 { v1:0.h += vadd(v0.ub,v0.ub) }
|
||||
|
||||
// V6_vaddububb_sat
|
||||
// Vd32.ub=vadd(Vu32.ub,Vv32.b):sat
|
||||
V0.ub=vadd(V0.ub,V0.b):sat
|
||||
# CHECK: 1ea0c080 { v0.ub = vadd(v0.ub,v0.b):sat }
|
||||
|
||||
// V6_vadduhw_acc
|
||||
// Vxx32.w+=vadd(Vu32.uh,Vv32.uh)
|
||||
V1:0.w+=vadd(V0.uh,V0.uh)
|
||||
# CHECK: 1c40e080 { v1:0.w += vadd(v0.uh,v0.uh) }
|
||||
|
||||
// V6_vadduwsat
|
||||
// Vd32.uw=vadd(Vu32.uw,Vv32.uw):sat
|
||||
V0.uw=vadd(V0.uw,V0.uw):sat
|
||||
# CHECK: 1f60c020 { v0.uw = vadd(v0.uw,v0.uw):sat }
|
||||
|
||||
// V6_vadduwsat_dv
|
||||
// Vdd32.uw=vadd(Vuu32.uw,Vvv32.uw):sat
|
||||
V1:0.uw=vadd(V1:0.uw,V1:0.uw):sat
|
||||
# CHECK: 1ea0c040 { v1:0.uw = vadd(v1:0.uw,v1:0.uw):sat }
|
||||
|
||||
// V6_vandnqrt
|
||||
// Vd32=vand(!Qu4,Rt32)
|
||||
V0=vand(!Q0,R0)
|
||||
# CHECK: 19a0c4a0 { v0 = vand(!q0,r0) }
|
||||
|
||||
// V6_vandnqrt_acc
|
||||
// Vx32|=vand(!Qu4,Rt32)
|
||||
V0|=vand(!Q0,R0)
|
||||
# CHECK: 1960e460 { v0 |= vand(!q0,r0) }
|
||||
|
||||
// V6_vandvnqv
|
||||
// Vd32=vand(!Qv4,Vu32)
|
||||
V0=vand(!Q0,V0)
|
||||
# CHECK: 1e03e020 { v0 = vand(!q0,v0) }
|
||||
|
||||
// V6_vandvqv
|
||||
// Vd32=vand(Qv4,Vu32)
|
||||
V0=vand(Q0,V0)
|
||||
# CHECK: 1e03e000 { v0 = vand(q0,v0) }
|
||||
|
||||
// V6_vasrhbsat
|
||||
// Vd32.b=vasr(Vu32.h,Vv32.h,Rt8):sat
|
||||
V0.b=vasr(V0.h,V0.h,R0):sat
|
||||
# CHECK: 1800c000 { v0.b = vasr(v0.h,v0.h,r0):sat }
|
||||
|
||||
// V6_vasruwuhrndsat
|
||||
// Vd32.uh=vasr(Vu32.uw,Vv32.uw,Rt8):rnd:sat
|
||||
V0.uh=vasr(V0.uw,V0.uw,R0):rnd:sat
|
||||
# CHECK: 1800c020 { v0.uh = vasr(v0.uw,v0.uw,r0):rnd:sat }
|
||||
|
||||
// V6_vasrwuhrndsat
|
||||
// Vd32.uh=vasr(Vu32.w,Vv32.w,Rt8):rnd:sat
|
||||
V0.uh=vasr(V0.w,V0.w,R0):rnd:sat
|
||||
# CHECK: 1800c040 { v0.uh = vasr(v0.w,v0.w,r0):rnd:sat }
|
||||
|
||||
// V6_vL32b_cur_npred_ai
|
||||
// if (!Pv4) Vd32.cur=vmem(Rt32+#s4)
|
||||
{
|
||||
v1=v0
|
||||
if (!P0) V0.cur=vmem(R0+#04)
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 2880c4a0 if (!p0) v0.cur = vmem(r0+#4) }
|
||||
|
||||
// V6_vL32b_cur_npred_pi
|
||||
// if (!Pv4) Vd32.cur=vmem(Rx32++#s3)
|
||||
{
|
||||
v1=v0
|
||||
if (!P0) V0.cur=vmem(R0++#03)
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 2980c3a0 if (!p0) v0.cur = vmem(r0++#3) }
|
||||
|
||||
// V6_vL32b_cur_npred_ppu
|
||||
// if (!Pv4) Vd32.cur=vmem(Rx32++Mu2)
|
||||
{
|
||||
v1=v0
|
||||
if (!P0) V0.cur=vmem(R0++M0)
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 2b80c0a0 if (!p0) v0.cur = vmem(r0++m0) }
|
||||
|
||||
// V6_vL32b_cur_pred_ai
|
||||
// if (Pv4) Vd32.cur=vmem(Rt32+#s4)
|
||||
{
|
||||
v1=v0
|
||||
if (P0) V0.cur=vmem(R0+#04)
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 2880c480 if (p0) v0.cur = vmem(r0+#4) }
|
||||
|
||||
// V6_vL32b_cur_pred_pi
|
||||
// if (Pv4) Vd32.cur=vmem(Rx32++#s3)
|
||||
{
|
||||
v1=v0
|
||||
if (P0) V0.cur=vmem(R0++#03)
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 2980c380 if (p0) v0.cur = vmem(r0++#3) }
|
||||
|
||||
// V6_vL32b_cur_pred_ppu
|
||||
// if (Pv4) Vd32.cur=vmem(Rx32++Mu2)
|
||||
{
|
||||
v1=v0
|
||||
if (P0) V0.cur=vmem(R0++M0)
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 2b80c080 if (p0) v0.cur = vmem(r0++m0) }
|
||||
|
||||
// V6_vL32b_npred_ai
|
||||
// if (!Pv4) Vd32=vmem(Rt32+#s4)
|
||||
if (!P0) V0=vmem(R0+#04)
|
||||
# CHECK: 2880c460 { if (!p0) v0 = vmem(r0+#4) }
|
||||
|
||||
// V6_vL32b_npred_pi
|
||||
// if (!Pv4) Vd32=vmem(Rx32++#s3)
|
||||
if (!P0) V0=vmem(R0++#03)
|
||||
# CHECK: 2980c360 { if (!p0) v0 = vmem(r0++#3) }
|
||||
|
||||
// V6_vL32b_npred_ppu
|
||||
// if (!Pv4) Vd32=vmem(Rx32++Mu2)
|
||||
if (!P0) V0=vmem(R0++M0)
|
||||
# CHECK: 2b80c060 { if (!p0) v0 = vmem(r0++m0) }
|
||||
|
||||
// V6_vL32b_nt_cur_npred_ai
|
||||
// if (!Pv4) Vd32.cur=vmem(Rt32+#s4):nt
|
||||
{
|
||||
v1=v0
|
||||
if (!P0) V0.cur=vmem(R0+#04):nt
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 28c0c4a0 if (!p0) v0.cur = vmem(r0+#4):nt }
|
||||
|
||||
// V6_vL32b_nt_cur_npred_pi
|
||||
// if (!Pv4) Vd32.cur=vmem(Rx32++#s3):nt
|
||||
{
|
||||
v1=v0
|
||||
if (!P0) V0.cur=vmem(R0++#03):nt
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 29c0c3a0 if (!p0) v0.cur = vmem(r0++#3):nt }
|
||||
|
||||
// V6_vL32b_nt_cur_npred_ppu
|
||||
// if (!Pv4) Vd32.cur=vmem(Rx32++Mu2):nt
|
||||
{
|
||||
v1=v0
|
||||
if (!P0) V0.cur=vmem(R0++M0):nt
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 2bc0c0a0 if (!p0) v0.cur = vmem(r0++m0):nt }
|
||||
|
||||
// V6_vL32b_nt_cur_pred_ai
|
||||
// if (Pv4) Vd32.cur=vmem(Rt32+#s4):nt
|
||||
{
|
||||
v1=v0
|
||||
if (P0) V0.cur=vmem(R0+#04):nt
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 28c0c480 if (p0) v0.cur = vmem(r0+#4):nt }
|
||||
|
||||
// V6_vL32b_nt_cur_pred_pi
|
||||
// if (Pv4) Vd32.cur=vmem(Rx32++#s3):nt
|
||||
{
|
||||
v1=v0
|
||||
if (P0) V0.cur=vmem(R0++#03):nt
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 29c0c380 if (p0) v0.cur = vmem(r0++#3):nt }
|
||||
|
||||
// V6_vL32b_nt_cur_pred_ppu
|
||||
// if (Pv4) Vd32.cur=vmem(Rx32++Mu2):nt
|
||||
{
|
||||
v1=v0
|
||||
if (P0) V0.cur=vmem(R0++M0):nt
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 2bc0c080 if (p0) v0.cur = vmem(r0++m0):nt }
|
||||
|
||||
// V6_vL32b_nt_npred_ai
|
||||
// if (!Pv4) Vd32=vmem(Rt32+#s4):nt
|
||||
if (!P0) V0=vmem(R0+#04):nt
|
||||
# CHECK: 28c0c460 { if (!p0) v0 = vmem(r0+#4):nt }
|
||||
|
||||
// V6_vL32b_nt_npred_pi
|
||||
// if (!Pv4) Vd32=vmem(Rx32++#s3):nt
|
||||
if (!P0) V0=vmem(R0++#03):nt
|
||||
# CHECK: 29c0c360 { if (!p0) v0 = vmem(r0++#3):nt }
|
||||
|
||||
// V6_vL32b_nt_npred_ppu
|
||||
// if (!Pv4) Vd32=vmem(Rx32++Mu2):nt
|
||||
if (!P0) V0=vmem(R0++M0):nt
|
||||
# CHECK: 2bc0c060 { if (!p0) v0 = vmem(r0++m0):nt }
|
||||
|
||||
// V6_vL32b_nt_pred_ai
|
||||
// if (Pv4) Vd32=vmem(Rt32+#s4):nt
|
||||
if (P0) V0=vmem(R0+#04):nt
|
||||
# CHECK: 28c0c440 { if (p0) v0 = vmem(r0+#4):nt }
|
||||
|
||||
// V6_vL32b_nt_pred_pi
|
||||
// if (Pv4) Vd32=vmem(Rx32++#s3):nt
|
||||
if (P0) V0=vmem(R0++#03):nt
|
||||
# CHECK: 29c0c340 { if (p0) v0 = vmem(r0++#3):nt }
|
||||
|
||||
// V6_vL32b_nt_pred_ppu
|
||||
// if (Pv4) Vd32=vmem(Rx32++Mu2):nt
|
||||
if (P0) V0=vmem(R0++M0):nt
|
||||
# CHECK: 2bc0c040 { if (p0) v0 = vmem(r0++m0):nt }
|
||||
|
||||
// V6_vL32b_nt_tmp_npred_ai
|
||||
// if (!Pv4) Vd32.tmp=vmem(Rt32+#s4):nt
|
||||
{
|
||||
v1=v0
|
||||
if (!P0) V0.tmp=vmem(R0+#04):nt
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 28c0c4e0 if (!p0) v0.tmp = vmem(r0+#4):nt }
|
||||
|
||||
// V6_vL32b_nt_tmp_npred_pi
|
||||
// if (!Pv4) Vd32.tmp=vmem(Rx32++#s3):nt
|
||||
{
|
||||
v1=v0
|
||||
if (!P0) V0.tmp=vmem(R0++#03):nt
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 29c0c3e0 if (!p0) v0.tmp = vmem(r0++#3):nt }
|
||||
|
||||
// V6_vL32b_nt_tmp_npred_ppu
|
||||
// if (!Pv4) Vd32.tmp=vmem(Rx32++Mu2):nt
|
||||
{
|
||||
v1=v0
|
||||
if (!P0) V0.tmp=vmem(R0++M0):nt
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 2bc0c0e0 if (!p0) v0.tmp = vmem(r0++m0):nt }
|
||||
|
||||
// V6_vL32b_nt_tmp_pred_ai
|
||||
// if (Pv4) Vd32.tmp=vmem(Rt32+#s4):nt
|
||||
{
|
||||
v1=v0
|
||||
if (P0) V0.tmp=vmem(R0+#04):nt
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 28c0c4c0 if (p0) v0.tmp = vmem(r0+#4):nt }
|
||||
|
||||
// V6_vL32b_nt_tmp_pred_pi
|
||||
// if (Pv4) Vd32.tmp=vmem(Rx32++#s3):nt
|
||||
{
|
||||
v1=v0
|
||||
if (P0) V0.tmp=vmem(R0++#03):nt
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 29c0c3c0 if (p0) v0.tmp = vmem(r0++#3):nt }
|
||||
|
||||
// V6_vL32b_nt_tmp_pred_ppu
|
||||
// if (Pv4) Vd32.tmp=vmem(Rx32++Mu2):nt
|
||||
{
|
||||
v1=v0
|
||||
if (P0) V0.tmp=vmem(R0++M0):nt
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 2bc0c0c0 if (p0) v0.tmp = vmem(r0++m0):nt }
|
||||
|
||||
// V6_vL32b_pred_ai
|
||||
// if (Pv4) Vd32=vmem(Rt32+#s4)
|
||||
if (P0) V0=vmem(R0+#04)
|
||||
# CHECK: 2880c440 { if (p0) v0 = vmem(r0+#4) }
|
||||
|
||||
// V6_vL32b_pred_pi
|
||||
// if (Pv4) Vd32=vmem(Rx32++#s3)
|
||||
if (P0) V0=vmem(R0++#03)
|
||||
# CHECK: 2980c340 { if (p0) v0 = vmem(r0++#3) }
|
||||
|
||||
// V6_vL32b_pred_ppu
|
||||
// if (Pv4) Vd32=vmem(Rx32++Mu2)
|
||||
if (P0) V0=vmem(R0++M0)
|
||||
# CHECK: 2b80c040 { if (p0) v0 = vmem(r0++m0) }
|
||||
|
||||
// V6_vL32b_tmp_npred_ai
|
||||
// if (!Pv4) Vd32.tmp=vmem(Rt32+#s4)
|
||||
{
|
||||
v1=v0
|
||||
if (!P0) V0.tmp=vmem(R0+#04)
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 2880c4e0 if (!p0) v0.tmp = vmem(r0+#4) }
|
||||
|
||||
// V6_vL32b_tmp_npred_pi
|
||||
// if (!Pv4) Vd32.tmp=vmem(Rx32++#s3)
|
||||
{
|
||||
v1=v0
|
||||
if (!P0) V0.tmp=vmem(R0++#03)
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 2980c3e0 if (!p0) v0.tmp = vmem(r0++#3) }
|
||||
|
||||
// V6_vL32b_tmp_npred_ppu
|
||||
// if (!Pv4) Vd32.tmp=vmem(Rx32++Mu2)
|
||||
{
|
||||
v1=v0
|
||||
if (!P0) V0.tmp=vmem(R0++M0)
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 2b80c0e0 if (!p0) v0.tmp = vmem(r0++m0) }
|
||||
|
||||
// V6_vL32b_tmp_pred_ai
|
||||
// if (Pv4) Vd32.tmp=vmem(Rt32+#s4)
|
||||
{
|
||||
v1=v0
|
||||
if (P0) V0.tmp=vmem(R0+#04)
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 2880c4c0 if (p0) v0.tmp = vmem(r0+#4) }
|
||||
|
||||
// V6_vL32b_tmp_pred_pi
|
||||
// if (Pv4) Vd32.tmp=vmem(Rx32++#s3)
|
||||
{
|
||||
v1=v0
|
||||
if (P0) V0.tmp=vmem(R0++#03)
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 2980c3c0 if (p0) v0.tmp = vmem(r0++#3) }
|
||||
|
||||
// V6_vL32b_tmp_pred_ppu
|
||||
// if (Pv4) Vd32.tmp=vmem(Rx32++Mu2)
|
||||
{
|
||||
v1=v0
|
||||
if (P0) V0.tmp=vmem(R0++M0)
|
||||
}
|
||||
# CHECK: 1e0360e1 { v1 = v0
|
||||
# CHECK: 2b80c0c0 if (p0) v0.tmp = vmem(r0++m0) }
|
||||
|
||||
// V6_vlsrb
|
||||
// Vd32.ub=vlsr(Vu32.ub,Rt32)
|
||||
V0.ub=vlsr(V0.ub,R0)
|
||||
# CHECK: 1980c060 { v0.ub = vlsr(v0.ub,r0) }
|
||||
|
||||
// V6_vlutvvbi
|
||||
// Vd32.b=vlut32(Vu32.b,Vv32.b,#u3)
|
||||
V0.b=vlut32(V0.b,V0.b,#03)
|
||||
# CHECK: 1e20c060 { v0.b = vlut32(v0.b,v0.b,#3) }
|
||||
|
||||
// V6_vlutvvb_nm
|
||||
// Vd32.b=vlut32(Vu32.b,Vv32.b,Rt8):nomatch
|
||||
V0.b=vlut32(V0.b,V0.b,R0):nomatch
|
||||
# CHECK: 1800c060 { v0.b = vlut32(v0.b,v0.b,r0):nomatch }
|
||||
|
||||
// V6_vlutvvb_oracci
|
||||
// Vx32.b|=vlut32(Vu32.b,Vv32.b,#u3)
|
||||
V0.b|=vlut32(V0.b,V0.b,#03)
|
||||
# CHECK: 1cc0e060 { v0.b |= vlut32(v0.b,v0.b,#3) }
|
||||
|
||||
// V6_vlutvwhi
|
||||
// Vdd32.h=vlut16(Vu32.b,Vv32.h,#u3)
|
||||
V1:0.h=vlut16(V0.b,V0.h,#03)
|
||||
# CHECK: 1e60c060 { v1:0.h = vlut16(v0.b,v0.h,#3) }
|
||||
|
||||
// V6_vlutvwh_nm
|
||||
// Vdd32.h=vlut16(Vu32.b,Vv32.h,Rt8):nomatch
|
||||
V1:0.h=vlut16(V0.b,V0.h,R0):nomatch
|
||||
# CHECK: 1800c080 { v1:0.h = vlut16(v0.b,v0.h,r0):nomatch }
|
||||
|
||||
// V6_vlutvwh_oracci
|
||||
// Vxx32.h|=vlut16(Vu32.b,Vv32.h,#u3)
|
||||
V1:0.h|=vlut16(V0.b,V0.h,#03)
|
||||
# CHECK: 1ce0e060 { v1:0.h |= vlut16(v0.b,v0.h,#3) }
|
||||
|
||||
// V6_vmaxb
|
||||
// Vd32.b=vmax(Vu32.b,Vv32.b)
|
||||
V0.b=vmax(V0.b,V0.b)
|
||||
# CHECK: 1f20c0a0 { v0.b = vmax(v0.b,v0.b) }
|
||||
|
||||
// V6_vminb
|
||||
// Vd32.b=vmin(Vu32.b,Vv32.b)
|
||||
V0.b=vmin(V0.b,V0.b)
|
||||
# CHECK: 1f20c080 { v0.b = vmin(v0.b,v0.b) }
|
||||
|
||||
// V6_vmpauhb
|
||||
// Vdd32.w=vmpa(Vuu32.uh,Rt32.b)
|
||||
V1:0.w=vmpa(V1:0.uh,R0.b)
|
||||
# CHECK: 1980c0a0 { v1:0.w = vmpa(v1:0.uh,r0.b) }
|
||||
|
||||
// V6_vmpauhb_acc
|
||||
// Vxx32.w+=vmpa(Vuu32.uh,Rt32.b)
|
||||
V1:0.w+=vmpa(V1:0.uh,R0.b)
|
||||
# CHECK: 1980e040 { v1:0.w += vmpa(v1:0.uh,r0.b) }
|
||||
|
||||
// V6_vmpyewuh_64
|
||||
// Vdd32=vmpye(Vu32.w,Vv32.uh)
|
||||
V1:0=vmpye(V0.w,V0.uh)
|
||||
# CHECK: 1ea0c0c0 { v1:0 = vmpye(v0.w,v0.uh) }
|
||||
|
||||
// V6_vmpyiwub
|
||||
// Vd32.w=vmpyi(Vu32.w,Rt32.ub)
|
||||
V0.w=vmpyi(V0.w,R0.ub)
|
||||
# CHECK: 1980c0c0 { v0.w = vmpyi(v0.w,r0.ub) }
|
||||
|
||||
// V6_vmpyiwub_acc
|
||||
// Vx32.w+=vmpyi(Vu32.w,Rt32.ub)
|
||||
V0.w+=vmpyi(V0.w,R0.ub)
|
||||
# CHECK: 1980e020 { v0.w += vmpyi(v0.w,r0.ub) }
|
||||
|
||||
// V6_vmpyowh_64_acc
|
||||
// Vxx32+=vmpyo(Vu32.w,Vv32.h)
|
||||
V1:0+=vmpyo(V0.w,V0.h)
|
||||
# CHECK: 1c20e060 { v1:0 += vmpyo(v0.w,v0.h) }
|
||||
|
||||
// V6_vrounduhub
|
||||
// Vd32.ub=vround(Vu32.uh,Vv32.uh):sat
|
||||
V0.ub=vround(V0.uh,V0.uh):sat
|
||||
# CHECK: 1fe0c060 { v0.ub = vround(v0.uh,v0.uh):sat }
|
||||
|
||||
// V6_vrounduwuh
|
||||
// Vd32.uh=vround(Vu32.uw,Vv32.uw):sat
|
||||
V0.uh=vround(V0.uw,V0.uw):sat
|
||||
# CHECK: 1fe0c080 { v0.uh = vround(v0.uw,v0.uw):sat }
|
||||
|
||||
// V6_vsatuwuh
|
||||
// Vd32.uh=vsat(Vu32.uw,Vv32.uw)
|
||||
V0.uh=vsat(V0.uw,V0.uw)
|
||||
# CHECK: 1f20c0c0 { v0.uh = vsat(v0.uw,v0.uw) }
|
||||
|
||||
// V6_vsubbsat
|
||||
// Vd32.b=vsub(Vu32.b,Vv32.b):sat
|
||||
V0.b=vsub(V0.b,V0.b):sat
|
||||
# CHECK: 1f20c040 { v0.b = vsub(v0.b,v0.b):sat }
|
||||
|
||||
// V6_vsubbsat_dv
|
||||
// Vdd32.b=vsub(Vuu32.b,Vvv32.b):sat
|
||||
V1:0.b=vsub(V1:0.b,V1:0.b):sat
|
||||
# CHECK: 1ea0c020 { v1:0.b = vsub(v1:0.b,v1:0.b):sat }
|
||||
|
||||
// V6_vsubcarry
|
||||
// Vd32.w=vsub(Vu32.w,Vv32.w,Qx4):carry
|
||||
V0.w=vsub(V0.w,V0.w,Q0):carry
|
||||
# CHECK: 1ca0e080 { v0.w = vsub(v0.w,v0.w,q0):carry }
|
||||
|
||||
// V6_vsubububb_sat
|
||||
// Vd32.ub=vsub(Vu32.ub,Vv32.b):sat
|
||||
V0.ub=vsub(V0.ub,V0.b):sat
|
||||
# CHECK: 1ea0c0a0 { v0.ub = vsub(v0.ub,v0.b):sat }
|
||||
|
||||
// V6_vsubuwsat
|
||||
// Vd32.uw=vsub(Vu32.uw,Vv32.uw):sat
|
||||
V0.uw=vsub(V0.uw,V0.uw):sat
|
||||
# CHECK: 1fc0c080 { v0.uw = vsub(v0.uw,v0.uw):sat }
|
||||
|
||||
// V6_vsubuwsat_dv
|
||||
// Vdd32.uw=vsub(Vuu32.uw,Vvv32.uw):sat
|
||||
V1:0.uw=vsub(V1:0.uw,V1:0.uw):sat
|
||||
# CHECK: 1ea0c060 { v1:0.uw = vsub(v1:0.uw,v1:0.uw):sat }
|
||||
|
||||
// V6_vwhist128
|
||||
// vwhist128
|
||||
vwhist128
|
||||
# CHECK: 1e00e480 { vwhist128 }
|
||||
|
||||
// V6_vwhist128m
|
||||
// vwhist128(#u1)
|
||||
vwhist128(#01)
|
||||
# CHECK: 1e00e780 { vwhist128(#1) }
|
||||
|
||||
// V6_vwhist128q
|
||||
// vwhist128(Qv4)
|
||||
vwhist128(Q0)
|
||||
# CHECK: 1e02e480 { vwhist128(q0) }
|
||||
|
||||
// V6_vwhist128qm
|
||||
// vwhist128(Qv4,#u1)
|
||||
vwhist128(Q0,#01)
|
||||
# CHECK: 1e02e780 { vwhist128(q0,#1) }
|
||||
|
||||
// V6_vwhist256
|
||||
// vwhist256
|
||||
vwhist256
|
||||
# CHECK: 1e00e280 { vwhist256 }
|
||||
|
||||
// V6_vwhist256q
|
||||
// vwhist256(Qv4)
|
||||
vwhist256(Q0)
|
||||
# CHECK: 1e02e280 { vwhist256(q0) }
|
||||
|
||||
// V6_vwhist256q_sat
|
||||
// vwhist256(Qv4):sat
|
||||
vwhist256(Q0):sat
|
||||
# CHECK: 1e02e380 { vwhist256(q0):sat }
|
||||
|
||||
// V6_vwhist256_sat
|
||||
// vwhist256:sat
|
||||
vwhist256:sat
|
||||
# CHECK: 1e00e380 { vwhist256:sat }
|
13
test/MC/Hexagon/v62_jumps.s
Normal file
13
test/MC/Hexagon/v62_jumps.s
Normal file
@ -0,0 +1,13 @@
|
||||
# RUN: llvm-mc -arch=hexagon -mcpu=hexagonv62 -filetype=obj %s | llvm-objdump -arch=hexagon -mcpu=hexagonv62 -d - | FileCheck %s
|
||||
|
||||
# verify compound is split into single instructions if needed
|
||||
{
|
||||
p0=cmp.eq(R1:0,R3:2)
|
||||
if (!p0.new) jump:nt ltmp
|
||||
r0=r1 ; jump ltmp
|
||||
}
|
||||
|
||||
# CHECK: 5c204800 { if (!p0.new) jump:nt
|
||||
# CHECK: d2804200 p0 = cmp.eq(r1:0,r3:2)
|
||||
# CHECK: 58004000 jump
|
||||
# CHECK: 7061c000 r0 = r1 }
|
19
test/MC/Hexagon/v62a.s
Normal file
19
test/MC/Hexagon/v62a.s
Normal file
@ -0,0 +1,19 @@
|
||||
# RUN: llvm-mc -arch=hexagon -mcpu=hexagonv62 -filetype=obj -o - %s | llvm-objdump -arch=hexagon -arch=hexagon -mcpu=hexagonv62 -d - | FileCheck %s
|
||||
|
||||
r31:30=vabsdiffb(r29:28, r27:26)
|
||||
# CHECK: e8fadc1e { r31:30 = vabsdiffb(r29:28,r27:26)
|
||||
|
||||
r25:24=vabsdiffub(r23:22, r21:20)
|
||||
# CHECK: e8b4d618 { r25:24 = vabsdiffub(r23:22,r21:20)
|
||||
|
||||
r19:18,p3=vminub(r17:16, r15:14)
|
||||
# CHECK: eaeed072 { r19:18,p3 = vminub(r17:16,r15:14)
|
||||
|
||||
r13:12=vtrunehb(r11:10, r9:8)
|
||||
# CHECK: c18ac86c { r13:12 = vtrunehb(r11:10,r9:8)
|
||||
|
||||
r7:6=vtrunohb(r5:4, r3:2)
|
||||
# CHECK: c184c2a6 { r7:6 = vtrunohb(r5:4,r3:2)
|
||||
|
||||
r1:0=vsplatb(r31)
|
||||
# CHECK: 845fc080 { r1:0 = vsplatb(r31)
|
44
test/MC/Hexagon/v62a_regs.s
Normal file
44
test/MC/Hexagon/v62a_regs.s
Normal file
@ -0,0 +1,44 @@
|
||||
# RUN: llvm-mc -arch=hexagon -mcpu=hexagonv62 -filetype=obj %s | llvm-objdump -d - | FileCheck %s --check-prefix=CHECK-V62
|
||||
# RUN: not llvm-mc -arch=hexagon -mcpu=hexagonv60 -filetype=asm %s 2>%t; FileCheck -check-prefix=CHECK-NOV62 %s < %t
|
||||
#
|
||||
|
||||
# Assure that v62 added registers are understood
|
||||
|
||||
r0=framelimit
|
||||
r0=framekey
|
||||
r1:0=c17:16
|
||||
|
||||
# CHECK-V62: 6a10c000 { r0 = framelimit }
|
||||
# CHECK-V62: 6a11c000 { r0 = framekey }
|
||||
# CHECK-V62: 6810c000 { r1:0 = c17:16 }
|
||||
# CHECK-NOV62: rror: invalid operand for instruction
|
||||
# CHECK-NOV62: rror: invalid operand for instruction
|
||||
# CHECK-NOV62: rror: invalid operand for instruction
|
||||
|
||||
r0=pktcountlo
|
||||
r0=pktcounthi
|
||||
r1:0=c19:18
|
||||
r1:0=pktcount
|
||||
|
||||
# CHECK-V62: 6a12c000 { r0 = pktcountlo }
|
||||
# CHECK-V62: 6a13c000 { r0 = pktcounthi }
|
||||
# CHECK-V62: 6812c000 { r1:0 = c19:18 }
|
||||
# CHECK-V62: 6812c000 { r1:0 = c19:18 }
|
||||
# CHECK-NOV62: rror: invalid operand for instruction
|
||||
# CHECK-NOV62: rror: invalid operand for instruction
|
||||
# CHECK-NOV62: rror: invalid operand for instruction
|
||||
# CHECK-NOV62: rror: invalid operand for instruction
|
||||
|
||||
r0=utimerlo
|
||||
r0=utimerhi
|
||||
r1:0=c31:30
|
||||
r1:0=UTIMER
|
||||
|
||||
# CHECK-V62: 6a1ec000 { r0 = utimerlo }
|
||||
# CHECK-V62: 6a1fc000 { r0 = utimerhi }
|
||||
# CHECK-V62: 681ec000 { r1:0 = c31:30 }
|
||||
# CHECK-V62: 681ec000 { r1:0 = c31:30 }
|
||||
# CHECK-NOV62: rror: invalid operand for instruction
|
||||
# CHECK-NOV62: rror: invalid operand for instruction
|
||||
# CHECK-NOV62: rror: invalid operand for instruction
|
||||
# CHECK-NOV62: rror: invalid operand for instruction
|
Loading…
Reference in New Issue
Block a user