diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2016-07-23 20:41:05 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2016-07-23 20:41:05 +0000 | 
| commit | 01095a5d43bbfde13731688ddcf6048ebb8b7721 (patch) | |
| tree | 4def12e759965de927d963ac65840d663ef9d1ea /lib/Target/ARM/MCTargetDesc/ARMMachObjectWriter.cpp | |
| parent | f0f4822ed4b66e3579e92a89f368f8fb860e218e (diff) | |
Diffstat (limited to 'lib/Target/ARM/MCTargetDesc/ARMMachObjectWriter.cpp')
| -rw-r--r-- | lib/Target/ARM/MCTargetDesc/ARMMachObjectWriter.cpp | 9 | 
1 files changed, 6 insertions, 3 deletions
| diff --git a/lib/Target/ARM/MCTargetDesc/ARMMachObjectWriter.cpp b/lib/Target/ARM/MCTargetDesc/ARMMachObjectWriter.cpp index cfd504e533afa..cfa6ce7da65e2 100644 --- a/lib/Target/ARM/MCTargetDesc/ARMMachObjectWriter.cpp +++ b/lib/Target/ARM/MCTargetDesc/ARMMachObjectWriter.cpp @@ -389,7 +389,8 @@ void ARMMachObjectWriter::recordRelocation(MachObjectWriter *Writer,    uint32_t Offset = Target.getConstant();    if (IsPCRel && RelocType == MachO::ARM_RELOC_VANILLA)      Offset += 1 << Log2Size; -  if (Offset && A && !Writer->doesSymbolRequireExternRelocation(*A)) +  if (Offset && A && !Writer->doesSymbolRequireExternRelocation(*A) && +      RelocType != MachO::ARM_RELOC_HALF)      return RecordARMScatteredRelocation(Writer, Asm, Layout, Fragment, Fixup,                                          Target, RelocType, Log2Size,                                          FixedValue); @@ -447,8 +448,10 @@ void ARMMachObjectWriter::recordRelocation(MachObjectWriter *Writer,    // Even when it's not a scattered relocation, movw/movt always uses    // a PAIR relocation.    if (Type == MachO::ARM_RELOC_HALF) { -    // The other-half value only gets populated for the movt and movw -    // relocation entries. +    // The entire addend is needed to correctly apply a relocation. One half is +    // extracted from the instruction itself, the other comes from this +    // PAIR. I.e. it's correct that we insert the high bits of the addend in the +    // MOVW case here.  relocation entries.      uint32_t Value = 0;      switch ((unsigned)Fixup.getKind()) {      default: break; | 
