summaryrefslogtreecommitdiffstats
path: root/llvm/include
diff options
context:
space:
mode:
authorBenjamin Kramer <benny.kra@googlemail.com>2013-04-10 20:50:44 +0000
committerBenjamin Kramer <benny.kra@googlemail.com>2013-04-10 20:50:44 +0000
commit04b6e803818592a469fef8fd4576b0a904a6c989 (patch)
tree16886b35809757b6d0752b6c31dcda7ef7b4dcdc /llvm/include
parentc03998bdb5f7376604dc75f38270d99592ff5200 (diff)
downloadbcm5719-llvm-04b6e803818592a469fef8fd4576b0a904a6c989.tar.gz
bcm5719-llvm-04b6e803818592a469fef8fd4576b0a904a6c989.zip
Use a real union for IdentifyingPassPtr.
This avoids a nasty const correctness issue (AnalysisIDs are const, Pass* isn't). llvm-svn: 179213
Diffstat (limited to 'llvm/include')
-rw-r--r--llvm/include/llvm/CodeGen/Passes.h16
1 files changed, 9 insertions, 7 deletions
diff --git a/llvm/include/llvm/CodeGen/Passes.h b/llvm/include/llvm/CodeGen/Passes.h
index 7b0aa8fab7a..b02f63e70b9 100644
--- a/llvm/include/llvm/CodeGen/Passes.h
+++ b/llvm/include/llvm/CodeGen/Passes.h
@@ -50,24 +50,26 @@ class PassConfigImpl;
///
/// AnalysisID is sadly char*, so PointerIntPair won't work.
class IdentifyingPassPtr {
- void *P;
+ union {
+ AnalysisID ID;
+ Pass *P;
+ };
bool IsInstance;
public:
- IdentifyingPassPtr(): P(0), IsInstance(false) {}
- IdentifyingPassPtr(AnalysisID IDPtr): P((void*)IDPtr), IsInstance(false) {}
- IdentifyingPassPtr(Pass *InstancePtr)
- : P((void*)InstancePtr), IsInstance(true) {}
+ IdentifyingPassPtr() : P(0), IsInstance(false) {}
+ IdentifyingPassPtr(AnalysisID IDPtr) : ID(IDPtr), IsInstance(false) {}
+ IdentifyingPassPtr(Pass *InstancePtr) : P(InstancePtr), IsInstance(true) {}
bool isValid() const { return P; }
bool isInstance() const { return IsInstance; }
AnalysisID getID() const {
assert(!IsInstance && "Not a Pass ID");
- return (AnalysisID)P;
+ return ID;
}
Pass *getInstance() const {
assert(IsInstance && "Not a Pass Instance");
- return (Pass *)P;
+ return P;
}
};
OpenPOWER on IntegriCloud