summaryrefslogtreecommitdiff
path: root/lib/IR
diff options
context:
space:
mode:
authorMatt Arsenault <Matthew.Arsenault@amd.com>2013-07-20 17:46:05 +0000
committerMatt Arsenault <Matthew.Arsenault@amd.com>2013-07-20 17:46:05 +0000
commit5f53c3be6fce77d494e82f23d5ea0b6a0144eb5d (patch)
tree407d27620b9b6fc54072170b73cabf2b2f8883e5 /lib/IR
parent3f49322818a3f2b9ca6fe75f49c7541c8dfb538d (diff)
downloadllvm-5f53c3be6fce77d494e82f23d5ea0b6a0144eb5d.tar.gz
llvm-5f53c3be6fce77d494e82f23d5ea0b6a0144eb5d.tar.bz2
llvm-5f53c3be6fce77d494e82f23d5ea0b6a0144eb5d.tar.xz
Disallow global aliases to bitcast between address spaces
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@186767 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/IR')
-rw-r--r--lib/IR/Verifier.cpp19
1 files changed, 15 insertions, 4 deletions
diff --git a/lib/IR/Verifier.cpp b/lib/IR/Verifier.cpp
index 6e04dfeef6..fa53a4ee69 100644
--- a/lib/IR/Verifier.cpp
+++ b/lib/IR/Verifier.cpp
@@ -498,18 +498,29 @@ void Verifier::visitGlobalAlias(GlobalAlias &GA) {
"Alias and aliasee types should match!", &GA);
Assert1(!GA.hasUnnamedAddr(), "Alias cannot have unnamed_addr!", &GA);
- if (!isa<GlobalValue>(GA.getAliasee())) {
- const ConstantExpr *CE = dyn_cast<ConstantExpr>(GA.getAliasee());
+ Constant *Aliasee = GA.getAliasee();
+
+ if (!isa<GlobalValue>(Aliasee)) {
+ ConstantExpr *CE = dyn_cast<ConstantExpr>(Aliasee);
Assert1(CE &&
(CE->getOpcode() == Instruction::BitCast ||
CE->getOpcode() == Instruction::GetElementPtr) &&
isa<GlobalValue>(CE->getOperand(0)),
"Aliasee should be either GlobalValue or bitcast of GlobalValue",
&GA);
+
+ if (CE->getOpcode() == Instruction::BitCast) {
+ unsigned SrcAS = CE->getOperand(0)->getType()->getPointerAddressSpace();
+ unsigned DstAS = CE->getType()->getPointerAddressSpace();
+
+ Assert1(SrcAS == DstAS,
+ "Alias bitcasts cannot be between different address spaces",
+ &GA);
+ }
}
- const GlobalValue* Aliasee = GA.resolveAliasedGlobal(/*stopOnWeak*/ false);
- Assert1(Aliasee,
+ const GlobalValue* Resolved = GA.resolveAliasedGlobal(/*stopOnWeak*/ false);
+ Assert1(Resolved,
"Aliasing chain should end with function or global variable", &GA);
visitGlobalValue(GA);