diff options
author | Robert Lytton <robert@xmos.com> | 2014-05-02 09:33:30 +0000 |
---|---|---|
committer | Robert Lytton <robert@xmos.com> | 2014-05-02 09:33:30 +0000 |
commit | f80d68847dcf2a5923eb1e7acfc50c290fdc8f79 (patch) | |
tree | 409ffa36619def5a60c5bdaf61676cf3fabe93a5 /clang/lib/CodeGen/CodeGenModule.cpp | |
parent | 894d25c1e026c830b6d2211255f785e5da2dceaa (diff) | |
download | bcm5719-llvm-f80d68847dcf2a5923eb1e7acfc50c290fdc8f79.tar.gz bcm5719-llvm-f80d68847dcf2a5923eb1e7acfc50c290fdc8f79.zip |
XCore target: fix bug in dereferencing null pointer.
Also add basic cpp ABI tests where they differ from C ABI output.
llvm-svn: 207834
Diffstat (limited to 'clang/lib/CodeGen/CodeGenModule.cpp')
-rw-r--r-- | clang/lib/CodeGen/CodeGenModule.cpp | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/clang/lib/CodeGen/CodeGenModule.cpp b/clang/lib/CodeGen/CodeGenModule.cpp index 11f69cc0fce..785c04cb390 100644 --- a/clang/lib/CodeGen/CodeGenModule.cpp +++ b/clang/lib/CodeGen/CodeGenModule.cpp @@ -1607,17 +1607,18 @@ CodeGenModule::GetOrCreateLLVMGlobal(StringRef MangledName, if (getCXXABI().isInlineInitializedStaticDataMemberLinkOnce() && isVarDeclInlineInitializedStaticDataMember(D)) EmitGlobalVarDefinition(D); + + // Handle XCore specific ABI requirements. + if (getTarget().getTriple().getArch() == llvm::Triple::xcore && + D->getLanguageLinkage() == CLanguageLinkage && + D->getType().isConstant(Context) && + isExternallyVisible(D->getLinkageAndVisibility().getLinkage())) + GV->setSection(".cp.rodata"); } if (AddrSpace != Ty->getAddressSpace()) return llvm::ConstantExpr::getAddrSpaceCast(GV, Ty); - if (getTarget().getTriple().getArch() == llvm::Triple::xcore && - D->getLanguageLinkage() == CLanguageLinkage && - D->getType().isConstant(Context) && - isExternallyVisible(D->getLinkageAndVisibility().getLinkage())) - GV->setSection(".cp.rodata"); - getTargetCodeGenInfo().emitTargetMD(D, GV, *this); return GV; |