forked from OSchip/llvm-project
[Hexagon] Introduce Hexagon v69 ISA
This commit is contained in:
parent
ab3640aa0e
commit
f766bc093c
|
@ -316,7 +316,7 @@ class Hexagon_v32i32_v64i32_Intrinsic<string GCCIntSuffix,
|
|||
[llvm_v32i32_ty], [llvm_v64i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_lvsplatb
|
||||
// tag : V6_lvsplatw
|
||||
class Hexagon_v16i32_i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
|
@ -414,14 +414,14 @@ class Hexagon__v128i1ptrv32i32_Intrinsic<string GCCIntSuffix,
|
|||
[], [llvm_v128i1_ty,llvm_ptr_ty,llvm_v32i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vabsb
|
||||
// tag : V6_vabs_hf
|
||||
class Hexagon_v16i32_v16i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v16i32_ty], [llvm_v16i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vabsb
|
||||
// tag : V6_vabs_hf
|
||||
class Hexagon_v32i32_v32i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
|
@ -442,6 +442,20 @@ class Hexagon_v32i32_v32i32v32i32_Intrinsic<string GCCIntSuffix,
|
|||
[llvm_v32i32_ty], [llvm_v32i32_ty,llvm_v32i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vadd_sf_hf
|
||||
class Hexagon_v32i32_v16i32v16i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v16i32_ty,llvm_v16i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vadd_sf_hf
|
||||
class Hexagon_v64i32_v32i32v32i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v64i32_ty], [llvm_v32i32_ty,llvm_v32i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vaddb_dv
|
||||
class Hexagon_v64i32_v64i32v64i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
|
@ -491,20 +505,6 @@ class Hexagon_v32i32_v32i32v32i32v128i1_Intrinsic<string GCCIntSuffix,
|
|||
[llvm_v32i32_ty], [llvm_v32i32_ty,llvm_v32i32_ty,llvm_v128i1_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vaddhw
|
||||
class Hexagon_v32i32_v16i32v16i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v16i32_ty,llvm_v16i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vaddhw
|
||||
class Hexagon_v64i32_v32i32v32i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v64i32_ty], [llvm_v32i32_ty,llvm_v32i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vaddhw_acc
|
||||
class Hexagon_v32i32_v32i32v16i32v16i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
|
@ -610,6 +610,20 @@ class Hexagon_v32i32_v32i32i32_Intrinsic<string GCCIntSuffix,
|
|||
[llvm_v32i32_ty], [llvm_v32i32_ty,llvm_i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vasrvuhubrndsat
|
||||
class Hexagon_v16i32_v32i32v16i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v16i32_ty], [llvm_v32i32_ty,llvm_v16i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vasrvuhubrndsat
|
||||
class Hexagon_v32i32_v64i32v32i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v64i32_ty,llvm_v32i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vassignp
|
||||
class Hexagon_v64i32_v64i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
|
@ -617,6 +631,20 @@ class Hexagon_v64i32_v64i32_Intrinsic<string GCCIntSuffix,
|
|||
[llvm_v64i32_ty], [llvm_v64i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vcvt_hf_b
|
||||
class Hexagon_v32i32_v16i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v16i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vcvt_hf_b
|
||||
class Hexagon_v64i32_v32i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v64i32_ty], [llvm_v32i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vd0
|
||||
class Hexagon_v16i32__Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
|
@ -652,6 +680,20 @@ class Hexagon_v64i32_v32i32v32i32i32_Intrinsic<string GCCIntSuffix,
|
|||
[llvm_v64i32_ty], [llvm_v32i32_ty,llvm_v32i32_ty,llvm_i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vdmpy_sf_hf_acc
|
||||
class Hexagon_v16i32_v16i32v16i32v16i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v16i32_ty], [llvm_v16i32_ty,llvm_v16i32_ty,llvm_v16i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vdmpy_sf_hf_acc
|
||||
class Hexagon_v32i32_v32i32v32i32v32i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v32i32_ty,llvm_v32i32_ty,llvm_v32i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vdmpybus_dv
|
||||
class Hexagon_v64i32_v64i32i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
|
@ -687,20 +729,6 @@ class Hexagon_v32i32_v32i32v64i32i32_Intrinsic<string GCCIntSuffix,
|
|||
[llvm_v32i32_ty], [llvm_v32i32_ty,llvm_v64i32_ty,llvm_i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vdmpyhvsat_acc
|
||||
class Hexagon_v16i32_v16i32v16i32v16i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v16i32_ty], [llvm_v16i32_ty,llvm_v16i32_ty,llvm_v16i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vdmpyhvsat_acc
|
||||
class Hexagon_v32i32_v32i32v32i32v32i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v32i32_ty,llvm_v32i32_ty,llvm_v32i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_veqb
|
||||
class Hexagon_v64i1_v16i32v16i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
|
@ -897,20 +925,6 @@ class Hexagon_v64i32_v64i32v64i32i32i32_Intrinsic<string GCCIntSuffix,
|
|||
[llvm_v64i32_ty], [llvm_v64i32_ty,llvm_v64i32_ty,llvm_i32_ty,llvm_i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vsb
|
||||
class Hexagon_v32i32_v16i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v32i32_ty], [llvm_v16i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vsb
|
||||
class Hexagon_v64i32_v32i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
: Hexagon_Intrinsic<GCCIntSuffix,
|
||||
[llvm_v64i32_ty], [llvm_v32i32_ty],
|
||||
intr_properties>;
|
||||
|
||||
// tag : V6_vscattermh
|
||||
class Hexagon__i32i32v16i32v16i32_Intrinsic<string GCCIntSuffix,
|
||||
list<IntrinsicProperty> intr_properties = [IntrNoMem]>
|
||||
|
@ -6139,3 +6153,437 @@ Hexagon_v32i32_v32i32v32i32v32i32i32_Intrinsic<"HEXAGON_V6_v6mpyvubs10_vxx", [In
|
|||
def int_hexagon_V6_v6mpyvubs10_vxx_128B :
|
||||
Hexagon_v64i32_v64i32v64i32v64i32i32_Intrinsic<"HEXAGON_V6_v6mpyvubs10_vxx_128B", [IntrNoMem, ImmArg<ArgIndex<3>>]>;
|
||||
|
||||
def int_hexagon_V6_vabs_hf :
|
||||
Hexagon_v16i32_v16i32_Intrinsic<"HEXAGON_V6_vabs_hf">;
|
||||
|
||||
def int_hexagon_V6_vabs_hf_128B :
|
||||
Hexagon_v32i32_v32i32_Intrinsic<"HEXAGON_V6_vabs_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vabs_sf :
|
||||
Hexagon_v16i32_v16i32_Intrinsic<"HEXAGON_V6_vabs_sf">;
|
||||
|
||||
def int_hexagon_V6_vabs_sf_128B :
|
||||
Hexagon_v32i32_v32i32_Intrinsic<"HEXAGON_V6_vabs_sf_128B">;
|
||||
|
||||
def int_hexagon_V6_vadd_hf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vadd_hf">;
|
||||
|
||||
def int_hexagon_V6_vadd_hf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vadd_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vadd_hf_hf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vadd_hf_hf">;
|
||||
|
||||
def int_hexagon_V6_vadd_hf_hf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vadd_hf_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vadd_qf16 :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vadd_qf16">;
|
||||
|
||||
def int_hexagon_V6_vadd_qf16_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vadd_qf16_128B">;
|
||||
|
||||
def int_hexagon_V6_vadd_qf16_mix :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vadd_qf16_mix">;
|
||||
|
||||
def int_hexagon_V6_vadd_qf16_mix_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vadd_qf16_mix_128B">;
|
||||
|
||||
def int_hexagon_V6_vadd_qf32 :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vadd_qf32">;
|
||||
|
||||
def int_hexagon_V6_vadd_qf32_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vadd_qf32_128B">;
|
||||
|
||||
def int_hexagon_V6_vadd_qf32_mix :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vadd_qf32_mix">;
|
||||
|
||||
def int_hexagon_V6_vadd_qf32_mix_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vadd_qf32_mix_128B">;
|
||||
|
||||
def int_hexagon_V6_vadd_sf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vadd_sf">;
|
||||
|
||||
def int_hexagon_V6_vadd_sf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vadd_sf_128B">;
|
||||
|
||||
def int_hexagon_V6_vadd_sf_hf :
|
||||
Hexagon_v32i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vadd_sf_hf">;
|
||||
|
||||
def int_hexagon_V6_vadd_sf_hf_128B :
|
||||
Hexagon_v64i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vadd_sf_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vadd_sf_sf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vadd_sf_sf">;
|
||||
|
||||
def int_hexagon_V6_vadd_sf_sf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vadd_sf_sf_128B">;
|
||||
|
||||
def int_hexagon_V6_vassign_fp :
|
||||
Hexagon_v16i32_v16i32_Intrinsic<"HEXAGON_V6_vassign_fp">;
|
||||
|
||||
def int_hexagon_V6_vassign_fp_128B :
|
||||
Hexagon_v32i32_v32i32_Intrinsic<"HEXAGON_V6_vassign_fp_128B">;
|
||||
|
||||
def int_hexagon_V6_vconv_hf_qf16 :
|
||||
Hexagon_v16i32_v16i32_Intrinsic<"HEXAGON_V6_vconv_hf_qf16">;
|
||||
|
||||
def int_hexagon_V6_vconv_hf_qf16_128B :
|
||||
Hexagon_v32i32_v32i32_Intrinsic<"HEXAGON_V6_vconv_hf_qf16_128B">;
|
||||
|
||||
def int_hexagon_V6_vconv_hf_qf32 :
|
||||
Hexagon_v16i32_v32i32_Intrinsic<"HEXAGON_V6_vconv_hf_qf32">;
|
||||
|
||||
def int_hexagon_V6_vconv_hf_qf32_128B :
|
||||
Hexagon_v32i32_v64i32_Intrinsic<"HEXAGON_V6_vconv_hf_qf32_128B">;
|
||||
|
||||
def int_hexagon_V6_vconv_sf_qf32 :
|
||||
Hexagon_v16i32_v16i32_Intrinsic<"HEXAGON_V6_vconv_sf_qf32">;
|
||||
|
||||
def int_hexagon_V6_vconv_sf_qf32_128B :
|
||||
Hexagon_v32i32_v32i32_Intrinsic<"HEXAGON_V6_vconv_sf_qf32_128B">;
|
||||
|
||||
def int_hexagon_V6_vcvt_b_hf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vcvt_b_hf">;
|
||||
|
||||
def int_hexagon_V6_vcvt_b_hf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vcvt_b_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vcvt_h_hf :
|
||||
Hexagon_v16i32_v16i32_Intrinsic<"HEXAGON_V6_vcvt_h_hf">;
|
||||
|
||||
def int_hexagon_V6_vcvt_h_hf_128B :
|
||||
Hexagon_v32i32_v32i32_Intrinsic<"HEXAGON_V6_vcvt_h_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vcvt_hf_b :
|
||||
Hexagon_v32i32_v16i32_Intrinsic<"HEXAGON_V6_vcvt_hf_b">;
|
||||
|
||||
def int_hexagon_V6_vcvt_hf_b_128B :
|
||||
Hexagon_v64i32_v32i32_Intrinsic<"HEXAGON_V6_vcvt_hf_b_128B">;
|
||||
|
||||
def int_hexagon_V6_vcvt_hf_h :
|
||||
Hexagon_v16i32_v16i32_Intrinsic<"HEXAGON_V6_vcvt_hf_h">;
|
||||
|
||||
def int_hexagon_V6_vcvt_hf_h_128B :
|
||||
Hexagon_v32i32_v32i32_Intrinsic<"HEXAGON_V6_vcvt_hf_h_128B">;
|
||||
|
||||
def int_hexagon_V6_vcvt_hf_sf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vcvt_hf_sf">;
|
||||
|
||||
def int_hexagon_V6_vcvt_hf_sf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vcvt_hf_sf_128B">;
|
||||
|
||||
def int_hexagon_V6_vcvt_hf_ub :
|
||||
Hexagon_v32i32_v16i32_Intrinsic<"HEXAGON_V6_vcvt_hf_ub">;
|
||||
|
||||
def int_hexagon_V6_vcvt_hf_ub_128B :
|
||||
Hexagon_v64i32_v32i32_Intrinsic<"HEXAGON_V6_vcvt_hf_ub_128B">;
|
||||
|
||||
def int_hexagon_V6_vcvt_hf_uh :
|
||||
Hexagon_v16i32_v16i32_Intrinsic<"HEXAGON_V6_vcvt_hf_uh">;
|
||||
|
||||
def int_hexagon_V6_vcvt_hf_uh_128B :
|
||||
Hexagon_v32i32_v32i32_Intrinsic<"HEXAGON_V6_vcvt_hf_uh_128B">;
|
||||
|
||||
def int_hexagon_V6_vcvt_sf_hf :
|
||||
Hexagon_v32i32_v16i32_Intrinsic<"HEXAGON_V6_vcvt_sf_hf">;
|
||||
|
||||
def int_hexagon_V6_vcvt_sf_hf_128B :
|
||||
Hexagon_v64i32_v32i32_Intrinsic<"HEXAGON_V6_vcvt_sf_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vcvt_ub_hf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vcvt_ub_hf">;
|
||||
|
||||
def int_hexagon_V6_vcvt_ub_hf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vcvt_ub_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vcvt_uh_hf :
|
||||
Hexagon_v16i32_v16i32_Intrinsic<"HEXAGON_V6_vcvt_uh_hf">;
|
||||
|
||||
def int_hexagon_V6_vcvt_uh_hf_128B :
|
||||
Hexagon_v32i32_v32i32_Intrinsic<"HEXAGON_V6_vcvt_uh_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vdmpy_sf_hf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vdmpy_sf_hf">;
|
||||
|
||||
def int_hexagon_V6_vdmpy_sf_hf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vdmpy_sf_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vdmpy_sf_hf_acc :
|
||||
Hexagon_v16i32_v16i32v16i32v16i32_Intrinsic<"HEXAGON_V6_vdmpy_sf_hf_acc">;
|
||||
|
||||
def int_hexagon_V6_vdmpy_sf_hf_acc_128B :
|
||||
Hexagon_v32i32_v32i32v32i32v32i32_Intrinsic<"HEXAGON_V6_vdmpy_sf_hf_acc_128B">;
|
||||
|
||||
def int_hexagon_V6_vfmax_hf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vfmax_hf">;
|
||||
|
||||
def int_hexagon_V6_vfmax_hf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vfmax_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vfmax_sf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vfmax_sf">;
|
||||
|
||||
def int_hexagon_V6_vfmax_sf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vfmax_sf_128B">;
|
||||
|
||||
def int_hexagon_V6_vfmin_hf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vfmin_hf">;
|
||||
|
||||
def int_hexagon_V6_vfmin_hf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vfmin_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vfmin_sf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vfmin_sf">;
|
||||
|
||||
def int_hexagon_V6_vfmin_sf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vfmin_sf_128B">;
|
||||
|
||||
def int_hexagon_V6_vfneg_hf :
|
||||
Hexagon_v16i32_v16i32_Intrinsic<"HEXAGON_V6_vfneg_hf">;
|
||||
|
||||
def int_hexagon_V6_vfneg_hf_128B :
|
||||
Hexagon_v32i32_v32i32_Intrinsic<"HEXAGON_V6_vfneg_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vfneg_sf :
|
||||
Hexagon_v16i32_v16i32_Intrinsic<"HEXAGON_V6_vfneg_sf">;
|
||||
|
||||
def int_hexagon_V6_vfneg_sf_128B :
|
||||
Hexagon_v32i32_v32i32_Intrinsic<"HEXAGON_V6_vfneg_sf_128B">;
|
||||
|
||||
def int_hexagon_V6_vgthf :
|
||||
Hexagon_v64i1_v16i32v16i32_Intrinsic<"HEXAGON_V6_vgthf">;
|
||||
|
||||
def int_hexagon_V6_vgthf_128B :
|
||||
Hexagon_v128i1_v32i32v32i32_Intrinsic<"HEXAGON_V6_vgthf_128B">;
|
||||
|
||||
def int_hexagon_V6_vgthf_and :
|
||||
Hexagon_v64i1_v64i1v16i32v16i32_Intrinsic<"HEXAGON_V6_vgthf_and">;
|
||||
|
||||
def int_hexagon_V6_vgthf_and_128B :
|
||||
Hexagon_v128i1_v128i1v32i32v32i32_Intrinsic<"HEXAGON_V6_vgthf_and_128B">;
|
||||
|
||||
def int_hexagon_V6_vgthf_or :
|
||||
Hexagon_v64i1_v64i1v16i32v16i32_Intrinsic<"HEXAGON_V6_vgthf_or">;
|
||||
|
||||
def int_hexagon_V6_vgthf_or_128B :
|
||||
Hexagon_v128i1_v128i1v32i32v32i32_Intrinsic<"HEXAGON_V6_vgthf_or_128B">;
|
||||
|
||||
def int_hexagon_V6_vgthf_xor :
|
||||
Hexagon_v64i1_v64i1v16i32v16i32_Intrinsic<"HEXAGON_V6_vgthf_xor">;
|
||||
|
||||
def int_hexagon_V6_vgthf_xor_128B :
|
||||
Hexagon_v128i1_v128i1v32i32v32i32_Intrinsic<"HEXAGON_V6_vgthf_xor_128B">;
|
||||
|
||||
def int_hexagon_V6_vgtsf :
|
||||
Hexagon_v64i1_v16i32v16i32_Intrinsic<"HEXAGON_V6_vgtsf">;
|
||||
|
||||
def int_hexagon_V6_vgtsf_128B :
|
||||
Hexagon_v128i1_v32i32v32i32_Intrinsic<"HEXAGON_V6_vgtsf_128B">;
|
||||
|
||||
def int_hexagon_V6_vgtsf_and :
|
||||
Hexagon_v64i1_v64i1v16i32v16i32_Intrinsic<"HEXAGON_V6_vgtsf_and">;
|
||||
|
||||
def int_hexagon_V6_vgtsf_and_128B :
|
||||
Hexagon_v128i1_v128i1v32i32v32i32_Intrinsic<"HEXAGON_V6_vgtsf_and_128B">;
|
||||
|
||||
def int_hexagon_V6_vgtsf_or :
|
||||
Hexagon_v64i1_v64i1v16i32v16i32_Intrinsic<"HEXAGON_V6_vgtsf_or">;
|
||||
|
||||
def int_hexagon_V6_vgtsf_or_128B :
|
||||
Hexagon_v128i1_v128i1v32i32v32i32_Intrinsic<"HEXAGON_V6_vgtsf_or_128B">;
|
||||
|
||||
def int_hexagon_V6_vgtsf_xor :
|
||||
Hexagon_v64i1_v64i1v16i32v16i32_Intrinsic<"HEXAGON_V6_vgtsf_xor">;
|
||||
|
||||
def int_hexagon_V6_vgtsf_xor_128B :
|
||||
Hexagon_v128i1_v128i1v32i32v32i32_Intrinsic<"HEXAGON_V6_vgtsf_xor_128B">;
|
||||
|
||||
def int_hexagon_V6_vmax_hf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vmax_hf">;
|
||||
|
||||
def int_hexagon_V6_vmax_hf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vmax_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vmax_sf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vmax_sf">;
|
||||
|
||||
def int_hexagon_V6_vmax_sf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vmax_sf_128B">;
|
||||
|
||||
def int_hexagon_V6_vmin_hf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vmin_hf">;
|
||||
|
||||
def int_hexagon_V6_vmin_hf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vmin_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vmin_sf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vmin_sf">;
|
||||
|
||||
def int_hexagon_V6_vmin_sf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vmin_sf_128B">;
|
||||
|
||||
def int_hexagon_V6_vmpy_hf_hf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vmpy_hf_hf">;
|
||||
|
||||
def int_hexagon_V6_vmpy_hf_hf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vmpy_hf_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vmpy_hf_hf_acc :
|
||||
Hexagon_v16i32_v16i32v16i32v16i32_Intrinsic<"HEXAGON_V6_vmpy_hf_hf_acc">;
|
||||
|
||||
def int_hexagon_V6_vmpy_hf_hf_acc_128B :
|
||||
Hexagon_v32i32_v32i32v32i32v32i32_Intrinsic<"HEXAGON_V6_vmpy_hf_hf_acc_128B">;
|
||||
|
||||
def int_hexagon_V6_vmpy_qf16 :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vmpy_qf16">;
|
||||
|
||||
def int_hexagon_V6_vmpy_qf16_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vmpy_qf16_128B">;
|
||||
|
||||
def int_hexagon_V6_vmpy_qf16_hf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vmpy_qf16_hf">;
|
||||
|
||||
def int_hexagon_V6_vmpy_qf16_hf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vmpy_qf16_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vmpy_qf16_mix_hf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vmpy_qf16_mix_hf">;
|
||||
|
||||
def int_hexagon_V6_vmpy_qf16_mix_hf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vmpy_qf16_mix_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vmpy_qf32 :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vmpy_qf32">;
|
||||
|
||||
def int_hexagon_V6_vmpy_qf32_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vmpy_qf32_128B">;
|
||||
|
||||
def int_hexagon_V6_vmpy_qf32_hf :
|
||||
Hexagon_v32i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vmpy_qf32_hf">;
|
||||
|
||||
def int_hexagon_V6_vmpy_qf32_hf_128B :
|
||||
Hexagon_v64i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vmpy_qf32_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vmpy_qf32_mix_hf :
|
||||
Hexagon_v32i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vmpy_qf32_mix_hf">;
|
||||
|
||||
def int_hexagon_V6_vmpy_qf32_mix_hf_128B :
|
||||
Hexagon_v64i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vmpy_qf32_mix_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vmpy_qf32_qf16 :
|
||||
Hexagon_v32i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vmpy_qf32_qf16">;
|
||||
|
||||
def int_hexagon_V6_vmpy_qf32_qf16_128B :
|
||||
Hexagon_v64i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vmpy_qf32_qf16_128B">;
|
||||
|
||||
def int_hexagon_V6_vmpy_qf32_sf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vmpy_qf32_sf">;
|
||||
|
||||
def int_hexagon_V6_vmpy_qf32_sf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vmpy_qf32_sf_128B">;
|
||||
|
||||
def int_hexagon_V6_vmpy_sf_hf :
|
||||
Hexagon_v32i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vmpy_sf_hf">;
|
||||
|
||||
def int_hexagon_V6_vmpy_sf_hf_128B :
|
||||
Hexagon_v64i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vmpy_sf_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vmpy_sf_hf_acc :
|
||||
Hexagon_v32i32_v32i32v16i32v16i32_Intrinsic<"HEXAGON_V6_vmpy_sf_hf_acc">;
|
||||
|
||||
def int_hexagon_V6_vmpy_sf_hf_acc_128B :
|
||||
Hexagon_v64i32_v64i32v32i32v32i32_Intrinsic<"HEXAGON_V6_vmpy_sf_hf_acc_128B">;
|
||||
|
||||
def int_hexagon_V6_vmpy_sf_sf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vmpy_sf_sf">;
|
||||
|
||||
def int_hexagon_V6_vmpy_sf_sf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vmpy_sf_sf_128B">;
|
||||
|
||||
def int_hexagon_V6_vsub_hf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vsub_hf">;
|
||||
|
||||
def int_hexagon_V6_vsub_hf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vsub_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vsub_hf_hf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vsub_hf_hf">;
|
||||
|
||||
def int_hexagon_V6_vsub_hf_hf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vsub_hf_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vsub_qf16 :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vsub_qf16">;
|
||||
|
||||
def int_hexagon_V6_vsub_qf16_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vsub_qf16_128B">;
|
||||
|
||||
def int_hexagon_V6_vsub_qf16_mix :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vsub_qf16_mix">;
|
||||
|
||||
def int_hexagon_V6_vsub_qf16_mix_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vsub_qf16_mix_128B">;
|
||||
|
||||
def int_hexagon_V6_vsub_qf32 :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vsub_qf32">;
|
||||
|
||||
def int_hexagon_V6_vsub_qf32_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vsub_qf32_128B">;
|
||||
|
||||
def int_hexagon_V6_vsub_qf32_mix :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vsub_qf32_mix">;
|
||||
|
||||
def int_hexagon_V6_vsub_qf32_mix_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vsub_qf32_mix_128B">;
|
||||
|
||||
def int_hexagon_V6_vsub_sf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vsub_sf">;
|
||||
|
||||
def int_hexagon_V6_vsub_sf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vsub_sf_128B">;
|
||||
|
||||
def int_hexagon_V6_vsub_sf_hf :
|
||||
Hexagon_v32i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vsub_sf_hf">;
|
||||
|
||||
def int_hexagon_V6_vsub_sf_hf_128B :
|
||||
Hexagon_v64i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vsub_sf_hf_128B">;
|
||||
|
||||
def int_hexagon_V6_vsub_sf_sf :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vsub_sf_sf">;
|
||||
|
||||
def int_hexagon_V6_vsub_sf_sf_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vsub_sf_sf_128B">;
|
||||
|
||||
// V69 HVX Instructions.
|
||||
|
||||
def int_hexagon_V6_vasrvuhubrndsat :
|
||||
Hexagon_v16i32_v32i32v16i32_Intrinsic<"HEXAGON_V6_vasrvuhubrndsat">;
|
||||
|
||||
def int_hexagon_V6_vasrvuhubrndsat_128B :
|
||||
Hexagon_v32i32_v64i32v32i32_Intrinsic<"HEXAGON_V6_vasrvuhubrndsat_128B">;
|
||||
|
||||
def int_hexagon_V6_vasrvuhubsat :
|
||||
Hexagon_v16i32_v32i32v16i32_Intrinsic<"HEXAGON_V6_vasrvuhubsat">;
|
||||
|
||||
def int_hexagon_V6_vasrvuhubsat_128B :
|
||||
Hexagon_v32i32_v64i32v32i32_Intrinsic<"HEXAGON_V6_vasrvuhubsat_128B">;
|
||||
|
||||
def int_hexagon_V6_vasrvwuhrndsat :
|
||||
Hexagon_v16i32_v32i32v16i32_Intrinsic<"HEXAGON_V6_vasrvwuhrndsat">;
|
||||
|
||||
def int_hexagon_V6_vasrvwuhrndsat_128B :
|
||||
Hexagon_v32i32_v64i32v32i32_Intrinsic<"HEXAGON_V6_vasrvwuhrndsat_128B">;
|
||||
|
||||
def int_hexagon_V6_vasrvwuhsat :
|
||||
Hexagon_v16i32_v32i32v16i32_Intrinsic<"HEXAGON_V6_vasrvwuhsat">;
|
||||
|
||||
def int_hexagon_V6_vasrvwuhsat_128B :
|
||||
Hexagon_v32i32_v64i32v32i32_Intrinsic<"HEXAGON_V6_vasrvwuhsat_128B">;
|
||||
|
||||
def int_hexagon_V6_vmpyuhvs :
|
||||
Hexagon_v16i32_v16i32v16i32_Intrinsic<"HEXAGON_V6_vmpyuhvs">;
|
||||
|
||||
def int_hexagon_V6_vmpyuhvs_128B :
|
||||
Hexagon_v32i32_v32i32v32i32_Intrinsic<"HEXAGON_V6_vmpyuhvs_128B">;
|
||||
|
||||
|
|
|
@ -29,6 +29,8 @@ def ProcTinyCore: SubtargetFeature<"tinycore", "HexagonProcFamily",
|
|||
// Hexagon ISA Extensions
|
||||
def ExtensionZReg: SubtargetFeature<"zreg", "UseZRegOps", "true",
|
||||
"Hexagon ZReg extension instructions">;
|
||||
def ExtensionHVXQFloat: SubtargetFeature<"hvx-qfloat", "UseHVXQFloatOps",
|
||||
"true", "Hexagon HVX QFloating point instructions">;
|
||||
|
||||
def ExtensionHVX: SubtargetFeature<"hvx", "HexagonHVXVersion",
|
||||
"Hexagon::ArchEnum::V60", "Hexagon HVX instructions">;
|
||||
|
@ -52,6 +54,10 @@ def ExtensionHVXV68: SubtargetFeature<"hvxv68", "HexagonHVXVersion",
|
|||
"Hexagon::ArchEnum::V68", "Hexagon HVX instructions",
|
||||
[ExtensionHVXV60, ExtensionHVXV62, ExtensionHVXV65, ExtensionHVXV66,
|
||||
ExtensionHVXV67]>;
|
||||
def ExtensionHVXV69: SubtargetFeature<"hvxv69", "HexagonHVXVersion",
|
||||
"Hexagon::ArchEnum::V69", "Hexagon HVX instructions",
|
||||
[ExtensionHVXV60, ExtensionHVXV62, ExtensionHVXV65, ExtensionHVXV66,
|
||||
ExtensionHVXV67, ExtensionHVXV68]>;
|
||||
|
||||
def ExtensionHVX64B: SubtargetFeature<"hvx-length64b", "UseHVX64BOps",
|
||||
"true", "Hexagon HVX 64B instructions", [ExtensionHVX]>;
|
||||
|
@ -61,6 +67,9 @@ def ExtensionHVX128B: SubtargetFeature<"hvx-length128b", "UseHVX128BOps",
|
|||
def ExtensionAudio: SubtargetFeature<"audio", "UseAudioOps", "true",
|
||||
"Hexagon Audio extension instructions">;
|
||||
|
||||
def ExtensionHVXIEEEFP: SubtargetFeature<"hvx-ieee-fp", "UseHVXIEEEFPOps",
|
||||
"true", "Hexagon HVX IEEE floating point instructions">;
|
||||
|
||||
def FeatureCompound: SubtargetFeature<"compound", "UseCompound", "true",
|
||||
"Use compound instructions">;
|
||||
def FeaturePackets: SubtargetFeature<"packets", "UsePackets", "true",
|
||||
|
@ -88,6 +97,8 @@ def FeatureReservedR19: SubtargetFeature<"reserved-r19", "ReservedR19",
|
|||
def FeatureNoreturnStackElim: SubtargetFeature<"noreturn-stack-elim",
|
||||
"NoreturnStackElim", "true",
|
||||
"Eliminate stack allocation in a noreturn function when possible">;
|
||||
def FeatureCabac: SubtargetFeature<"cabac", "UseCabac", "false",
|
||||
"Emit the CABAC instruction">;
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// Hexagon Instruction Predicate Definitions.
|
||||
|
@ -112,6 +123,8 @@ def UseHVXV67 : Predicate<"HST->useHVXV67Ops()">,
|
|||
AssemblerPredicate<(all_of ExtensionHVXV67)>;
|
||||
def UseHVXV68 : Predicate<"HST->useHVXV68Ops()">,
|
||||
AssemblerPredicate<(all_of ExtensionHVXV68)>;
|
||||
def UseHVXV69 : Predicate<"HST->useHVXV69Ops()">,
|
||||
AssemblerPredicate<(all_of ExtensionHVXV69)>;
|
||||
def UseAudio : Predicate<"HST->useAudioOps()">,
|
||||
AssemblerPredicate<(all_of ExtensionAudio)>;
|
||||
def UseZReg : Predicate<"HST->useZRegOps()">,
|
||||
|
@ -119,6 +132,11 @@ def UseZReg : Predicate<"HST->useZRegOps()">,
|
|||
def UseCompound : Predicate<"HST->useCompound()">;
|
||||
def HasPreV65 : Predicate<"HST->hasPreV65()">,
|
||||
AssemblerPredicate<(all_of FeaturePreV65)>;
|
||||
def UseHVXIEEEFP : Predicate<"HST->useHVXIEEEFPOps()">,
|
||||
AssemblerPredicate<(all_of ExtensionHVXIEEEFP)>;
|
||||
def UseHVXQFloat : Predicate<"HST->useHVXQFloatOps()">,
|
||||
AssemblerPredicate<(all_of ExtensionHVXQFloat)>;
|
||||
def UseHVXFloatingPoint: Predicate<"HST->useHVXFloatingPoint()">;
|
||||
def HasMemNoShuf : Predicate<"HST->hasMemNoShuf()">,
|
||||
AssemblerPredicate<(all_of FeatureMemNoShuf)>;
|
||||
def UseUnsafeMath : Predicate<"HST->useUnsafeMath()">;
|
||||
|
@ -127,6 +145,8 @@ def NotOptTinyCore : Predicate<"!HST->isTinyCore() ||"
|
|||
let RecomputePerFunction = 1;
|
||||
}
|
||||
def UseSmallData : Predicate<"HST->useSmallData()">;
|
||||
def UseCabac : Predicate<"HST->useCabac()">,
|
||||
AssemblerPredicate<(any_of FeatureCabac)>;
|
||||
|
||||
def Hvx64: HwMode<"+hvx-length64b">;
|
||||
def Hvx128: HwMode<"+hvx-length128b">;
|
||||
|
@ -299,7 +319,7 @@ def changeAddrMode_rr_ur: InstrMapping {
|
|||
let ValueCols = [["BaseLongOffset"]];
|
||||
}
|
||||
|
||||
def changeAddrMode_ur_rr : InstrMapping {
|
||||
def changeAddrMode_ur_rr: InstrMapping {
|
||||
let FilterClass = "ImmRegShl";
|
||||
let RowFields = ["CextOpcode", "PredSense", "PNewValue", "isNVStore"];
|
||||
let ColFields = ["addrMode"];
|
||||
|
@ -370,40 +390,55 @@ class Proc<string Name, SchedMachineModel Model,
|
|||
def : Proc<"generic", HexagonModelV60,
|
||||
[ArchV5, ArchV55, ArchV60,
|
||||
FeatureCompound, FeatureDuplex, FeaturePreV65, FeatureMemops,
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData]>;
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData,
|
||||
FeatureCabac]>;
|
||||
def : Proc<"hexagonv5", HexagonModelV5,
|
||||
[ArchV5,
|
||||
FeatureCompound, FeatureDuplex, FeaturePreV65, FeatureMemops,
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData]>;
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData,
|
||||
FeatureCabac]>;
|
||||
def : Proc<"hexagonv55", HexagonModelV55,
|
||||
[ArchV5, ArchV55,
|
||||
FeatureCompound, FeatureDuplex, FeaturePreV65, FeatureMemops,
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData]>;
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData,
|
||||
FeatureCabac]>;
|
||||
def : Proc<"hexagonv60", HexagonModelV60,
|
||||
[ArchV5, ArchV55, ArchV60,
|
||||
FeatureCompound, FeatureDuplex, FeaturePreV65, FeatureMemops,
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData]>;
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData,
|
||||
FeatureCabac]>;
|
||||
def : Proc<"hexagonv62", HexagonModelV62,
|
||||
[ArchV5, ArchV55, ArchV60, ArchV62,
|
||||
FeatureCompound, FeatureDuplex, FeaturePreV65, FeatureMemops,
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData]>;
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData,
|
||||
FeatureCabac]>;
|
||||
def : Proc<"hexagonv65", HexagonModelV65,
|
||||
[ArchV5, ArchV55, ArchV60, ArchV62, ArchV65,
|
||||
FeatureCompound, FeatureDuplex, FeatureMemNoShuf, FeatureMemops,
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData]>;
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData,
|
||||
FeatureCabac]>;
|
||||
def : Proc<"hexagonv66", HexagonModelV66,
|
||||
[ArchV5, ArchV55, ArchV60, ArchV62, ArchV65, ArchV66,
|
||||
FeatureCompound, FeatureDuplex, FeatureMemNoShuf, FeatureMemops,
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData]>;
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData,
|
||||
FeatureCabac]>;
|
||||
def : Proc<"hexagonv67", HexagonModelV67,
|
||||
[ArchV5, ArchV55, ArchV60, ArchV62, ArchV65, ArchV66, ArchV67,
|
||||
FeatureCompound, FeatureDuplex, FeatureMemNoShuf, FeatureMemops,
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData]>;
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData,
|
||||
FeatureCabac]>;
|
||||
def : Proc<"hexagonv68", HexagonModelV68,
|
||||
[ArchV5, ArchV55, ArchV60, ArchV62, ArchV65, ArchV66, ArchV67,
|
||||
ArchV68,
|
||||
FeatureCompound, FeatureDuplex, FeatureMemNoShuf, FeatureMemops,
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData]>;
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData,
|
||||
FeatureCabac]>;
|
||||
def : Proc<"hexagonv69", HexagonModelV69,
|
||||
[ArchV5, ArchV55, ArchV60, ArchV62, ArchV65, ArchV66, ArchV67,
|
||||
ArchV68, ArchV69,
|
||||
FeatureCompound, FeatureDuplex, FeatureMemNoShuf, FeatureMemops,
|
||||
FeatureNVJ, FeatureNVS, FeaturePackets, FeatureSmallData,
|
||||
FeatureCabac]>;
|
||||
// Need to update the correct features for tiny core.
|
||||
// Disable NewValueJumps since the packetizer is unable to handle a packet with
|
||||
// a new value jump and another SLOT0 instruction.
|
||||
|
|
|
@ -21,31 +21,32 @@
|
|||
|
||||
namespace llvm {
|
||||
namespace Hexagon {
|
||||
enum class ArchEnum { NoArch, Generic, V5, V55, V60, V62, V65, V66, V67, V68 };
|
||||
enum class ArchEnum { NoArch, Generic, V5, V55, V60, V62, V65, V66, V67, V68, V69 };
|
||||
|
||||
static constexpr unsigned ArchValsNumArray[] = {5, 55, 60, 62, 65, 66, 67, 68};
|
||||
static constexpr unsigned ArchValsNumArray[] = {5, 55, 60, 62, 65, 66, 67, 68, 69};
|
||||
static constexpr ArrayRef<unsigned> ArchValsNum(ArchValsNumArray);
|
||||
|
||||
static constexpr StringLiteral ArchValsTextArray[] = { "v5", "v55", "v60", "v62", "v65", "v66", "v67", "v68" };
|
||||
static constexpr StringLiteral ArchValsTextArray[] = { "v5", "v55", "v60", "v62", "v65", "v66", "v67", "v68", "v69" };
|
||||
static constexpr ArrayRef<StringLiteral> ArchValsText(ArchValsTextArray);
|
||||
|
||||
static constexpr StringLiteral CpuValsTextArray[] = { "hexagonv5", "hexagonv55", "hexagonv60", "hexagonv62", "hexagonv65", "hexagonv66", "hexagonv67", "hexagonv67t", "hexagonv68" };
|
||||
static constexpr StringLiteral CpuValsTextArray[] = { "hexagonv5", "hexagonv55", "hexagonv60", "hexagonv62", "hexagonv65", "hexagonv66", "hexagonv67", "hexagonv67t", "hexagonv68", "hexagonv69" };
|
||||
static constexpr ArrayRef<StringLiteral> CpuValsText(CpuValsTextArray);
|
||||
|
||||
static constexpr StringLiteral CpuNickTextArray[] = { "v5", "v55", "v60", "v62", "v65", "v66", "v67", "v67t", "v68" };
|
||||
static constexpr StringLiteral CpuNickTextArray[] = { "v5", "v55", "v60", "v62", "v65", "v66", "v67", "v67t", "v68", "v69" };
|
||||
static constexpr ArrayRef<StringLiteral> CpuNickText(CpuNickTextArray);
|
||||
|
||||
static const std::map<std::string, ArchEnum> CpuTable{
|
||||
{"generic", Hexagon::ArchEnum::V5},
|
||||
{"hexagonv5", Hexagon::ArchEnum::V5},
|
||||
{"hexagonv55", Hexagon::ArchEnum::V55},
|
||||
{"hexagonv60", Hexagon::ArchEnum::V60},
|
||||
{"hexagonv62", Hexagon::ArchEnum::V62},
|
||||
{"hexagonv65", Hexagon::ArchEnum::V65},
|
||||
{"hexagonv66", Hexagon::ArchEnum::V66},
|
||||
{"hexagonv67", Hexagon::ArchEnum::V67},
|
||||
{"hexagonv67t", Hexagon::ArchEnum::V67},
|
||||
{"hexagonv68", Hexagon::ArchEnum::V68},
|
||||
{"generic", Hexagon::ArchEnum::V5},
|
||||
{"hexagonv5", Hexagon::ArchEnum::V5},
|
||||
{"hexagonv55", Hexagon::ArchEnum::V55},
|
||||
{"hexagonv60", Hexagon::ArchEnum::V60},
|
||||
{"hexagonv62", Hexagon::ArchEnum::V62},
|
||||
{"hexagonv65", Hexagon::ArchEnum::V65},
|
||||
{"hexagonv66", Hexagon::ArchEnum::V66},
|
||||
{"hexagonv67", Hexagon::ArchEnum::V67},
|
||||
{"hexagonv67t", Hexagon::ArchEnum::V67},
|
||||
{"hexagonv68", Hexagon::ArchEnum::V68},
|
||||
{"hexagonv69", Hexagon::ArchEnum::V69},
|
||||
};
|
||||
|
||||
static const std::map<std::string, unsigned> ElfFlagsByCpuStr = {
|
||||
|
@ -59,6 +60,7 @@ static const std::map<std::string, unsigned> ElfFlagsByCpuStr = {
|
|||
{"hexagonv67", llvm::ELF::EF_HEXAGON_MACH_V67},
|
||||
{"hexagonv67t", llvm::ELF::EF_HEXAGON_MACH_V67T},
|
||||
{"hexagonv68", llvm::ELF::EF_HEXAGON_MACH_V68},
|
||||
{"hexagonv69", llvm::ELF::EF_HEXAGON_MACH_V69},
|
||||
};
|
||||
static const std::map<unsigned, std::string> ElfArchByMachFlags = {
|
||||
{llvm::ELF::EF_HEXAGON_MACH_V5, "V5"},
|
||||
|
@ -70,6 +72,7 @@ static const std::map<unsigned, std::string> ElfArchByMachFlags = {
|
|||
{llvm::ELF::EF_HEXAGON_MACH_V67, "V67"},
|
||||
{llvm::ELF::EF_HEXAGON_MACH_V67T, "V67T"},
|
||||
{llvm::ELF::EF_HEXAGON_MACH_V68, "V68"},
|
||||
{llvm::ELF::EF_HEXAGON_MACH_V69, "V69"},
|
||||
};
|
||||
static const std::map<unsigned, std::string> ElfCpuByMachFlags = {
|
||||
{llvm::ELF::EF_HEXAGON_MACH_V5, "hexagonv5"},
|
||||
|
@ -81,6 +84,7 @@ static const std::map<unsigned, std::string> ElfCpuByMachFlags = {
|
|||
{llvm::ELF::EF_HEXAGON_MACH_V67, "hexagonv67"},
|
||||
{llvm::ELF::EF_HEXAGON_MACH_V67T, "hexagonv67t"},
|
||||
{llvm::ELF::EF_HEXAGON_MACH_V68, "hexagonv68"},
|
||||
{llvm::ELF::EF_HEXAGON_MACH_V69, "hexagonv69"},
|
||||
};
|
||||
|
||||
} // namespace Hexagon
|
||||
|
|
|
@ -24,3 +24,5 @@ def ArchV67: SubtargetFeature<"v67", "HexagonArchVersion", "Hexagon::ArchEnum::V
|
|||
def HasV67 : Predicate<"HST->hasV67Ops()">, AssemblerPredicate<(all_of ArchV67)>;
|
||||
def ArchV68: SubtargetFeature<"v68", "HexagonArchVersion", "Hexagon::ArchEnum::V68", "Enable Hexagon V68 architecture">;
|
||||
def HasV68 : Predicate<"HST->hasV68Ops()">, AssemblerPredicate<(all_of ArchV68)>;
|
||||
def ArchV69: SubtargetFeature<"v69", "HexagonArchVersion", "Hexagon::ArchEnum::V69", "Enable Hexagon V69 architecture">;
|
||||
def HasV69 : Predicate<"HST->hasV69Ops()">, AssemblerPredicate<(all_of ArchV69)>;
|
||||
|
|
|
@ -8,6 +8,7 @@
|
|||
// Automatically generated file, do not edit!
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
|
||||
#if defined(__clang__)
|
||||
#pragma clang diagnostic push
|
||||
#pragma clang diagnostic ignored "-Wunused-function"
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -7338,3 +7338,771 @@ class DepScalarItinV68 {
|
|||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>
|
||||
];
|
||||
}
|
||||
|
||||
class DepScalarItinV69 {
|
||||
list<InstrItinData> DepScalarItinV69_list = [
|
||||
InstrItinData <tc_011e0e9d, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [2, 1, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_01d44cb2, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_01e1be3b, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 1, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_02fe1c65, /*tc_4x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [5, 1, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_0655b949, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [2, 3],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_075c8dd8, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 3, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_0a195f2c, /*tc_4x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [5, 2, 1, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_0a6c20ae, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [2, 1, 1, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_0ba0d5da, /*tc_3stall*/
|
||||
[InstrStage<1, [SLOT2]>], [1],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_0dfac0a7, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_0fac1eb8, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [3, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_112d30d6, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [2],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_1242dc2a, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0]>], [2],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_1248597c, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT3]>], [2, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_14ab4f41, /*tc_newvjump*/
|
||||
[InstrStage<1, [SLOT0]>], [3, 3, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_151bf368, /*tc_1*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [3, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_158aa3f7, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [1, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_197dce51, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT3]>], [4, 2, 1, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_1981450d, /*tc_newvjump*/
|
||||
[InstrStage<1, [SLOT0]>], [3],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_1c2c7a4a, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [3, 2, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_1c7522a8, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 3, 2, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_1d41f8b7, /*tc_1*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [3, 4, 2, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_1fcb8495, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_1fe4ab69, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [2, 1, 1, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_20131976, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_2237d952, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0]>], [1, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_23708a21, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [],
|
||||
[]>,
|
||||
|
||||
InstrItinData <tc_2471c1c8, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0]>], [4, 1],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_24e109c7, /*tc_newvjump*/
|
||||
[InstrStage<1, [SLOT0]>], [3, 3, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_24f426ab, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [2, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_280f7fe1, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [1, 1, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_28e55c6f, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT3]>], [1, 1],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_2c13e7f5, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_2c3e17fc, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT3]>], [1],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_2f573607, /*tc_1*/
|
||||
[InstrStage<1, [SLOT2]>], [2, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_362b0be2, /*tc_3*/
|
||||
[InstrStage<1, [SLOT2]>], [1],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_38382228, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_388f9897, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [3, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_38e0bae9, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 4, 2, 1, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_3d14a17b, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [3, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_3edca78f, /*tc_2*/
|
||||
[InstrStage<1, [SLOT3]>], [4, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_3fbf1042, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [3],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_407e96f9, /*tc_1*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [3, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_40d64c94, /*tc_newvjump*/
|
||||
[InstrStage<1, [SLOT0]>], [3, 1],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_4222e6bf, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_42ff66ba, /*tc_1*/
|
||||
[InstrStage<1, [SLOT2]>], [2, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_442395f3, /*tc_2latepred*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [4, 3, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_449acf79, /*tc_latepredstaia*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 3, 1, 2, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_44d5a428, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [1, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_44fffc58, /*tc_3*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [2],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_45791fb8, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 2, 1, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_45f9d1be, /*tc_2early*/
|
||||
[InstrStage<1, [SLOT2]>], [2],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_49fdfd4b, /*tc_3stall*/
|
||||
[InstrStage<1, [SLOT3]>], [4, 1],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_4a55d03c, /*tc_1*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [3, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_4abdbdc6, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT3]>], [2, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_4ac61d92, /*tc_2latepred*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [4, 3, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_4bf903b0, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [3],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_503ce0f3, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 2, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_53c851ab, /*tc_3stall*/
|
||||
[InstrStage<1, [SLOT2]>], [4, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_5502c366, /*tc_1*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [3, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_55255f2b, /*tc_3stall*/
|
||||
[InstrStage<1, [SLOT3]>], [],
|
||||
[]>,
|
||||
|
||||
InstrItinData <tc_556f6577, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 1, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_55a9a350, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [1, 2, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_55b33fda, /*tc_1*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [3, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_56a124a7, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [2, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_57a55b54, /*tc_1*/
|
||||
[InstrStage<1, [SLOT3]>], [2, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_5944960d, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [1, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_59a7822c, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [2, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_5a4b5e58, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT3]>], [4, 1, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_5b347363, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [3, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_5ceb2f9e, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 3, 1, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_5da50c4b, /*tc_1*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [3, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_5deb5e47, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [1, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_5e4cf0e8, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_5f2afaf7, /*tc_latepredldaia*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 4, 3, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_60e324ff, /*tc_1*/
|
||||
[InstrStage<1, [SLOT2]>], [2],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_63567288, /*tc_2latepred*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_64b00d8a, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0]>], [4, 1],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_651cbe02, /*tc_1*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [3, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_65279839, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_65cbd974, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [3, 1, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_69bfb303, /*tc_3*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [2, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_6ae3426b, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT3]>], [4, 1],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_6d861a95, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT3]>], [2, 1],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_6e20402a, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [2, 3],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_6f42bc60, /*tc_3stall*/
|
||||
[InstrStage<1, [SLOT0]>], [4, 1, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_6fc5dbea, /*tc_1*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [3, 2, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_711c805f, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [2, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_713b66bf, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [3, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_7401744f, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 4, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_7476d766, /*tc_3stall*/
|
||||
[InstrStage<1, [SLOT3]>], [4, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_74a42bda, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [3, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_76bb5435, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 3, 2, 1, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_77f94a5e, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [],
|
||||
[]>,
|
||||
|
||||
InstrItinData <tc_788b1d09, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 1, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_7af3a37e, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [1, 3],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_7b9187d3, /*tc_newvjump*/
|
||||
[InstrStage<1, [SLOT0]>], [3, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_7c31e19a, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [1, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_7c6d32e4, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_7f7f45f5, /*tc_4x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [5, 5, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_7f8ae742, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 1, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_8035e91f, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [2, 1, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_822c3c68, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 3, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_829d8a86, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [3, 1, 1, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_838c4d7a, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [1, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_84a7500d, /*tc_2*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [4, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_86173609, /*tc_2latepred*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [4, 3, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_887d1bb7, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [1, 2, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_8a6d0d94, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_8a825db2, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_8b5bd4f5, /*tc_2*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [4, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_8e82e8ca, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [3, 1, 1, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_9124c04f, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [3, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_92240447, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [3, 1, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_934753bb, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0]>], [3, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_937dd41c, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [],
|
||||
[]>,
|
||||
|
||||
InstrItinData <tc_9406230a, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT3]>], [2, 1],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_95a33176, /*tc_2*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [4, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_96ef76ef, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [1, 1, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_975a4e54, /*tc_newvjump*/
|
||||
[InstrStage<1, [SLOT0]>], [3, 3, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_9783714b, /*tc_4x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [5, 1],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_9b34f5e0, /*tc_3stall*/
|
||||
[InstrStage<1, [SLOT2]>], [],
|
||||
[]>,
|
||||
|
||||
InstrItinData <tc_9b3c0462, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_9bcfb2ee, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [1, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_9c52f549, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [3, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_9e27f2f9, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [2, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_9e72dc89, /*tc_4x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [5, 2, 1, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_9edb7c77, /*tc_4x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [5, 2, 1, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_9edefe01, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [3, 2, 1, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_9f6cd987, /*tc_1*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [3, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_a08b630b, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_a1297125, /*tc_1*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [3, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_a154b476, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_a2b365d2, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [3, 1, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_a3070909, /*tc_3stall*/
|
||||
[InstrStage<1, [SLOT0]>], [1, 1],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_a32e03e7, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 2, 1, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_a38c45dc, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 1, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_a4e22bbd, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_a4ee89db, /*tc_2early*/
|
||||
[InstrStage<1, [SLOT0]>], [],
|
||||
[]>,
|
||||
|
||||
InstrItinData <tc_a7a13fac, /*tc_1*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [3, 2, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_a7bdb22c, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_a9edeffa, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [1, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_abfd9a6d, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 1, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_ac65613f, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 3, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_addc37a8, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [3, 1, 2, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_ae5babd7, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [1, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_aee6250c, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 1],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_b1ae5f67, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [1],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_b4dc7630, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [3, 1, 2, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_b7c4062a, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 3, 1, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_b837298f, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [],
|
||||
[]>,
|
||||
|
||||
InstrItinData <tc_ba9255a6, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [2, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_bb07f2c5, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [3, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_bb831a7c, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 2, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_bf2ffc0f, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 1, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_c20701f0, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_c21d7447, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 1, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_c57d9f39, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [3, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_c818ff7f, /*tc_newvjump*/
|
||||
[InstrStage<1, [SLOT0]>], [],
|
||||
[]>,
|
||||
|
||||
InstrItinData <tc_ce59038e, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [3, 2, 1, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_cfa0e29b, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [2, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_d03278fd, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [2, 1, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_d33e5eee, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [3, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_d3632d88, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_d45ba9cd, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0]>], [1],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_d57d649c, /*tc_3stall*/
|
||||
[InstrStage<1, [SLOT2]>], [2],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_d61dfdc3, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_d68dca5c, /*tc_3stall*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 1, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_d7718fbe, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT3]>], [1],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_db596beb, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 1, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_db96aa6b, /*tc_st*/
|
||||
[InstrStage<1, [SLOT0]>], [1],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_dc51281d, /*tc_3*/
|
||||
[InstrStage<1, [SLOT2]>], [2, 1],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_decdde8a, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [2],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_df5d53f9, /*tc_newvjump*/
|
||||
[InstrStage<1, [SLOT0]>], [3, 2, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_e3d699e3, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_e9170fb7, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 1],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_ed03645c, /*tc_1*/
|
||||
[InstrStage<1, [SLOT2]>], [3, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_eed07714, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_eeda4109, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [3, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_ef921005, /*tc_1*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [3, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_f098b237, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_f0cdeccf, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 1, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_f0e8e832, /*tc_4x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [5, 1, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_f34c1c21, /*tc_2*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [4, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_f38f92e1, /*tc_newvjump*/
|
||||
[InstrStage<1, [SLOT0]>], [2],
|
||||
[Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_f529831b, /*tc_latepredstaia*/
|
||||
[InstrStage<1, [SLOT0]>], [4, 3, 1, 2, 3],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_f6e2aff9, /*tc_newvjump*/
|
||||
[InstrStage<1, [SLOT0]>], [3, 2, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_f7569068, /*tc_4x*/
|
||||
[InstrStage<1, [SLOT2, SLOT3]>], [5, 5, 1, 1],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_f999c66e, /*tc_1*/
|
||||
[InstrStage<1, [SLOT0, SLOT1, SLOT2, SLOT3]>], [2, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_fae9dfa5, /*tc_3x*/
|
||||
[InstrStage<1, [SLOT3]>], [4, 2],
|
||||
[Hex_FWD, Hex_FWD]>,
|
||||
|
||||
InstrItinData <tc_fedb7e19, /*tc_ld*/
|
||||
[InstrStage<1, [SLOT0, SLOT1]>], [4, 2, 1, 2],
|
||||
[Hex_FWD, Hex_FWD, Hex_FWD, Hex_FWD]>
|
||||
];
|
||||
}
|
||||
|
|
|
@ -2288,6 +2288,12 @@ class Enc_a30110 : OpcodeHexagon {
|
|||
bits <5> Vd32;
|
||||
let Inst{4-0} = Vd32{4-0};
|
||||
}
|
||||
class Enc_a33d04 : OpcodeHexagon {
|
||||
bits <5> Vuu32;
|
||||
let Inst{12-8} = Vuu32{4-0};
|
||||
bits <5> Vd32;
|
||||
let Inst{4-0} = Vd32{4-0};
|
||||
}
|
||||
class Enc_a42857 : OpcodeHexagon {
|
||||
bits <11> Ii;
|
||||
let Inst{21-20} = Ii{10-9};
|
||||
|
@ -3109,6 +3115,14 @@ class Enc_de0214 : OpcodeHexagon {
|
|||
bits <5> Rd32;
|
||||
let Inst{4-0} = Rd32{4-0};
|
||||
}
|
||||
class Enc_de5ea0 : OpcodeHexagon {
|
||||
bits <5> Vuu32;
|
||||
let Inst{12-8} = Vuu32{4-0};
|
||||
bits <5> Vv32;
|
||||
let Inst{20-16} = Vv32{4-0};
|
||||
bits <5> Vd32;
|
||||
let Inst{4-0} = Vd32{4-0};
|
||||
}
|
||||
class Enc_e07374 : OpcodeHexagon {
|
||||
bits <5> Rs32;
|
||||
let Inst{20-16} = Rs32{4-0};
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1661,8 +1661,6 @@ def: Pat<(int_hexagon_Y2_dccleana IntRegs:$src1),
|
|||
(Y2_dccleana IntRegs:$src1)>, Requires<[HasV5]>;
|
||||
def: Pat<(int_hexagon_Y2_dccleaninva IntRegs:$src1),
|
||||
(Y2_dccleaninva IntRegs:$src1)>, Requires<[HasV5]>;
|
||||
def: Pat<(int_hexagon_Y2_dcfetch IntRegs:$src1),
|
||||
(Y2_dcfetch IntRegs:$src1)>, Requires<[HasV5]>;
|
||||
def: Pat<(int_hexagon_Y2_dcinva IntRegs:$src1),
|
||||
(Y2_dcinva IntRegs:$src1)>, Requires<[HasV5]>;
|
||||
def: Pat<(int_hexagon_Y2_dczeroa IntRegs:$src1),
|
||||
|
@ -3380,3 +3378,294 @@ def: Pat<(int_hexagon_V6_v6mpyvubs10_vxx HvxWR:$src1, HvxWR:$src2, HvxWR:$src3,
|
|||
(V6_v6mpyvubs10_vxx HvxWR:$src1, HvxWR:$src2, HvxWR:$src3, u2_0ImmPred_timm:$src4)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_v6mpyvubs10_vxx_128B HvxWR:$src1, HvxWR:$src2, HvxWR:$src3, u2_0ImmPred_timm:$src4),
|
||||
(V6_v6mpyvubs10_vxx HvxWR:$src1, HvxWR:$src2, HvxWR:$src3, u2_0ImmPred_timm:$src4)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vabs_hf HvxVR:$src1),
|
||||
(V6_vabs_hf HvxVR:$src1)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vabs_hf_128B HvxVR:$src1),
|
||||
(V6_vabs_hf HvxVR:$src1)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vabs_sf HvxVR:$src1),
|
||||
(V6_vabs_sf HvxVR:$src1)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vabs_sf_128B HvxVR:$src1),
|
||||
(V6_vabs_sf HvxVR:$src1)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_hf_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_hf_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_hf_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_hf_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_qf16 HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_qf16 HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_qf16_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_qf16 HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_qf16_mix HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_qf16_mix HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_qf16_mix_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_qf16_mix HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_qf32 HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_qf32 HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_qf32_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_qf32 HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_qf32_mix HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_qf32_mix HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_qf32_mix_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_qf32_mix HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_sf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_sf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_sf_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_sf_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_sf_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_sf_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_sf_sf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_sf_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vadd_sf_sf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vadd_sf_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vassign_fp HvxVR:$src1),
|
||||
(V6_vassign_fp HvxVR:$src1)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vassign_fp_128B HvxVR:$src1),
|
||||
(V6_vassign_fp HvxVR:$src1)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vconv_hf_qf16 HvxVR:$src1),
|
||||
(V6_vconv_hf_qf16 HvxVR:$src1)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vconv_hf_qf16_128B HvxVR:$src1),
|
||||
(V6_vconv_hf_qf16 HvxVR:$src1)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vconv_hf_qf32 HvxWR:$src1),
|
||||
(V6_vconv_hf_qf32 HvxWR:$src1)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vconv_hf_qf32_128B HvxWR:$src1),
|
||||
(V6_vconv_hf_qf32 HvxWR:$src1)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vconv_sf_qf32 HvxVR:$src1),
|
||||
(V6_vconv_sf_qf32 HvxVR:$src1)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vconv_sf_qf32_128B HvxVR:$src1),
|
||||
(V6_vconv_sf_qf32 HvxVR:$src1)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_b_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vcvt_b_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_b_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vcvt_b_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_h_hf HvxVR:$src1),
|
||||
(V6_vcvt_h_hf HvxVR:$src1)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_h_hf_128B HvxVR:$src1),
|
||||
(V6_vcvt_h_hf HvxVR:$src1)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_hf_b HvxVR:$src1),
|
||||
(V6_vcvt_hf_b HvxVR:$src1)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_hf_b_128B HvxVR:$src1),
|
||||
(V6_vcvt_hf_b HvxVR:$src1)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_hf_h HvxVR:$src1),
|
||||
(V6_vcvt_hf_h HvxVR:$src1)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_hf_h_128B HvxVR:$src1),
|
||||
(V6_vcvt_hf_h HvxVR:$src1)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_hf_sf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vcvt_hf_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_hf_sf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vcvt_hf_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_hf_ub HvxVR:$src1),
|
||||
(V6_vcvt_hf_ub HvxVR:$src1)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_hf_ub_128B HvxVR:$src1),
|
||||
(V6_vcvt_hf_ub HvxVR:$src1)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_hf_uh HvxVR:$src1),
|
||||
(V6_vcvt_hf_uh HvxVR:$src1)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_hf_uh_128B HvxVR:$src1),
|
||||
(V6_vcvt_hf_uh HvxVR:$src1)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_sf_hf HvxVR:$src1),
|
||||
(V6_vcvt_sf_hf HvxVR:$src1)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_sf_hf_128B HvxVR:$src1),
|
||||
(V6_vcvt_sf_hf HvxVR:$src1)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_ub_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vcvt_ub_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_ub_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vcvt_ub_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_uh_hf HvxVR:$src1),
|
||||
(V6_vcvt_uh_hf HvxVR:$src1)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vcvt_uh_hf_128B HvxVR:$src1),
|
||||
(V6_vcvt_uh_hf HvxVR:$src1)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vdmpy_sf_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vdmpy_sf_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vdmpy_sf_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vdmpy_sf_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vdmpy_sf_hf_acc HvxVR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vdmpy_sf_hf_acc HvxVR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vdmpy_sf_hf_acc_128B HvxVR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vdmpy_sf_hf_acc HvxVR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vfmax_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vfmax_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vfmax_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vfmax_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vfmax_sf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vfmax_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vfmax_sf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vfmax_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vfmin_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vfmin_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vfmin_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vfmin_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vfmin_sf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vfmin_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vfmin_sf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vfmin_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vfneg_hf HvxVR:$src1),
|
||||
(V6_vfneg_hf HvxVR:$src1)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vfneg_hf_128B HvxVR:$src1),
|
||||
(V6_vfneg_hf HvxVR:$src1)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vfneg_sf HvxVR:$src1),
|
||||
(V6_vfneg_sf HvxVR:$src1)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vfneg_sf_128B HvxVR:$src1),
|
||||
(V6_vfneg_sf HvxVR:$src1)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vgthf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vgthf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vgthf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vgthf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vgthf_and HvxQR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vgthf_and HvxQR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vgthf_and_128B HvxQR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vgthf_and HvxQR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vgthf_or HvxQR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vgthf_or HvxQR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vgthf_or_128B HvxQR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vgthf_or HvxQR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vgthf_xor HvxQR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vgthf_xor HvxQR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vgthf_xor_128B HvxQR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vgthf_xor HvxQR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vgtsf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vgtsf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vgtsf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vgtsf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vgtsf_and HvxQR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vgtsf_and HvxQR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vgtsf_and_128B HvxQR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vgtsf_and HvxQR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vgtsf_or HvxQR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vgtsf_or HvxQR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vgtsf_or_128B HvxQR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vgtsf_or HvxQR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vgtsf_xor HvxQR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vgtsf_xor HvxQR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vgtsf_xor_128B HvxQR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vgtsf_xor HvxQR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmax_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmax_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmax_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmax_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmax_sf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmax_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmax_sf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmax_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmin_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmin_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmin_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmin_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmin_sf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmin_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmin_sf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmin_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_hf_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_hf_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_hf_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_hf_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_hf_hf_acc HvxVR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vmpy_hf_hf_acc HvxVR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_hf_hf_acc_128B HvxVR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vmpy_hf_hf_acc HvxVR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_qf16 HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_qf16 HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_qf16_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_qf16 HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_qf16_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_qf16_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_qf16_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_qf16_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_qf16_mix_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_qf16_mix_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_qf16_mix_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_qf16_mix_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_qf32 HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_qf32 HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_qf32_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_qf32 HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_qf32_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_qf32_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_qf32_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_qf32_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_qf32_mix_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_qf32_mix_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_qf32_mix_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_qf32_mix_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_qf32_qf16 HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_qf32_qf16 HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_qf32_qf16_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_qf32_qf16 HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_qf32_sf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_qf32_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_qf32_sf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_qf32_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_sf_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_sf_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_sf_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_sf_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_sf_hf_acc HvxWR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vmpy_sf_hf_acc HvxWR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_sf_hf_acc_128B HvxWR:$src1, HvxVR:$src2, HvxVR:$src3),
|
||||
(V6_vmpy_sf_hf_acc HvxWR:$src1, HvxVR:$src2, HvxVR:$src3)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_sf_sf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_sf_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vmpy_sf_sf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpy_sf_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_hf_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_hf_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_hf_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_hf_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_qf16 HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_qf16 HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_qf16_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_qf16 HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_qf16_mix HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_qf16_mix HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_qf16_mix_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_qf16_mix HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_qf32 HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_qf32 HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_qf32_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_qf32 HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_qf32_mix HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_qf32_mix HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_qf32_mix_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_qf32_mix HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_sf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_sf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B, UseHVXQFloat]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_sf_hf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_sf_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_sf_hf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_sf_hf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_sf_sf HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_sf_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vsub_sf_sf_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vsub_sf_sf HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV68, UseHVX128B]>;
|
||||
|
||||
// V69 HVX Instructions.
|
||||
|
||||
def: Pat<(int_hexagon_V6_vasrvuhubrndsat HvxWR:$src1, HvxVR:$src2),
|
||||
(V6_vasrvuhubrndsat HvxWR:$src1, HvxVR:$src2)>, Requires<[HasV69, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vasrvuhubrndsat_128B HvxWR:$src1, HvxVR:$src2),
|
||||
(V6_vasrvuhubrndsat HvxWR:$src1, HvxVR:$src2)>, Requires<[HasV69, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vasrvuhubsat HvxWR:$src1, HvxVR:$src2),
|
||||
(V6_vasrvuhubsat HvxWR:$src1, HvxVR:$src2)>, Requires<[HasV69, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vasrvuhubsat_128B HvxWR:$src1, HvxVR:$src2),
|
||||
(V6_vasrvuhubsat HvxWR:$src1, HvxVR:$src2)>, Requires<[HasV69, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vasrvwuhrndsat HvxWR:$src1, HvxVR:$src2),
|
||||
(V6_vasrvwuhrndsat HvxWR:$src1, HvxVR:$src2)>, Requires<[HasV69, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vasrvwuhrndsat_128B HvxWR:$src1, HvxVR:$src2),
|
||||
(V6_vasrvwuhrndsat HvxWR:$src1, HvxVR:$src2)>, Requires<[HasV69, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vasrvwuhsat HvxWR:$src1, HvxVR:$src2),
|
||||
(V6_vasrvwuhsat HvxWR:$src1, HvxVR:$src2)>, Requires<[HasV69, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vasrvwuhsat_128B HvxWR:$src1, HvxVR:$src2),
|
||||
(V6_vasrvwuhsat HvxWR:$src1, HvxVR:$src2)>, Requires<[HasV69, UseHVX128B]>;
|
||||
def: Pat<(int_hexagon_V6_vmpyuhvs HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpyuhvs HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV69, UseHVX64B]>;
|
||||
def: Pat<(int_hexagon_V6_vmpyuhvs_128B HvxVR:$src1, HvxVR:$src2),
|
||||
(V6_vmpyuhvs HvxVR:$src1, HvxVR:$src2)>, Requires<[HasV69, UseHVX128B]>;
|
||||
|
|
|
@ -174,7 +174,6 @@ def V6_ldcpnt0Alias : InstAlias<"if ($Pv4) $Vd32.cur = vmem($Rt32):nt", (V6_vL32
|
|||
def V6_ldnp0Alias : InstAlias<"if (!$Pv4) $Vd32 = vmem($Rt32)", (V6_vL32b_npred_pi HvxVR:$Vd32, IntRegs:$Rt32, PredRegs:$Pv4, 0)>, Requires<[UseHVX]>;
|
||||
def V6_ldnpnt0Alias : InstAlias<"if (!$Pv4) $Vd32 = vmem($Rt32):nt", (V6_vL32b_nt_npred_pi HvxVR:$Vd32, IntRegs:$Rt32, PredRegs:$Pv4, 0)>, Requires<[UseHVX]>;
|
||||
def V6_ldnt0Alias : InstAlias<"$Vd32 = vmem($Rt32):nt", (V6_vL32b_nt_ai HvxVR:$Vd32, IntRegs:$Rt32, 0)>, Requires<[UseHVX]>;
|
||||
def V6_ldntnt0Alias : InstAlias<"$Vd32 = vmem($Rt32):nt", (V6_vL32b_nt_ai HvxVR:$Vd32, IntRegs:$Rt32, 0)>;
|
||||
def V6_ldp0Alias : InstAlias<"if ($Pv4) $Vd32 = vmem($Rt32)", (V6_vL32b_pred_ai HvxVR:$Vd32, PredRegs:$Pv4, IntRegs:$Rt32, 0)>, Requires<[UseHVX]>;
|
||||
def V6_ldpnt0Alias : InstAlias<"if ($Pv4) $Vd32 = vmem($Rt32):nt", (V6_vL32b_nt_pred_ai HvxVR:$Vd32, PredRegs:$Pv4, IntRegs:$Rt32, 0)>, Requires<[UseHVX]>;
|
||||
def V6_ldtnp0Alias : InstAlias<"if (!$Pv4) $Vd32.tmp = vmem($Rt32)", (V6_vL32b_npred_ai HvxVR:$Vd32, PredRegs:$Pv4, IntRegs:$Rt32, 0)>, Requires<[UseHVX]>;
|
||||
|
|
|
@ -146,9 +146,6 @@ class InstHexagon<dag outs, dag ins, string asmstr, list<dag> pattern,
|
|||
bits<1> isFP = 0;
|
||||
let TSFlags {50} = isFP; // Floating-point.
|
||||
|
||||
bits<1> isSomeOK = 0;
|
||||
let TSFlags {51} = isSomeOK; // Relax some grouping constraints.
|
||||
|
||||
bits<1> hasNewValue2 = 0;
|
||||
let TSFlags{52} = hasNewValue2; // Second New-value producer insn.
|
||||
bits<3> opNewValue2 = 0;
|
||||
|
@ -160,8 +157,8 @@ class InstHexagon<dag outs, dag ins, string asmstr, list<dag> pattern,
|
|||
bits<1> prefersSlot3 = 0;
|
||||
let TSFlags{57} = prefersSlot3; // Complex XU
|
||||
|
||||
bits<1> hasTmpDst = 0;
|
||||
let TSFlags{60} = hasTmpDst; // v65 : 'fake" register VTMP is set
|
||||
bits<1> hasHvxTmp = 0;
|
||||
let TSFlags{60} = hasHvxTmp; // vector register vX.tmp false-write
|
||||
|
||||
bit CVINew = 0;
|
||||
let TSFlags{62} = CVINew;
|
||||
|
|
|
@ -572,3 +572,14 @@ defm PS_storerd : NewCircularStore<DoubleRegs, WordAccess>;
|
|||
// __builtin_trap.
|
||||
let hasSideEffects = 1, isPseudo = 1, isCodeGenOnly = 1, isSolo = 1 in
|
||||
def PS_crash: InstHexagon<(outs), (ins), "", [], "", PSEUDO, TypePSEUDO>;
|
||||
|
||||
// This is actual trap1 instruction from before v65. It's here since it is
|
||||
// no longer included in DepInstrInfo.td.
|
||||
def PS_trap1 : HInst<(outs), (ins u8_0Imm:$Ii), "trap1(#$Ii)", tc_53c851ab,
|
||||
TypeJ>, Enc_a51a9a, Requires<[HasPreV65]> {
|
||||
let Inst{1-0} = 0b00;
|
||||
let Inst{7-5} = 0b000;
|
||||
let Inst{13-13} = 0b0;
|
||||
let Inst{31-16} = 0b0101010010000000;
|
||||
}
|
||||
|
||||
|
|
|
@ -69,3 +69,4 @@ include "HexagonScheduleV66.td"
|
|||
include "HexagonScheduleV67.td"
|
||||
include "HexagonScheduleV67T.td"
|
||||
include "HexagonScheduleV68.td"
|
||||
include "HexagonScheduleV69.td"
|
||||
|
|
|
@ -0,0 +1,40 @@
|
|||
//=-HexagonScheduleV69.td - HexagonV69 Scheduling Definitions *- tablegen -*-=//
|
||||
//
|
||||
// The LLVM Compiler Infrastructure
|
||||
//
|
||||
// This file is distributed under the University of Illinois Open Source
|
||||
// License. See LICENSE.TXT for details.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
//
|
||||
// ScalarItin and HVXItin contain some old itineraries
|
||||
// still used by a handful of instructions. Hopefully, we will be able
|
||||
// to get rid of them soon.
|
||||
def HexagonV69ItinList : DepScalarItinV69, ScalarItin,
|
||||
DepHVXItinV69, HVXItin, PseudoItin {
|
||||
list<InstrItinData> ItinList =
|
||||
!listconcat(DepScalarItinV69_list, ScalarItin_list,
|
||||
DepHVXItinV69_list, HVXItin_list, PseudoItin_list);
|
||||
}
|
||||
|
||||
def HexagonItinerariesV69 :
|
||||
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,
|
||||
CVI_ALL_NOMEM, CVI_ZW],
|
||||
[Hex_FWD, HVX_FWD],
|
||||
HexagonV69ItinList.ItinList>;
|
||||
|
||||
def HexagonModelV69 : SchedMachineModel {
|
||||
// Max issue per cycle == bundle width.
|
||||
let IssueWidth = 4;
|
||||
let Itineraries = HexagonItinerariesV69;
|
||||
let LoadLatency = 1;
|
||||
let CompleteModel = 0;
|
||||
}
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// Hexagon V69 Resource Definitions -
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
|
@ -75,6 +75,10 @@ static cl::opt<bool> EnableCheckBankConflict("hexagon-check-bank-conflict",
|
|||
cl::Hidden, cl::ZeroOrMore, cl::init(true),
|
||||
cl::desc("Enable checking for cache bank conflicts"));
|
||||
|
||||
static cl::opt<bool> EnableV68FloatCodeGen(
|
||||
"force-hvx-float", cl::Hidden, cl::ZeroOrMore, cl::init(false),
|
||||
cl::desc("Enable the code-generation for vector float instructions on v68."));
|
||||
|
||||
HexagonSubtarget::HexagonSubtarget(const Triple &TT, StringRef CPU,
|
||||
StringRef FS, const TargetMachine &TM)
|
||||
: HexagonGenSubtargetInfo(TT, CPU, /*TuneCPU*/ CPU, FS),
|
||||
|
@ -103,13 +107,71 @@ HexagonSubtarget::initializeSubtargetDependencies(StringRef CPU, StringRef FS) {
|
|||
UseAudioOps = false;
|
||||
UseLongCalls = false;
|
||||
|
||||
UseBSBScheduling = hasV60Ops() && EnableBSBSched;
|
||||
SubtargetFeatures Features(FS);
|
||||
|
||||
ParseSubtargetFeatures(CPUString, /*TuneCPU*/ CPUString, FS);
|
||||
// Turn on QFloat if the HVX version is v68+.
|
||||
// The function ParseSubtargetFeatures will set feature bits and initialize
|
||||
// subtarget's variables all in one, so there isn't a good way to preprocess
|
||||
// the feature string, other than by tinkering with it directly.
|
||||
auto IsQFloatFS = [](StringRef F) {
|
||||
return F == "+hvx-qfloat" || F == "-hvx-qfloat";
|
||||
};
|
||||
if (!llvm::count_if(Features.getFeatures(), IsQFloatFS)) {
|
||||
auto getHvxVersion = [&Features](StringRef FS) -> StringRef {
|
||||
for (StringRef F : llvm::reverse(Features.getFeatures())) {
|
||||
if (F.startswith("+hvxv"))
|
||||
return F;
|
||||
}
|
||||
for (StringRef F : llvm::reverse(Features.getFeatures())) {
|
||||
if (F == "-hvx")
|
||||
return StringRef();
|
||||
if (F.startswith("+hvx") || F == "-hvx")
|
||||
return F.take_front(4); // Return "+hvx" or "-hvx".
|
||||
}
|
||||
return StringRef();
|
||||
};
|
||||
|
||||
bool AddQFloat = false;
|
||||
StringRef HvxVer = getHvxVersion(FS);
|
||||
if (HvxVer.startswith("+hvxv")) {
|
||||
int Ver = 0;
|
||||
if (!HvxVer.drop_front(5).consumeInteger(10, Ver) && Ver >= 68)
|
||||
AddQFloat = true;
|
||||
} else if (HvxVer == "+hvx") {
|
||||
if (hasV68Ops())
|
||||
AddQFloat = true;
|
||||
}
|
||||
|
||||
if (AddQFloat)
|
||||
Features.AddFeature("+hvx-qfloat");
|
||||
}
|
||||
|
||||
std::string FeatureString = Features.getString();
|
||||
ParseSubtargetFeatures(CPUString, /*TuneCPU*/ CPUString, FeatureString);
|
||||
|
||||
// Enable float code generation only if the flag(s) are set and
|
||||
// the feature is enabled. v68 is guarded by additional flags.
|
||||
bool GreaterThanV68 = false;
|
||||
if (useHVXV69Ops())
|
||||
GreaterThanV68 = true;
|
||||
|
||||
// Support for deprecated qfloat/ieee codegen flags
|
||||
if (!GreaterThanV68) {
|
||||
if (EnableV68FloatCodeGen)
|
||||
UseHVXFloatingPoint = true;
|
||||
} else {
|
||||
UseHVXFloatingPoint = true;
|
||||
}
|
||||
|
||||
if (UseHVXQFloatOps && UseHVXIEEEFPOps && UseHVXFloatingPoint)
|
||||
LLVM_DEBUG(
|
||||
dbgs() << "Behavior is undefined for simultaneous qfloat and ieee hvx codegen...");
|
||||
|
||||
if (OverrideLongCalls.getPosition())
|
||||
UseLongCalls = OverrideLongCalls;
|
||||
|
||||
UseBSBScheduling = hasV60Ops() && EnableBSBSched;
|
||||
|
||||
if (isTinyCore()) {
|
||||
// Tiny core has a single thread, so back-to-back scheduling is enabled by
|
||||
// default.
|
||||
|
@ -117,10 +179,10 @@ HexagonSubtarget::initializeSubtargetDependencies(StringRef CPU, StringRef FS) {
|
|||
UseBSBScheduling = false;
|
||||
}
|
||||
|
||||
FeatureBitset Features = getFeatureBits();
|
||||
FeatureBitset FeatureBits = getFeatureBits();
|
||||
if (HexagonDisableDuplex)
|
||||
setFeatureBits(Features.reset(Hexagon::FeatureDuplex));
|
||||
setFeatureBits(Hexagon_MC::completeHVXFeatures(Features));
|
||||
setFeatureBits(FeatureBits.reset(Hexagon::FeatureDuplex));
|
||||
setFeatureBits(Hexagon_MC::completeHVXFeatures(FeatureBits));
|
||||
|
||||
return *this;
|
||||
}
|
||||
|
|
|
@ -56,6 +56,10 @@ class HexagonSubtarget : public HexagonGenSubtargetInfo {
|
|||
bool UseSmallData = false;
|
||||
bool UseUnsafeMath = false;
|
||||
bool UseZRegOps = false;
|
||||
bool UseHVXIEEEFPOps = false;
|
||||
bool UseHVXQFloatOps = false;
|
||||
bool UseHVXFloatingPoint = false;
|
||||
bool UseCabac = false;
|
||||
|
||||
bool HasPreV65 = false;
|
||||
bool HasMemNoShuf = false;
|
||||
|
@ -188,6 +192,12 @@ public:
|
|||
bool hasV68OpsOnly() const {
|
||||
return getHexagonArchVersion() == Hexagon::ArchEnum::V68;
|
||||
}
|
||||
bool hasV69Ops() const {
|
||||
return getHexagonArchVersion() >= Hexagon::ArchEnum::V69;
|
||||
}
|
||||
bool hasV69OpsOnly() const {
|
||||
return getHexagonArchVersion() == Hexagon::ArchEnum::V69;
|
||||
}
|
||||
|
||||
bool useAudioOps() const { return UseAudioOps; }
|
||||
bool useCompound() const { return UseCompound; }
|
||||
|
@ -199,10 +209,16 @@ public:
|
|||
bool useSmallData() const { return UseSmallData; }
|
||||
bool useUnsafeMath() const { return UseUnsafeMath; }
|
||||
bool useZRegOps() const { return UseZRegOps; }
|
||||
bool useCabac() const { return UseCabac; }
|
||||
|
||||
bool isTinyCore() const { return HexagonProcFamily == TinyCore; }
|
||||
bool isTinyCoreWithDuplex() const { return isTinyCore() && EnableDuplex; }
|
||||
|
||||
bool useHVXIEEEFPOps() const { return UseHVXIEEEFPOps && useHVXOps(); }
|
||||
bool useHVXQFloatOps() const {
|
||||
return UseHVXQFloatOps && HexagonHVXVersion >= Hexagon::ArchEnum::V68;
|
||||
}
|
||||
bool useHVXFloatingPoint() const { return UseHVXFloatingPoint; }
|
||||
bool useHVXOps() const {
|
||||
return HexagonHVXVersion > Hexagon::ArchEnum::NoArch;
|
||||
}
|
||||
|
@ -224,6 +240,9 @@ public:
|
|||
bool useHVXV68Ops() const {
|
||||
return HexagonHVXVersion >= Hexagon::ArchEnum::V68;
|
||||
}
|
||||
bool useHVXV69Ops() const {
|
||||
return HexagonHVXVersion >= Hexagon::ArchEnum::V69;
|
||||
}
|
||||
bool useHVX128BOps() const { return useHVXOps() && UseHVX128BOps; }
|
||||
bool useHVX64BOps() const { return useHVXOps() && UseHVX64BOps; }
|
||||
|
||||
|
@ -283,7 +302,11 @@ public:
|
|||
}
|
||||
|
||||
ArrayRef<MVT> getHVXElementTypes() const {
|
||||
static MVT Types[] = { MVT::i8, MVT::i16, MVT::i32 };
|
||||
static MVT Types[] = {MVT::i8, MVT::i16, MVT::i32};
|
||||
static MVT TypesV68[] = {MVT::i8, MVT::i16, MVT::i32, MVT::f16, MVT::f32};
|
||||
|
||||
if (useHVXV68Ops() && useHVXFloatingPoint())
|
||||
return makeArrayRef(TypesV68);
|
||||
return makeArrayRef(Types);
|
||||
}
|
||||
|
||||
|
|
|
@ -154,9 +154,8 @@ namespace HexagonII {
|
|||
PrefersSlot3Pos = 57,
|
||||
PrefersSlot3Mask = 0x1,
|
||||
|
||||
// v65
|
||||
HasTmpDstPos = 60,
|
||||
HasTmpDstMask = 0x1,
|
||||
HasHvxTmpPos = 60,
|
||||
HasHvxTmpMask = 0x1,
|
||||
|
||||
CVINewPos = 62,
|
||||
CVINewMask = 0x1,
|
||||
|
|
|
@ -98,6 +98,10 @@ void HexagonMCChecker::init(MCInst const &MCI) {
|
|||
for (unsigned i = 0; i < MCID.getNumImplicitUses(); ++i)
|
||||
initReg(MCI, MCID.getImplicitUses()[i], PredReg, isTrue);
|
||||
|
||||
const bool IgnoreTmpDst = (HexagonMCInstrInfo::hasTmpDst(MCII, MCI) ||
|
||||
HexagonMCInstrInfo::hasHvxTmp(MCII, MCI)) &&
|
||||
STI.getFeatureBits()[Hexagon::ArchV69];
|
||||
|
||||
// Get implicit register definitions.
|
||||
if (const MCPhysReg *ImpDef = MCID.getImplicitDefs())
|
||||
for (; *ImpDef; ++ImpDef) {
|
||||
|
@ -123,7 +127,7 @@ void HexagonMCChecker::init(MCInst const &MCI) {
|
|||
HexagonMCInstrInfo::isPredicateLate(MCII, MCI))
|
||||
// Include implicit late predicates.
|
||||
LatePreds.insert(R);
|
||||
else
|
||||
else if (!IgnoreTmpDst)
|
||||
Defs[R].insert(PredSense(PredReg, isTrue));
|
||||
}
|
||||
|
||||
|
@ -178,7 +182,7 @@ void HexagonMCChecker::init(MCInst const &MCI) {
|
|||
// vshuff(Vx, Vy, Rx) <- Vx(0) and Vy(1) are both source and
|
||||
// destination registers with this instruction. same for vdeal(Vx,Vy,Rx)
|
||||
Uses.insert(*SRI);
|
||||
else
|
||||
else if (!IgnoreTmpDst)
|
||||
Defs[*SRI].insert(PredSense(PredReg, isTrue));
|
||||
}
|
||||
}
|
||||
|
@ -227,9 +231,11 @@ bool HexagonMCChecker::check(bool FullCheck) {
|
|||
bool chkAXOK = checkAXOK();
|
||||
bool chkCofMax1 = checkCOFMax1();
|
||||
bool chkHWLoop = checkHWLoop();
|
||||
bool chkValidTmpDst = FullCheck ? checkValidTmpDst() : true;
|
||||
bool chkLegalVecRegPair = checkLegalVecRegPair();
|
||||
bool chk = chkP && chkNV && chkR && chkRRO && chkS && chkSh && chkSl &&
|
||||
chkAXOK && chkCofMax1 && chkHWLoop && chkLegalVecRegPair;
|
||||
chkAXOK && chkCofMax1 && chkHWLoop && chkValidTmpDst &&
|
||||
chkLegalVecRegPair;
|
||||
|
||||
return chk;
|
||||
}
|
||||
|
@ -676,6 +682,32 @@ bool HexagonMCChecker::checkShuffle() {
|
|||
return MCSDX.check();
|
||||
}
|
||||
|
||||
bool HexagonMCChecker::checkValidTmpDst() {
|
||||
if (!STI.getFeatureBits()[Hexagon::ArchV69]) {
|
||||
return true;
|
||||
}
|
||||
auto HasTmp = [&](MCInst const &I) {
|
||||
return HexagonMCInstrInfo::hasTmpDst(MCII, I) ||
|
||||
HexagonMCInstrInfo::hasHvxTmp(MCII, I);
|
||||
};
|
||||
unsigned HasTmpCount =
|
||||
llvm::count_if(HexagonMCInstrInfo::bundleInstructions(MCII, MCB), HasTmp);
|
||||
|
||||
if (HasTmpCount > 1) {
|
||||
reportError(
|
||||
MCB.getLoc(),
|
||||
"this packet has more than one HVX vtmp/.tmp destination instruction");
|
||||
|
||||
for (auto const &I : HexagonMCInstrInfo::bundleInstructions(MCII, MCB))
|
||||
if (HasTmp(I))
|
||||
reportNote(I.getLoc(),
|
||||
"this is an HVX vtmp/.tmp destination instruction");
|
||||
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
void HexagonMCChecker::compoundRegisterMap(unsigned &Register) {
|
||||
switch (Register) {
|
||||
default:
|
||||
|
|
|
@ -99,6 +99,7 @@ class HexagonMCChecker {
|
|||
bool checkHWLoop();
|
||||
bool checkCOFMax1();
|
||||
bool checkLegalVecRegPair();
|
||||
bool checkValidTmpDst();
|
||||
|
||||
static void compoundRegisterMap(unsigned &);
|
||||
|
||||
|
|
|
@ -939,10 +939,24 @@ bool HexagonMCInstrInfo::prefersSlot3(MCInstrInfo const &MCII,
|
|||
return (F >> HexagonII::PrefersSlot3Pos) & HexagonII::PrefersSlot3Mask;
|
||||
}
|
||||
|
||||
/// return true if instruction has hasTmpDst attribute.
|
||||
bool HexagonMCInstrInfo::hasTmpDst(MCInstrInfo const &MCII, MCInst const &MCI) {
|
||||
switch (MCI.getOpcode()) {
|
||||
default:
|
||||
return false;
|
||||
case Hexagon::V6_vgathermh:
|
||||
case Hexagon::V6_vgathermhq:
|
||||
case Hexagon::V6_vgathermhw:
|
||||
case Hexagon::V6_vgathermhwq:
|
||||
case Hexagon::V6_vgathermw:
|
||||
case Hexagon::V6_vgathermwq:
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
bool HexagonMCInstrInfo::hasHvxTmp(MCInstrInfo const &MCII, MCInst const &MCI) {
|
||||
const uint64_t F = HexagonMCInstrInfo::getDesc(MCII, MCI).TSFlags;
|
||||
return (F >> HexagonII::HasTmpDstPos) & HexagonII::HasTmpDstMask;
|
||||
return (F >> HexagonII::HasHvxTmpPos) & HexagonII::HasHvxTmpMask;
|
||||
}
|
||||
|
||||
bool HexagonMCInstrInfo::requiresSlot(MCSubtargetInfo const &STI,
|
||||
|
|
|
@ -41,7 +41,8 @@ public:
|
|||
|
||||
namespace Hexagon {
|
||||
|
||||
class PacketIterator {
|
||||
class PacketIterator : public std::iterator<std::forward_iterator_tag,
|
||||
PacketIterator> {
|
||||
MCInstrInfo const &MCII;
|
||||
MCInst::const_iterator BundleCurrent;
|
||||
MCInst::const_iterator BundleEnd;
|
||||
|
@ -188,6 +189,7 @@ bool hasImmExt(MCInst const &MCI);
|
|||
bool hasNewValue(MCInstrInfo const &MCII, MCInst const &MCI);
|
||||
bool hasNewValue2(MCInstrInfo const &MCII, MCInst const &MCI);
|
||||
bool hasTmpDst(MCInstrInfo const &MCII, MCInst const &MCI);
|
||||
bool hasHvxTmp(MCInstrInfo const &MCII, MCInst const &MCI);
|
||||
unsigned iClassOfDuplexPair(unsigned Ga, unsigned Gb);
|
||||
|
||||
int64_t minConstant(MCInst const &MCI, size_t Index);
|
||||
|
|
|
@ -80,6 +80,8 @@ cl::opt<bool> MV67T("mv67t", cl::Hidden, cl::desc("Build for Hexagon V67T"),
|
|||
cl::init(false));
|
||||
cl::opt<bool> MV68("mv68", cl::Hidden, cl::desc("Build for Hexagon V68"),
|
||||
cl::init(false));
|
||||
cl::opt<bool> MV69("mv69", cl::Hidden, cl::desc("Build for Hexagon V69"),
|
||||
cl::init(false));
|
||||
|
||||
cl::opt<Hexagon::ArchEnum>
|
||||
EnableHVX("mhvx",
|
||||
|
@ -91,6 +93,7 @@ cl::opt<Hexagon::ArchEnum>
|
|||
clEnumValN(Hexagon::ArchEnum::V66, "v66", "Build for HVX v66"),
|
||||
clEnumValN(Hexagon::ArchEnum::V67, "v67", "Build for HVX v67"),
|
||||
clEnumValN(Hexagon::ArchEnum::V68, "v68", "Build for HVX v68"),
|
||||
clEnumValN(Hexagon::ArchEnum::V69, "v69", "Build for HVX v69"),
|
||||
// Sentinel for no value specified.
|
||||
clEnumValN(Hexagon::ArchEnum::Generic, "", "")),
|
||||
// Sentinel for flag not present.
|
||||
|
@ -101,6 +104,11 @@ static cl::opt<bool>
|
|||
DisableHVX("mno-hvx", cl::Hidden,
|
||||
cl::desc("Disable Hexagon Vector eXtensions"));
|
||||
|
||||
static cl::opt<bool>
|
||||
EnableHvxIeeeFp("mhvx-ieee-fp", cl::Hidden,
|
||||
cl::desc("Enable HVX IEEE floating point extensions"));
|
||||
static cl::opt<bool> EnableHexagonCabac
|
||||
("mcabac", cl::desc("tbd"), cl::init(false));
|
||||
|
||||
static StringRef DefaultArch = "hexagonv60";
|
||||
|
||||
|
@ -123,6 +131,8 @@ static StringRef HexagonGetArchVariant() {
|
|||
return "hexagonv67t";
|
||||
if (MV68)
|
||||
return "hexagonv68";
|
||||
if (MV69)
|
||||
return "hexagonv69";
|
||||
return "";
|
||||
}
|
||||
|
||||
|
@ -371,6 +381,9 @@ std::string selectHexagonFS(StringRef CPU, StringRef FS) {
|
|||
case Hexagon::ArchEnum::V68:
|
||||
Result.push_back("+hvxv68");
|
||||
break;
|
||||
case Hexagon::ArchEnum::V69:
|
||||
Result.push_back("+hvxv69");
|
||||
break;
|
||||
case Hexagon::ArchEnum::Generic:{
|
||||
Result.push_back(StringSwitch<StringRef>(CPU)
|
||||
.Case("hexagonv60", "+hvxv60")
|
||||
|
@ -379,13 +392,19 @@ std::string selectHexagonFS(StringRef CPU, StringRef FS) {
|
|||
.Case("hexagonv66", "+hvxv66")
|
||||
.Case("hexagonv67", "+hvxv67")
|
||||
.Case("hexagonv67t", "+hvxv67")
|
||||
.Case("hexagonv68", "+hvxv68"));
|
||||
.Case("hexagonv68", "+hvxv68")
|
||||
.Case("hexagonv69", "+hvxv69"));
|
||||
break;
|
||||
}
|
||||
case Hexagon::ArchEnum::NoArch:
|
||||
// Sentinel if -mhvx isn't specified
|
||||
break;
|
||||
}
|
||||
if (EnableHvxIeeeFp)
|
||||
Result.push_back("+hvx-ieee-fp");
|
||||
if (EnableHexagonCabac)
|
||||
Result.push_back("+cabac");
|
||||
|
||||
return join(Result.begin(), Result.end(), ",");
|
||||
}
|
||||
}
|
||||
|
@ -422,8 +441,8 @@ FeatureBitset Hexagon_MC::completeHVXFeatures(const FeatureBitset &S) {
|
|||
// turns on hvxvNN, corresponding to the existing ArchVNN.
|
||||
FeatureBitset FB = S;
|
||||
unsigned CpuArch = ArchV5;
|
||||
for (unsigned F : {ArchV68, ArchV67, ArchV66, ArchV65, ArchV62, ArchV60,
|
||||
ArchV55, ArchV5}) {
|
||||
for (unsigned F : {ArchV69, ArchV68, ArchV67, ArchV66, ArchV65, ArchV62,
|
||||
ArchV60, ArchV55, ArchV5}) {
|
||||
if (!FB.test(F))
|
||||
continue;
|
||||
CpuArch = F;
|
||||
|
@ -438,7 +457,8 @@ FeatureBitset Hexagon_MC::completeHVXFeatures(const FeatureBitset &S) {
|
|||
}
|
||||
bool HasHvxVer = false;
|
||||
for (unsigned F : {ExtensionHVXV60, ExtensionHVXV62, ExtensionHVXV65,
|
||||
ExtensionHVXV66, ExtensionHVXV67, ExtensionHVXV68}) {
|
||||
ExtensionHVXV66, ExtensionHVXV67, ExtensionHVXV68,
|
||||
ExtensionHVXV69}) {
|
||||
if (!FB.test(F))
|
||||
continue;
|
||||
HasHvxVer = true;
|
||||
|
@ -451,6 +471,9 @@ FeatureBitset Hexagon_MC::completeHVXFeatures(const FeatureBitset &S) {
|
|||
|
||||
// HasHvxVer is false, and UseHvx is true.
|
||||
switch (CpuArch) {
|
||||
case ArchV69:
|
||||
FB.set(ExtensionHVXV69);
|
||||
LLVM_FALLTHROUGH;
|
||||
case ArchV68:
|
||||
FB.set(ExtensionHVXV68);
|
||||
LLVM_FALLTHROUGH;
|
||||
|
@ -538,6 +561,7 @@ unsigned Hexagon_MC::GetELFFlags(const MCSubtargetInfo &STI) {
|
|||
{"hexagonv67", ELF::EF_HEXAGON_MACH_V67},
|
||||
{"hexagonv67t", ELF::EF_HEXAGON_MACH_V67T},
|
||||
{"hexagonv68", ELF::EF_HEXAGON_MACH_V68},
|
||||
{"hexagonv69", ELF::EF_HEXAGON_MACH_V69},
|
||||
};
|
||||
|
||||
auto F = ElfFlags.find(STI.getCPU());
|
||||
|
|
Loading…
Reference in New Issue