<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Mon, Jan 18, 2016 at 9:11 AM, Rafael Espíndola <span dir="ltr"><<a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">> +<br>
> +    // Symbol offsets for AMDGPU need to be the offset in bytes of the symbol<br>
> +    // from the beginning of the section.<br>
> +    if (Config->EMachine == EM_AMDGPU)<br>
> +      return SC->getOffset(DR.Sym);<br>
>      if (DR.Sym.getType() == STT_TLS)<br>
>        return SC->OutSec->getVA() + SC->getOffset(DR.Sym) -<br>
>               Out<ELFT>::TlsPhdr->p_vaddr;<br>
> @@ -1325,7 +1330,11 @@ void SymbolTableSection<ELFT>::writeLoca<br>
>            continue;<br>
>          const OutputSectionBase<ELFT> *OutSec = Section->OutSec;<br>
>          ESym->st_shndx = OutSec->SectionIndex;<br>
> -        VA += OutSec->getVA() + Section->getOffset(Sym);<br>
> +        VA = Section->getOffset(Sym);<br>
> +        // Symbol offsets for AMDGPU need to be the offset in bytes of the<br>
> +        // symbol from the beginning of the section.<br>
> +        if (Config->EMachine != EM_AMDGPU)<br>
> +          VA += OutSec->getVA();<br>
>        }<br>
<br>
<br>
</span>This is a horrible design error. The ELF spec is very explicit:<br>
<br>
In executable and shared object files, st_value holds a virtual address.<br>
<br>
Is there any hope of fixing this? AMDGPU using ELF is relatively new,<br>
so I hope so. Some options<br>
<br>
* User -r.<br>
* Change the consumer.<br>
<br>
But please do something. The fact that symbols and relocations use<br>
offsets in .o and addresses in .so and executables is central to ELF.<br></blockquote><div><br></div><div>I agree with that. The current definition of st_value field for AMDGPU ELF files looks pretty odd and not in line with the ELF spec. I'd greatly appreciate if you do something before it's baked in to the AMDGPU ELF spec forever.</div><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Cheers,<br>
Rafael<br>
<div class="HOEnZb"><div class="h5">_______________________________________________<br>
llvm-commits mailing list<br>
<a href="mailto:llvm-commits@lists.llvm.org">llvm-commits@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits</a><br>
</div></div></blockquote></div><br></div></div>