Skip to content
  • Peter Collingbourne's avatar
    ELF: Do not use -1 to mark pieces of merge sections as being tail merged. · e29e142a
    Peter Collingbourne authored
    We were previously using an output offset of -1 for both GC'd and tail
    merged pieces. We need to distinguish these two cases in order to filter
    GC'd symbols from the symbol table -- we were previously asserting when we
    asked for the VA of a symbol pointing into a dead piece, which would end
    up asking the tail merging string table for an offset even though we hadn't
    initialized it properly.
    
    This patch fixes the bug by using an offset of -1 to exclusively mean GC'd
    pieces, using 0 for tail merges, and distinguishing the tail merge case from
    an offset of 0 by asking the output section whether it is tail merge.
    
    Differential Revision: http://reviews.llvm.org/D19953
    
    llvm-svn: 268604
    e29e142a
Loading