forked from OSchip/llvm-project
[RISCV] Remove references to 'B' extension from AssemblerPredicate and SubtargetFeature strings.
For Zba/Zbb/Zbc/Zbs I've removed the 'B' completely and used the extension names as presented at the start of Chapter 1 of the 1.0.0 Bitmanipulation spec. For the unratified extensions, I've replaced 'B' with 'Zb' and otherwise left them unchanged. Reviewed By: asb Differential Revision: https://reviews.llvm.org/D117822
This commit is contained in:
parent
4691f00a63
commit
b3d94b199c
|
@ -66,82 +66,82 @@ def HasStdExtC : Predicate<"Subtarget->hasStdExtC()">,
|
||||||
|
|
||||||
def FeatureStdExtZba
|
def FeatureStdExtZba
|
||||||
: SubtargetFeature<"zba", "HasStdExtZba", "true",
|
: SubtargetFeature<"zba", "HasStdExtZba", "true",
|
||||||
"'Zba' (Address calculation 'B' Instructions)">;
|
"'Zba' (Address Generation Instructions)">;
|
||||||
def HasStdExtZba : Predicate<"Subtarget->hasStdExtZba()">,
|
def HasStdExtZba : Predicate<"Subtarget->hasStdExtZba()">,
|
||||||
AssemblerPredicate<(all_of FeatureStdExtZba),
|
AssemblerPredicate<(all_of FeatureStdExtZba),
|
||||||
"'Zba' (Address calculation 'B' Instructions)">;
|
"'Zba' (Address Generation Instructions)">;
|
||||||
def NotHasStdExtZba : Predicate<"!Subtarget->hasStdExtZba()">;
|
def NotHasStdExtZba : Predicate<"!Subtarget->hasStdExtZba()">;
|
||||||
|
|
||||||
def FeatureStdExtZbb
|
def FeatureStdExtZbb
|
||||||
: SubtargetFeature<"zbb", "HasStdExtZbb", "true",
|
: SubtargetFeature<"zbb", "HasStdExtZbb", "true",
|
||||||
"'Zbb' (Base 'B' Instructions)">;
|
"'Zbb' (Basic Bit-Manipulation)">;
|
||||||
def HasStdExtZbb : Predicate<"Subtarget->hasStdExtZbb()">,
|
def HasStdExtZbb : Predicate<"Subtarget->hasStdExtZbb()">,
|
||||||
AssemblerPredicate<(all_of FeatureStdExtZbb),
|
AssemblerPredicate<(all_of FeatureStdExtZbb),
|
||||||
"'Zbb' (Base 'B' Instructions)">;
|
"'Zbb' (Basic Bit-Manipulation)">;
|
||||||
|
|
||||||
def FeatureStdExtZbc
|
def FeatureStdExtZbc
|
||||||
: SubtargetFeature<"zbc", "HasStdExtZbc", "true",
|
: SubtargetFeature<"zbc", "HasStdExtZbc", "true",
|
||||||
"'Zbc' (Carry-Less 'B' Instructions)">;
|
"'Zbc' (Carry-Less Multiplication)">;
|
||||||
def HasStdExtZbc : Predicate<"Subtarget->hasStdExtZbc()">,
|
def HasStdExtZbc : Predicate<"Subtarget->hasStdExtZbc()">,
|
||||||
AssemblerPredicate<(all_of FeatureStdExtZbc),
|
AssemblerPredicate<(all_of FeatureStdExtZbc),
|
||||||
"'Zbc' (Carry-Less 'B' Instructions)">;
|
"'Zbc' (Carry-Less Multiplication)">;
|
||||||
|
|
||||||
def FeatureStdExtZbe
|
def FeatureStdExtZbe
|
||||||
: SubtargetFeature<"experimental-zbe", "HasStdExtZbe", "true",
|
: SubtargetFeature<"experimental-zbe", "HasStdExtZbe", "true",
|
||||||
"'Zbe' (Extract-Deposit 'B' Instructions)">;
|
"'Zbe' (Extract-Deposit 'Zb' Instructions)">;
|
||||||
def HasStdExtZbe : Predicate<"Subtarget->hasStdExtZbe()">,
|
def HasStdExtZbe : Predicate<"Subtarget->hasStdExtZbe()">,
|
||||||
AssemblerPredicate<(all_of FeatureStdExtZbe),
|
AssemblerPredicate<(all_of FeatureStdExtZbe),
|
||||||
"'Zbe' (Extract-Deposit 'B' Instructions)">;
|
"'Zbe' (Extract-Deposit 'Zb' Instructions)">;
|
||||||
|
|
||||||
def FeatureStdExtZbf
|
def FeatureStdExtZbf
|
||||||
: SubtargetFeature<"experimental-zbf", "HasStdExtZbf", "true",
|
: SubtargetFeature<"experimental-zbf", "HasStdExtZbf", "true",
|
||||||
"'Zbf' (Bit-Field 'B' Instructions)">;
|
"'Zbf' (Bit-Field 'Zb' Instructions)">;
|
||||||
def HasStdExtZbf : Predicate<"Subtarget->hasStdExtZbf()">,
|
def HasStdExtZbf : Predicate<"Subtarget->hasStdExtZbf()">,
|
||||||
AssemblerPredicate<(all_of FeatureStdExtZbf),
|
AssemblerPredicate<(all_of FeatureStdExtZbf),
|
||||||
"'Zbf' (Bit-Field 'B' Instructions)">;
|
"'Zbf' (Bit-Field 'Zb' Instructions)">;
|
||||||
|
|
||||||
def FeatureStdExtZbm
|
def FeatureStdExtZbm
|
||||||
: SubtargetFeature<"experimental-zbm", "HasStdExtZbm", "true",
|
: SubtargetFeature<"experimental-zbm", "HasStdExtZbm", "true",
|
||||||
"'Zbm' (Matrix 'B' Instructions)">;
|
"'Zbm' (Matrix 'Zb' Instructions)">;
|
||||||
def HasStdExtZbm : Predicate<"Subtarget->hasStdExtZbm()">,
|
def HasStdExtZbm : Predicate<"Subtarget->hasStdExtZbm()">,
|
||||||
AssemblerPredicate<(all_of FeatureStdExtZbm),
|
AssemblerPredicate<(all_of FeatureStdExtZbm),
|
||||||
"'Zbm' (Matrix 'B' Instructions)">;
|
"'Zbm' (Matrix 'Zb' Instructions)">;
|
||||||
|
|
||||||
def FeatureStdExtZbp
|
def FeatureStdExtZbp
|
||||||
: SubtargetFeature<"experimental-zbp", "HasStdExtZbp", "true",
|
: SubtargetFeature<"experimental-zbp", "HasStdExtZbp", "true",
|
||||||
"'Zbp' (Permutation 'B' Instructions)">;
|
"'Zbp' (Permutation 'Zb' Instructions)">;
|
||||||
def HasStdExtZbp : Predicate<"Subtarget->hasStdExtZbp()">,
|
def HasStdExtZbp : Predicate<"Subtarget->hasStdExtZbp()">,
|
||||||
AssemblerPredicate<(all_of FeatureStdExtZbp),
|
AssemblerPredicate<(all_of FeatureStdExtZbp),
|
||||||
"'Zbp' (Permutation 'B' Instructions)">;
|
"'Zbp' (Permutation 'Zb' Instructions)">;
|
||||||
|
|
||||||
def FeatureStdExtZbr
|
def FeatureStdExtZbr
|
||||||
: SubtargetFeature<"experimental-zbr", "HasStdExtZbr", "true",
|
: SubtargetFeature<"experimental-zbr", "HasStdExtZbr", "true",
|
||||||
"'Zbr' (Polynomial Reduction 'B' Instructions)">;
|
"'Zbr' (Polynomial Reduction 'Zb' Instructions)">;
|
||||||
def HasStdExtZbr : Predicate<"Subtarget->hasStdExtZbr()">,
|
def HasStdExtZbr : Predicate<"Subtarget->hasStdExtZbr()">,
|
||||||
AssemblerPredicate<(all_of FeatureStdExtZbr),
|
AssemblerPredicate<(all_of FeatureStdExtZbr),
|
||||||
"'Zbr' (Polynomial Reduction 'B' Instructions)">;
|
"'Zbr' (Polynomial Reduction 'Zb' Instructions)">;
|
||||||
|
|
||||||
def FeatureStdExtZbs
|
def FeatureStdExtZbs
|
||||||
: SubtargetFeature<"zbs", "HasStdExtZbs", "true",
|
: SubtargetFeature<"zbs", "HasStdExtZbs", "true",
|
||||||
"'Zbs' (Single-Bit 'B' Instructions)">;
|
"'Zbs' (Single-Bit Instructions)">;
|
||||||
def HasStdExtZbs : Predicate<"Subtarget->hasStdExtZbs()">,
|
def HasStdExtZbs : Predicate<"Subtarget->hasStdExtZbs()">,
|
||||||
AssemblerPredicate<(all_of FeatureStdExtZbs),
|
AssemblerPredicate<(all_of FeatureStdExtZbs),
|
||||||
"'Zbs' (Single-Bit 'B' Instructions)">;
|
"'Zbs' (Single-Bit Instructions)">;
|
||||||
|
|
||||||
def FeatureStdExtZbt
|
def FeatureStdExtZbt
|
||||||
: SubtargetFeature<"experimental-zbt", "HasStdExtZbt", "true",
|
: SubtargetFeature<"experimental-zbt", "HasStdExtZbt", "true",
|
||||||
"'Zbt' (Ternary 'B' Instructions)">;
|
"'Zbt' (Ternary 'Zb' Instructions)">;
|
||||||
def HasStdExtZbt : Predicate<"Subtarget->hasStdExtZbt()">,
|
def HasStdExtZbt : Predicate<"Subtarget->hasStdExtZbt()">,
|
||||||
AssemblerPredicate<(all_of FeatureStdExtZbt),
|
AssemblerPredicate<(all_of FeatureStdExtZbt),
|
||||||
"'Zbt' (Ternary 'B' Instructions)">;
|
"'Zbt' (Ternary 'Zb' Instructions)">;
|
||||||
|
|
||||||
// Some instructions belong to both the basic and the permutation
|
// Some instructions belong to both the basic and the permutation
|
||||||
// subextensions. They should be enabled if either has been specified.
|
// subextensions. They should be enabled if either has been specified.
|
||||||
def HasStdExtZbbOrZbp
|
def HasStdExtZbbOrZbp
|
||||||
: Predicate<"Subtarget->hasStdExtZbb() || Subtarget->hasStdExtZbp()">,
|
: Predicate<"Subtarget->hasStdExtZbb() || Subtarget->hasStdExtZbp()">,
|
||||||
AssemblerPredicate<(any_of FeatureStdExtZbb, FeatureStdExtZbp),
|
AssemblerPredicate<(any_of FeatureStdExtZbb, FeatureStdExtZbp),
|
||||||
"'Zbb' (Base 'B' Instructions) or "
|
"'Zbb' (Basic Bit-Manipulation) or "
|
||||||
"'Zbp' (Permutation 'B' Instructions)">;
|
"'Zbp' (Permutation 'Zb' Instructions)">;
|
||||||
|
|
||||||
def FeatureStdExtZbkb
|
def FeatureStdExtZbkb
|
||||||
: SubtargetFeature<"zbkb", "HasStdExtZbkb", "true",
|
: SubtargetFeature<"zbkb", "HasStdExtZbkb", "true",
|
||||||
|
@ -166,14 +166,14 @@ def HasStdExtZbpOrZbkx
|
||||||
def HasStdExtZbpOrZbkb
|
def HasStdExtZbpOrZbkb
|
||||||
: Predicate<"Subtarget->hasStdExtZbp() || Subtarget->hasStdExtZbkb()">,
|
: Predicate<"Subtarget->hasStdExtZbp() || Subtarget->hasStdExtZbkb()">,
|
||||||
AssemblerPredicate<(any_of FeatureStdExtZbp, FeatureStdExtZbkb),
|
AssemblerPredicate<(any_of FeatureStdExtZbp, FeatureStdExtZbkb),
|
||||||
"'Zbp' (Permutation 'B' Instructions) or "
|
"'Zbp' (Permutation 'Zb' Instructions) or "
|
||||||
"'Zbkb' (Bitmanip instructions for Cryptography)">;
|
"'Zbkb' (Bitmanip instructions for Cryptography)">;
|
||||||
|
|
||||||
def HasStdExtZbbOrZbpOrZbkb
|
def HasStdExtZbbOrZbpOrZbkb
|
||||||
: Predicate<"Subtarget->hasStdExtZbb() || Subtarget->hasStdExtZbp() || Subtarget->hasStdExtZbkb()">,
|
: Predicate<"Subtarget->hasStdExtZbb() || Subtarget->hasStdExtZbp() || Subtarget->hasStdExtZbkb()">,
|
||||||
AssemblerPredicate<(any_of FeatureStdExtZbb, FeatureStdExtZbp, FeatureStdExtZbkb),
|
AssemblerPredicate<(any_of FeatureStdExtZbb, FeatureStdExtZbp, FeatureStdExtZbkb),
|
||||||
"'Zbb' (Base 'B' Instructions) or "
|
"'Zbb' (Basic Bit-Manipulation) or "
|
||||||
"'Zbp' (Permutation 'B' Instructions) or "
|
"'Zbp' (Permutation 'Zb' Instructions) or "
|
||||||
"'Zbkb' (Bitmanip instructions for Cryptography)">;
|
"'Zbkb' (Bitmanip instructions for Cryptography)">;
|
||||||
|
|
||||||
// The Carry-less multiply subextension for cryptography is a subset of basic carry-less multiply subextension. The former should be enabled if the latter is enabled.
|
// The Carry-less multiply subextension for cryptography is a subset of basic carry-less multiply subextension. The former should be enabled if the latter is enabled.
|
||||||
|
@ -188,7 +188,7 @@ def HasStdExtZbkc
|
||||||
def HasStdExtZbcOrZbkc
|
def HasStdExtZbcOrZbkc
|
||||||
: Predicate<"Subtarget->hasStdExtZbc() || Subtarget->hasStdExtZbkc()">,
|
: Predicate<"Subtarget->hasStdExtZbc() || Subtarget->hasStdExtZbkc()">,
|
||||||
AssemblerPredicate<(any_of FeatureStdExtZbc, FeatureStdExtZbkc),
|
AssemblerPredicate<(any_of FeatureStdExtZbc, FeatureStdExtZbkc),
|
||||||
"'Zbc' (Carry-Less 'B' Instructions) or "
|
"'Zbc' (Carry-Less Multiplication) or "
|
||||||
"'Zbkc' (Carry-less multiply instructions for Cryptography)">;
|
"'Zbkc' (Carry-less multiply instructions for Cryptography)">;
|
||||||
|
|
||||||
def FeatureStdExtZknd
|
def FeatureStdExtZknd
|
||||||
|
|
|
@ -173,6 +173,10 @@ mul a4, ra, s0 # CHECK: :[[@LINE]]:1: error: instruction requires the following:
|
||||||
amomaxu.w s5, s4, (s3) # CHECK: :[[@LINE]]:1: error: instruction requires the following: 'A' (Atomic Instructions)
|
amomaxu.w s5, s4, (s3) # CHECK: :[[@LINE]]:1: error: instruction requires the following: 'A' (Atomic Instructions)
|
||||||
fadd.s ft0, ft1, ft2 # CHECK: :[[@LINE]]:1: error: instruction requires the following: 'F' (Single-Precision Floating-Point)
|
fadd.s ft0, ft1, ft2 # CHECK: :[[@LINE]]:1: error: instruction requires the following: 'F' (Single-Precision Floating-Point)
|
||||||
fadd.h ft0, ft1, ft2 # CHECK: :[[@LINE]]:1: error: instruction requires the following: 'Zfh' (Half-Precision Floating-Point)
|
fadd.h ft0, ft1, ft2 # CHECK: :[[@LINE]]:1: error: instruction requires the following: 'Zfh' (Half-Precision Floating-Point)
|
||||||
|
sh1add a0, a1, a2 # CHECK: :[[@LINE]]:1: error: instruction requires the following: 'Zba' (Address Generation Instructions)
|
||||||
|
clz a0, a1 # CHECK: :[[@LINE]]:1: error: instruction requires the following: 'Zbb' (Basic Bit-Manipulation)
|
||||||
|
clmul a0, a1, a2 # CHECK: :[[@LINE]]:1: error: instruction requires the following: 'Zbc' (Carry-Less Multiplication)
|
||||||
|
bset a0, a1, a2 # CHECK: :[[@LINE]]:1: error: instruction requires the following: 'Zbs' (Single-Bit Instructions)
|
||||||
|
|
||||||
# Using floating point registers when integer registers are expected
|
# Using floating point registers when integer registers are expected
|
||||||
addi a2, ft0, 24 # CHECK: :[[@LINE]]:10: error: invalid operand for instruction
|
addi a2, ft0, 24 # CHECK: :[[@LINE]]:10: error: invalid operand for instruction
|
||||||
|
|
|
@ -6,4 +6,4 @@ clmul t0, t1 # CHECK: :[[@LINE]]:1: error: too few operands for instruction
|
||||||
clmulh t0, t1 # CHECK: :[[@LINE]]:1: error: too few operands for instruction
|
clmulh t0, t1 # CHECK: :[[@LINE]]:1: error: too few operands for instruction
|
||||||
|
|
||||||
# Undefined zbc instruction in zbkc
|
# Undefined zbc instruction in zbkc
|
||||||
clmulr t0, t1, t2 # CHECK: :[[@LINE]]:1: error: instruction requires the following: 'Zbc' (Carry-Less 'B' Instructions)
|
clmulr t0, t1, t2 # CHECK: :[[@LINE]]:1: error: instruction requires the following: 'Zbc' (Carry-Less Multiplication)
|
||||||
|
|
|
@ -6,4 +6,4 @@ xperm8 t0, t1 # CHECK: :[[@LINE]]:1: error: too few operands for instruction
|
||||||
xperm4 t0, t1 # CHECK: :[[@LINE]]:1: error: too few operands for instruction
|
xperm4 t0, t1 # CHECK: :[[@LINE]]:1: error: too few operands for instruction
|
||||||
|
|
||||||
# Undefined Zbp instruction in Zbkx
|
# Undefined Zbp instruction in Zbkx
|
||||||
xperm.h t0, t1, t2 # CHECK: :[[@LINE]]:1: error: instruction requires the following: 'Zbp' (Permutation 'B' Instructions)
|
xperm.h t0, t1, t2 # CHECK: :[[@LINE]]:1: error: instruction requires the following: 'Zbp' (Permutation 'Zb' Instructions)
|
||||||
|
|
Loading…
Reference in New Issue