Skip to content

Commit

Permalink
[Clang][XTHeadVector] Implement vwadd/vwsub/vwaddu/vwsubu intrinsics (
Browse files Browse the repository at this point in the history
llvm#59)

* [Clang][XTHeadVector] Define `vwadd/vwsub`

* [Clang][XTHeadVector] Tes `vwadd/vwsub`

* [Clang][XTHeadVector] Tes `vwadd/vwsub` wrappers
  • Loading branch information
imkiva committed Apr 1, 2024
1 parent dfba0d8 commit 7da7b66
Show file tree
Hide file tree
Showing 10 changed files with 3,443 additions and 3 deletions.
75 changes: 72 additions & 3 deletions clang/include/clang/Basic/riscv_vector_xtheadv.td
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,11 @@ class RVVOutOp1Builtin<string suffix, string prototype, string type_range>
let IntrinsicTypes = [-1, 1];
}

class RVVOutOp0Op1Builtin<string suffix, string prototype, string type_range>
: RVVBuiltin<suffix, prototype, type_range> {
let IntrinsicTypes = [-1, 0, 1];
}

multiclass RVVBuiltinSet<string intrinsic_name, string type_range,
list<list<string>> suffixes_prototypes,
list<int> intrinsic_types> {
Expand Down Expand Up @@ -58,6 +63,56 @@ multiclass RVVIntBinBuiltinSet
: RVVSignedBinBuiltinSet,
RVVUnsignedBinBuiltinSet;

multiclass RVVWidenBuiltinSet<string intrinsic_name, string type_range,
list<list<string>> suffixes_prototypes> {
let Log2LMUL = [-3, -2, -1, 0, 1, 2],
IRName = intrinsic_name, MaskedIRName = intrinsic_name # "_mask" in {
foreach s_p = suffixes_prototypes in {
let Name = NAME # "_" # s_p[0],
OverloadedName = NAME # "_" # s_p[0] in {
defvar suffix = s_p[1];
defvar prototype = s_p[2];
def : RVVOutOp0Op1Builtin<suffix, prototype, type_range>;
}
}
}
}

multiclass RVVWidenWOp0BuiltinSet<string intrinsic_name, string type_range,
list<list<string>> suffixes_prototypes> {
let Log2LMUL = [-3, -2, -1, 0, 1, 2],
IRName = intrinsic_name, MaskedIRName = intrinsic_name # "_mask" in {
foreach s_p = suffixes_prototypes in {
let Name = NAME # "_" # s_p[0],
OverloadedName = NAME # "_" # s_p[0] in {
defvar suffix = s_p[1];
defvar prototype = s_p[2];
def : RVVOutOp1Builtin<suffix, prototype, type_range>;
}
}
}
}

multiclass RVVUnsignedWidenBinBuiltinSet
: RVVWidenBuiltinSet<NAME, "csi",
[["vv", "Uw", "UwUvUv"],
["vx", "Uw", "UwUvUe"]]>;

multiclass RVVSignedWidenBinBuiltinSet
: RVVWidenBuiltinSet<NAME, "csi",
[["vv", "w", "wvv"],
["vx", "w", "wve"]]>;

multiclass RVVUnsignedWidenOp0BinBuiltinSet
: RVVWidenWOp0BuiltinSet<NAME # "_w", "csi",
[["wv", "Uw", "UwUwUv"],
["wx", "Uw", "UwUwUe"]]>;

multiclass RVVSignedWidenOp0BinBuiltinSet
: RVVWidenWOp0BuiltinSet<NAME # "_w", "csi",
[["wv", "w", "wwv"],
["wx", "w", "wwe"]]>;

defvar NFList = [2, 3, 4, 5, 6, 7, 8];
defvar TypeList = ["c", "s", "i", "l", "x", "f", "d"];
defvar EEWList = [["8", "(Log2EEW:3)"],
Expand Down Expand Up @@ -781,10 +836,10 @@ let UnMaskedPolicyScheme = NonePolicy,
// 12. Vector Integer Arithmetic Operations
//===----------------------------------------------------------------------===//

multiclass RVVPseudoUnaryBuiltin<string IR, string type_range> {
multiclass RVVPseudoUnaryBuiltin<string ir, string type_range> {
let Name = NAME,
IRName = IR,
MaskedIRName = IR # "_mask",
IRName = ir,
MaskedIRName = ir # "_mask",
UnMaskedPolicyScheme = HasPassthruOperand,
ManualCodegen = [{
{
Expand Down Expand Up @@ -815,6 +870,7 @@ multiclass RVVPseudoUnaryBuiltin<string IR, string type_range> {
}
}

// 12.1. Vector Single-Width Integer Add and Subtract
let UnMaskedPolicyScheme = HasPassthruOperand in {
defm th_vadd : RVVIntBinBuiltinSet;
defm th_vsub : RVVIntBinBuiltinSet;
Expand All @@ -824,4 +880,17 @@ let UnMaskedPolicyScheme = HasPassthruOperand in {
}
defm th_vneg_v : RVVPseudoUnaryBuiltin<"th_vrsub", "csil">;

// 12.2. Vector Widening Integer Add/Subtract Operations
let UnMaskedPolicyScheme = HasPassthruOperand in {
defm th_vwaddu : RVVUnsignedWidenBinBuiltinSet;
defm th_vwaddu : RVVUnsignedWidenOp0BinBuiltinSet;
defm th_vwsubu : RVVUnsignedWidenBinBuiltinSet;
defm th_vwsubu : RVVUnsignedWidenOp0BinBuiltinSet;
defm th_vwadd : RVVSignedWidenBinBuiltinSet;
defm th_vwadd : RVVSignedWidenOp0BinBuiltinSet;
defm th_vwsub : RVVSignedWidenBinBuiltinSet;
defm th_vwsub : RVVSignedWidenOp0BinBuiltinSet;
}


include "riscv_vector_xtheadv_wrappers.td"
203 changes: 203 additions & 0 deletions clang/include/clang/Basic/riscv_vector_xtheadv_wrappers.td

Large diffs are not rendered by default.

Large diffs are not rendered by default.

Large diffs are not rendered by default.

Large diffs are not rendered by default.

Large diffs are not rendered by default.

Large diffs are not rendered by default.

Large diffs are not rendered by default.

Large diffs are not rendered by default.

Large diffs are not rendered by default.

0 comments on commit 7da7b66

Please sign in to comment.