Skip to content

Commit

Permalink
[RISCV] Allow crypto features to imply dependents
Browse files Browse the repository at this point in the history
  • Loading branch information
workingjubilee committed Oct 25, 2024
1 parent 47e6d18 commit e71598e
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 62 deletions.
27 changes: 18 additions & 9 deletions llvm/lib/Target/RISCV/RISCVFeatures.td
Original file line number Diff line number Diff line change
Expand Up @@ -733,7 +733,8 @@ def HasStdExtZfhOrZvfh

def FeatureStdExtZvkb
: RISCVExtension<"zvkb", 1, 0,
"'Zvkb' (Vector Bit-manipulation used in Cryptography)">,
"'Zvkb' (Vector Bit-manipulation used in Cryptography)",
[FeatureStdExtZve32x]>,
RISCVExtensionBitmask<0, 52>;
def HasStdExtZvkb : Predicate<"Subtarget->hasStdExtZvkb()">,
AssemblerPredicate<(all_of FeatureStdExtZvkb),
Expand All @@ -750,23 +751,26 @@ def HasStdExtZvbb : Predicate<"Subtarget->hasStdExtZvbb()">,

def FeatureStdExtZvbc
: RISCVExtension<"zvbc", 1, 0,
"'Zvbc' (Vector Carryless Multiplication)">,
"'Zvbc' (Vector Carryless Multiplication)",
[FeatureStdExtZve64x]>,
RISCVExtensionBitmask<0, 49>;
def HasStdExtZvbc : Predicate<"Subtarget->hasStdExtZvbc()">,
AssemblerPredicate<(all_of FeatureStdExtZvbc),
"'Zvbc' (Vector Carryless Multiplication)">;

def FeatureStdExtZvbc32e
: RISCVExperimentalExtension<"zvbc32e", 0, 7,
"'Zvbc32e' (Vector Carryless Multiplication with 32-bits elements)">;
"'Zvbc32e' (Vector Carryless Multiplication with 32-bits elements)",
[FeatureStdExtZve32x]>;

def HasStdExtZvbcOrZvbc32e : Predicate<"Subtarget->hasStdExtZvbc() || Subtarget->hasStdExtZvbc32e()">,
AssemblerPredicate<(any_of FeatureStdExtZvbc, FeatureStdExtZvbc32e),
"'Zvbc' or 'Zvbc32e' (Vector Carryless Multiplication)">;

def FeatureStdExtZvkg
: RISCVExtension<"zvkg", 1, 0,
"'Zvkg' (Vector GCM instructions for Cryptography)">,
"'Zvkg' (Vector GCM instructions for Cryptography)",
[FeatureStdExtZve32x]>,
RISCVExtensionBitmask<0, 53>;
def HasStdExtZvkg : Predicate<"Subtarget->hasStdExtZvkg()">,
AssemblerPredicate<(all_of FeatureStdExtZvkg),
Expand All @@ -782,23 +786,26 @@ def HasStdExtZvkgs : Predicate<"Subtarget->hasStdExtZvkgs()">,

def FeatureStdExtZvkned
: RISCVExtension<"zvkned", 1, 0,
"'Zvkned' (Vector AES Encryption & Decryption (Single Round))">,
"'Zvkned' (Vector AES Encryption & Decryption (Single Round))",
[FeatureStdExtZve32x]>,
RISCVExtensionBitmask<0, 54>;
def HasStdExtZvkned : Predicate<"Subtarget->hasStdExtZvkned()">,
AssemblerPredicate<(all_of FeatureStdExtZvkned),
"'Zvkned' (Vector AES Encryption & Decryption (Single Round))">;

def FeatureStdExtZvknha
: RISCVExtension<"zvknha", 1, 0,
"'Zvknha' (Vector SHA-2 (SHA-256 only))">,
"'Zvknha' (Vector SHA-2 (SHA-256 only))",
[FeatureStdExtZve32x]>,
RISCVExtensionBitmask<0, 55>;
def HasStdExtZvknha : Predicate<"Subtarget->hasStdExtZvknha()">,
AssemblerPredicate<(all_of FeatureStdExtZvknha),
"'Zvknha' (Vector SHA-2 (SHA-256 only))">;

def FeatureStdExtZvknhb
: RISCVExtension<"zvknhb", 1, 0,
"'Zvknhb' (Vector SHA-2 (SHA-256 and SHA-512))">,
"'Zvknhb' (Vector SHA-2 (SHA-256 and SHA-512))",
[FeatureStdExtZve64x]>,
RISCVExtensionBitmask<0, 56>;
def HasStdExtZvknhb : Predicate<"Subtarget->hasStdExtZvknhb()">,
AssemblerPredicate<(all_of FeatureStdExtZvknhb),
Expand All @@ -810,15 +817,17 @@ def HasStdExtZvknhaOrZvknhb : Predicate<"Subtarget->hasStdExtZvknha() || Subtarg

