diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2010-12-24 21:22:02 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2010-12-24 21:22:02 +0000 |
commit | 0f8abeba1d526068ac8bd8ce6ec00ea661225721 (patch) | |
tree | 8deb76f610ff835623712674082eb7aecd73a355 /llvm/lib/MC/MCObjectWriter.cpp | |
parent | ea9152e551364e54da36e51a483c36ee15669a2e (diff) | |
download | bcm5719-llvm-0f8abeba1d526068ac8bd8ce6ec00ea661225721.tar.gz bcm5719-llvm-0f8abeba1d526068ac8bd8ce6ec00ea661225721.zip |
Merge IsFixupFullyResolved and IsSymbolRefDifferenceFullyResolved. We now
have a single point where targets test if a relocation is needed.
llvm-svn: 122549
Diffstat (limited to 'llvm/lib/MC/MCObjectWriter.cpp')
-rw-r--r-- | llvm/lib/MC/MCObjectWriter.cpp | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/llvm/lib/MC/MCObjectWriter.cpp b/llvm/lib/MC/MCObjectWriter.cpp index e5f5f703289..f7a790410cd 100644 --- a/llvm/lib/MC/MCObjectWriter.cpp +++ b/llvm/lib/MC/MCObjectWriter.cpp @@ -7,6 +7,7 @@ // //===----------------------------------------------------------------------===// +#include "llvm/MC/MCAssembler.h" #include "llvm/MC/MCExpr.h" #include "llvm/MC/MCObjectWriter.h" #include "llvm/MC/MCSymbol.h" @@ -54,9 +55,14 @@ MCObjectWriter::IsSymbolRefDifferenceFullyResolved(const MCAssembler &Asm, const MCSymbol &SA = A->getSymbol(); const MCSymbol &SB = B->getSymbol(); - if (SA.isUndefined() || SB.isUndefined()) + if (SA.AliasedSymbol().isUndefined() || SB.AliasedSymbol().isUndefined()) return false; - // On ELF and COFF A - B is absolute if A and B are in the same section. - return &SA.getSection() == &SB.getSection(); + const MCSymbolData &DataA = Asm.getSymbolData(SA); + const MCSymbolData &DataB = Asm.getSymbolData(SB); + + return IsSymbolRefDifferenceFullyResolvedImpl(Asm, DataA, + *DataB.getFragment(), + InSet, + false); } |