mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-04-03 00:01:39 +00:00
[docs] Update AMDGPU relocation information
- Added new notation for specifying relocation calculation - Renamed: - R_AMDGPU_32_LOW -> R_AMDGPU_ABS32_LO - R_AMDGPU_32_HIGH -> R_AMDGPU_ABS32_HI - R_AMDGPU_64 -> R_AMDGPU_ABS64 - Added: - R_AMDGPU_REL32 - R_AMDGPU_REL64 - R_AMDGPU_ABS32 - Updated calculations for relative relocations Differential Revision: http://reviews.llvm.org/D21215 llvm-svn: 272684
This commit is contained in:
parent
385661593f
commit
035608a55b
@ -2672,25 +2672,26 @@ Supported relocatable fields are:
|
|||||||
byte alignment. These values use the same byte order as other word values in
|
byte alignment. These values use the same byte order as other word values in
|
||||||
the AMD GPU architecture
|
the AMD GPU architecture
|
||||||
|
|
||||||
Following notations are used for specifying relocation types
|
Following notations are used for specifying relocation calculations:
|
||||||
|
|
||||||
* **A** --- Represents the addend used to compute the value of the relocatable
|
* **A** --- Represents the addend used to compute the value of the relocatable
|
||||||
field
|
field
|
||||||
|
* **P** --- Represents the place (section offset or address) of the storage unit
|
||||||
|
being relocated (computed using ``r_offset``)
|
||||||
* **S** --- Represents the value of the symbol whose index resides in the
|
* **S** --- Represents the value of the symbol whose index resides in the
|
||||||
relocation entry
|
relocation entry
|
||||||
|
|
||||||
AMDGPU Backend generates *Elf64_Rela* relocation records with the following
|
AMDGPU Backend generates *Elf64_Rela* relocation records with the following
|
||||||
supported relocation types:
|
supported relocation types:
|
||||||
|
|
||||||
==================== ===== ========== ============================
|
===================== ===== ========== ====================
|
||||||
Relocation type Value Field Calculation
|
Relocation type Value Field Calculation
|
||||||
==================== ===== ========== ============================
|
===================== ===== ========== ====================
|
||||||
``R_AMDGPU_NONE`` 0 ``none`` ``none``
|
``R_AMDGPU_NONE`` 0 ``none`` ``none``
|
||||||
``R_AMDGPU_32_LOW`` 1 ``word32`` (S + A) & 0xFFFFFFFF
|
``R_AMDGPU_ABS32_LO`` 1 ``word32`` (S + A) & 0xFFFFFFFF
|
||||||
``R_AMDGPU_32_HIGH`` 2 ``word32`` ((S + A) >> 32) & 0xFFFFFFFF
|
``R_AMDGPU_ABS32_HI`` 2 ``word32`` (S + A) >> 32
|
||||||
``R_AMDGPU_64`` 3 ``word64`` S + A
|
``R_AMDGPU_ABS64`` 3 ``word64`` S + A
|
||||||
``R_AMDGPU_32`` 4 ``word32`` S + A
|
``R_AMDGPU_REL32`` 4 ``word32`` S + A - P
|
||||||
==================== ===== ========== ============================
|
``R_AMDGPU_REL64`` 5 ``word64`` S + A - P
|
||||||
|
``R_AMDGPU_ABS32`` 6 ``word32`` S + A
|
||||||
Only R_AMDGPU_32_LOW and R_AMDGPU_32_HIGH can be handled by the
|
===================== ===== ========== ====================
|
||||||
dynamic linker. The rest must be statically resolved.
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user