diff options
| author | Jim Grosbach <grosbach@apple.com> | 2012-01-24 21:45:25 +0000 |
|---|---|---|
| committer | Jim Grosbach <grosbach@apple.com> | 2012-01-24 21:45:25 +0000 |
| commit | 35bc8f915923904a38827f103c0403a8e3a70dfb (patch) | |
| tree | c4f75385256bfc8ed84e0891c35ba4dd59892630 /llvm | |
| parent | a410ed3ced5cb7c0576d15896bad32d5973721de (diff) | |
| download | bcm5719-llvm-35bc8f915923904a38827f103c0403a8e3a70dfb.tar.gz bcm5719-llvm-35bc8f915923904a38827f103c0403a8e3a70dfb.zip | |
ARM Darwin symbol ref differences w/o subsection-via-symbols.
When not using subsections via symbols, the assembler can resolve
symbol differences (including pcrel references) to non-local
labels at assembly time, not just those in the same atom.
llvm-svn: 148865
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/lib/MC/MachObjectWriter.cpp | 3 | ||||
| -rw-r--r-- | llvm/test/MC/MachO/ARM/no-subsections-reloc.s | 18 |
2 files changed, 20 insertions, 1 deletions
diff --git a/llvm/lib/MC/MachObjectWriter.cpp b/llvm/lib/MC/MachObjectWriter.cpp index a3445219f1e..57f90d95527 100644 --- a/llvm/lib/MC/MachObjectWriter.cpp +++ b/llvm/lib/MC/MachObjectWriter.cpp @@ -592,7 +592,8 @@ IsSymbolRefDifferenceFullyResolvedImpl(const MCAssembler &Asm, if (!Asm.getBackend().hasReliableSymbolDifference()) { if (!SA.isInSection() || &SecA != &SecB || (!SA.isTemporary() && - FB.getAtom() != Asm.getSymbolData(SA).getFragment()->getAtom())) + FB.getAtom() != Asm.getSymbolData(SA).getFragment()->getAtom() && + Asm.getSubsectionsViaSymbols())) return false; return true; } diff --git a/llvm/test/MC/MachO/ARM/no-subsections-reloc.s b/llvm/test/MC/MachO/ARM/no-subsections-reloc.s new file mode 100644 index 00000000000..7701c59c680 --- /dev/null +++ b/llvm/test/MC/MachO/ARM/no-subsections-reloc.s @@ -0,0 +1,18 @@ +@ RUN: llvm-mc -n -triple thumbv7-apple-darwin10 %s -filetype=obj -o %t.obj +@ RUN: macho-dump --dump-section-data < %t.obj > %t.dump +@ RUN: FileCheck < %t.dump %s + +@ When not using subsections-via-symbols, references to non-local symbols +@ in the same section can be resolved at assembly time w/o relocations. + + .syntax unified + .text + .thumb + .thumb_func _foo +_foo: + ldr r3, bar +bar: + .long 0 + +@ CHECK: 'num_reloc', 0 +@ CHECK: '_section_data', 'dff80030 00000000' |

