summaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorvoid <void@91177308-0d34-0410-b5e6-96231b3b80d8>2012-09-20 16:27:05 +0000
committervoid <void@91177308-0d34-0410-b5e6-96231b3b80d8>2012-09-20 16:27:05 +0000
commit06e070322920eb98f8c85a38517e878462cfdeb4 (patch)
treeda39c70cb12e9a479178eaa5b98549aef85082db /include
parent0d1a5cf6e15a396cf56ef1b07fbce9f08280fe10 (diff)
Make the 'get*AlignmentFromAttr' functions into member functions within the Attributes class.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@164308 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include')
-rw-r--r--include/llvm/Attributes.h40
1 files changed, 21 insertions, 19 deletions
diff --git a/include/llvm/Attributes.h b/include/llvm/Attributes.h
index 01b3be8cb6..2a7e0dea4f 100644
--- a/include/llvm/Attributes.h
+++ b/include/llvm/Attributes.h
@@ -205,6 +205,24 @@ public:
return Bits & Attribute::StackAlignment_i;
}
+ /// This returns the alignment field of an attribute as a byte alignment
+ /// value.
+ unsigned getAlignment() const {
+ if (!hasAlignmentAttr())
+ return 0;
+
+ return 1U << ((getRawAlignment() >> 16) - 1);
+ }
+
+ /// This returns the stack alignment field of an attribute as a byte alignment
+ /// value.
+ unsigned getStackAlignment() const {
+ if (!hasStackAlignmentAttr())
+ return 0;
+
+ return 1U << ((getRawStackAlignment() >> 26) - 1);
+ }
+
// This is a "safe bool() operator".
operator const void *() const { return Bits ? this : 0; }
bool isEmptyOrSingleton() const { return (Bits & (Bits - 1)) == 0; }
@@ -212,8 +230,9 @@ public:
return Bits == Attrs.Bits;
}
bool operator != (const Attributes &Attrs) const {
- return Bits != Attrs.Bits;
+ return !(this == Attrs);
}
+
Attributes operator | (const Attributes &Attrs) const {
return Attributes(Bits | Attrs.Bits);
}
@@ -294,14 +313,6 @@ inline Attributes constructAlignmentFromInt(unsigned i) {
return Attributes((Log2_32(i)+1) << 16);
}
-/// This returns the alignment field of an attribute as a byte alignment value.
-inline unsigned getAlignmentFromAttrs(Attributes A) {
- if (!A.hasAlignmentAttr())
- return 0;
-
- return 1U << ((A.getRawAlignment() >> 16) - 1);
-}
-
/// This turns an int stack alignment (which must be a power of 2) into
/// the form used internally in Attributes.
inline Attributes constructStackAlignmentFromInt(unsigned i) {
@@ -314,15 +325,6 @@ inline Attributes constructStackAlignmentFromInt(unsigned i) {
return Attributes((Log2_32(i)+1) << 26);
}
-/// This returns the stack alignment field of an attribute as a byte alignment
-/// value.
-inline unsigned getStackAlignmentFromAttrs(Attributes A) {
- if (!A.hasStackAlignmentAttr())
- return 0;
-
- return 1U << ((A.getRawStackAlignment() >> 26) - 1);
-}
-
/// This returns an integer containing an encoding of all the
/// LLVM attributes found in the given attribute bitset. Any
/// change to this encoding is a breaking change to bitcode
@@ -450,7 +452,7 @@ public:
/// getParamAlignment - Return the alignment for the specified function
/// parameter.
unsigned getParamAlignment(unsigned Idx) const {
- return Attribute::getAlignmentFromAttrs(getAttributes(Idx));
+ return getAttributes(Idx).getAlignment();
}
/// hasAttrSomewhere - Return true if the specified attribute is set for at