diff options
author | Richard Osborne <richard@xmos.com> | 2009-08-17 16:37:11 +0000 |
---|---|---|
committer | Richard Osborne <richard@xmos.com> | 2009-08-17 16:37:11 +0000 |
commit | 2a5e23b44ddf1efde1d98bd3379489d93a90d55a (patch) | |
tree | 26262ae54619c2cc9025c30cf4006541abfec116 | |
parent | fac8541dd40e01aa2b52962516f9ae67c99720cc (diff) | |
download | external_llvm-2a5e23b44ddf1efde1d98bd3379489d93a90d55a.zip external_llvm-2a5e23b44ddf1efde1d98bd3379489d93a90d55a.tar.gz external_llvm-2a5e23b44ddf1efde1d98bd3379489d93a90d55a.tar.bz2 |
Update getSectionForConstant() to to allow mergable sections to be nulled out
if not supported by the ELF subtarget.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@79249 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Target/TargetLoweringObjectFile.cpp | 6 | ||||
-rw-r--r-- | test/CodeGen/XCore/constants.ll | 11 |
2 files changed, 14 insertions, 3 deletions
diff --git a/lib/Target/TargetLoweringObjectFile.cpp b/lib/Target/TargetLoweringObjectFile.cpp index d64cf07..8e1351b 100644 --- a/lib/Target/TargetLoweringObjectFile.cpp +++ b/lib/Target/TargetLoweringObjectFile.cpp @@ -609,11 +609,11 @@ SelectSectionForGlobal(const GlobalValue *GV, SectionKind Kind, /// should be placed in. const MCSection *TargetLoweringObjectFileELF:: getSectionForConstant(SectionKind Kind) const { - if (Kind.isMergeableConst4()) + if (Kind.isMergeableConst4() && MergeableConst4Section) return MergeableConst4Section; - if (Kind.isMergeableConst8()) + if (Kind.isMergeableConst8() && MergeableConst8Section) return MergeableConst8Section; - if (Kind.isMergeableConst16()) + if (Kind.isMergeableConst16() && MergeableConst16Section) return MergeableConst16Section; if (Kind.isReadOnly()) return ReadOnlySection; diff --git a/test/CodeGen/XCore/constants.ll b/test/CodeGen/XCore/constants.ll new file mode 100644 index 0000000..2aee6a2 --- /dev/null +++ b/test/CodeGen/XCore/constants.ll @@ -0,0 +1,11 @@ +; RUN: llvm-as < %s | llc -march=xcore -mcpu=xs1b-generic | FileCheck %s + +; CHECK: .section .cp.rodata,"ac",@progbits +; CHECK: .LCPI1_0: +; CHECK: .long 12345678 +; CHECK: f: +; CHECK: ldw r0, cp[.LCPI1_0] +define i32 @f() { +entry: + ret i32 12345678 +} |