From: Robert Lytton Date: Tue, 11 Feb 2014 10:34:51 +0000 (+0000) Subject: XCore target: add section information. X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=15abd1881ff232a33f98a30c0d5b7e145a83e82c;p=platform%2Fupstream%2Fllvm.git XCore target: add section information. Xcore target ABI requires const data that is externally visible to be handled differently if it has C-language linkage rather than C++ language linkage. llvm-svn: 201142 --- diff --git a/clang/lib/CodeGen/CodeGenModule.cpp b/clang/lib/CodeGen/CodeGenModule.cpp index 7b1eab9..7392ec6 100644 --- a/clang/lib/CodeGen/CodeGenModule.cpp +++ b/clang/lib/CodeGen/CodeGenModule.cpp @@ -1578,6 +1578,12 @@ CodeGenModule::GetOrCreateLLVMGlobal(StringRef MangledName, 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"); + return GV; } diff --git a/clang/test/CodeGen/xcore-abi.c b/clang/test/CodeGen/xcore-abi.c index f92f52e..6dbc44b 100644 --- a/clang/test/CodeGen/xcore-abi.c +++ b/clang/test/CodeGen/xcore-abi.c @@ -10,8 +10,13 @@ _Static_assert(_Alignof(double) == 4, "alignof double is wrong"); // CHECK: target triple = "xcore-unknown-unknown" +// CHECK: @cgx = external constant i32, section ".cp.rodata" +extern const int cgx; +int fcgx() { return cgx;} // CHECK: @g1 = global i32 0, align 4 int g1; +// CHECK: @cg1 = constant i32 0, section ".cp.rodata", align 4 +const int cg1; #include struct x { int a[5]; };