XCore target: add section information.
authorRobert Lytton <robert@xmos.com>
Tue, 11 Feb 2014 10:34:51 +0000 (10:34 +0000)
committerRobert Lytton <robert@xmos.com>
Tue, 11 Feb 2014 10:34:51 +0000 (10:34 +0000)
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

clang/lib/CodeGen/CodeGenModule.cpp
clang/test/CodeGen/xcore-abi.c

index 7b1eab9..7392ec6 100644 (file)
@@ -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;
 }
 
index f92f52e..6dbc44b 100644 (file)
@@ -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 <stdarg.h>
 struct x { int a[5]; };