diff options
Diffstat (limited to 'clang/lib')
-rw-r--r-- | clang/lib/Basic/Targets.cpp | 16 | ||||
-rw-r--r-- | clang/lib/CodeGen/CodeGenModule.cpp | 26 |
2 files changed, 38 insertions, 4 deletions
diff --git a/clang/lib/Basic/Targets.cpp b/clang/lib/Basic/Targets.cpp index ce55ec80465..5f5ba60e858 100644 --- a/clang/lib/Basic/Targets.cpp +++ b/clang/lib/Basic/Targets.cpp @@ -658,6 +658,14 @@ public: return IsConstant ? "\01LC" : "\01lC"; } + virtual const char *getUnicodeStringSymbolPrefix() const { + return "__utf16_string_"; + } + + virtual const char *getUnicodeStringSection() const { + return "__TEXT,__ustring"; + } + virtual const char *getCFStringSymbolPrefix() const { return "\01LC"; } @@ -810,6 +818,14 @@ public: return IsConstant ? "\01LC" : "\01lC"; } + virtual const char *getUnicodeStringSymbolPrefix() const { + return "__utf16_string_"; + } + + virtual const char *getUnicodeStringSection() const { + return "__TEXT,__ustring"; + } + virtual const char *getCFStringSymbolPrefix() const { return "\01L_unnamed_cfstring_"; } diff --git a/clang/lib/CodeGen/CodeGenModule.cpp b/clang/lib/CodeGen/CodeGenModule.cpp index fa475ced6e8..1132c3f721d 100644 --- a/clang/lib/CodeGen/CodeGenModule.cpp +++ b/clang/lib/CodeGen/CodeGenModule.cpp @@ -1082,13 +1082,31 @@ GetAddrOfConstantCFString(const StringLiteral *Literal) { CurField = NextField; NextField = *Field++; llvm::Constant *C = llvm::ConstantArray::get(str); + + const char *Sect, *Prefix; + bool isConstant; + if (isUTF16) { + Prefix = getContext().Target.getUnicodeStringSymbolPrefix(); + Sect = getContext().Target.getUnicodeStringSection(); + // FIXME: Why does GCC not set constant here? + isConstant = false; + } else { + Prefix = getContext().Target.getStringSymbolPrefix(true); + Sect = getContext().Target.getCFStringDataSection(); + // FIXME: -fwritable-strings should probably affect this, but we + // are following gcc here. + isConstant = true; + } llvm::GlobalVariable *GV = - new llvm::GlobalVariable(C->getType(), true, + new llvm::GlobalVariable(C->getType(), isConstant, llvm::GlobalValue::InternalLinkage, - C, getContext().Target.getStringSymbolPrefix(true), - &getModule()); - if (const char *Sect = getContext().Target.getCFStringDataSection()) + C, Prefix, &getModule()); + if (Sect) GV->setSection(Sect); + if (isUTF16) { + unsigned Align = getContext().getTypeAlign(getContext().ShortTy)/8; + GV->setAlignment(Align); + } appendFieldAndPadding(*this, Fields, CurField, NextField, llvm::ConstantExpr::getGetElementPtr(GV, Zeros, 2), CFRD, STy); |