[PATCH] D129147: [llvm][AArch64] Fix "+all" feature for sysreg aliases
David Spickett via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Jul 5 09:17:33 PDT 2022
DavidSpickett created this revision.
Herald added subscribers: jeroen.dobbelaere, hiraditya, kristof.beyls.
Herald added a project: All.
DavidSpickett requested review of this revision.
Herald added a project: LLVM.
Herald added a subscriber: llvm-commits.
For example the predres extension adds one instruction that
is a sys alias. Previously this wasn't disassembled properly
with "+all".
This was because a check for "+all" was added to haveFeatures
in AArch64SysReg but not in SysAlias.
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D129147
Files:
llvm/lib/Target/AArch64/Utils/AArch64BaseInfo.h
llvm/test/MC/Disassembler/AArch64/mattr-all.txt
Index: llvm/test/MC/Disassembler/AArch64/mattr-all.txt
===================================================================
--- llvm/test/MC/Disassembler/AArch64/mattr-all.txt
+++ llvm/test/MC/Disassembler/AArch64/mattr-all.txt
@@ -35,3 +35,7 @@
## armv9a rme
# CHECK: mrs x0, MFAR_EL3
[0xa0,0x60,0x3e,0xd5]
+
+## predres (to make sure sysreg aliases work)
+# CHECK: cfp rctx, x0
+[0x80,0x73,0x0b,0xd5]
Index: llvm/lib/Target/AArch64/Utils/AArch64BaseInfo.h
===================================================================
--- llvm/lib/Target/AArch64/Utils/AArch64BaseInfo.h
+++ llvm/lib/Target/AArch64/Utils/AArch64BaseInfo.h
@@ -343,7 +343,8 @@
: Name(N), Encoding(E), FeaturesRequired(F) {}
bool haveFeatures(FeatureBitset ActiveFeatures) const {
- return (FeaturesRequired & ActiveFeatures) == FeaturesRequired;
+ return ActiveFeatures[llvm::AArch64::FeatureAll] ||
+ (FeaturesRequired & ActiveFeatures) == FeaturesRequired;
}
FeatureBitset getRequiredFeatures() const { return FeaturesRequired; }
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D129147.442327.patch
Type: text/x-patch
Size: 1038 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20220705/8cd62c32/attachment.bin>
More information about the llvm-commits
mailing list