summaryrefslogtreecommitdiff
path: root/lib/VMCore
diff options
context:
space:
mode:
authorBill Wendling <isanbard@gmail.com>2012-12-29 12:29:38 +0000
committerBill Wendling <isanbard@gmail.com>2012-12-29 12:29:38 +0000
commit7c1683d47c960a66dc0e006f789962b3f10d6f45 (patch)
tree1f9e41871cedf2572d5a5e57b6613d2738090e27 /lib/VMCore
parent4d5e5e5d61b404cb3bac9745e0dbfca6a1b8af2e (diff)
downloadllvm-7c1683d47c960a66dc0e006f789962b3f10d6f45.tar.gz
llvm-7c1683d47c960a66dc0e006f789962b3f10d6f45.tar.bz2
llvm-7c1683d47c960a66dc0e006f789962b3f10d6f45.tar.xz
Use a 'Constant' object instead of a bit field to store the attribute data.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@171221 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/VMCore')
-rw-r--r--lib/VMCore/AttributeImpl.h13
-rw-r--r--lib/VMCore/Attributes.cpp14
2 files changed, 19 insertions, 8 deletions
diff --git a/lib/VMCore/AttributeImpl.h b/lib/VMCore/AttributeImpl.h
index e27a0297df..3b8f818a17 100644
--- a/lib/VMCore/AttributeImpl.h
+++ b/lib/VMCore/AttributeImpl.h
@@ -21,6 +21,7 @@
namespace llvm {
+class Constant;
class LLVMContext;
//===----------------------------------------------------------------------===//
@@ -29,9 +30,9 @@ class LLVMContext;
/// could be a single enum, a tuple, or a string. It uses a discriminated union
/// to distinguish them.
class AttributeImpl : public FoldingSetNode {
- uint64_t Bits; // FIXME: We will be expanding this.
+ Constant *Data;
public:
- AttributeImpl(uint64_t bits) : Bits(bits) {}
+ AttributeImpl(LLVMContext &C, uint64_t data);
bool hasAttribute(uint64_t A) const;
@@ -41,16 +42,14 @@ public:
uint64_t getAlignment() const;
uint64_t getStackAlignment() const;
- uint64_t Raw() const { return Bits; } // FIXME: Remove.
+ uint64_t Raw() const; // FIXME: Remove.
static uint64_t getAttrMask(uint64_t Val);
void Profile(FoldingSetNodeID &ID) const {
- Profile(ID, Bits);
- }
- static void Profile(FoldingSetNodeID &ID, uint64_t Bits) {
- ID.AddInteger(Bits);
+ Profile(ID, Data);
}
+ static void Profile(FoldingSetNodeID &ID, Constant *Data);
};
//===----------------------------------------------------------------------===//
diff --git a/lib/VMCore/Attributes.cpp b/lib/VMCore/Attributes.cpp
index 3a593574cc..c85e5fe51c 100644
--- a/lib/VMCore/Attributes.cpp
+++ b/lib/VMCore/Attributes.cpp
@@ -53,7 +53,7 @@ Attribute Attribute::get(LLVMContext &Context, AttrBuilder &B) {
if (!PA) {
// If we didn't find any existing attributes of the same shape then create a
// new one and insert it.
- PA = new AttributeImpl(B.Raw());
+ PA = new AttributeImpl(Context, B.Raw());
pImpl->AttrsSet.InsertNode(PA, InsertPoint);
}
@@ -298,6 +298,14 @@ uint64_t AttrBuilder::getStackAlignment() const {
// AttributeImpl Definition
//===----------------------------------------------------------------------===//
+AttributeImpl::AttributeImpl(LLVMContext &C, uint64_t data) {
+ Data = ConstantInt::get(Type::getInt64Ty(C), data);
+}
+
+uint64_t AttributeImpl::Raw() const {
+ return cast<ConstantInt>(Data)->getZExtValue();
+}
+
uint64_t AttributeImpl::getAttrMask(uint64_t Val) {
switch (Val) {
case Attribute::None: return 0;
@@ -354,6 +362,10 @@ uint64_t AttributeImpl::getStackAlignment() const {
return Raw() & getAttrMask(Attribute::StackAlignment);
}
+void AttributeImpl::Profile(FoldingSetNodeID &ID, Constant *Data) {
+ ID.AddInteger(cast<ConstantInt>(Data)->getZExtValue());
+}
+
//===----------------------------------------------------------------------===//
// AttributeSetImpl Definition
//===----------------------------------------------------------------------===//