commit | 8c177eea6d4d030923bb2975a57bca3601bdfc9d | [log] [tgz] |
---|---|---|
author | Fangrui Song <maskray@google.com> | Sat May 18 01:58:40 2019 +0000 |
committer | Fangrui Song <maskray@google.com> | Sat May 18 01:58:40 2019 +0000 |
tree | d1bfb880019c592452b935930aeff71b8889c3ea | |
parent | 07a5cef069c794b3b0bd30f2fa7ef2875e55c845 [diff] |
[ELF][X86] Fix R_RELAX_TLS_GD_TO_LE_NEG and R_NEG_TLS after D62059 After D62059, we don't align p_memsz of PT_TLS to p_align. The getRelocTargetVA formula should align it instead. It becomes clear that R_NEG_TLS and R_TLS are opposite from each other. In i386-tls-le-align.s, I put ret after call ___tls_get_addr@plt as otherwise ld.bfd would reject the relaxation: TLS transition from R_386_TLS_GD to R_386_TLS_LE_32 against `a' at 0x3 in section `.text' failed git-svn-id: https://llvm.org/svn/llvm-project/lld/trunk@361088 91177308-0d34-0410-b5e6-96231b3b80d8
This directory and its subdirectories contain source code for the LLVM Linker, a modular cross platform linker which is built as part of the LLVM compiler infrastructure project.
lld is open source software. You may freely distribute it under the terms of the license agreement found in LICENSE.txt.
In order to make sure various developers can evaluate patches over the same tests, we create a collection of self contained programs.
It is hosted at https://s3-us-west-2.amazonaws.com/linker-tests/lld-speed-test.tar.xz
The current sha256 is 10eec685463d5a8bbf08d77f4ca96282161d396c65bd97dc99dbde644a31610f.