[llvm] 35651fd - [IR] Add AttributeBitSet wrapper (NFC)
Nikita Popov via llvm-commits
llvm-commits at lists.llvm.org
Mon Jun 15 12:28:35 PDT 2020
Author: Nikita Popov
Date: 2020-06-15T21:28:25+02:00
New Revision: 35651fdd4537c081ca47acde58b6fd4b5f6997b3
URL: https://github.com/llvm/llvm-project/commit/35651fdd4537c081ca47acde58b6fd4b5f6997b3
DIFF: https://github.com/llvm/llvm-project/commit/35651fdd4537c081ca47acde58b6fd4b5f6997b3.diff
LOG: [IR] Add AttributeBitSet wrapper (NFC)
This wraps the uint8_t[12] type used in two places, because I
plan to introduce a third use of the same pattern.
Added:
Modified:
llvm/lib/IR/AttributeImpl.h
llvm/lib/IR/Attributes.cpp
Removed:
################################################################################
diff --git a/llvm/lib/IR/AttributeImpl.h b/llvm/lib/IR/AttributeImpl.h
index 1306c81adf4f..6aca780e3e5d 100644
--- a/llvm/lib/IR/AttributeImpl.h
+++ b/llvm/lib/IR/AttributeImpl.h
@@ -185,6 +185,22 @@ class TypeAttributeImpl : public EnumAttributeImpl {
Type *getTypeValue() const { return Ty; }
};
+class AttributeBitSet {
+ /// Bitset with a bit for each available attribute Attribute::AttrKind.
+ uint8_t AvailableAttrs[12] = {};
+ static_assert(Attribute::EndAttrKinds <= sizeof(AvailableAttrs) * CHAR_BIT,
+ "Too many attributes");
+
+public:
+ bool hasAttribute(Attribute::AttrKind Kind) const {
+ return AvailableAttrs[Kind / 8] & ((uint64_t)1) << (Kind % 8);
+ }
+
+ void addAttribute(Attribute::AttrKind Kind) {
+ AvailableAttrs[Kind / 8] |= 1ULL << (Kind % 8);
+ }
+};
+
//===----------------------------------------------------------------------===//
/// \class
/// This class represents a group of attributes that apply to one
@@ -195,8 +211,7 @@ class AttributeSetNode final
friend TrailingObjects;
unsigned NumAttrs; ///< Number of attributes in this node.
- /// Bitset with a bit for each available attribute Attribute::AttrKind.
- uint8_t AvailableAttrs[12] = {};
+ AttributeBitSet AvailableAttrs; ///< Available enum attributes.
DenseMap<StringRef, Attribute> StringAttrs;
@@ -221,7 +236,7 @@ class AttributeSetNode final
unsigned getNumAttributes() const { return NumAttrs; }
bool hasAttribute(Attribute::AttrKind Kind) const {
- return AvailableAttrs[Kind / 8] & ((uint64_t)1) << (Kind % 8);
+ return AvailableAttrs.hasAttribute(Kind);
}
bool hasAttribute(StringRef Kind) const;
bool hasAttributes() const { return NumAttrs != 0; }
@@ -265,8 +280,8 @@ class AttributeListImpl final
private:
unsigned NumAttrSets; ///< Number of entries in this set.
- /// Bitset with a bit for each available attribute Attribute::AttrKind.
- uint8_t AvailableFunctionAttrs[12] = {};
+ /// Available enum function attributes.
+ AttributeBitSet AvailableFunctionAttrs;
// Helper fn for TrailingObjects class.
size_t numTrailingObjects(OverloadToken<AttributeSet>) { return NumAttrSets; }
@@ -281,7 +296,7 @@ class AttributeListImpl final
/// Return true if the AttributeSet or the FunctionIndex has an
/// enum attribute of the given kind.
bool hasFnAttribute(Attribute::AttrKind Kind) const {
- return AvailableFunctionAttrs[Kind / 8] & ((uint64_t)1) << (Kind % 8);
+ return AvailableFunctionAttrs.hasAttribute(Kind);
}
using iterator = const AttributeSet *;
diff --git a/llvm/lib/IR/Attributes.cpp b/llvm/lib/IR/Attributes.cpp
index 191668dacc18..d8798eb12ae7 100644
--- a/llvm/lib/IR/Attributes.cpp
+++ b/llvm/lib/IR/Attributes.cpp
@@ -780,17 +780,11 @@ AttributeSetNode::AttributeSetNode(ArrayRef<Attribute> Attrs)
// There's memory after the node where we can store the entries in.
llvm::copy(Attrs, getTrailingObjects<Attribute>());
- static_assert(Attribute::EndAttrKinds <=
- sizeof(AvailableAttrs) * CHAR_BIT,
- "Too many attributes");
-
for (const auto &I : *this) {
- if (I.isStringAttribute()) {
+ if (I.isStringAttribute())
StringAttrs.insert({ I.getKindAsString(), I });
- } else {
- Attribute::AttrKind Kind = I.getKindAsEnum();
- AvailableAttrs[Kind / 8] |= 1ULL << (Kind % 8);
- }
+ else
+ AvailableAttrs.addAttribute(I.getKindAsEnum());
}
}
@@ -986,16 +980,11 @@ AttributeListImpl::AttributeListImpl(ArrayRef<AttributeSet> Sets)
llvm::copy(Sets, getTrailingObjects<AttributeSet>());
// Initialize AvailableFunctionAttrs summary bitset.
- static_assert(Attribute::EndAttrKinds <=
- sizeof(AvailableFunctionAttrs) * CHAR_BIT,
- "Too many attributes");
static_assert(attrIdxToArrayIdx(AttributeList::FunctionIndex) == 0U,
"function should be stored in slot 0");
for (const auto &I : Sets[0]) {
- if (!I.isStringAttribute()) {
- Attribute::AttrKind Kind = I.getKindAsEnum();
- AvailableFunctionAttrs[Kind / 8] |= 1ULL << (Kind % 8);
- }
+ if (!I.isStringAttribute())
+ AvailableFunctionAttrs.addAttribute(I.getKindAsEnum());
}
}
More information about the llvm-commits
mailing list