def FeatureStdExtZvksed
: RISCVExtension<"zvksed", 1, 0,
"'Zvksed' (SM4 Block Cipher Instructions)">,
"'Zvksed' (SM4 Block Cipher Instructions)",
[FeatureStdExtZve32x]>,
RISCVExtensionBitmask<0, 57>;
def HasStdExtZvksed : Predicate<"Subtarget->hasStdExtZvksed()">,
AssemblerPredicate<(all_of FeatureStdExtZvksed),
"'Zvksed' (SM4 Block Cipher Instructions)">;

def FeatureStdExtZvksh
: RISCVExtension<"zvksh", 1, 0,
"'Zvksh' (SM3 Hash Function Instructions)">,
"'Zvksh' (SM3 Hash Function Instructions)",
[FeatureStdExtZve32x]>,
RISCVExtensionBitmask<0, 58>;
def HasStdExtZvksh : Predicate<"Subtarget->hasStdExtZvksh()">,
AssemblerPredicate<(all_of FeatureStdExtZvksh),
Expand Down
60 changes: 7 additions & 53 deletions llvm/unittests/TargetParser/RISCVISAInfoTest.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -643,60 +643,14 @@ TEST(ParseArchString, MissingDepency) {
"'zvl*b' requires 'v' or 'zve*' extension to also be specified");
}

for (StringRef Input : {"rv32i_zvbb"}) {
// These all have an implication relationship, thus should pass
for (StringRef Input : {
"rv32i_zvbb", "rv32i_zvbc32e0p7", "rv32i_zvbc", "rv32i_zvkb", "rv32i_zvkg",
"rv32i_zvkgs0p7", "rv32i_zvkned", "rv32i_zvknha", "rv32i_zvksed",
"rv32i_zvksh", "rv32i_zvknhb",
}) {
EXPECT_EQ(toString(RISCVISAInfo::parseArchString(Input, true).takeError()),
"'zvbb' requires 'v' or 'zve*' extension to also be specified");
}

for (StringRef Input : {"rv32i_zvbc32e0p7"}) {
EXPECT_EQ(toString(RISCVISAInfo::parseArchString(Input, true).takeError()),
"'zvbc32e' requires 'v' or 'zve*' extension to also be specified");
}

for (StringRef Input : {"rv32i_zvbc"}) {
EXPECT_EQ(toString(RISCVISAInfo::parseArchString(Input, true).takeError()),
"'zvbc' requires 'v' or 'zve64*' extension to also be specified");
}

for (StringRef Input : {"rv32i_zvkb"}) {
EXPECT_EQ(toString(RISCVISAInfo::parseArchString(Input, true).takeError()),
"'zvkb' requires 'v' or 'zve*' extension to also be specified");
}

for (StringRef Input : {"rv32i_zvkg"}) {
EXPECT_EQ(toString(RISCVISAInfo::parseArchString(Input, true).takeError()),
"'zvkg' requires 'v' or 'zve*' extension to also be specified");
}

for (StringRef Input : {"rv32i_zvkgs0p7"}) {
EXPECT_EQ(toString(RISCVISAInfo::parseArchString(Input, true).takeError()),
"'zvkg' requires 'v' or 'zve*' extension to also be specified");
}

for (StringRef Input : {"rv32i_zvkned"}) {
EXPECT_EQ(toString(RISCVISAInfo::parseArchString(Input, true).takeError()),
"'zvkned' requires 'v' or 'zve*' extension to also be specified");
}

for (StringRef Input : {"rv32i_zvknha"}) {
EXPECT_EQ(toString(RISCVISAInfo::parseArchString(Input, true).takeError()),
"'zvknha' requires 'v' or 'zve*' extension to also be specified");
}

for (StringRef Input : {"rv32i_zvksed"}) {
EXPECT_EQ(toString(RISCVISAInfo::parseArchString(Input, true).takeError()),
"'zvksed' requires 'v' or 'zve*' extension to also be specified");
}

for (StringRef Input : {"rv32i_zvksh"}) {
EXPECT_EQ(toString(RISCVISAInfo::parseArchString(Input, true).takeError()),
"'zvksh' requires 'v' or 'zve*' extension to also be specified");
}

for (StringRef Input : {"rv32i_zvknhb"}) {
EXPECT_EQ(
toString(RISCVISAInfo::parseArchString(Input, true).takeError()),
"'zvknhb' requires 'v' or 'zve64*' extension to also be specified");
"");
}

for (StringRef Input : {"rv32i_zacas1p0"}) {
Expand Down

0 comments on commit e71598e

Please sign in to comment.