summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/MC/MCSubtargetInfo.cpp12
1 files changed, 12 insertions, 0 deletions
diff --git a/llvm/lib/MC/MCSubtargetInfo.cpp b/llvm/lib/MC/MCSubtargetInfo.cpp
index 385cdcc6232..bf7a10c285f 100644
--- a/llvm/lib/MC/MCSubtargetInfo.cpp
+++ b/llvm/lib/MC/MCSubtargetInfo.cpp
@@ -75,6 +75,18 @@ FeatureBitset MCSubtargetInfo::ApplyFeatureFlag(StringRef FS) {
return FeatureBits;
}
+bool MCSubtargetInfo::checkFeatures(StringRef FS) const {
+ SubtargetFeatures T(FS);
+ FeatureBitset Set, All;
+ for (std::string F : T.getFeatures()) {
+ SubtargetFeatures::ApplyFeatureFlag(Set, F, ProcFeatures);
+ if (F[0] == '-')
+ F[0] = '+';
+ SubtargetFeatures::ApplyFeatureFlag(All, F, ProcFeatures);
+ }
+ return (FeatureBits & All) == Set;
+}
+
const MCSchedModel &MCSubtargetInfo::getSchedModelForCPU(StringRef CPU) const {
assert(ProcSchedModels && "Processor machine model not available!");
OpenPOWER on IntegriCloud