clang 20.0.0 (based on r547379) from build 12806354. Bug: http://b/379133546 Test: N/A Change-Id: I2eb8938af55d809de674be63cb30cf27e801862b Upstream-Commit: ad834e67b1105d15ef907f6255d4c96e8e733f57
191 lines
9.5 KiB
TableGen
191 lines
9.5 KiB
TableGen
//===- IntrinsicsRISCVXsf.td - SiFive intrinsics -----------*- tablegen -*-===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file defines all of the SiFive vendor intrinsics for RISC-V.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
class VCIXSuffix<string range> {
|
|
list<string> suffix = !cond(!eq(range, "c"): ["e8mf8", "e8mf4", "e8mf2", "e8m1", "e8m2", "e8m4", "e8m8"],
|
|
!eq(range, "s"): ["e16mf4", "e16mf2", "e16m1", "e16m2", "e16m4", "e16m8"],
|
|
!eq(range, "i"): ["e32mf2", "e32m1", "e32m2", "e32m4", "e32m8"],
|
|
!eq(range, "l"): ["e64m1", "e64m2", "e64m4", "e64m8"]);
|
|
}
|
|
|
|
let TargetPrefix = "riscv" in {
|
|
// Output: (vector_out)
|
|
// Input: (bit<27-26>, bit<24-20>, scalar_in, vl) or
|
|
class RISCVSFCustomVC_X<bit HasSE, bit ImmScalar>
|
|
: Intrinsic<[llvm_anyvector_ty],
|
|
[llvm_anyint_ty, LLVMMatchType<1>, llvm_any_ty, llvm_anyint_ty],
|
|
!listconcat([IntrNoMem, ImmArg<ArgIndex<0>>, ImmArg<ArgIndex<1>>], // bit<27-26> and bit<24-20>
|
|
!if(ImmScalar, [ImmArg<ArgIndex<2>>], []), // ScalarOperand
|
|
!if(HasSE, [IntrHasSideEffects], []))>,
|
|
RISCVVIntrinsic {
|
|
let ScalarOperand = !cond(ImmScalar: NoScalarOperand,
|
|
true: 2);
|
|
let VLOperand = 3;
|
|
}
|
|
// Output: ()
|
|
// Input: (bit<27-26>, bit<24-20>, bit<11-7>, scalar_in, sew, log2lmul, vl)
|
|
class RISCVSFCustomVC_X_WO_Suffix<bit ImmScalar>
|
|
: Intrinsic<[],
|
|
[llvm_anyint_ty, LLVMMatchType<0>, LLVMMatchType<0>,
|
|
llvm_any_ty, LLVMMatchType<0>, LLVMMatchType<0>, llvm_anyint_ty],
|
|
!listconcat([IntrNoMem, IntrHasSideEffects, ImmArg<ArgIndex<0>>,
|
|
ImmArg<ArgIndex<1>>, ImmArg<ArgIndex<2>>,
|
|
ImmArg<ArgIndex<4>>, ImmArg<ArgIndex<5>>], // bit<27-26>, bit<24-20>, bit<11-7>, sew, log2lmul
|
|
!if(ImmScalar, [ImmArg<ArgIndex<3>>], []))>, // ScalarOperand
|
|
RISCVVIntrinsic {
|
|
let ScalarOperand = !cond(ImmScalar: NoScalarOperand,
|
|
true: 3);
|
|
let VLOperand = 6;
|
|
}
|
|
// Output: (vector_out) or ()
|
|
// Input: (bit<27-26>, vector_in, vector_in/scalar_in, vl) or
|
|
// (bit<27-26>, bit<11-7>, vector_in, vector_in/scalar_in, vl)
|
|
class RISCVSFCustomVC_XV<bit HasDst, bit HasSE, bit ImmScalar>
|
|
: Intrinsic<!if(HasDst, [llvm_anyvector_ty], []),
|
|
!listconcat(!if(HasDst, [llvm_anyint_ty, llvm_anyvector_ty],
|
|
[llvm_anyint_ty, LLVMMatchType<0>, llvm_anyvector_ty]),
|
|
[llvm_any_ty, llvm_anyint_ty]),
|
|
!listconcat([IntrNoMem, ImmArg<ArgIndex<0>>], // bit<27-26>
|
|
!if(HasDst, [], [ImmArg<ArgIndex<1>>]), // Vd or bit<11-7>
|
|
!if(ImmScalar, !if(HasDst, [ImmArg<ArgIndex<2>>],
|
|
[ImmArg<ArgIndex<3>>]), []), // ScalarOperand
|
|
!if(HasSE, [IntrHasSideEffects], []))>,
|
|
RISCVVIntrinsic {
|
|
let ScalarOperand = !cond(ImmScalar: NoScalarOperand,
|
|
HasDst: 2,
|
|
true: 3);
|
|
let VLOperand = !if(HasDst, 3, 4);
|
|
}
|
|
// Output: (vector_out) or ()
|
|
// Input: (bit<27-26>, passthru, vector_in, vector_in/scalar_in, vl) or
|
|
// (bit<27-26>, vector_in, vector_in, vector_in/scalar_in, vl)
|
|
class RISCVSFCustomVC_XVV<bit HasDst, bit HasSE, bit ImmScalar>
|
|
: Intrinsic<!if(HasDst, [llvm_anyvector_ty], []),
|
|
!listconcat(!if(HasDst, [llvm_anyint_ty, llvm_anyvector_ty, llvm_anyvector_ty],
|
|
[llvm_anyint_ty, llvm_anyvector_ty, llvm_anyvector_ty]),
|
|
[llvm_any_ty, llvm_anyint_ty]),
|
|
!listconcat([IntrNoMem, ImmArg<ArgIndex<0>>], // bit<27-26>
|
|
!if(ImmScalar, [ImmArg<ArgIndex<3>>], []), // ScalarOperand
|
|
!if(HasSE, [IntrHasSideEffects], []))>,
|
|
RISCVVIntrinsic {
|
|
let ScalarOperand = !if(ImmScalar, NoScalarOperand, 3);
|
|
let VLOperand = 4;
|
|
}
|
|
// Output: (wvector_out) or ()
|
|
// Input: (bit<27-26>, passthru, vector_in, vector_in/scalar_in, vl) or
|
|
// (bit<27-26>, wvector_in, vector_in, vector_in/scalar_in, vl)
|
|
class RISCVSFCustomVC_XVW<bit HasDst, bit HasSE, bit ImmScalar>
|
|
: Intrinsic<!if(HasDst, [llvm_anyvector_ty], []),
|
|
!listconcat(!if(HasDst, [llvm_anyint_ty, llvm_anyvector_ty, llvm_anyvector_ty],
|
|
[llvm_anyint_ty, llvm_anyvector_ty, llvm_anyvector_ty]),
|
|
[llvm_any_ty, llvm_anyint_ty]),
|
|
!listconcat([IntrNoMem, ImmArg<ArgIndex<0>>], // bit<27-26>
|
|
!if(ImmScalar, [ImmArg<ArgIndex<3>>], []), // ScalarOperand
|
|
!if(HasSE, [IntrHasSideEffects], []))>,
|
|
RISCVVIntrinsic {
|
|
let ScalarOperand = !if(ImmScalar, NoScalarOperand, 3);
|
|
let VLOperand = 4;
|
|
}
|
|
|
|
multiclass RISCVSFCustomVC_X<list<string> type> {
|
|
foreach t = type in {
|
|
defvar ImmScalar = !eq(t, "i");
|
|
def "int_riscv_sf_vc_" # t # "_se" : RISCVSFCustomVC_X_WO_Suffix<ImmScalar=ImmScalar>;
|
|
def "int_riscv_sf_vc_v_" # t # "_se" : RISCVSFCustomVC_X<HasSE=1, ImmScalar=ImmScalar>;
|
|
def "int_riscv_sf_vc_v_" # t : RISCVSFCustomVC_X<HasSE=0, ImmScalar=ImmScalar>;
|
|
}
|
|
}
|
|
|
|
multiclass RISCVSFCustomVC_XV<list<string> type> {
|
|
foreach t = type in {
|
|
defvar ImmScalar = !eq(t, "i");
|
|
def "int_riscv_sf_vc_" # t # "v_se" : RISCVSFCustomVC_XV<HasDst=0, HasSE=1, ImmScalar=ImmScalar>;
|
|
def "int_riscv_sf_vc_v_" # t # "v_se" : RISCVSFCustomVC_XV<HasDst=1, HasSE=1, ImmScalar=ImmScalar>;
|
|
def "int_riscv_sf_vc_v_" # t # "v" : RISCVSFCustomVC_XV<HasDst=1, HasSE=0, ImmScalar=ImmScalar>;
|
|
}
|
|
}
|
|
|
|
multiclass RISCVSFCustomVC_XVV<list<string> type> {
|
|
foreach t = type in {
|
|
defvar ImmScalar = !eq(t, "i");
|
|
def "int_riscv_sf_vc_" # t # "vv_se" : RISCVSFCustomVC_XVV<HasDst=0, HasSE=1, ImmScalar=ImmScalar>;
|
|
def "int_riscv_sf_vc_v_" # t # "vv_se" : RISCVSFCustomVC_XVV<HasDst=1, HasSE=1, ImmScalar=ImmScalar>;
|
|
def "int_riscv_sf_vc_v_" # t # "vv" : RISCVSFCustomVC_XVV<HasDst=1, HasSE=0, ImmScalar=ImmScalar>;
|
|
}
|
|
}
|
|
|
|
multiclass RISCVSFCustomVC_XVW<list<string> type> {
|
|
foreach t = type in {
|
|
defvar ImmScalar = !eq(t, "i");
|
|
def "int_riscv_sf_vc_" # t # "vw_se" : RISCVSFCustomVC_XVW<HasDst=0, HasSE=1, ImmScalar=ImmScalar>;
|
|
def "int_riscv_sf_vc_v_" # t # "vw_se" : RISCVSFCustomVC_XVW<HasDst=1, HasSE=1, ImmScalar=ImmScalar>;
|
|
def "int_riscv_sf_vc_v_" # t # "vw" : RISCVSFCustomVC_XVW<HasDst=1, HasSE=0, ImmScalar=ImmScalar>;
|
|
}
|
|
}
|
|
|
|
class RISCVSFCustomVMACC
|
|
: DefaultAttrsIntrinsic< [llvm_anyvector_ty],
|
|
[LLVMMatchType<0>, llvm_anyvector_ty, llvm_anyvector_ty,
|
|
llvm_anyint_ty, LLVMMatchType<3>],
|
|
[ImmArg<ArgIndex<4>>, IntrNoMem] >, RISCVVIntrinsic {
|
|
let VLOperand = 3;
|
|
}
|
|
|
|
// Input: (passthru, vector_in, scalar_in, frm, vl)
|
|
class RISCVSFCustomVFNRCLIPUnMasked
|
|
: DefaultAttrsIntrinsic<[llvm_anyvector_ty],
|
|
[LLVMMatchType<0>, llvm_anyfloat_ty, LLVMVectorElementType<1>,
|
|
llvm_anyint_ty, LLVMMatchType<2>],
|
|
[ImmArg<ArgIndex<3>>, IntrNoMem]>, RISCVVIntrinsic {
|
|
let VLOperand = 4;
|
|
}
|
|
|
|
// Input: (maskedoff, vector_in, vector_in/scalar_in, mask, frm, vl, policy)
|
|
class RISCVSFCustomVFNRCLIPMasked
|
|
: DefaultAttrsIntrinsic<[llvm_anyvector_ty],
|
|
[LLVMMatchType<0>, llvm_anyfloat_ty, LLVMVectorElementType<1>,
|
|
LLVMScalarOrSameVectorWidth<0, llvm_i1_ty>, llvm_anyint_ty,
|
|
LLVMMatchType<2>, LLVMMatchType<2>],
|
|
[ImmArg<ArgIndex<4>>, ImmArg<ArgIndex<6>>, IntrNoMem]>, RISCVVIntrinsic {
|
|
let VLOperand = 5;
|
|
}
|
|
|
|
multiclass RISCVSFCustomVFNRCLIP {
|
|
def NAME : RISCVSFCustomVFNRCLIPUnMasked;
|
|
def NAME # "_mask" : RISCVSFCustomVFNRCLIPMasked;
|
|
}
|
|
|
|
defm "" : RISCVSFCustomVC_X<["x", "i"]>;
|
|
defm "" : RISCVSFCustomVC_XV<["x", "i", "v", "f"]>;
|
|
defm "" : RISCVSFCustomVC_XVV<["x", "i", "v", "f"]>;
|
|
defm "" : RISCVSFCustomVC_XVW<["x", "i", "v", "f"]>;
|
|
|
|
// XSfvqmaccdod
|
|
def int_riscv_sf_vqmaccu_2x8x2 : RISCVSFCustomVMACC;
|
|
def int_riscv_sf_vqmacc_2x8x2 : RISCVSFCustomVMACC;
|
|
def int_riscv_sf_vqmaccus_2x8x2 : RISCVSFCustomVMACC;
|
|
def int_riscv_sf_vqmaccsu_2x8x2 : RISCVSFCustomVMACC;
|
|
|
|
// XSfvqmaccqoq
|
|
def int_riscv_sf_vqmaccu_4x8x4 : RISCVSFCustomVMACC;
|
|
def int_riscv_sf_vqmacc_4x8x4 : RISCVSFCustomVMACC;
|
|
def int_riscv_sf_vqmaccus_4x8x4 : RISCVSFCustomVMACC;
|
|
def int_riscv_sf_vqmaccsu_4x8x4 : RISCVSFCustomVMACC;
|
|
|
|
// XSfvfwmaccqqq
|
|
def int_riscv_sf_vfwmacc_4x4x4 : RISCVSFCustomVMACC;
|
|
|
|
// XSfvfnrclipxfqf
|
|
defm int_riscv_sf_vfnrclip_x_f_qf : RISCVSFCustomVFNRCLIP;
|
|
defm int_riscv_sf_vfnrclip_xu_f_qf : RISCVSFCustomVFNRCLIP;
|
|
} // TargetPrefix = "riscv"
|