Skip to content
  • George Rimar's avatar
    40c28c7f
    [ELF] - Change the way how we compute offsets for binary output. · 40c28c7f
    George Rimar authored
    Binary output feature is a bit confuzing. bfd and gold output differs a lot sometimes,
    though it is important for FreeBSD mbr loaders.
    
    Patch change the way how we compute file offsets for binary output.
    This fixes PR31196.
    
    Previously offsets were calculated basing on offsets and addresses of sections
    from the same loads:
    if (Sec == First)
      return alignTo(Off, Target->MaxPageSize, Sec->Addr);
    return First->Offset + Sec->Addr - First->Addr;
    
    bfd assigns offsets for each section to VA - MinVA:
    https://github.com/redox-os/binutils-gdb/blob/master/bfd/binary.c#L27
    https://github.com/redox-os/binutils-gdb/blob/master/bfd/binary.c#L255 
    (LMA == VA usually)
    
    This patch for now just stops creating phdrs for binary output. 
    An effect from this that no any additional calculation for offset is performed:
    
    uintX_t getFileAlignment(uintX_t Off, OutputSectionBase *Sec) {
    OutputSectionBase *First = Sec->FirstInPtLoad;
    // If the section is not in a PT_LOAD, we have no other constraint.
    if (!First)
      return Off; //**First is always null, condition always happens**
    
    That is enough now with combination of another patch to generate output
    that is similar to what bfd produce for mbr loader.
    
    Differential revision: https://reviews.llvm.org/D27341
    
    llvm-svn: 288580
    40c28c7f
    [ELF] - Change the way how we compute offsets for binary output.
    George Rimar authored
    Binary output feature is a bit confuzing. bfd and gold output differs a lot sometimes,
    though it is important for FreeBSD mbr loaders.
    
    Patch change the way how we compute file offsets for binary output.
    This fixes PR31196.
    
    Previously offsets were calculated basing on offsets and addresses of sections
    from the same loads:
    if (Sec == First)
      return alignTo(Off, Target->MaxPageSize, Sec->Addr);
    return First->Offset + Sec->Addr - First->Addr;
    
    bfd assigns offsets for each section to VA - MinVA:
    https://github.com/redox-os/binutils-gdb/blob/master/bfd/binary.c#L27
    https://github.com/redox-os/binutils-gdb/blob/master/bfd/binary.c#L255 
    (LMA == VA usually)
    
    This patch for now just stops creating phdrs for binary output. 
    An effect from this that no any additional calculation for offset is performed:
    
    uintX_t getFileAlignment(uintX_t Off, OutputSectionBase *Sec) {
    OutputSectionBase *First = Sec->FirstInPtLoad;
    // If the section is not in a PT_LOAD, we have no other constraint.
    if (!First)
      return Off; //**First is always null, condition always happens**
    
    That is enough now with combination of another patch to generate output
    that is similar to what bfd produce for mbr loader.
    
    Differential revision: https://reviews.llvm.org/D27341
    
    llvm-svn: 288580
Loading