diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2014-05-16 13:34:04 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2014-05-16 13:34:04 +0000 |
commit | ab67b30df6b14e8e90f4778215ed4e1d5939638e (patch) | |
tree | 0dd738ae6d07cd9fac9f37bc7f34dbea1d7014c1 /lib/Bitcode | |
parent | b95580a711b70e373ba7a52b3867e7ea6881e413 (diff) | |
download | llvm-ab67b30df6b14e8e90f4778215ed4e1d5939638e.tar.gz llvm-ab67b30df6b14e8e90f4778215ed4e1d5939638e.tar.bz2 llvm-ab67b30df6b14e8e90f4778215ed4e1d5939638e.tar.xz |
Change the GlobalAlias constructor to look a bit more like GlobalVariable.
This is part of the fix for pr10367. A GlobalAlias always has a pointer type,
so just have the constructor build the type.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@208983 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Bitcode')
-rw-r--r-- | lib/Bitcode/Reader/BitcodeReader.cpp | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/lib/Bitcode/Reader/BitcodeReader.cpp b/lib/Bitcode/Reader/BitcodeReader.cpp index d0ce237ee6..a1ae6baff9 100644 --- a/lib/Bitcode/Reader/BitcodeReader.cpp +++ b/lib/Bitcode/Reader/BitcodeReader.cpp @@ -1966,8 +1966,10 @@ error_code BitcodeReader::ParseModule(bool Resume) { if (!Ty->isPointerTy()) return Error(InvalidTypeForValue); - GlobalAlias *NewGA = new GlobalAlias(Ty, GetDecodedLinkage(Record[2]), - "", nullptr, TheModule); + auto *PTy = cast<PointerType>(Ty); + GlobalAlias *NewGA = + new GlobalAlias(PTy->getElementType(), GetDecodedLinkage(Record[2]), + "", nullptr, TheModule, PTy->getAddressSpace()); // Old bitcode files didn't have visibility field. // Local linkage must have default visibility. if (Record.size() > 3 && !NewGA->hasLocalLinkage()) |